Use the following HTML code to embed the calculators within other websites:
Class Carry
This class provides a very fast random number generator using George Marsaglia's multiply with carry algorithm.
It produces uniformly distributed pseudo-random 32-bit values with period of
are prime.
To give you an idea of the running time for each of the functions, here are the results for generating 100,000,000 random numbers on a 750MHz microprocessor :
genReal() 4 seconds
genInt() 4 seconds
This diagram is obtained by generating two sequences of 1000 uniform
floating point random numbers in the (0, 1) interval and then plotting them one versus the other.
It shows that the distribution is indeed uniform.
References:
George Marsaglia's original post of the multiply with carry random number generator, http://groups-beta.google.com/group/sci.math/msg/fa034083b193adf0?hl=en&lr=&ie=UTF-8
The Newran03 random number generator library of Robert Davies, http://www.robertnz.net/nr03doc.htm
Example 1
The following example displays 20 random floating point numbers and 20 random large integers.
It uses two different generators to achieve this. The first generator uses the system timer to
initialize the seed, while the second is simply initialized with a particular value.
Notice that it was necessary to divide the timer with the CARRYDIV value in order to
keep the seed in the (0, 1) interval. The output of the first generator will obviously vary with
each execution of the program, while the output of the second will always be the same
if the seed is never changed.