Pseudorandom Numbers

The Wolfram Language has three functions for generating pseudorandom numbers that are distributed uniformly over a range of values.

RandomInteger[]0 or 1 with probability
RandomInteger[{imin,imax}]an integer between imin and imax, inclusive
RandomInteger[imax]an integer between 0 and imax, inclusive
RandomReal[ ]a real number between 0 and 1
RandomReal[{Null, Null}]a real number between xmin and xmax
RandomReal[Null]a real number between 0 and xmax
RandomComplex[]a complex number in the unit square
RandomComplex[{zmin,zmax}]a complex number in the rectangle defined by zmin and zmax
RandomComplex[Null]a complex number in the rectangle defined by 0 and zmax

Pseudorandom number generation.

a list of n pseudorandom numbers from the given range
an n1×n2× array of pseudorandom numbers

Generating tables of pseudorandom numbers.

This will give 0 or 1 with equal probability:
Click for copyable input
This gives a pseudorandom complex number:
Click for copyable input
This gives a list of 10 pseudorandom integers between 0 and 9 (inclusive):
Click for copyable input
This gives a matrix of pseudorandom reals between 0 and 1:
Click for copyable input

RandomReal and RandomComplex allow you to obtain pseudorandom numbers with any precision.

option name
default value
WorkingPrecisionMachinePrecisionprecision to use for real or complex numbers

Changing the precision for pseudorandom numbers.

Here is a 30digit pseudorandom real number in the range 0 to 1:
Click for copyable input
Here is a list of four 20-digit pseudorandom complex numbers:
Click for copyable input

If you get arrays of pseudorandom numbers repeatedly, you should get a "typical" sequence of numbers, with no particular pattern. There are many ways to use such numbers.

One common way to use pseudorandom numbers is in making numerical tests of hypotheses. For example, if you believe that two symbolic expressions are mathematically equal, you can test this by plugging in "typical" numerical values for symbolic parameters, and then comparing the numerical results. (If you do this, you should be careful about numerical accuracy problems and about functions of complex variables that may not have unique values.)

Here is a symbolic equation:
Click for copyable input
Substituting in a random numerical value shows that the equation is not always True:
Click for copyable input

Other common uses of pseudorandom numbers include simulating probabilistic processes, and sampling large spaces of possibilities. The pseudorandom numbers that the Wolfram Language generates for a range of numbers are always uniformly distributed over the range you specify.

RandomInteger, RandomReal, and RandomComplex are unlike almost any other Wolfram Language functions in that every time you call them, you potentially get a different result. If you use them in a calculation, therefore, you may get different answers on different occasions.

The sequences that you get from RandomInteger, RandomReal, and RandomComplex are not in most senses "truly random", although they should be "random enough" for practical purposes. The sequences are in fact produced by applying a definite mathematical algorithm, starting from a particular "seed". If you give the same seed, then you get the same sequence.

When the Wolfram Language starts up, it takes the time of day (measured in small fractions of a second) as the seed for the pseudorandom number generator. Two different Wolfram Language sessions will therefore almost always give different sequences of pseudorandom numbers.

If you want to make sure that you always get the same sequence of pseudorandom numbers, you can explicitly give a seed for the pseudorandom generator, using SeedRandom.

SeedRandom[]reseed the pseudorandom generator, with the time of day
SeedRandom[s]reseed with the integer s

Pseudorandom number generator seed.

This reseeds the pseudorandom generator:
Click for copyable input
Here are three pseudorandom numbers:
Click for copyable input
If you reseed the pseudorandom generator with the same seed, you get the same sequence of pseudorandom numbers:
Click for copyable input

Every single time RandomInteger, RandomReal, or RandomComplex is called, the internal state of the pseudorandom generator that it uses is changed. This means that subsequent calls to these functions made in subsidiary calculations will have an effect on the numbers returned in your main calculation. To avoid any problems associated with this, you can localize this effect of their use by doing the calculation inside of BlockRandom.

BlockRandom[expr]evaluates expr with the current state of the pseudorandom generators localized

Localizing the effects of using RandomInteger, RandomReal, or RandomComplex.

By localizing the calculation inside BlockRandom, the internal state of the pseudorandom generator is restored after generating the first list:
Click for copyable input

Many applications require random numbers from nonuniform distributions. The Wolfram Language has many distributions built into the system. You can give a distribution with appropriate parameters instead of a range to RandomInteger or RandomReal.

a pseudorandom number distributed by the random distribution dist
a list of n pseudorandom numbers distributed by the random distribution dist
an n1×n2× array of pseudorandom numbers distributed by the random distribution dist

Generating pseudorandom numbers with non-uniform distributions.

This generates 12 integers distributed by the Poisson distribution with mean 3:
Click for copyable input
This generates a 4×4 matrix of real numbers using the standard normal distribution:
Click for copyable input
This generates five high-precision real numbers distributed normally with mean 2 and standard deviation 4:
Click for copyable input

An additional use of pseudorandom numbers is for selecting from a list. RandomChoice selects with replacement and RandomSample samples without replacement.

RandomChoice[list, n]choose n items at random from list
RandomChoice[list,{n1,n2,}]an n1×n2× array of values chosen randomly from list
RandomSample[list, n]a sample of size n from list

Selecting at random.

Choose 10 items at random from the digits 0 through 9:
Click for copyable input

Chances are very high that at least one of the choices was repeated in the output. That is because when an element is chosen, it is immediately replaced. On the other hand, if you want to select from an actual set of elements, there should be no replacement.

Sample 10 items at random from the digits 0 through 9 without replacement. The result is a random permutation of the digits:
Click for copyable input
Sample 10 items from a set having different frequencies for each digit:
Click for copyable input