std:: negative_binomial_distribution
From cppreference.net
|
Definido en el encabezado
<random>
|
||
|
template
<
class
IntType
=
int
>
class negative_binomial_distribution ; |
(desde C++11) | |
Produce valores enteros no negativos aleatorios i , distribuidos según la función de probabilidad discreta:
-
P(i|k,p) =
⎛
⎜
⎝ k + i − 1
i ⎞
⎟
⎠ · p k
· (1 − p) i
El valor representa el número de fallos en una serie de ensayos independientes sí/no (cada uno tiene éxito con probabilidad p ), antes de que ocurran exactamente k éxitos.
std::negative_binomial_distribution
satisface
RandomNumberDistribution
.
Contenidos |
Parámetros de plantilla
| IntType | - | El tipo de resultado generado por el generador. El efecto es indefinido si este no es uno de short , int , long , long long , unsigned short , unsigned int , unsigned long , o unsigned long long . |
Tipos de miembros
| Tipo de miembro | Definición |
result_type
(C++11)
|
IntType |
param_type
(C++11)
|
el tipo del conjunto de parámetros, ver RandomNumberDistribution . |
Funciones miembro
|
(C++11)
|
construye nueva distribución
(función miembro pública) |
|
(C++11)
|
reinicia el estado interno de la distribución
(función miembro pública) |
Generación |
|
|
(C++11)
|
genera el siguiente número aleatorio en la distribución
(función miembro pública) |
Características |
|
|
(C++11)
|
devuelve los parámetros de la distribución
(función miembro pública) |
|
(C++11)
|
obtiene o establece el objeto de parámetros de la distribución
(función miembro pública) |
|
(C++11)
|
devuelve el valor mínimo potencialmente generado
(función miembro pública) |
|
(C++11)
|
devuelve el valor máximo potencialmente generado
(función miembro pública) |
Funciones no miembro
|
(C++11)
(C++11)
(removed in C++20)
|
compara dos objetos de distribución
(función) |
|
(C++11)
|
realiza entrada y salida de flujo en distribución de números pseudoaleatorios
(plantilla de función) |
Ejemplo
Ejecutar este código
#include <iomanip> #include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::mt19937 gen(rd()); // Pat va de puerta en puerta vendiendo galletas // En cada casa, hay un 75% de probabilidad de que venda una caja // ¿cuántas veces será rechazada antes de vender 5 cajas? 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'; }
Salida posible:
0 *********************** 1 ***************************** 2 ********************** 3 ************* 4 ****** 5 *** 6 * 7 8 9 a b
Enlaces externos
| Weisstein, Eric W. "Distribución Binomial Negativa." De MathWorld — Un recurso web de Wolfram. |