| Common mathematical functions | |||||||||||||||||||||||||||||||
| Mathematical special functions(C++17) | |||||||||||||||||||||||||||||||
| Mathematical constants(C++20) | |||||||||||||||||||||||||||||||
| Basic linear algebra algorithms(C++26) | |||||||||||||||||||||||||||||||
| Data-parallel types (SIMD)(C++26) | |||||||||||||||||||||||||||||||
| Floating-point environment(C++11) | |||||||||||||||||||||||||||||||
| Complex numbers | |||||||||||||||||||||||||||||||
Numeric array (valarray) | |||||||||||||||||||||||||||||||
| Pseudo-random number generation | |||||||||||||||||||||||||||||||
| Bit manipulation(C++20) | |||||||||||||||||||||||||||||||
| Saturation arithmetic(C++26) | |||||||||||||||||||||||||||||||
| Factor operations | |||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||
| Interpolations | |||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||
| Generic numeric operations | |||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||
| C-style checked integer arithmetic | |||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||
|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Generation | ||||
| Characteristics | ||||
| Non-member functions | ||||
(C++11)(C++11)(until C++20) | ||||
(C++11)(C++11) |
Defined in header <random> | ||
template<class IntType=int> class negative_binomial_distribution; | (since C++11) | |
Produces random non-negative integer valuesi, distributed according to discrete probability function:
The value represents the number of failures in a series of independent yes/no trials (each succeeds with probabilityp), before exactlyk successes occur.
std::negative_binomial_distribution satisfiesRandomNumberDistribution.
Contents |
| IntType | - | The result type generated by the generator. The effect is undefined if this is not one ofshort,int,long,longlong,unsignedshort,unsignedint,unsignedlong, orunsignedlonglong. |
| Member type | Definition |
result_type(C++11) | IntType |
param_type(C++11) | the type of the parameter set, seeRandomNumberDistribution. |
(C++11) | constructs new distribution (public member function)[edit] |
(C++11) | resets the internal state of the distribution (public member function)[edit] |
Generation | |
(C++11) | generates the next random number in the distribution (public member function)[edit] |
Characteristics | |
(C++11) | returns the distribution parameters (public member function)[edit] |
(C++11) | gets or sets the distribution parameter object (public member function)[edit] |
(C++11) | returns the minimum potentially generated value (public member function)[edit] |
(C++11) | returns the maximum potentially generated value (public member function)[edit] |
(C++11)(C++11)(removed in C++20) | compares two distribution objects (function)[edit] |
(C++11) | performs stream input and output on pseudo-random number distribution (function template)[edit] |
#include <iomanip>#include <iostream>#include <map>#include <random>#include <string> 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[x, y]: hist)std::cout<<std::hex<< x<<' '<<std::string(y/100,'*')<<'\n';}
Possible output:
0 ***********************1 *****************************2 **********************3 *************4 ******5 ***6 *789ab
| Weisstein, Eric W. "Negative Binomial Distribution." From MathWorld — A Wolfram Web Resource. |