名前空間
変種
操作

std::negative_binomial_distribution

提供: cppreference.com
< cpp‎ | numeric‎ | random
 
 
 
擬似乱数生成
一様ランダムビットジェネレータ
エンジンとエンジンアダプタ
非決定的なジェネレータ
分布
一様分布
ベルヌーイ分布
negative_binomial_distribution
(C++11)
ポアソン分布
正規分布
標本分布
シードシーケンス
(C++11)
C のライブラリ
 
 
ヘッダ <random> で定義
template< class IntType = int >
class negative_binomial_distribution;
(C++11およびそれ以降)

以下の離散確率関数に従って分布する、ランダムな非負の整数値 i を生成します。

P(i|k,p) =

k + i − 1
i


· pk
· (1 − p)i

値は、各試行が p の確率で成功する独立した成功/失敗の一連の試行において、ちょうど k 回の成功が発生するまでの失敗回数を表します。

std::negative_binomial_distributionRandomNumberDistribution を満たします。

目次

[編集] テンプレート引数

IntType - ジェネレータが生成する結果の型。 shortintlonglong longunsigned shortunsigned intunsigned long または unsigned long long のいずれかでない場合、効果は未定義です


[編集] メンバ型

メンバ型 定義
result_type IntType
param_type パラメータセットの型、 RandomNumberDistribution を参照してください

[編集] メンバ関数

新しい分布を構築します
(パブリックメンバ関数) [edit]
分布の内部状態をリセットします
(パブリックメンバ関数) [edit]
生成
分布の次の乱数を生成します
(パブリックメンバ関数) [edit]
特性
分布のパラメータを返します
(パブリックメンバ関数) [edit]
分布のパラメータオブジェクトを取得または設定します
(パブリックメンバ関数) [edit]
生成される可能性のある最小値を返します
(パブリックメンバ関数) [edit]
生成される可能性のある最大値を返します
(パブリックメンバ関数) [edit]

[編集] 非メンバ関数

2つの分布オブジェクトを比較します
(関数) [edit]
乱数分布に対してストリーム入出力を行います
(関数テンプレート) [edit]

[編集]

#include <iostream>
#include <iomanip>
#include <string>
#include <map>
#include <random>
 
int main()
{
    std::random_device rd;
    std::mt19937 gen(rd());
    // Pat goes door-to-door selling cookies
    // At each house, there's a 75% chance that she sells one box
    // how many times will she be turned away before selling 5 boxes?
    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 p : hist) {
        std::cout  << p.first << ' ' << std::string(p.second/100, '*') << '\n';
    }
}

出力:

0 ***********************
1 *****************************
2 **********************
3 *************
4 ******
5 ***
6 *
7 
8 
9 
10 
11

[編集] 外部リンク

Weisstein, Eric W. "Negative Binomial Distribution." From MathWorld--A Wolfram Web Resource.