Intel® oneAPI Math Kernel Library Developer Reference - C
Generates normally distributed random numbers.
status = vsRngGaussian( method, stream, n, r, a, sigma );
status = vdRngGaussian( method, stream, n, r, a, sigma );
The vRngGaussian function generates random numbers with normal (Gaussian) distribution with mean value a and standard deviation σ, where
a, σ ∈ R ; σ > 0.
The probability density function is given by:
The cumulative distribution function is as follows:
The cumulative distribution function Fa,σ(x) can be expressed in terms of standard normal distribution Φ(x) as
F a,σ (x) = Φ((x - a)/σ)
Product and Performance Information |
---|
Performance varies by use, configuration and other factors. Learn more at www.Intel.com/PerformanceIndex. Notice revision #20201201 |
Name |
Type |
Description |
---|---|---|
method |
const MKL_INT |
Generation method. The specific values are as follows: VSL_RNG_METHOD_GAUSSIAN_BOXMULLER VSL_RNG_METHOD_GAUSSIAN_BOXMULLER2 VSL_RNG_METHOD_GAUSSIAN_ICDFSee brief description of the methods BOXMULLER, BOXMULLER2, and ICDF 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. |
a |
const float for vsRngGaussian const double for vdRngGaussian |
Mean value a. |
sigma |
const float for vsRngGaussian const double for vdRngGaussian |
Standard deviation σ. |
Name |
Type |
Description |
---|---|---|
r |
float* for vsRngGaussian double* for vdRngGaussian |
Vector of n normally distributed random numbers. |
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.