NAME

Math::Random::MT::Perl - Pure Perl Mersenne Twister Random Number Generator

SYNOPSIS

## Object-oriented interface:
use Math::Random::MT::Perl;
$gen = Math::Random::MT->new()        # or...
$gen = Math::Random::MT->new($seed);  # or...
$gen = Math::Random::MT->new(@seeds);
$seed = $gen->get_seed();             # seed generating the random numbers
$rand = $gen->rand(42);               # random number in the interval [0, 42)
$dice = int($gen->rand(6)+1);         # random integer between 1 and 6
$coin = $gen->rand() < 0.5 ?          # flip a coin
  "heads" : "tails"

## Function-oriented interface
use Math::Random::MT qw(srand rand);
$seed = srand();       # OR...
$seed = srand($seed);  # OR...
$seed = srand(@seeds);
# rand() behaves as usual in Perl, but is more precise

DESCRIPTION

Pure Perl implementation of the Mersenne Twister algorithm. Mersenne Twister is a 32 bit pseudorandom number generator developed by Makoto Matsumoto and Takuji Nishimura. The algorithm is characterised by a very uniform distribution but is not cryptographically secure. What this means in real terms is that it is fine for modeling but no good for crypto.

Internally, unsigned 32 bit integers are used. The range of possible values for such integers is 0 .. 4,294,967,295 (0..2**32-1). The generator takes a random integer from within this range and multiplies it by (1.0/4294967296.0). As a result the range of possible return values is 0 .. 0.999999999767169. This number is then multiplied by the argument passed to rand (default=1). In other words the maximum return value from rand will always be slightly less than the argument - it will never equal that argument. Only the first 10 digits of the returned float are mathematically significant.

This module implements the same pseudorandom number generator found in Math::Random::MT (implemented in C/XS). Their output is identical but their interface may be slightly different.

Object-oriented functions

new()

Creates a new generator. It can be provided with a single unsigned 32-bit integer, an array of them, or nothing. If no argument is passed, it is automatically seeded with a random seed.

rand($num)

Behaves exactly like Perl's builtin rand(), returning a number uniformly distributed in [0, $num) ($num defaults to 1), except that the underlying complexity is 32 bits rather than a fraction of it (~15).

set_seed()

Seeds the generator. It takes the same arguments as new().

get_seed()

Retrieves the value of the seed used.

Function-oriented functions

srand()

Seed the random number generator. It takes the same arguments as new(), but returns the seed used. It is strongly recommended that you call srand() explicitly before you call rand() for the first time.

rand($num)

Behaves exactly like Perl's builtin rand(), returning a number uniformly distributed in [0, $num) ($num defaults to 1), except that the underlying complexity is 32 bits rather than a fraction of it (~15).

Export

Nothing by default. rand() and srand() on demand.

SPEED

Runs around 1/3 as fast as the C code of Math::Random::MT, however that still means a random number generation speed of 100,000/sec on modest hardware.

SEE ALSO

Math::Random::MT

http://www.math.keio.ac.jp/~matumoto/emt.html

AUTHOR

(c) Dr James Freeman 2000-08 <airmedical [at] gmail [dot] com> All rights reserved.

Credits

almut from perlmonks for 64 bit debug and fix.

Abhijit Menon-Sen, Philip Newton and Sean M. Burke who contributed to Math::Random::MT as this module is mostly a translation.

LICENSE

This package is free software and is provided "as is" without express or implied warranty. It may be used, redistributed and/or modified under the terms of the Artistic License 2.0. A copy is included in this distribution.