Showing content from http://umontreal-simul.github.io/ssj/docs/master/namespaceumontreal_1_1ssj_1_1randvar.html below:
SSJ: Package umontreal.ssj.randvar
Generating Non-Uniform Random Numbers. More...
class BernoulliGen This class implements random variate generators for the Bernoulli distribution (see class umontreal.ssj.probdist.BernoulliDist ). More...
class BetaGen This class implements random variate generators with the beta distribution with shape parameters \(\alpha> 0\) and \(\beta> 0\), over the interval \((a,b)\), where \(a < b\). More...
class BetaRejectionLoglogisticGen Implements Beta random variate generators using the rejection method with log-logistic envelopes from [34] . More...
class BetaStratifiedRejectionGen This class implements Beta random variate generators using the stratified rejection/patchwork rejection method from [210], [223] . More...
class BetaSymmetricalBestGen This class implements symmetrical beta random variate generators using Devroye’s one-liner method. More...
class BetaSymmetricalGen This class implements random variate generators with the symmetrical beta distribution with shape parameters \(\alpha= \beta\), over the interval \((0,1)\). More...
class BetaSymmetricalPolarGen This class implements symmetrical beta random variate generators using Ulrich’s polar method [232] . More...
class BinomialConvolutionGen Implements binomial random variate generators using the convolution method. More...
class BinomialGen This class implements random variate generators for the binomial distribution. More...
class CauchyGen This class implements random variate generators for the Cauchy distribution. More...
class ChiGen This class implements random variate generators for the chi distribution. More...
class ChiRatioOfUniformsGen This class implements Chi random variate generators using the ratio of uniforms method with shift. More...
class ChiSquareGen This class implements random variate generators with the chi square distribution with \(n>0\) degrees of freedom. More...
class ChiSquareNoncentralGamGen This class implements noncentral chi square random variate generators using the additive property of the noncentral chi square distribution [115] . More...
class ChiSquareNoncentralGen This class implements random variate generators for the noncentral chi square distribution with \(\nu> 0\) degrees of freedom and noncentrality parameter \(\lambda> 0\). More...
class ChiSquareNoncentralPoisGen This class implements noncentral chi square random variate generators using Poisson and central chi square generators. More...
class ConstantGen This class implements a random variate generator that returns a constant value. More...
class ErlangConvolutionGen This class implements Erlang random variate generators using the convolution method. More...
class ErlangGen This class implements random variate generators for the Erlang distribution with parameters \(k > 0\) and \(\lambda> 0\). More...
class ExponentialGen This class implements random variate generators for the exponential distribution. More...
class ExponentialInverseFromDensityGen This class implements exponential random variate generators using numerical inversion of the exponential density as described in [44] . More...
class ExtremeValueGen This class has been replaced by GumbelGen . More...
class FatigueLifeGen This class implements random variate generators for the fatigue life distribution [20] with location parameter \(\mu\), scale parameter \(\beta\) and shape parameter \(\gamma\). More...
class FisherFGen This class implements random variate generators for the Fisher F distribution with \(n\) and \(m\) degrees of freedom, where \(n\) and \(m\) are positive integers. More...
class FNoncentralGen This class implements random variate generators for the noncentral F-distribution. More...
class FoldedNormalGen This class implements methods for generating random variates from the folded normal distribution with parameters \(\mu\ge0\) and \(\sigma> 0\). More...
class FrechetGen This class implements methods for generating random variates from the Fréchet distribution, with location parameter \(\delta\), scale parameter \(\beta> 0\), and shape parameter \(\alpha> 0\), where we use the notation \(z = (x-\delta)/\beta\). More...
class GammaAcceptanceRejectionGen This class implements gamma random variate generators using a method that combines acceptance-rejection with acceptance-complement, and proposed in [2], [4] . More...
class GammaGen This class implements random variate generators for the gamma distribution. More...
class GammaRejectionLoglogisticGen This class implements gamma random variate generators using a rejection method with loglogistic envelopes, from [33] . More...
class GeometricGen This class implements a random variate generator for the geometric distribution. More...
class GumbelGen This class implements methods for generating random variates from the Gumbel distribution. More...
class HalfNormalGen This class implements methods for generating random variates from the half-normal distribution with parameters \(\mu\) and \(\sigma> 0\). More...
class HyperbolicSecantGen This class implements random variate generators for the hyperbolic secant distribution with location parameter \(\mu\) and scale parameter \(\sigma\). More...
class HypergeometricGen This class implements random variate generators for the hypergeometric distribution. More...
class HypoExponentialGen This class implements random variate generators for the hypoexponential distribution (see classes umontreal.ssj.probdist.HypoExponentialDist and umontreal.ssj.probdist.HypoExponentialDistQuick in package probdist
for the definition). More...
class InverseFromDensityGen Implements a method for generating random variates by numerical inversion of an arbitrary continuous distribution when only the probability density is known [44] . More...
class InverseGammaGen This class implements random variate generators for the inverse gamma distribution with shape parameter \(\alpha> 0\) and scale parameter \(\beta> 0\). More...
class InverseGaussianGen This class implements random variate generators for the inverse Gaussian distribution with location parameter \(\mu> 0\) and scale parameter \(\lambda> 0\). More...
class InverseGaussianMSHGen This class implements inverse gaussian random variate generators using the many-to-one transformation method of Michael, Schucany and Haas (MHS) [180], [48] . More...
class JohnsonSBGen This class implements random variate generators for the Johnson \(S_B\) distribution. More...
class JohnsonSLGen This class implements random variate generators for the Johnson \(S_L\) distribution. More...
class JohnsonSUGen This class implements random variate generators for the Johnson \(S_U\) distribution. More...
class JohnsonSystemG This class contains common parameters and methods for the random variate generators associated with the Johnson system of distributions [101], [99] . More...
class KernelDensityGen This class implements random variate generators for distributions obtained via kernel density estimation methods from a set of \(n\) individual observations \(x_1,…,x_n\) [45], [46], [89], [90], [215] . More...
class KernelDensityVarCorrectGen This class is a variant of KernelDensityGen, but with a rescaling of the empirical distribution so that the variance of the density used to generate the random variates is equal to the empirical variance, as suggested by [215] . More...
class LaplaceGen This class implements methods for generating random variates from the Laplace distribution. More...
class LogarithmicGen This class implements random variate generators for the (discrete) logarithmic distribution. More...
class LogisticGen This class implements random variate generators for the logistic distribution. More...
class LoglogisticGen This class implements random variate generators for the log-logistic distribution with shape parameter \(\alpha> 0\) and scale parameter \(\beta> 0\). More...
class LognormalGen This class implements methods for generating random variates from the lognormal distribution. More...
class LognormalSpecialGen Implements methods for generating random variates from the lognormal distribution using an arbitrary normal random variate generator. More...
class MixtureGen This class implements random variate generators for a mixture distribution. More...
class NakagamiGen This class implements random variate generators for the Nakagami distribution. More...
class NegativeBinomialGen This class implements random variate generators having the negative binomial distribution. More...
class NormalACRGen This class implements normal random variate generators using the acceptance-complement ratio method [87] . More...
class NormalBoxMullerGen This class implements normal random variate generators using the Box-Muller method from [23] . More...
class NormalGen This class implements methods for generating random variates from the normal distribution \(N(\mu, \sigma)\). More...
class NormalInverseFromDensityGen This class implements normal random variate generators using numerical inversion of the normal density as described in [44] . More...
class NormalInverseGaussianGen This class implements random variate generators for the normal inverse gaussian ( \(\mathcal{NIG}\)) distribution. More...
class NormalInverseGaussianIGGen This class implements a normal inverse gaussian ( \({NIG}\)) random variate generator by using a normal generator ( \(N\)) and an inverse gaussian generator ( \(IG\)), as described in the following [239], [103] . More...
class NormalKindermannRamageGen This class implements normal random variate generators using the Kindermann-Ramage method [106] . More...
class NormalPolarGen This class implements normal random variate generators using the polar method with rejection [176] . More...
class ParetoGen This class implements random variate generators for one of the Pareto distributions, with parameters \(\alpha>0\) and \(\beta>0\). More...
class PascalConvolutionGen Implements Pascal random variate generators by the convolution method (see [118] ). More...
class PascalGen Implements Pascal random variate generators, which is a special case of the negative binomial generator with parameter \(\gamma\) equal to a positive integer. More...
class Pearson5Gen THIS CLASS HAS BEEN RENAMED InverseGammaGen . More...
class Pearson6Gen This class implements random variate generators for the Pearson type VI distribution with shape parameters \(\alpha_1 > 0\) and \(\alpha_2 > 0\), and scale parameter \(\beta> 0\). More...
class PoissonGen This class implements random variate generators having the Poisson distribution. More...
class PoissonTIACGen This class implements random variate generators having the Poisson distribution (see PoissonGen ). More...
class PowerGen This class implements random variate generators for the power distribution with shape parameter \(c > 0\), over the interval \([a,b]\). More...
class RandomVariateGen This is the base class for all random variate generators over the real line. More...
class RandomVariateGenInt This is the base class for all generators of discrete random variates over the set of integers. More...
class RandomVariateGenWithCache This class represents a random variate generator whose values are cached for more efficiency when using common random numbers. More...
class RandUnuran This internal class provides the access point to the C package UNURAN. More...
class RayleighGen This class implements random variate generators for the Rayleigh distribution. More...
class StudentGen This class implements methods for generating random variates from the Student distribution with \(n>0\) degrees of freedom. More...
class StudentNoncentralGen This class implements random variate generators for the noncentral Student-t distribution with \(n>0\) degrees of freedom and noncentrality parameter \(\delta\). More...
class StudentPolarGen This class implements Student random variate generators using the polar method of [14] . More...
class TriangularGen This class implements random variate generators for the triangular distribution. More...
class UniformGen This class implements random variate generators for the (continuous) uniform distribution over the interval \((a,b)\), where \(a\) and \(b\) are real numbers with \(a < b\). More...
class UniformIntGen This class implements a random variate generator for the uniform distribution over integers, over the interval \([i,j]\). More...
class UnuranContinuous This class permits one to create continuous univariate generators using UNURAN via its string API. More...
class UnuranDiscreteInt This class permits one to create a discrete univariate generator using UNURAN via its string API. More...
class UnuranEmpirical This class permits one to create generators for empirical and quasi-empirical univariate distributions using UNURAN via its string interface. More...
class UnuranException This type of unchecked exception is thrown when an error occurs inside the UNURAN package. More...
class WeibullGen This class implements random variate generators for the Weibull distribution. More...
Generating Non-Uniform Random Numbers.
This package provides tools for non-uniform random variate generation, primarily from standard univariate distributions. Each non-uniform random variate generator requires at least one umontreal.ssj.rng.RandomStream object to generate the underlying uniform random numbers.
The generic classes RandomVariateGen and RandomVariateGenInt permit one to construct a random variate generator from a random stream and an arbitrary distribution (see the interface umontreal.ssj.probdist.Distribution ). To generate random variates by inversion from an arbitrary distribution over the real numbers using a given random stream, it suffices to construct a RandomVariateGen object with the desired (previously created) umontreal.ssj.probdist.Distribution and umontreal.ssj.rng.RandomStream objects, and then call its RandomVariateGen.nextDouble
method as many times as needed. For discrete distributions over the integers, one can construct a RandomVariateGenInt object containing the desired umontreal.ssj.probdist.DiscreteDistributionInt and umontreal.ssj.rng.RandomStream, and call its umontreal.ssj.randvar.RandomVariateGenInt.nextInt
method. By default, these generators simply call the inverseF
method from the specified distribution object. These two classes suffice as long as we are willing to use inversion. Here is a simple example in which we create three streams of normal random variates, one stream of gamma variates, and one stream of Poisson variates, all generated by inversion, and then we generate and print some values.
Using three parallel streams of random normal variates [randvarExample1]
package randvar;
import java.util.Arrays;
public class RandvarExample1 {
private static void generate(RandomVariateGen gen, int n) {
double u;
for (int i = 0; i < n; i++) {
u = gen.nextDouble();
System.out.printf("%12.6f%n", u);
}
System.out.println("----------------------");
}
public static void main(String[] args) {
RandomVariateGen gen0 = new RandomVariateGen (new MRG31k3p(), new NormalDist());
RandomVariateGen gen1 = new NormalGen (new MRG31k3p());
RandomVariateGen gen2 = new NormalGen (new MRG31k3p(), 5.0, 121.4);
RandomVariateGen gen3 = new GammaGen (new MRG31k3p(), 2.0, 10.0);
RandomVariateGenInt gen4 = new PoissonGen (new MRG31k3p(), 10.0);
System.out.println ("Some normal, gamma, and Poisson variates \n");
generate(gen0, 3);
generate(gen1, 5);
generate(gen2, 3);
generate(gen3, 2);
int[] arrayP = gen4.nextArrayOfInt (10000);
Arrays.sort(arrayP);
System.out.println ("50% quantile from Poisson(10) variates: " + arrayP[5000]);
System.out.println ("90% quantile from Poisson(10) variates: " + arrayP[9000]);
System.out.println ("99% quantile from Poisson(10) variates: " + arrayP[9900]);
System.out.println ("99.9% quantile from Poisson(10) variates: " + arrayP[9990]);
}
}
To generate random variates by other methods than inversion, one can use specialized classes that extend RandomVariateGen or RandomVariateGenInt. Such classes are provided for a variety of standard discrete and continuous distributions. For example, five different subclasses implement normal random variate generators, using five different methods. One of them, the class NormalGen, extends RandomVariateGen directly and provides normal random variate generators based on inversion, so it does the same thing as using RandomVariateGen with the normal distribution. The others are subclasses of NormalGen; they implement various non-inversion normal variate generation methods. To generate random variates with a specific method, it suffices to construct an object of the appropriate subclass and then call its nextDouble
method.
In most cases, the specialized classes maintain local copies of the distribution parameters and use them for variate generation. If the parameters of the contained distribution objects are later modified, this may lead to inconsistencies: the variate generator object will keep using the old values. In fact, the constructors of the specialized classes often precompute constants and tables based on these parameter values, which would have to be recomputed if the parameters are changed. On the other hand, the generic classes RandomVariateGen and RandomVariateGenInt call directly the inverseF
method of the contained distribution object, so they will always use the new parameter values whenever the parameters in the distribution object are changed.
With some variate generation methods (e.g., the rejection method), the number of uniforms required to get a single non-uniform variate varies from one call to the next. In that case, an auxiliary stream is often used to preserve the synchronization between random variates when implementing variance-reduction methods [118]. The main random number stream is called a fixed number of times per non-uniform variate generation. If more uniform random numbers are needed, they are obtained from the auxiliary stream. For these types of generators, two umontreal.ssj.rng.RandomStream objects should be passed to the constructor. Otherwise, by default, the same stream will be used for all uniforms.
Static methods in the specialized classes allow the generation of random variates from specific distributions without constructing a RandomVariateGen object.
This package also provides an interface to the UNURAN (Universal Non-Uniform RANdom number generators) package, a rich library of C functions designed and implemented by the ARVAG (Automatic Random VAriate Generation) project group in Vienna [166] . This interface can be used to access distributions or generation methods not available directly in SSJ. To get a UNURAN generator, it suffices to instantiate one of the UNURAN interface classes: UnuranDiscreteInt for discrete random variates, UnuranContinuous for continuous ones (in one dimension), and UnuranEmpirical for quasi-empirical distributions based on experimental data. The type of distribution and its parameters are specified to UNURAN via its String API (see the UNURAN documentation). Only univariate distributions are supported because the UNURAN String API does not support the multivariate ones yet.
In the UNURAN interface classes, RandomVariateGen.nextDouble
and RandomVariateGenInt.nextInt
can be invoked as usual to generate variates, but these methods are slowed down significantly by the overhead in the interactions between code on the native side and on the Java side. When several random variates are needed, it is much more efficient to generate them in a single call, via the methods RandomVariateGen.nextArrayOfDouble
and RandomVariateGenInt.nextArrayOfInt
.
RetroSearch is an open source project built by @garambo
| Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4