Class GammaDistr
java.lang.Object
org.apache.commons.math3.distribution.AbstractRealDistribution
org.apache.commons.math3.distribution.GammaDistribution
org.cloudsimplus.distributions.GammaDistr
- All Implemented Interfaces:
Serializable,org.apache.commons.math3.distribution.RealDistribution,ContinuousDistribution,StatisticalDistribution
public class GammaDistr
extends org.apache.commons.math3.distribution.GammaDistribution
implements ContinuousDistribution
A Pseudo-Random Number Generator following the
Gamma distribution.
- Since:
- CloudSim Toolkit 1.0
- Author:
- Marcos Dias de Assuncao, Manoel Campos da Silva Filho
- See Also:
-
Field Summary
Fields inherited from class org.apache.commons.math3.distribution.GammaDistribution
DEFAULT_INVERSE_ABSOLUTE_ACCURACYFields inherited from class org.apache.commons.math3.distribution.AbstractRealDistribution
random, randomData, SOLVER_DEFAULT_ABSOLUTE_ACCURACYFields inherited from interface org.cloudsimplus.distributions.ContinuousDistribution
NULL -
Constructor Summary
ConstructorsConstructorDescriptionGammaDistr(int shape, double scale) Creates a Gamma Pseudo-Random Number Generator (PRNG) using the current time as seed.GammaDistr(int shape, double scale, long seed) Creates a Gamma Pseudo-Random Number Generator (PRNG).GammaDistr(int shape, double scale, long seed, org.apache.commons.math3.random.RandomGenerator rng) Creates a Gamma Pseudo-Random Number Generator (RNG). -
Method Summary
Modifier and TypeMethodDescriptionlonggetSeed()booleanIndicates if the Pseudo-Random Number Generator (RNG) applies the Antithetic Variates Technique to reduce variance of experiments using the generated numbers.doubleGenerate a new pseudo random number directly from theRealDistribution.sample()method.voidreseedRandomGenerator(long seed) setApplyAntitheticVariates(boolean applyAntitheticVariates) Indicates if the Pseudo-Random Number Generator (RNG) applies the Antithetic Variates Technique to reduce variance of experiments using the generated numbers.Methods inherited from class org.apache.commons.math3.distribution.GammaDistribution
cumulativeProbability, density, getAlpha, getBeta, getNumericalMean, getNumericalVariance, getScale, getShape, getSolverAbsoluteAccuracy, getSupportLowerBound, getSupportUpperBound, isSupportConnected, isSupportLowerBoundInclusive, isSupportUpperBoundInclusive, logDensity, sampleMethods inherited from class org.apache.commons.math3.distribution.AbstractRealDistribution
cumulativeProbability, inverseCumulativeProbability, probability, probability, sampleMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.cloudsimplus.distributions.ContinuousDistribution
sampleMethods inherited from interface org.apache.commons.math3.distribution.RealDistribution
cumulativeProbability, cumulativeProbability, density, getNumericalMean, getNumericalVariance, getSupportLowerBound, getSupportUpperBound, inverseCumulativeProbability, isSupportConnected, isSupportLowerBoundInclusive, isSupportUpperBoundInclusive, probability, sample
-
Constructor Details
-
GammaDistr
public GammaDistr(int shape, double scale) Creates a Gamma Pseudo-Random Number Generator (PRNG) using the current time as seed.Internally, it relies on the
JDKRandomGenerator, a wrapper for theRandomclass that doesn't have high-quality randomness properties but is very fast.- Parameters:
shape- the shape parameter of this distributionscale- the scale parameter of this distribution- See Also:
-
GammaDistr
public GammaDistr(int shape, double scale, long seed) Creates a Gamma Pseudo-Random Number Generator (PRNG).- Parameters:
shape- the shape parameter of this distributionscale- the scale parameter of this distributionseed- the seed to initialize the generator- See Also:
-
GammaDistr
public GammaDistr(int shape, double scale, long seed, org.apache.commons.math3.random.RandomGenerator rng) Creates a Gamma Pseudo-Random Number Generator (RNG).- Parameters:
shape- the shape parameter of this distributionscale- the scale parameter of this distributionseed- the seed already used to initialize the Pseudo-Random Number Generatorrng- the actual Pseudo-Random Number Generator that will be the base to generate random numbers following a continuous distribution.
-
-
Method Details
-
getSeed
public long getSeed()- Specified by:
getSeedin interfaceStatisticalDistribution- Returns:
- the seed used to initialize the generator
-
reseedRandomGenerator
public void reseedRandomGenerator(long seed) - Specified by:
reseedRandomGeneratorin interfaceorg.apache.commons.math3.distribution.RealDistribution- Overrides:
reseedRandomGeneratorin classorg.apache.commons.math3.distribution.AbstractRealDistribution
-
isApplyAntitheticVariates
public boolean isApplyAntitheticVariates()Description copied from interface:StatisticalDistributionIndicates if the Pseudo-Random Number Generator (RNG) applies the Antithetic Variates Technique to reduce variance of experiments using the generated numbers.This technique doesn't work for all the cases. However, in the cases it can be applied, in order for it to work, you have to perform some actions. Consider an experiment that has to run "n" times. The first half of these experiments has to use the seeds you want. However, the second half of the experiments have to set the
Thus, the first half of experiments are run using PRNGs, returning random numbers as U(0, 1)[seed_1], ..., U(0, 1)[seed_n]. The second half of experiments then uses the seeds of the first half of experiments, returning random numbers as 1 - U(0, 1)[seed_1], ..., 1 - U(0, 1)[seed_n].applyAntitheticVariatesattribute totrueand use the seeds of the first half of experiments.- Specified by:
isApplyAntitheticVariatesin interfaceStatisticalDistribution- Returns:
- true if the technique is applied, false otherwise
- See Also:
-
setApplyAntitheticVariates
Description copied from interface:StatisticalDistributionIndicates if the Pseudo-Random Number Generator (RNG) applies the Antithetic Variates Technique to reduce variance of experiments using the generated numbers.- Specified by:
setApplyAntitheticVariatesin interfaceStatisticalDistribution- Parameters:
applyAntitheticVariates- true if the technique is to be applied, false otherwise- See Also:
-
originalSample
public double originalSample()Description copied from interface:StatisticalDistributionGenerate a new pseudo random number directly from theRealDistribution.sample()method. This way, theAntithetic Variates Techniqueis ignored if enabled.Usually you shouldn't call this method but
StatisticalDistribution.sample()instead.- Specified by:
originalSamplein interfaceStatisticalDistribution- Returns:
- the next pseudo random number in the sequence, following the
implemented distribution, ignoring the
Antithetic Variates Techniqueif enabled
-