Generates lognormally distributed random numbers.
Fortran:
status = vsrnglognormal( method, stream, n, r, a, sigma, b, beta )
status = vdrnglognormal( method, stream, n, r, a, sigma, b, beta )
C:
status = vsRngLognormal( method, stream, n, r, a, sigma, b, beta );
status = vdRngLognormal( method, stream, n, r, a, sigma, b, beta );
The FORTRAN 77 interfaces are specified in the mkl_vsl.f77 include file, the Fortran 90 interfaces are specified in the mkl_vsl.f90 include file, and the C interfaces are specified in the mkl_vsl_functions.h include file.
Name |
Type |
Description |
---|---|---|
method |
FORTRAN 77: INTEGER Fortran 90: INTEGER, INTENT(IN) C: const int |
Generation method. The specific values are as follows: 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 |
a |
FORTRAN 77: REAL for vsrnglognormal DOUBLE PRECISION for vdrnglognormal Fortran 90: REAL, INTENT(IN) for vsrnglognormal DOUBLE PRECISION, INTENT(IN) for vdrnglognormal C: const float for vsRngLognormal const double for vdRngLognormal |
Average a of the subject normal distribution |
sigma |
FORTRAN 77: REAL for vsrnglognormal DOUBLE PRECISION for vdrnglognormal Fortran 90: REAL, INTENT(IN) for vsrnglognormal DOUBLE PRECISION, INTENT(IN) for vdrnglognormal C: const float for vsRngLognormal const double for vdRngLognormal |
Standard deviation σ of the subject normal distribution |
b |
FORTRAN 77: REAL for vsrnglognormal DOUBLE PRECISION for vdrnglognormal Fortran 90: REAL, INTENT(IN) for vsrnglognormal DOUBLE PRECISION, INTENT(IN) for vdrnglognormal C: const float for vsRngLognormal const double for vdRngLognormal |
Displacement b |
beta |
FORTRAN 77: REAL for vsrnglognormal DOUBLE PRECISION for vdrnglognormal Fortran 90: REAL, INTENT(IN) for vsrnglognormal DOUBLE PRECISION, INTENT(IN) for vdrnglognormal C: const float for vsRngLognormal const double for vdRngLognormal |
Scalefactor β. |
Name |
Type |
Description |
---|---|---|
r |
FORTRAN 77: REAL for vsrnglognormal DOUBLE PRECISION for vdrnglognormal Fortran 90: REAL, INTENT(OUT) for vsrnglognormal DOUBLE PRECISION, INTENT(OUT) for vdrnglognormal C: float* for vsRngLognormal double* for vdRngLognormal |
Vector of n lognormally distributed random numbers |
The Lognormal function generates lognormally distributed random numbers with average of distribution a and standard deviation σ of subject normal distribution, displacement b, and scalefactor β, where a, σ, b, β∈R ; σ > 0 , β > 0.
The probability density function is given by:
The cumulative distribution function is as follows:
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.
Copyright © 1994 - 2011, Intel Corporation. All rights reserved.