Class GammaDistributionImpl
java.lang.Object
org.apache.commons.math.distribution.AbstractDistribution
org.apache.commons.math.distribution.AbstractContinuousDistribution
org.apache.commons.math.distribution.GammaDistributionImpl
- All Implemented Interfaces:
Serializable,ContinuousDistribution,Distribution,GammaDistribution,HasDensity<Double>
public class GammaDistributionImpl
extends AbstractContinuousDistribution
implements GammaDistribution, Serializable
The default implementation of
GammaDistribution.- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final doubleDefault inverse cumulative probability accuracy -
Constructor Summary
ConstructorsConstructorDescriptionGammaDistributionImpl(double alpha, double beta) Create a new gamma distribution with the given alpha and beta values.GammaDistributionImpl(double alpha, double beta, double inverseCumAccuracy) Create a new gamma distribution with the given alpha and beta values. -
Method Summary
Modifier and TypeMethodDescriptiondoublecumulativeProbability(double x) For this distribution, X, this method returns P(X < x).doubledensity(double x) Returns the probability density for a particular point.doubleDeprecated.doublegetAlpha()Access the shape parameter, alphadoublegetBeta()Access the scale parameter, betadoubleReturns the mean.doubleReturns the variance.doubleReturns the upper bound of the support for the distribution.doubleReturns the upper bound of the support for the distribution.doubleinverseCumulativeProbability(double p) For this distribution, X, this method returns the critical point x, such that P(X < x) =p.voidsetAlpha(double alpha) Deprecated.as of 2.1 (class will become immutable in 3.0)voidsetBeta(double newBeta) Deprecated.as of 2.1 (class will become immutable in 3.0)Methods inherited from class org.apache.commons.math.distribution.AbstractContinuousDistribution
reseedRandomGenerator, sample, sampleMethods inherited from class org.apache.commons.math.distribution.AbstractDistribution
cumulativeProbabilityMethods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.commons.math.distribution.Distribution
cumulativeProbability
-
Field Details
-
DEFAULT_INVERSE_ABSOLUTE_ACCURACY
public static final double DEFAULT_INVERSE_ABSOLUTE_ACCURACYDefault inverse cumulative probability accuracy- Since:
- 2.1
- See Also:
-
-
Constructor Details
-
GammaDistributionImpl
public GammaDistributionImpl(double alpha, double beta) Create a new gamma distribution with the given alpha and beta values.- Parameters:
alpha- the shape parameter.beta- the scale parameter.
-
GammaDistributionImpl
public GammaDistributionImpl(double alpha, double beta, double inverseCumAccuracy) Create a new gamma distribution with the given alpha and beta values.- Parameters:
alpha- the shape parameter.beta- the scale parameter.inverseCumAccuracy- the maximum absolute error in inverse cumulative probability estimates (defaults toDEFAULT_INVERSE_ABSOLUTE_ACCURACY)- Since:
- 2.1
-
-
Method Details
-
cumulativeProbability
For this distribution, X, this method returns P(X < x). The implementation of this method is based on:- Chi-Squared Distribution, equation (9).
- Casella, G., invalid input: '&' Berger, R. (1990). Statistical Inference. Belmont, CA: Duxbury Press.
- Specified by:
cumulativeProbabilityin interfaceDistribution- Parameters:
x- the value at which the CDF is evaluated.- Returns:
- CDF for this distribution.
- Throws:
MathException- if the cumulative probability can not be computed due to convergence or other numerical errors.
-
inverseCumulativeProbability
For this distribution, X, this method returns the critical point x, such that P(X < x) =p.Returns 0 for p=0 and
Double.POSITIVE_INFINITYfor p=1.- Specified by:
inverseCumulativeProbabilityin interfaceContinuousDistribution- Overrides:
inverseCumulativeProbabilityin classAbstractContinuousDistribution- Parameters:
p- the desired probability- Returns:
- x, such that P(X < x) =
p - Throws:
MathException- if the inverse cumulative probability can not be computed due to convergence or other numerical errors.IllegalArgumentException- ifpis not a valid probability.
-
setAlpha
Deprecated.as of 2.1 (class will become immutable in 3.0)Modify the shape parameter, alpha.- Specified by:
setAlphain interfaceGammaDistribution- Parameters:
alpha- the new shape parameter.- Throws:
IllegalArgumentException- ifalphais not positive.
-
getAlpha
public double getAlpha()Access the shape parameter, alpha- Specified by:
getAlphain interfaceGammaDistribution- Returns:
- alpha.
-
setBeta
Deprecated.as of 2.1 (class will become immutable in 3.0)Modify the scale parameter, beta.- Specified by:
setBetain interfaceGammaDistribution- Parameters:
newBeta- the new scale parameter.- Throws:
IllegalArgumentException- ifnewBetais not positive.
-
getBeta
public double getBeta()Access the scale parameter, beta- Specified by:
getBetain interfaceGammaDistribution- Returns:
- beta.
-
density
public double density(double x) Returns the probability density for a particular point.- Overrides:
densityin classAbstractContinuousDistribution- Parameters:
x- The point at which the density should be computed.- Returns:
- The pdf at point x.
-
density
Deprecated.Return the probability density for a particular point.- Specified by:
densityin interfaceGammaDistribution- Specified by:
densityin interfaceHasDensity<Double>- Parameters:
x- The point at which the density should be computed.- Returns:
- The pdf at point x.
-
getSupportLowerBound
public double getSupportLowerBound()Returns the upper bound of the support for the distribution. The lower bound of the support is always 0, regardless of the parameters.- Returns:
- lower bound of the support (always 0)
- Since:
- 2.2
-
getSupportUpperBound
public double getSupportUpperBound()Returns the upper bound of the support for the distribution. The upper bound of the support is always positive infinity, regardless of the parameters.- Returns:
- upper bound of the support (always Double.POSITIVE_INFINITY)
- Since:
- 2.2
-
getNumericalMean
public double getNumericalMean()Returns the mean. For shape parameteralphaand scale parameterbeta, the mean isalpha * beta- Returns:
- the mean
- Since:
- 2.2
-
getNumericalVariance
public double getNumericalVariance()Returns the variance. For shape parameteralphaand scale parameterbeta, the variance isalpha * beta^2- Returns:
- the variance
- Since:
- 2.2
-