blob: 1e1668f4380fea9a2f8868af19bfdfec97e2498f [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001:mod:`random` --- Generate pseudo-random numbers
2================================================
3
4.. module:: random
5 :synopsis: Generate pseudo-random numbers with various common distributions.
6
7
8This module implements pseudo-random number generators for various
9distributions.
10
Raymond Hettingerb21dac12010-09-07 05:32:49 +000011For integers, there is uniform selection from a range. For sequences, there is
12uniform selection of a random element, a function to generate a random
13permutation of a list in-place, and a function for random sampling without
14replacement.
Georg Brandl116aa622007-08-15 14:28:22 +000015
16On the real line, there are functions to compute uniform, normal (Gaussian),
17lognormal, negative exponential, gamma, and beta distributions. For generating
18distributions of angles, the von Mises distribution is available.
19
20Almost all module functions depend on the basic function :func:`random`, which
21generates a random float uniformly in the semi-open range [0.0, 1.0). Python
22uses the Mersenne Twister as the core generator. It produces 53-bit precision
23floats and has a period of 2\*\*19937-1. The underlying implementation in C is
24both fast and threadsafe. The Mersenne Twister is one of the most extensively
25tested random number generators in existence. However, being completely
26deterministic, it is not suitable for all purposes, and is completely unsuitable
27for cryptographic purposes.
28
29The functions supplied by this module are actually bound methods of a hidden
30instance of the :class:`random.Random` class. You can instantiate your own
Raymond Hettinger28de64f2008-01-13 23:40:30 +000031instances of :class:`Random` to get generators that don't share state.
Georg Brandl116aa622007-08-15 14:28:22 +000032
33Class :class:`Random` can also be subclassed if you want to use a different
34basic generator of your own devising: in that case, override the :meth:`random`,
Raymond Hettingerafd30452009-02-24 10:57:02 +000035:meth:`seed`, :meth:`getstate`, and :meth:`setstate` methods.
Benjamin Petersond18de0e2008-07-31 20:21:46 +000036Optionally, a new generator can supply a :meth:`getrandbits` method --- this
Georg Brandl116aa622007-08-15 14:28:22 +000037allows :meth:`randrange` to produce selections over an arbitrarily large range.
38
Benjamin Peterson21896a32010-03-21 22:03:03 +000039The :mod:`random` module also provides the :class:`SystemRandom` class which
40uses the system function :func:`os.urandom` to generate random numbers
41from sources provided by the operating system.
Georg Brandl116aa622007-08-15 14:28:22 +000042
Georg Brandl116aa622007-08-15 14:28:22 +000043Bookkeeping functions:
44
45
Raymond Hettingerf763a722010-09-07 00:38:15 +000046.. function:: seed([x], version=2)
Georg Brandl116aa622007-08-15 14:28:22 +000047
Raymond Hettingerf763a722010-09-07 00:38:15 +000048 Initialize the random number generator.
Georg Brandl116aa622007-08-15 14:28:22 +000049
Raymond Hettingerf763a722010-09-07 00:38:15 +000050 If *x* is omitted or ``None``, the current system time is used. If
51 randomness sources are provided by the operating system, they are used
52 instead of the system time (see the :func:`os.urandom` function for details
53 on availability).
Georg Brandl116aa622007-08-15 14:28:22 +000054
Raymond Hettingerf763a722010-09-07 00:38:15 +000055 If *x* is an int, it is used directly.
56
57 With version 2 (the default), a :class:`str`, :class:`bytes`, or :class:`bytearray`
58 object gets converted to a :class:`int` and all of its bits are used. With version 1,
59 the :func:`hash` of *x* is used instead.
60
61 .. versionchanged:: 3.2
62 Moved to the version 2 scheme which uses all of the bits in a string seed.
Georg Brandl116aa622007-08-15 14:28:22 +000063
64.. function:: getstate()
65
66 Return an object capturing the current internal state of the generator. This
67 object can be passed to :func:`setstate` to restore the state.
68
Georg Brandl116aa622007-08-15 14:28:22 +000069
70.. function:: setstate(state)
71
72 *state* should have been obtained from a previous call to :func:`getstate`, and
73 :func:`setstate` restores the internal state of the generator to what it was at
74 the time :func:`setstate` was called.
75
Georg Brandl116aa622007-08-15 14:28:22 +000076
Georg Brandl116aa622007-08-15 14:28:22 +000077.. function:: getrandbits(k)
78
Ezio Melotti0639d5a2009-12-19 23:26:38 +000079 Returns a Python integer with *k* random bits. This method is supplied with
Georg Brandl5c106642007-11-29 17:41:05 +000080 the MersenneTwister generator and some other generators may also provide it
Georg Brandl116aa622007-08-15 14:28:22 +000081 as an optional part of the API. When available, :meth:`getrandbits` enables
82 :meth:`randrange` to handle arbitrarily large ranges.
83
Georg Brandl116aa622007-08-15 14:28:22 +000084
85Functions for integers:
86
Georg Brandl116aa622007-08-15 14:28:22 +000087.. function:: randrange([start,] stop[, step])
88
89 Return a randomly selected element from ``range(start, stop, step)``. This is
90 equivalent to ``choice(range(start, stop, step))``, but doesn't actually build a
91 range object.
92
Raymond Hettinger05156612010-09-07 04:44:52 +000093 The positional argument pattern matches that of :func:`range`. Keyword arguments
94 should not be used because the function may use them in unexpected ways.
95
96 .. versionchanged:: 3.2
97 :meth:`randrange` is more sophisticated about producing equally distributed
98 values. Formerly it used a style like ``int(random()*n)`` which could produce
99 slightly uneven distributions.
Georg Brandl116aa622007-08-15 14:28:22 +0000100
101.. function:: randint(a, b)
102
Raymond Hettingerafd30452009-02-24 10:57:02 +0000103 Return a random integer *N* such that ``a <= N <= b``. Alias for
104 ``randrange(a, b+1)``.
Georg Brandl116aa622007-08-15 14:28:22 +0000105
Georg Brandl116aa622007-08-15 14:28:22 +0000106
Georg Brandl55ac8f02007-09-01 13:51:09 +0000107Functions for sequences:
Georg Brandl116aa622007-08-15 14:28:22 +0000108
109.. function:: choice(seq)
110
111 Return a random element from the non-empty sequence *seq*. If *seq* is empty,
112 raises :exc:`IndexError`.
113
114
115.. function:: shuffle(x[, random])
116
117 Shuffle the sequence *x* in place. The optional argument *random* is a
118 0-argument function returning a random float in [0.0, 1.0); by default, this is
119 the function :func:`random`.
120
121 Note that for even rather small ``len(x)``, the total number of permutations of
122 *x* is larger than the period of most random number generators; this implies
123 that most permutations of a long sequence can never be generated.
124
125
126.. function:: sample(population, k)
127
Raymond Hettinger1acde192008-01-14 01:00:53 +0000128 Return a *k* length list of unique elements chosen from the population sequence
129 or set. Used for random sampling without replacement.
Georg Brandl116aa622007-08-15 14:28:22 +0000130
Georg Brandl116aa622007-08-15 14:28:22 +0000131 Returns a new list containing elements from the population while leaving the
132 original population unchanged. The resulting list is in selection order so that
133 all sub-slices will also be valid random samples. This allows raffle winners
134 (the sample) to be partitioned into grand prize and second place winners (the
135 subslices).
136
Guido van Rossum2cc30da2007-11-02 23:46:40 +0000137 Members of the population need not be :term:`hashable` or unique. If the population
Georg Brandl116aa622007-08-15 14:28:22 +0000138 contains repeats, then each occurrence is a possible selection in the sample.
139
140 To choose a sample from a range of integers, use an :func:`range` object as an
141 argument. This is especially fast and space efficient for sampling from a large
142 population: ``sample(range(10000000), 60)``.
143
144The following functions generate specific real-valued distributions. Function
145parameters are named after the corresponding variables in the distribution's
146equation, as used in common mathematical practice; most of these equations can
147be found in any statistics text.
148
149
150.. function:: random()
151
152 Return the next random floating point number in the range [0.0, 1.0).
153
154
155.. function:: uniform(a, b)
156
Benjamin Petersonb58dda72009-01-18 22:27:04 +0000157 Return a random floating point number *N* such that ``a <= N <= b`` for
158 ``a <= b`` and ``b <= N <= a`` for ``b < a``.
Georg Brandl116aa622007-08-15 14:28:22 +0000159
Raymond Hettingerbe40db02009-06-11 23:12:14 +0000160 The end-point value ``b`` may or may not be included in the range
161 depending on floating-point rounding in the equation ``a + (b-a) * random()``.
Benjamin Peterson35e8c462008-04-24 02:34:53 +0000162
Christian Heimesfe337bf2008-03-23 21:54:12 +0000163.. function:: triangular(low, high, mode)
164
Benjamin Petersonb58dda72009-01-18 22:27:04 +0000165 Return a random floating point number *N* such that ``low <= N <= high`` and
Christian Heimescc47b052008-03-25 14:56:36 +0000166 with the specified *mode* between those bounds. The *low* and *high* bounds
167 default to zero and one. The *mode* argument defaults to the midpoint
168 between the bounds, giving a symmetric distribution.
Christian Heimesfe337bf2008-03-23 21:54:12 +0000169
Georg Brandl116aa622007-08-15 14:28:22 +0000170
171.. function:: betavariate(alpha, beta)
172
Benjamin Petersonb58dda72009-01-18 22:27:04 +0000173 Beta distribution. Conditions on the parameters are ``alpha > 0`` and
174 ``beta > 0``. Returned values range between 0 and 1.
Georg Brandl116aa622007-08-15 14:28:22 +0000175
176
177.. function:: expovariate(lambd)
178
Mark Dickinson2f947362009-01-07 17:54:07 +0000179 Exponential distribution. *lambd* is 1.0 divided by the desired
180 mean. It should be nonzero. (The parameter would be called
181 "lambda", but that is a reserved word in Python.) Returned values
182 range from 0 to positive infinity if *lambd* is positive, and from
183 negative infinity to 0 if *lambd* is negative.
Georg Brandl116aa622007-08-15 14:28:22 +0000184
185
186.. function:: gammavariate(alpha, beta)
187
Benjamin Petersonb58dda72009-01-18 22:27:04 +0000188 Gamma distribution. (*Not* the gamma function!) Conditions on the
189 parameters are ``alpha > 0`` and ``beta > 0``.
Georg Brandl116aa622007-08-15 14:28:22 +0000190
191
192.. function:: gauss(mu, sigma)
193
Benjamin Petersonb58dda72009-01-18 22:27:04 +0000194 Gaussian distribution. *mu* is the mean, and *sigma* is the standard
195 deviation. This is slightly faster than the :func:`normalvariate` function
196 defined below.
Georg Brandl116aa622007-08-15 14:28:22 +0000197
198
199.. function:: lognormvariate(mu, sigma)
200
201 Log normal distribution. If you take the natural logarithm of this
202 distribution, you'll get a normal distribution with mean *mu* and standard
203 deviation *sigma*. *mu* can have any value, and *sigma* must be greater than
204 zero.
205
206
207.. function:: normalvariate(mu, sigma)
208
209 Normal distribution. *mu* is the mean, and *sigma* is the standard deviation.
210
211
212.. function:: vonmisesvariate(mu, kappa)
213
214 *mu* is the mean angle, expressed in radians between 0 and 2\*\ *pi*, and *kappa*
215 is the concentration parameter, which must be greater than or equal to zero. If
216 *kappa* is equal to zero, this distribution reduces to a uniform random angle
217 over the range 0 to 2\*\ *pi*.
218
219
220.. function:: paretovariate(alpha)
221
222 Pareto distribution. *alpha* is the shape parameter.
223
224
225.. function:: weibullvariate(alpha, beta)
226
227 Weibull distribution. *alpha* is the scale parameter and *beta* is the shape
228 parameter.
229
230
231Alternative Generators:
232
Georg Brandl116aa622007-08-15 14:28:22 +0000233.. class:: SystemRandom([seed])
234
235 Class that uses the :func:`os.urandom` function for generating random numbers
236 from sources provided by the operating system. Not available on all systems.
237 Does not rely on software state and sequences are not reproducible. Accordingly,
Raymond Hettingerafd30452009-02-24 10:57:02 +0000238 the :meth:`seed` method has no effect and is ignored.
Georg Brandl116aa622007-08-15 14:28:22 +0000239 The :meth:`getstate` and :meth:`setstate` methods raise
240 :exc:`NotImplementedError` if called.
241
Georg Brandl116aa622007-08-15 14:28:22 +0000242
243Examples of basic usage::
244
245 >>> random.random() # Random float x, 0.0 <= x < 1.0
246 0.37444887175646646
247 >>> random.uniform(1, 10) # Random float x, 1.0 <= x < 10.0
248 1.1800146073117523
249 >>> random.randint(1, 10) # Integer from 1 to 10, endpoints included
250 7
251 >>> random.randrange(0, 101, 2) # Even integer from 0 to 100
252 26
253 >>> random.choice('abcdefghij') # Choose a random element
254 'c'
255
256 >>> items = [1, 2, 3, 4, 5, 6, 7]
257 >>> random.shuffle(items)
258 >>> items
259 [7, 3, 2, 5, 6, 4, 1]
260
261 >>> random.sample([1, 2, 3, 4, 5], 3) # Choose 3 elements
262 [4, 1, 5]
263
264
265
266.. seealso::
267
268 M. Matsumoto and T. Nishimura, "Mersenne Twister: A 623-dimensionally
269 equidistributed uniform pseudorandom number generator", ACM Transactions on
270 Modeling and Computer Simulation Vol. 8, No. 1, January pp.3-30 1998.
271
Georg Brandl116aa622007-08-15 14:28:22 +0000272
Raymond Hettinger1fd32a62009-04-01 20:52:13 +0000273 `Complementary-Multiply-with-Carry recipe
Raymond Hettinger9743fd02009-04-03 05:47:33 +0000274 <http://code.activestate.com/recipes/576707/>`_ for a compatible alternative
275 random number generator with a long period and comparatively simple update
Raymond Hettinger1fd32a62009-04-01 20:52:13 +0000276 operations.
Raymond Hettinger435cb0f2010-09-06 23:36:31 +0000277
278Notes on Reproducibility
279========================
280
281Sometimes it is useful to be able to reproduce the sequences given by a pseudo
282random number generator. By re-using a seed value, the same sequence should be
283reproducible from run to run as long as multiple threads are not running.
284
285Most of the random module's algorithms and seeding functions are subject to
286change across Python versions, but two aspects are guaranteed not to change:
287
288* If a new seeding method is added, then a backward compatible seeder will be
289 offered.
290
291* The generator's :meth:`random` method will continue to produce the same
292 sequence when the compatible seeder is given the same seed.