Class FDistributionImpl
java.lang.Object
org.apache.commons.math.distribution.AbstractDistribution
org.apache.commons.math.distribution.AbstractContinuousDistribution
org.apache.commons.math.distribution.FDistributionImpl
- All Implemented Interfaces:
Serializable,ContinuousDistribution,Distribution,FDistribution
public class FDistributionImpl
extends AbstractContinuousDistribution
implements FDistribution, Serializable
Default implementation of
FDistribution.- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final doubleDefault inverse cumulative probability accuracy -
Constructor Summary
ConstructorsConstructorDescriptionFDistributionImpl(double numeratorDegreesOfFreedom, double denominatorDegreesOfFreedom) Create a F distribution using the given degrees of freedom.FDistributionImpl(double numeratorDegreesOfFreedom, double denominatorDegreesOfFreedom, double inverseCumAccuracy) Create a F distribution using the given degrees of freedom and inverse cumulative probability accuracy. -
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.doubleAccess the denominator degrees of freedom.doubleAccess the numerator degrees of freedom.doubleReturns the mean of the distribution.doubleReturns the variance of the distribution.doubleReturns the lower 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.voidsetDenominatorDegreesOfFreedom(double degreesOfFreedom) Deprecated.as of 2.1 (class will become immutable in 3.0)voidsetNumeratorDegreesOfFreedom(double degreesOfFreedom) 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
-
FDistributionImpl
public FDistributionImpl(double numeratorDegreesOfFreedom, double denominatorDegreesOfFreedom) Create a F distribution using the given degrees of freedom.- Parameters:
numeratorDegreesOfFreedom- the numerator degrees of freedom.denominatorDegreesOfFreedom- the denominator degrees of freedom.
-
FDistributionImpl
public FDistributionImpl(double numeratorDegreesOfFreedom, double denominatorDegreesOfFreedom, double inverseCumAccuracy) Create a F distribution using the given degrees of freedom and inverse cumulative probability accuracy.- Parameters:
numeratorDegreesOfFreedom- the numerator degrees of freedom.denominatorDegreesOfFreedom- the denominator degrees of freedom.inverseCumAccuracy- the maximum absolute error in inverse cumulative probability estimates (defaults toDEFAULT_INVERSE_ABSOLUTE_ACCURACY)- Since:
- 2.1
-
-
Method Details
-
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.
- Since:
- 2.1
-
cumulativeProbability
For this distribution, X, this method returns P(X < x). The implementation of this method is based on:- F-Distribution, equation (4).
- 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.
-
setNumeratorDegreesOfFreedom
Deprecated.as of 2.1 (class will become immutable in 3.0)Modify the numerator degrees of freedom.- Specified by:
setNumeratorDegreesOfFreedomin interfaceFDistribution- Parameters:
degreesOfFreedom- the new numerator degrees of freedom.- Throws:
IllegalArgumentException- ifdegreesOfFreedomis not positive.
-
getNumeratorDegreesOfFreedom
public double getNumeratorDegreesOfFreedom()Access the numerator degrees of freedom.- Specified by:
getNumeratorDegreesOfFreedomin interfaceFDistribution- Returns:
- the numerator degrees of freedom.
-
setDenominatorDegreesOfFreedom
Deprecated.as of 2.1 (class will become immutable in 3.0)Modify the denominator degrees of freedom.- Specified by:
setDenominatorDegreesOfFreedomin interfaceFDistribution- Parameters:
degreesOfFreedom- the new denominator degrees of freedom.- Throws:
IllegalArgumentException- ifdegreesOfFreedomis not positive.
-
getDenominatorDegreesOfFreedom
public double getDenominatorDegreesOfFreedom()Access the denominator degrees of freedom.- Specified by:
getDenominatorDegreesOfFreedomin interfaceFDistribution- Returns:
- the denominator degrees of freedom.
-
getSupportLowerBound
public double getSupportLowerBound()Returns the lower 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 of the distribution. For denominator degrees of freedom parameterb, the mean is- if
b > 2thenb / (b - 2) - else
undefined
- Returns:
- the mean
- Since:
- 2.2
- if
-
getNumericalVariance
public double getNumericalVariance()Returns the variance of the distribution. For numerator degrees of freedom parameteraand denominator degrees of freedom parameterb, the variance is-
if
b > 4then[ 2 * b^2 * (a + b - 2) ] / [ a * (b - 2)^2 * (b - 4) ] - else
undefined
- Returns:
- the variance
- Since:
- 2.2
-
if
-