Intel® oneAPI Math Kernel Library Developer Reference - C
Generates binomially distributed random numbers.
status = viRngBinomial( method, stream, n, r, ntrial, p );
Name |
Type |
Description |
---|---|---|
method |
const MKL_INT |
Generation method. The specific value is as follows: VSL_RNG_METHOD_BINOMIAL_BTPE
See brief description of the BTPE method in Table "Values of <method> in method parameter". |
stream |
VSLStreamStatePtr |
Pointer to the stream state structure |
n |
const MKL_INT |
Number of random values to be generated |
ntrial |
const int |
Number of independent trials m |
p |
const double |
Success probability p of a single trial |
Name |
Type |
Description |
---|---|---|
r |
int* |
Vector of n binomially distributed random values |
The vRngBinomial function generates binomially distributed random numbers with number of independent Bernoulli trials m, and with probability p of a single trial success, where p∈R; 0 ≤p≤ 1, m∈N.
A binomially distributed variate represents the number of successes in m independent Bernoulli trials with probability of a single trial success p.
The probability distribution is given by:
The cumulative distribution function is as follows:
Product and Performance Information |
---|
Performance varies by use, configuration and other factors. Learn more at www.Intel.com/PerformanceIndex. Notice revision #20201201 |
Indicates no error, execution is successful.
stream is a NULL pointer.
stream is not a valid random stream.
Callback function for an abstract BRNG returns an invalid number of updated entries in a buffer, that is, < 0 or > nmax.
Callback function for an abstract BRNG returns 0 as the number of updated entries in a buffer.
Period of the generator has been exceeded.
Number of retries to generate a random number by using non-deterministic random number generator exceeds threshold.
ARS-5 random number generator is not supported on the CPU running the application.