Pseudo-random number sampling
Pseudo-random number sampling or non-uniform pseudo-random variate generation is the numerical practice of generating pseudo-random numbers that are distributed according to a given probability distribution.
Methods of sampling a non-uniform distribution are typically based on the availability of a pseudo-random number generator producing numbers X that are uniformly distributed. Computational algorithms are then used to manipulate a single random variate, X, or often several such variates, into a new random variate Y such that these values have the required distribution.
Historically, basic methods of pseudo-random number sampling were developed for Monte-Carlo simulations in the Manhattan project; they were first published by John von Neumann in the early 1950s.Finite discrete distributions
For a discrete probability distribution with a finite number n of indices at which the probability mass function f takes non-zero values, the basic sampling algorithm is straightforward. The interval 0, 1) is divided in n intervals [0, f), [f, f + f), ... The width of interval i equals the probability f.
One draws a uniformly distributed pseudo-random number X, and searches for the index i of the corresponding interval. The so determined i will have the distribution f.
Formalizing this idea becomes easier by using the [cumulative distribution function
It is convenient to set F = 0. The n intervals are then simply F, F), [F, F),..., [F, F). The main computational task is then to determine i for which F ≤ X < F.
This can be done by different algorithms:
, computational time linear in n. Binary search, computational time goes with log n. Indexed search, also called the cutpoint method. Alias method, computational time is constant, using some pre-computed tables. There are other methods that cost constant time.Continuous distributions
Generic methods for generating independent samples:
Generic methods for generating correlated samples :
For generating a normal distribution:
For generating a Poisson distribution:
- See Poisson distribution#Generating Poisson-distributed random variables
Software libraries
has a section entitled "Random Number Distributions" with routines for sampling under more than twenty different distributions.Footnotes
Literature
- Devroye, L. . New York: Springer
- Fishman, G.S. . New York: Springer
- Hörmann, W.; J Leydold, G Derflinger . Berlin: Springer.
- Knuth, D.E. The Art of Computer Programming, Vol. 2 Seminumerical Algorithms, Chapter 3.4.1.
- Ripley, B.D. Stochastic Simulation. Wiley.