mirror of https://github.com/python/cpython.git
91 lines
3.5 KiB
TeX
91 lines
3.5 KiB
TeX
\section{\module{random} ---
|
|
Generate pseudo-random numbers with various distributions.}
|
|
\declaremodule{standard}{random}
|
|
|
|
\modulesynopsis{Generate pseudo-random numbers with various common
|
|
distributions.}
|
|
|
|
|
|
This module implements pseudo-random number generators for various
|
|
distributions: on the real line, there are functions to compute normal
|
|
or Gaussian, lognormal, negative exponential, gamma, and beta
|
|
distributions. For generating distribution of angles, the circular
|
|
uniform and von Mises distributions are available.
|
|
|
|
The module exports the following functions, which are exactly
|
|
equivalent to those in the \module{whrandom} module:
|
|
\function{choice()}, \function{randint()}, \function{random()} and
|
|
\function{uniform()}. See the documentation for the \module{whrandom}
|
|
module for these functions.
|
|
|
|
The following functions specific to the \module{random} module are also
|
|
defined, and all return real values. 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.
|
|
|
|
\begin{funcdesc}{betavariate}{alpha, beta}
|
|
Beta distribution. Conditions on the parameters are
|
|
\code{\var{alpha} >- 1} and \code{\var{beta} > -1}.
|
|
Returned values will range between 0 and 1.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{cunifvariate}{mean, arc}
|
|
Circular uniform distribution. \var{mean} is the mean angle, and
|
|
\var{arc} is the range of the distribution, centered around the mean
|
|
angle. Both values must be expressed in radians, and can range
|
|
between 0 and pi. Returned values will range between
|
|
\code{\var{mean} - \var{arc}/2} and \code{\var{mean} + \var{arc}/2}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{expovariate}{lambd}
|
|
Exponential distribution. \var{lambd} is 1.0 divided by the desired
|
|
mean. (The parameter would be called ``lambda'', but that is a
|
|
reserved word in Python.) Returned values will range from 0 to
|
|
positive infinity.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{gamma}{alpha, beta}
|
|
Gamma distribution. (\emph{Not} the gamma function!) Conditions on
|
|
the parameters are \code{\var{alpha} > -1} and \code{\var{beta} > 0}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{gauss}{mu, sigma}
|
|
Gaussian distribution. \var{mu} is the mean, and \var{sigma} is the
|
|
standard deviation. This is slightly faster than the
|
|
\function{normalvariate()} function defined below.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{lognormvariate}{mu, sigma}
|
|
Log normal distribution. If you take the natural logarithm of this
|
|
distribution, you'll get a normal distribution with mean \var{mu} and
|
|
standard deviation \var{sigma}. \var{mu} can have any value, and \var{sigma}
|
|
must be greater than zero.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{normalvariate}{mu, sigma}
|
|
Normal distribution. \var{mu} is the mean, and \var{sigma} is the
|
|
standard deviation.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{vonmisesvariate}{mu, kappa}
|
|
\var{mu} is the mean angle, expressed in radians between 0 and 2*pi,
|
|
and \var{kappa} is the concentration parameter, which must be greater
|
|
than or equal to zero. If \var{kappa} is equal to zero, this
|
|
distribution reduces to a uniform random angle over the range 0 to
|
|
2*pi.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{paretovariate}{alpha}
|
|
Pareto distribution. \var{alpha} is the shape parameter.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{weibullvariate}{alpha, beta}
|
|
Weibull distribution. \var{alpha} is the scale parameter and
|
|
\var{beta} is the shape parameter.
|
|
\end{funcdesc}
|
|
|
|
\begin{seealso}
|
|
\seemodule{whrandom}{the standard Python random number generator}
|
|
\end{seealso}
|