explicit negative_binomial_distribution(IntType k = 1, double p = 0.5); // (1)
negative_binomial_distribution() : negative_binomial_distribution(1) {} // (1) C++20
explicit negative_binomial_distribution(IntType k, double p = 0.5); // (2) C++20
explicit negative_binomial_distribution(const param_type& parm); // (3)
概要
- (1) : デフォルトコンストラクタ
- C++17まで : 成功回数
k、および一度の事象が成功する確率pを受け取るコンストラクタ - C++20 : 成功回数
k = 1、一度の事象が成功する確率p = 0.5として(2)に委譲。
- C++17まで : 成功回数
- (2) : 成功回数
k、および一度の事象が成功する確率pを受け取るコンストラクタ - (3) : パラメータオブジェクトを受け取るコンストラクタ。
param_typeは、このクラスの(1)のコンストラクタと同じオーバーロードを持ち、それらのコンストラクタのパラメータを保持している。このコンストラクタでは、paramオブジェクトが持っているパラメータを、このクラスのコンストラクタに転送する。
要件
- (2) :
p > 0.0 && p <= 1.0かつk > 0であること。(p == 0だと無限ループしてしまうため)
例
#include <iostream>
#include <random>
#include <cstdint>
int main()
{
std::random_device seed_gen;
std::uint32_t seed = seed_gen();
std::default_random_engine engine(seed);
// (2) パラメータを個別に指定する
{
// 確率0.5で成功する事象を、3回成功させる
std::negative_binomial_distribution<> dist(3, 0.5);
// 3回成功するまでに失敗した回数を取得
int result = dist(engine);
std::cout << result << std::endl;
}
// (3) パラメータを通して範囲指定する
{
using dist_type = std::negative_binomial_distribution<>;
// 確率0.5で成功する事象を、3回成功させる
dist_type::param_type param(3, 0.5);
dist_type dist(param);
// 3回成功するまでに失敗した回数を取得
int result = dist(engine);
std::cout << result << std::endl;
}
}
出力例
2
0
バージョン
言語
- C++11
処理系
- Clang: ??
- GCC: 4.7.2 ✅
- ICC: ??
- Visual C++: ??