Class Normal
- java.lang.Object
-
- com.opengamma.strata.math.impl.cern.Normal
-
- All Implemented Interfaces:
Serializable,Cloneable,DoubleUnaryOperator,IntUnaryOperator
public class Normal extends Object
Normal (aka Gaussian) distribution; See the math definition and animated definition.1 2 pdf(x) = --------- exp( - (x-mean) / 2v ) sqrt(2pi*v) x - 1 | | 2 cdf(x) = --------- | exp( - (t-mean) / 2v ) dt sqrt(2pi*v)| | - -inf.where v = variance = standardDeviation^2.Instance methods operate on a user supplied uniform random number generator; they are unsynchronized.
- Static methods operate on a default uniform random number generator; they are synchronized.
Implementation: Polar Box-Muller transformation. See G.E.P. Box, M.E. Muller (1958): A note on the generation of random normal deviates, Annals Math. Statist. 29, 610-611.
- Version:
- 1.0, 09/24/99
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected doublecacheprotected booleancacheFilledprotected doublemeanprotected RandomEnginerandomGeneratorprotected static Normalsharedprotected doubleSQRT_INVprotected doublestandardDeviationprotected doublevariance
-
Constructor Summary
Constructors Constructor Description Normal(double mean, double standardDeviation, RandomEngine randomGenerator)Constructs a normal (gauss) distribution.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description doubleapplyAsDouble(double dummy)Equivalent to nextDouble().intapplyAsInt(int dummy)Equivalent to nextInt().doublecdf(double x)Returns the cumulative distribution function.Objectclone()Returns a deep copy of the receiver; the copy will produce identical sequences.protected RandomEnginegetRandomGenerator()Returns the used uniform random number generator;static RandomEnginemakeDefaultGenerator()Constructs and returns a new uniform random number generation engine seeded with the current time.doublenextDouble()Returns a random number from the distribution.doublenextDouble(double mean, double standardDeviation)Returns a random number from the distribution; bypasses the internal state.intnextInt()Returns a random number from the distribution; returns (int) Math.round(nextDouble()).doublepdf(double x)Returns the probability distribution function.protected voidsetRandomGenerator(RandomEngine randomGenerator)Sets the uniform random generator internally used.voidsetState(double mean, double standardDeviation)Sets the mean and variance.static doublestaticNextDouble(double mean, double standardDeviation)Returns a random number from the distribution with the given mean and standard deviation.StringtoString()Returns a String representation of the receiver.-
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.function.DoubleUnaryOperator
andThen, compose
-
Methods inherited from interface java.util.function.IntUnaryOperator
andThen, compose
-
-
-
-
Field Detail
-
mean
protected double mean
-
variance
protected double variance
-
standardDeviation
protected double standardDeviation
-
cache
protected double cache
-
cacheFilled
protected boolean cacheFilled
-
SQRT_INV
protected double SQRT_INV
-
shared
protected static Normal shared
-
randomGenerator
protected RandomEngine randomGenerator
-
-
Constructor Detail
-
Normal
public Normal(double mean, double standardDeviation, RandomEngine randomGenerator)Constructs a normal (gauss) distribution. Example: mean=0.0, standardDeviation=1.0.- Parameters:
mean- meanstandardDeviation- standard deviationrandomGenerator- generator
-
-
Method Detail
-
cdf
public double cdf(double x)
Returns the cumulative distribution function.- Parameters:
x- x- Returns:
- result
-
nextDouble
public double nextDouble()
Returns a random number from the distribution.- Returns:
- result
-
nextDouble
public double nextDouble(double mean, double standardDeviation)Returns a random number from the distribution; bypasses the internal state.- Parameters:
mean- meanstandardDeviation- standard deviation- Returns:
- result
-
pdf
public double pdf(double x)
Returns the probability distribution function.- Parameters:
x- x- Returns:
- result
-
setRandomGenerator
protected void setRandomGenerator(RandomEngine randomGenerator)
Sets the uniform random generator internally used.- Parameters:
randomGenerator- input
-
setState
public void setState(double mean, double standardDeviation)Sets the mean and variance.- Parameters:
mean- meanstandardDeviation- standard deviation
-
staticNextDouble
public static double staticNextDouble(double mean, double standardDeviation)Returns a random number from the distribution with the given mean and standard deviation.- Parameters:
mean- meanstandardDeviation- standard deviation- Returns:
- result
-
toString
public String toString()
Returns a String representation of the receiver.
-
applyAsDouble
public double applyAsDouble(double dummy)
Equivalent to nextDouble(). This has the effect that distributions can now be used as function objects, returning a random number upon function evaluation.- Specified by:
applyAsDoublein interfaceDoubleUnaryOperator
-
applyAsInt
public int applyAsInt(int dummy)
Equivalent to nextInt(). This has the effect that distributions can now be used as function objects, returning a random number upon function evaluation.- Specified by:
applyAsIntin interfaceIntUnaryOperator
-
clone
public Object clone()
Returns a deep copy of the receiver; the copy will produce identical sequences. After this call has returned, the copy and the receiver have equal but separate state.- Returns:
- a copy of the receiver.
-
getRandomGenerator
protected RandomEngine getRandomGenerator()
Returns the used uniform random number generator;- Returns:
- result
-
makeDefaultGenerator
public static RandomEngine makeDefaultGenerator()
Constructs and returns a new uniform random number generation engine seeded with the current time. Currently this isMersenneTwister.- Returns:
- result
-
nextInt
public int nextInt()
Returns a random number from the distribution; returns (int) Math.round(nextDouble()). Override this method if necessary.- Returns:
- result
-
-