| :mod:`random` --- Generate pseudo-random numbers | 
 | ================================================ | 
 |  | 
 | .. module:: random | 
 |    :synopsis: Generate pseudo-random numbers with various common distributions. | 
 |  | 
 | **Source code:** :source:`Lib/random.py` | 
 |  | 
 | -------------- | 
 |  | 
 | This module implements pseudo-random number generators for various | 
 | distributions. | 
 |  | 
 | For integers, there is uniform selection from a range. For sequences, there is | 
 | uniform selection of a random element, a function to generate a random | 
 | permutation of a list in-place, and a function for random sampling without | 
 | replacement. | 
 |  | 
 | On the real line, there are functions to compute uniform, normal (Gaussian), | 
 | lognormal, negative exponential, gamma, and beta distributions. For generating | 
 | distributions of angles, the von Mises distribution is available. | 
 |  | 
 | Almost all module functions depend on the basic function :func:`random`, which | 
 | generates a random float uniformly in the semi-open range [0.0, 1.0).  Python | 
 | uses the Mersenne Twister as the core generator.  It produces 53-bit precision | 
 | floats and has a period of 2\*\*19937-1.  The underlying implementation in C is | 
 | both fast and threadsafe.  The Mersenne Twister is one of the most extensively | 
 | tested random number generators in existence.  However, being completely | 
 | deterministic, it is not suitable for all purposes, and is completely unsuitable | 
 | for cryptographic purposes. | 
 |  | 
 | The functions supplied by this module are actually bound methods of a hidden | 
 | instance of the :class:`random.Random` class.  You can instantiate your own | 
 | instances of :class:`Random` to get generators that don't share state. | 
 |  | 
 | Class :class:`Random` can also be subclassed if you want to use a different | 
 | basic generator of your own devising: in that case, override the :meth:`random`, | 
 | :meth:`seed`, :meth:`getstate`, and :meth:`setstate` methods. | 
 | Optionally, a new generator can supply a :meth:`getrandbits` method --- this | 
 | allows :meth:`randrange` to produce selections over an arbitrarily large range. | 
 |  | 
 | The :mod:`random` module also provides the :class:`SystemRandom` class which | 
 | uses the system function :func:`os.urandom` to generate random numbers | 
 | from sources provided by the operating system. | 
 |  | 
 |  | 
 | Bookkeeping functions: | 
 |  | 
 | .. function:: seed([x], version=2) | 
 |  | 
 |    Initialize the random number generator. | 
 |  | 
 |    If *x* is omitted or ``None``, the current system time is used.  If | 
 |    randomness sources are provided by the operating system, they are used | 
 |    instead of the system time (see the :func:`os.urandom` function for details | 
 |    on availability). | 
 |  | 
 |    If *x* is an int, it is used directly. | 
 |  | 
 |    With version 2 (the default), a :class:`str`, :class:`bytes`, or :class:`bytearray` | 
 |    object gets converted to an :class:`int` and all of its bits are used.  With version 1, | 
 |    the :func:`hash` of *x* is used instead. | 
 |  | 
 |    .. versionchanged:: 3.2 | 
 |       Moved to the version 2 scheme which uses all of the bits in a string seed. | 
 |  | 
 | .. function:: getstate() | 
 |  | 
 |    Return an object capturing the current internal state of the generator.  This | 
 |    object can be passed to :func:`setstate` to restore the state. | 
 |  | 
 |  | 
 | .. function:: setstate(state) | 
 |  | 
 |    *state* should have been obtained from a previous call to :func:`getstate`, and | 
 |    :func:`setstate` restores the internal state of the generator to what it was at | 
 |    the time :func:`setstate` was called. | 
 |  | 
 |  | 
 | .. function:: getrandbits(k) | 
 |  | 
 |    Returns a Python integer with *k* random bits. This method is supplied with | 
 |    the MersenneTwister generator and some other generators may also provide it | 
 |    as an optional part of the API. When available, :meth:`getrandbits` enables | 
 |    :meth:`randrange` to handle arbitrarily large ranges. | 
 |  | 
 |  | 
 | Functions for integers: | 
 |  | 
 | .. function:: randrange([start,] stop[, step]) | 
 |  | 
 |    Return a randomly selected element from ``range(start, stop, step)``.  This is | 
 |    equivalent to ``choice(range(start, stop, step))``, but doesn't actually build a | 
 |    range object. | 
 |  | 
 |    The positional argument pattern matches that of :func:`range`.  Keyword arguments | 
 |    should not be used because the function may use them in unexpected ways. | 
 |  | 
 |    .. versionchanged:: 3.2 | 
 |       :meth:`randrange` is more sophisticated about producing equally distributed | 
 |       values.  Formerly it used a style like ``int(random()*n)`` which could produce | 
 |       slightly uneven distributions. | 
 |  | 
 | .. function:: randint(a, b) | 
 |  | 
 |    Return a random integer *N* such that ``a <= N <= b``.  Alias for | 
 |    ``randrange(a, b+1)``. | 
 |  | 
 |  | 
 | Functions for sequences: | 
 |  | 
 | .. function:: choice(seq) | 
 |  | 
 |    Return a random element from the non-empty sequence *seq*. If *seq* is empty, | 
 |    raises :exc:`IndexError`. | 
 |  | 
 |  | 
 | .. function:: shuffle(x[, random]) | 
 |  | 
 |    Shuffle the sequence *x* in place. The optional argument *random* is a | 
 |    0-argument function returning a random float in [0.0, 1.0); by default, this is | 
 |    the function :func:`random`. | 
 |  | 
 |    Note that for even rather small ``len(x)``, the total number of permutations of | 
 |    *x* is larger than the period of most random number generators; this implies | 
 |    that most permutations of a long sequence can never be generated. | 
 |  | 
 |  | 
 | .. function:: sample(population, k) | 
 |  | 
 |    Return a *k* length list of unique elements chosen from the population sequence | 
 |    or set. Used for random sampling without replacement. | 
 |  | 
 |    Returns a new list containing elements from the population while leaving the | 
 |    original population unchanged.  The resulting list is in selection order so that | 
 |    all sub-slices will also be valid random samples.  This allows raffle winners | 
 |    (the sample) to be partitioned into grand prize and second place winners (the | 
 |    subslices). | 
 |  | 
 |    Members of the population need not be :term:`hashable` or unique.  If the population | 
 |    contains repeats, then each occurrence is a possible selection in the sample. | 
 |  | 
 |    To choose a sample from a range of integers, use an :func:`range` object as an | 
 |    argument.  This is especially fast and space efficient for sampling from a large | 
 |    population:  ``sample(range(10000000), 60)``. | 
 |  | 
 | The following functions generate specific real-valued distributions. Function | 
 | parameters are named after the corresponding variables in the distribution's | 
 | equation, as used in common mathematical practice; most of these equations can | 
 | be found in any statistics text. | 
 |  | 
 |  | 
 | .. function:: random() | 
 |  | 
 |    Return the next random floating point number in the range [0.0, 1.0). | 
 |  | 
 |  | 
 | .. function:: uniform(a, b) | 
 |  | 
 |    Return a random floating point number *N* such that ``a <= N <= b`` for | 
 |    ``a <= b`` and ``b <= N <= a`` for ``b < a``. | 
 |  | 
 |    The end-point value ``b`` may or may not be included in the range | 
 |    depending on floating-point rounding in the equation ``a + (b-a) * random()``. | 
 |  | 
 | .. function:: triangular(low, high, mode) | 
 |  | 
 |    Return a random floating point number *N* such that ``low <= N <= high`` and | 
 |    with the specified *mode* between those bounds.  The *low* and *high* bounds | 
 |    default to zero and one.  The *mode* argument defaults to the midpoint | 
 |    between the bounds, giving a symmetric distribution. | 
 |  | 
 |  | 
 | .. function:: betavariate(alpha, beta) | 
 |  | 
 |    Beta distribution.  Conditions on the parameters are ``alpha > 0`` and | 
 |    ``beta > 0``. Returned values range between 0 and 1. | 
 |  | 
 |  | 
 | .. function:: expovariate(lambd) | 
 |  | 
 |    Exponential distribution.  *lambd* is 1.0 divided by the desired | 
 |    mean.  It should be nonzero.  (The parameter would be called | 
 |    "lambda", but that is a reserved word in Python.)  Returned values | 
 |    range from 0 to positive infinity if *lambd* is positive, and from | 
 |    negative infinity to 0 if *lambd* is negative. | 
 |  | 
 |  | 
 | .. function:: gammavariate(alpha, beta) | 
 |  | 
 |    Gamma distribution.  (*Not* the gamma function!)  Conditions on the | 
 |    parameters are ``alpha > 0`` and ``beta > 0``. | 
 |  | 
 |  | 
 | .. function:: gauss(mu, sigma) | 
 |  | 
 |    Gaussian distribution.  *mu* is the mean, and *sigma* is the standard | 
 |    deviation.  This is slightly faster than the :func:`normalvariate` function | 
 |    defined below. | 
 |  | 
 |  | 
 | .. function:: lognormvariate(mu, sigma) | 
 |  | 
 |    Log normal distribution.  If you take the natural logarithm of this | 
 |    distribution, you'll get a normal distribution with mean *mu* and standard | 
 |    deviation *sigma*.  *mu* can have any value, and *sigma* must be greater than | 
 |    zero. | 
 |  | 
 |  | 
 | .. function:: normalvariate(mu, sigma) | 
 |  | 
 |    Normal distribution.  *mu* is the mean, and *sigma* is the standard deviation. | 
 |  | 
 |  | 
 | .. function:: vonmisesvariate(mu, kappa) | 
 |  | 
 |    *mu* is the mean angle, expressed in radians between 0 and 2\*\ *pi*, and *kappa* | 
 |    is the concentration parameter, which must be greater than or equal to zero.  If | 
 |    *kappa* is equal to zero, this distribution reduces to a uniform random angle | 
 |    over the range 0 to 2\*\ *pi*. | 
 |  | 
 |  | 
 | .. function:: paretovariate(alpha) | 
 |  | 
 |    Pareto distribution.  *alpha* is the shape parameter. | 
 |  | 
 |  | 
 | .. function:: weibullvariate(alpha, beta) | 
 |  | 
 |    Weibull distribution.  *alpha* is the scale parameter and *beta* is the shape | 
 |    parameter. | 
 |  | 
 |  | 
 | Alternative Generator: | 
 |  | 
 | .. class:: SystemRandom([seed]) | 
 |  | 
 |    Class that uses the :func:`os.urandom` function for generating random numbers | 
 |    from sources provided by the operating system. Not available on all systems. | 
 |    Does not rely on software state, and sequences are not reproducible. Accordingly, | 
 |    the :meth:`seed` method has no effect and is ignored. | 
 |    The :meth:`getstate` and :meth:`setstate` methods raise | 
 |    :exc:`NotImplementedError` if called. | 
 |  | 
 |  | 
 | .. seealso:: | 
 |  | 
 |    M. Matsumoto and T. Nishimura, "Mersenne Twister: A 623-dimensionally | 
 |    equidistributed uniform pseudorandom number generator", ACM Transactions on | 
 |    Modeling and Computer Simulation Vol. 8, No. 1, January pp.3-30 1998. | 
 |  | 
 |  | 
 |    `Complementary-Multiply-with-Carry recipe | 
 |    <http://code.activestate.com/recipes/576707/>`_ for a compatible alternative | 
 |    random number generator with a long period and comparatively simple update | 
 |    operations. | 
 |  | 
 |  | 
 | Notes on Reproducibility | 
 | ------------------------ | 
 |  | 
 | Sometimes it is useful to be able to reproduce the sequences given by a pseudo | 
 | random number generator.  By re-using a seed value, the same sequence should be | 
 | reproducible from run to run as long as multiple threads are not running. | 
 |  | 
 | Most of the random module's algorithms and seeding functions are subject to | 
 | change across Python versions, but two aspects are guaranteed not to change: | 
 |  | 
 | * If a new seeding method is added, then a backward compatible seeder will be | 
 |   offered. | 
 |  | 
 | * The generator's :meth:`random` method will continue to produce the same | 
 |   sequence when the compatible seeder is given the same seed. | 
 |  | 
 | .. _random-examples: | 
 |  | 
 | Examples and Recipes | 
 | -------------------- | 
 |  | 
 | Basic usage:: | 
 |  | 
 |    >>> random.random()                      # Random float x, 0.0 <= x < 1.0 | 
 |    0.37444887175646646 | 
 |  | 
 |    >>> random.uniform(1, 10)                # Random float x, 1.0 <= x < 10.0 | 
 |    1.1800146073117523 | 
 |  | 
 |    >>> random.randrange(10)                 # Integer from 0 to 9 | 
 |    7 | 
 |  | 
 |    >>> random.randrange(0, 101, 2)          # Even integer from 0 to 100 | 
 |    26 | 
 |  | 
 |    >>> random.choice('abcdefghij')          # Single random element | 
 |    'c' | 
 |  | 
 |    >>> items = [1, 2, 3, 4, 5, 6, 7] | 
 |    >>> random.shuffle(items) | 
 |    >>> items | 
 |    [7, 3, 2, 5, 6, 4, 1] | 
 |  | 
 |    >>> random.sample([1, 2, 3, 4, 5],  3)   # Three samples without replacement | 
 |    [4, 1, 5] | 
 |  | 
 | A common task is to make a :func:`random.choice` with weighted probababilites. | 
 |  | 
 | If the weights are small integer ratios, a simple technique is to build a sample | 
 | population with repeats:: | 
 |  | 
 |     >>> weighted_choices = [('Red', 3), ('Blue', 2), ('Yellow', 1), ('Green', 4)] | 
 |     >>> population = [val for val, cnt in weighted_choices for i in range(cnt)] | 
 |     >>> random.choice(population) | 
 |     'Green' | 
 |  | 
 | A more general approach is to arrange the weights in a cumulative distribution | 
 | with :func:`itertools.accumulate`, and then locate the random value with | 
 | :func:`bisect.bisect`:: | 
 |  | 
 |     >>> choices, weights = zip(*weighted_choices) | 
 |     >>> cumdist = list(itertools.accumulate(weights)) | 
 |     >>> x = random.random() * cumdist[-1] | 
 |     >>> choices[bisect.bisect(cumdist, x)] | 
 |     'Blue' |