std:: negative_binomial_distribution
From cppreference.net
|
Definiert im Header
<random>
|
||
|
template
<
class
IntType
=
int
>
class negative_binomial_distribution ; |
(seit C++11) | |
Erzeugt zufällige nicht-negative Ganzzahlwerte i , verteilt gemäß diskreter Wahrscheinlichkeitsfunktion:
-
P(i|k,p) =
⎛
⎜
⎝ k + i − 1
i ⎞
⎟
⎠ · p k
· (1 − p) i
Der Wert stellt die Anzahl der Fehlschläge in einer Reihe unabhängiger Ja/Nein-Versuche dar (jeder gelingt mit Wahrscheinlichkeit p ), bevor genau k Erfolge eintreten.
std::negative_binomial_distribution
erfüllt die Anforderungen von
RandomNumberDistribution
.
Inhaltsverzeichnis |
Template-Parameter
| IntType | - | Der vom Generator erzeugte Ergebnistyp. Der Effekt ist undefiniert, falls dies nicht einer der Typen short , int , long , long long , unsigned short , unsigned int , unsigned long , oder unsigned long long ist. |
Mitgliedertypen
| Mitgliedstyp | Definition |
result_type
(C++11)
|
IntType |
param_type
(C++11)
|
der Typ des Parametersatzes, siehe RandomNumberDistribution . |
Memberfunktionen
|
(C++11)
|
Konstruiert eine neue Verteilung
(öffentliche Elementfunktion) |
|
(C++11)
|
Setzt den internen Zustand der Verteilung zurück
(öffentliche Elementfunktion) |
Erzeugung |
|
|
(C++11)
|
Erzeugt die nächste Zufallszahl in der Verteilung
(öffentliche Elementfunktion) |
Eigenschaften |
|
|
(C++11)
|
Gibt die Verteilungsparameter zurück
(öffentliche Elementfunktion) |
|
(C++11)
|
Ruft das Verteilungsparameterobjekt ab oder legt es fest
(öffentliche Elementfunktion) |
|
(C++11)
|
Gibt den minimal möglichen generierten Wert zurück
(öffentliche Elementfunktion) |
|
(C++11)
|
Gibt den maximal möglichen generierten Wert zurück
(öffentliche Elementfunktion) |
Nicht-Member-Funktionen
|
(C++11)
(C++11)
(entfernt in C++20)
|
vergleicht zwei Verteilungsobjekte
(Funktion) |
|
(C++11)
|
führt Stream-Eingabe und -Ausgabe auf Pseudozufallszahlenverteilung durch
(Funktionsschablone) |
Beispiel
Diesen Code ausführen
#include <iomanip> #include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::mt19937 gen(rd()); // Pat geht von Tür zu Tür und verkauft Kekse // An jedem Haus besteht eine 75% Chance, dass sie eine Schachtel verkauft // wie oft wird sie abgewiesen, bevor sie 5 Schachteln verkauft? std::negative_binomial_distribution<> d(5, 0.75); std::map<int, int> hist; for (int n = 0; n != 10000; ++n) ++hist[d(gen)]; for (auto [x, y] : hist) std::cout << std::hex << x << ' ' << std::string(y / 100, '*') << '\n'; }
Mögliche Ausgabe:
0 *********************** 1 ***************************** 2 ********************** 3 ************* 4 ****** 5 *** 6 * 7 8 9 a b
Externe Links
| Weisstein, Eric W. "Negative Binomial Distribution." Von MathWorld — Eine Wolfram Web Resource. |