std::lognormal_distribution
提供: cppreference.com
ヘッダ <random> で定義
|
||
template< class RealType = double > class lognormal_distribution; |
(C++11以上) | |
lognormal_distribution
乱数分布は対数正規分布に従った x > 0 の乱数を生成します。
- f(x; m,s) =
exp⎛1 sx√2 π
⎜
⎝-
⎞(ln x - m)2 2s2
⎟
⎠
パラメータ m および s はそれぞれ x の自然対数の平均と標準偏差です。
std::lognormal_distribution
は RandomNumberDistribution の要件をすべて満たします。
目次 |
[編集] テンプレート引数
RealType | - | ジェネレータが生成する結果の型。 float、 double または long double のいずれかでない場合、効果は未定義です
|
[編集] メンバ型
メンバ型 | 定義 |
result_type
|
RealType |
param_type
|
パラメータセットの型、 RandomNumberDistribution を参照してください |
[編集] メンバ関数
新しい分布を構築します (パブリックメンバ関数) | |
分布の内部状態をリセットします (パブリックメンバ関数) | |
生成 | |
分布の次の乱数を生成します (パブリックメンバ関数) | |
特性 | |
分布のパラメータを返します (パブリックメンバ関数) | |
分布のパラメータオブジェクトを取得または設定します (パブリックメンバ関数) | |
生成される可能性のある最小値を返します (パブリックメンバ関数) | |
生成される可能性のある最大値を返します (パブリックメンバ関数) |
[編集] 非メンバ関数
2つの分布オブジェクトを比較します (関数) | |
乱数分布に対してストリーム入出力を行います (関数テンプレート) |
[編集] 例
Run this code
#include <iostream> #include <iomanip> #include <string> #include <map> #include <random> #include <cmath> 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<10000; ++n) { ++hist[std::round(d(gen))]; } for(auto p : hist) { std::cout << std::fixed << std::setprecision(1) << std::setw(2) << p.first << ' ' << std::string(p.second/200, '*') << '\n'; } }
出力:
2 3 *** 4 ************* 5 *************** 6 ********* 7 **** 8 * 9 10 11 12
[編集] 外部リンク
- Weisstein, Eric W. "Log Normal Distribution." From MathWorld--A Wolfram Web Resource.