vRngBernoulli

Generates Bernoulli distributed random values.

Syntax

FORTRAN:

status = virngbernoulli( method, stream, n, r, p )

C:

status = viRngBernoulli( method, stream, n, r, p );

Include Files

Input Parameters

Name

Type

Description

method

FORTRAN 77: INTEGER

Fortran 90: INTEGER, INTENT(IN)

C: const int

Generation method. The specific value is as follows:

VSL_RNG_METHOD_BERNOULLI_ICDF

Inverse cumulative distribution function method.

stream

FORTRAN 77: INTEGER*4 stream(2)

Fortran 90: TYPE (VSL_STREAM_STATE), INTENT(IN)

C: VSLStreamStatePtr

Fortran: Descriptor of the stream state structure.

C: Pointer to the stream state structure

n

FORTRAN 77: INTEGER

Fortran 90: INTEGER, INTENT(IN)

C: const int

Number of random values to be generated

p

FORTRAN 77: DOUBLE PRECISION

Fortran 90: REAL(KIND=8), INTENT(IN)

C: const double

Success probability p of a trial

Output Parameters

Name

Type

Description

r

FORTRAN 77: INTEGER*4

Fortran 90: INTEGER(KIND=4), INTENT(OUT)

C: int*

Vector of n Bernoulli distributed random values

Description

The vRngBernoulli function generates Bernoulli distributed random numbers with probability p of a single trial success, wherepR; 0 p 1.

A variate is called Bernoulli distributed, if after a trial it is equal to 1 with probability of success p, and to 0 with probability 1 - p.

The probability distribution is given by: P(X = 1) = p
P(X = 0) = 1 - p

The cumulative distribution function is as follows:


Equation

Return Values

VSL_ERROR_OK, VSL_STATUS_OK

Indicates no error, execution is successful.

VSL_ERROR_NULL_PTR

stream is a NULL pointer.

VSL_RNG_ERROR_BAD_STREAM

stream is not a valid random stream.

VSL_RNG_ERROR_BAD_UPDATE

Callback function for an abstract BRNG returns an invalid number of updated entries in a buffer, that is, < 0 or > nmax.

VSL_RNG_ERROR_NO_NUMBERS

Callback function for an abstract BRNG returns 0 as the number of updated entries in a buffer.

VSL_RNG_ERROR_QRNG_PERIOD_ELAPSED

Period of the generator has been exceeded.


Submit feedback on this help topic