std:: lognormal_distribution
From cppreference.net
|
Definido en el encabezado
<random>
|
||
|
template
<
class
RealType
=
double
>
class lognormal_distribution ; |
(desde C++11) | |
La distribución de números aleatorios lognormal_distribution produce números aleatorios x > 0 de acuerdo con una distribución log-normal :
-
f(x; m,s) =
exp ⎛1 sx √ 2 π
⎜
⎝ -
⎞(ln x - m) 2
2s 2
⎟
⎠
Los parámetros m y s son, respectivamente, la media y la desviación estándar del logaritmo natural de x .
std::lognormal_distribution
satisface todos los requisitos de
RandomNumberDistribution
.
Contenidos |
Parámetros de plantilla
| RealType | - | El tipo de resultado generado por el generador. El efecto es indefinido si este no es uno de float , double , o long double . |
Tipos de miembros
| Tipo de miembro | Definición |
result_type
(C++11)
|
RealType |
param_type
(C++11)
|
el tipo del conjunto de parámetros, ver RandomNumberDistribution . |
Funciones miembro
|
(C++11)
|
construye una 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 la distribución de números pseudoaleatorios
(plantilla de función) |
Ejemplo
Ejecutar este código
#include <cmath> #include <iomanip> #include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::mt19937 gen(rd()); std::lognormal_distribution<> d(1.6, 0.25); std::map<int, int> hist; for (int n = 0; n < 1e4; ++n) ++hist[std::round(d(gen))]; for (std::cout << std::fixed << std::setprecision(1); auto [x, y] : hist) std::cout << std::hex << x << ' ' << std::string(y / 200, '*') << '\n'; }
Salida posible:
2 3 *** 4 ************* 5 *************** 6 ********* 7 **** 8 * 9 a b c
Enlaces externos
| Weisstein, Eric W. "Log Normal Distribution." De MathWorld — Un recurso web de Wolfram. |