URCW1_R 3CW "21 March 2008" "mathcw-1.00"

Table of contents


NAME

urcw1f_r, urcw1_r, urcw1l_r, urcw1w_r, urcw1q_r, urcw1ll_r, urcw1df_r, urcw1d_r, urcw1dl_r, urcw1dll_r - pseudorandom number in [0,1] with external state

SYNOPSIS

cc [ flags ] -I/usr/local/include file(s) -L/usr/local/lib -lmcw [ ... ]

#include <mathcw.h>

extern float urcw1f_r (randcw_state_t state);

extern double urcw1_r (randcw_state_t state);

extern long double urcw1l_r (randcw_state_t state);

extern __float80 urcw1w_r (randcw_state_t state);

extern __float128 urcw1q_r (randcw_state_t state);

extern long_long_double urcw1ll_r (randcw_state_t state);

extern decimal_float urcw1df_r (randcw_state_t state);

extern decimal_double urcw1d_r (randcw_state_t state);

extern decimal_long_double urcw1dl_r (randcw_state_t state);

extern decimal_long_long_double urcw1dll_r (randcw_state_t state);

NB: Functions with prototypes containing underscores in type names may be available only with certain extended compilers.


DESCRIPTION

Return a pseudorandom number uniformly distributed on [0,1] (that is, 0 <= urcw1_r(state) <= 1).

The generator state is keep externally in the state argument, a vector of four UINT_LEAST32_T values, most conveniently initialized with incw_r(). This makes the functions thread safe, and allows creation of a practically-unlimited number of independent families of generators, each with its own state.

The generator is Marsaglia's KISS generator, which has a long period of about 2**123 (approximately 10**37), and has passed several difficult tests of randomness, including Marsaglia's Diehard Battery test suite, and the Marsaglia/Tsang tuftest suite.

The double functions sample the 32-bit integer generator twice, the long double functions sample it four times, and the long long double functions sample it eight times,

When precision permits, the decimal floating-point functions use the corresponding binary generator, and then convert that result to decimal. Otherwise, they convert several samples of the integer generator to decimal floating-point with suitable scaling.


RETURN VALUES

The pseudorandom number.

ERRORS

None.

SEE ALSO

ercw(3CW), ercw_r(3CW), gscw(3CW), incw_r(3CW), llrancw(3CW), llrancw_r(3CW), llrincw(3CW), llrincw_r(3CW), lrancw(3CW), lrancw_r(3CW), lrcw(3CW), lrcw_r(3CW), lrincw(3CW), lrincw_r(3CW), mscw(3CW), nrcw(3CW), nrcw_r(3CW), sccw(3CW), sscw(3CW), urcw(3CW), urcw1(3CW), urcw2(3CW), urcw2_r(3CW), urcw3(3CW), urcw3_r(3CW), urcw4(3CW), urcw4_r(3CW), urcw_r(3CW), vercw(3CW), vercw_r(3CW), vllrancw(3CW), vllrancw_r(3CW), vllrincw(3CW), vllrincw_r(3CW), vlrancw(3CW), vlrancw_r(3CW), vlrcw(3CW), vlrcw_r(3CW), vlrincw(3CW), vlrincw_r(3CW), vnrcw(3CW), vnrcw_r(3CW), vurcw(3CW), vurcw1(3CW), vurcw1_r(3CW), vurcw2(3CW), vurcw2_r(3CW), vurcw3(3CW), vurcw3_r(3CW), vurcw4(3CW), vurcw4_r(3CW), vurcw_r(3CW).