std::lognormal_distribution
Von cppreference.com
| Definiert in Header <random> |
||
| template< class RealType = double > class lognormal_distribution; |
(seit C++11) | |
Die lognormal_distribution Zufallszahlverteilung erzeugt Zufallszahlen x > 0 gemäß einer Log-normalen Verteilung
- f(x; m,s) =
exp⎛1 sx√2 π
⎜
⎝-
⎞(ln x - m)2 2s2
⎟
⎠
Die Parameter m und s sind die Mittelwerts- bzw. Standardabweichung des natürlichen Logarithmus von x.
std::lognormal_distribution erfüllt alle Anforderungen von RandomNumberDistribution.
Inhalt |
[Abschnitt bearbeiten] Template-Parameter
| RealType | - | Der Rückgabetyp, der vom Generator erzeugt wird. Die Wirkung ist undefiniert, wenn dies nicht einer der Typen float, double oder long double ist. |
[Abschnitt bearbeiten] Member-Typen
| Mitgliedertyp | Definition |
result_type (C++11) |
RealType |
param_type (C++11) |
Der Typ des Parametersets, siehe RandomNumberDistribution. |
[Abschnitt bearbeiten] Member-Funktionen
| (C++11) |
erzeugt neue Verteilung (public member function) |
| (C++11) |
setzt den internen Zustand der Verteilung zurück (public member function) |
Generierung | |
| (C++11) |
erzeugt die nächste Zufallszahl in der Verteilung (public member function) |
Eigenschaften des Generators | |
| (C++11) |
gibt die Verteilungsparameter zurück (public member function) |
| (C++11) |
holt oder setzt das Parameterobjekt der Verteilung (public member function) |
| (C++11) |
gibt den minimalen potenziell generierten Wert zurück (public member function) |
| (C++11) |
gibt den maximalen potenziell generierten Wert zurück (public member function) |
[Abschnitt bearbeiten] Nicht-Member-Funktionen
| (C++11)(C++11)(entfernt in C++20) |
vergleicht zwei Verteilungsobjekte (function) |
| (C++11) |
führt Stream-Ein- und -Ausgabe auf Pseudo-Zufallszahlendistributionen durch (function template) |
[Abschnitt bearbeiten] Beispiel
Führen Sie diesen Code aus
#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'; }
Mögliche Ausgabe
2 3 *** 4 ************* 5 *************** 6 ********* 7 **** 8 * 9 a b c
[Abschnitt bearbeiten] Externe Links
| Weisstein, Eric W. "Log Normal Distribution." From MathWorld — A Wolfram Web Resource. |