public class Gamma extends AbstractContinousDistribution
p(x) = k * x^(alpha-1) * e^(-x/beta) with k = 1/(g(alpha) * b^a)) and g(a) being the gamma function.
Valid parameter ranges: alpha > 0.
Note: For a Gamma distribution to have the mean mean and variance variance, set the parameters as follows:
alpha = mean*mean / variance; lambda = 1 / (variance / mean);
Instance methods operate on a user supplied uniform random number generator; they are unsynchronized.
Implementation:
J.H. Ahrens, U. Dieter (1974): Computer methods for sampling from gamma, beta, Poisson and binomial distributions, Computing 12, 223-246.
and
J.H. Ahrens, U. Dieter (1982): Generating gamma variates by a modified rejection technique, Communications of the ACM 25, 47-54.
Modifier and Type | Field and Description |
---|---|
protected double |
alpha |
protected double |
lambda |
protected static Gamma |
shared |
randomGenerator
serialVersionUID
Constructor and Description |
---|
Gamma(double alpha,
double lambda,
RandomEngine randomGenerator)
Constructs a Gamma distribution.
|
Modifier and Type | Method and Description |
---|---|
double |
cdf(double x)
Returns the cumulative distribution function.
|
double |
nextDouble()
Returns a random number from the distribution.
|
double |
nextDouble(double alpha,
double lambda)
Returns a random number from the distribution; bypasses the internal state.
|
double |
pdf(double x)
Returns the probability distribution function.
|
void |
setState(double alpha,
double lambda)
Sets the mean and variance.
|
static double |
staticNextDouble(double alpha,
double lambda)
Returns a random number from the distribution.
|
String |
toString()
Returns a String representation of the receiver.
|
apply, apply, clone, getRandomGenerator, makeDefaultGenerator, nextInt, setRandomGenerator
protected double alpha
protected double lambda
protected static Gamma shared
public Gamma(double alpha, double lambda, RandomEngine randomGenerator)
IllegalArgumentException
- if alpha <= 0.0 || lambda <= 0.0.public double cdf(double x)
public double nextDouble()
nextDouble
in class AbstractDistribution
public double nextDouble(double alpha, double lambda)
public double pdf(double x)
public void setState(double alpha, double lambda)
IllegalArgumentException
- if alpha <= 0.0 || lambda <= 0.0.public static double staticNextDouble(double alpha, double lambda)
IllegalArgumentException
- if alpha <= 0.0 || lambda <= 0.0.Copyright © 2006–2019 SYSTAP, LLC DBA Blazegraph. All rights reserved.