RandomTools[MersenneTwister][NewGenerator] - Mersenne Twister Pseudo Random Number Generator
|
Calling Sequence
|
|
NewGenerator( opt1, opt2, ... )
|
|
Parameters
|
|
opt1, opt2, ...
|
-
|
(optional) argument of the form option=value where option is range
|
|
|
|
|
Description
|
|
•
|
The NewGenerator command outputs a Maple procedure, a pseudo-random number generator, which when called outputs one pseudo-random integer. The output of the generator depends on the options described below. The default is to output integers on the range , i.e., a random 12 digit integer.
|
•
|
The returned procedure calls the MersenneTwister algorithm to generate the numbers. Although you can have multiple generating procedures, they all share the same state. This means that calling one procedure will effect the numbers returned by another.
|
•
|
The following optional arguments are supported. They are input as equations in any order.
|
•
|
range=integer..integer or integer
|
|
If the value of the range argument is a range, then the integer will be chosen from that range. If the value of the range argument is an integer, then the integer will be take from the range [0..value). The default range is .
|
•
|
If one only needs to generate a small number of integers then the GenerateInteger function can be used. However, using a procedure returned by NewGenerator is faster than calling GenerateInteger multiple times.
|
|
|
Examples
|
|
>
|
|
| (1) |
>
|
|
| (2) |
>
|
|
| (3) |
>
|
|
| (4) |
>
|
|
| (5) |
>
|
|
| (6) |
>
|
|
| (7) |
>
|
|
| (8) |
>
|
|
| (9) |
>
|
|
>
|
|
| (10) |
|
|