This commit is contained in:
Gilles 2016-05-17 13:09:45 +02:00
parent bc93a9f76a
commit 085816b7cf
1 changed files with 48 additions and 33 deletions

View File

@ -214,18 +214,19 @@ public class Gamma {
private static final double INV_GAMMA1P_M1_C13 = -.205633841697760710345015413002057E-06; private static final double INV_GAMMA1P_M1_C13 = -.205633841697760710345015413002057E-06;
/** /**
* Default constructor. Prohibit instantiation. * Class contains only static methods.
*/ */
private Gamma() {} private Gamma() {}
/** /**
* Returns the value of \( \log \Gamma(x) \) for \( x > 0 \). * Computes the function \( \ln \Gamma(x) \) for \( x > 0 \).
* *
* <p> * <p>
* For \( x \leq 8 \), the implementation is based on the double precision * For \( x \leq 8 \), the implementation is based on the double precision
* implementation in the <em>NSWC Library of Mathematics Subroutines</em>, * implementation in the <em>NSWC Library of Mathematics Subroutines</em>,
* {@code DGAMLN}. For \( x \geq 8 \), the implementation is based on * {@code DGAMLN}. For \( x \geq 8 \), the implementation is based on
* </p> * </p>
*
* <ul> * <ul>
* <li><a href="http://mathworld.wolfram.com/GammaFunction.html">Gamma * <li><a href="http://mathworld.wolfram.com/GammaFunction.html">Gamma
* Function</a>, equation (28).</li> * Function</a>, equation (28).</li>
@ -237,7 +238,7 @@ public class Gamma {
* </ul> * </ul>
* *
* @param x Argument. * @param x Argument.
* @return the value of {@code log(Gamma(x))} or {@code NaN} if {@code x <= 0}. * @return \( \ln \Gamma(x) \), or {@code NaN} if {@code x <= 0}.
*/ */
public static double logGamma(double x) { public static double logGamma(double x) {
double ret; double ret;
@ -266,11 +267,11 @@ public class Gamma {
} }
/** /**
* Returns the regularized gamma function \( P(a, x) \). * Computes the regularized gamma function \( P(a, x) \).
* *
* @param a Parameter. * @param a Parameter \( a \).
* @param x Value. * @param x Value.
* @return the regularized gamma function P(a, x). * @return \( P(a, x) \)
* @throws MaxCountExceededException if the algorithm fails to converge. * @throws MaxCountExceededException if the algorithm fails to converge.
*/ */
public static double regularizedGammaP(double a, double x) { public static double regularizedGammaP(double a, double x) {
@ -278,7 +279,7 @@ public class Gamma {
} }
/** /**
* Returns the regularized gamma function \( P(a, x) \). * Computes the regularized gamma function \( P(a, x) \).
* *
* The implementation of this method is based on: * The implementation of this method is based on:
* <ul> * <ul>
@ -296,13 +297,13 @@ public class Gamma {
* </li> * </li>
* </ul> * </ul>
* *
* @param a the a parameter. * @param a Parameter \( a \).
* @param x the value. * @param x Argument.
* @param epsilon When the absolute value of the nth item in the * @param epsilon When the absolute value of the nth item in the
* series is less than epsilon the approximation ceases to calculate * series is less than epsilon the approximation ceases to calculate
* further elements in the series. * further elements in the series.
* @param maxIterations Maximum number of "iterations" to complete. * @param maxIterations Maximum number of "iterations" to complete.
* @return the regularized gamma function P(a, x) * @return \( P(a, x) \)
* @throws MaxCountExceededException if the algorithm fails to converge. * @throws MaxCountExceededException if the algorithm fails to converge.
*/ */
public static double regularizedGammaP(double a, public static double regularizedGammaP(double a,
@ -347,11 +348,11 @@ public class Gamma {
} }
/** /**
* Returns the regularized gamma function Q(a, x) = 1 - P(a, x). * Computes the regularized gamma function \( Q(a, x) = 1 - P(a, x) \).
* *
* @param a the a parameter. * @param a Parameter \( a \).
* @param x the value. * @param x Argument.
* @return the regularized gamma function Q(a, x) * @return \( Q(a, x) \)
* @throws MaxCountExceededException if the algorithm fails to converge. * @throws MaxCountExceededException if the algorithm fails to converge.
*/ */
public static double regularizedGammaQ(double a, double x) { public static double regularizedGammaQ(double a, double x) {
@ -359,7 +360,7 @@ public class Gamma {
} }
/** /**
* Returns the regularized gamma function \( Q(a, x) = 1 - P(a, x) \). * Computes the regularized gamma function \( Q(a, x) = 1 - P(a, x) \).
* *
* The implementation of this method is based on: * The implementation of this method is based on:
* <ul> * <ul>
@ -374,13 +375,13 @@ public class Gamma {
* </li> * </li>
* </ul> * </ul>
* *
* @param a the a parameter. * @param a Parameter \( a \).
* @param x the value. * @param x Argument.
* @param epsilon When the absolute value of the nth item in the * @param epsilon When the absolute value of the nth item in the
* series is less than epsilon the approximation ceases to calculate * series is less than epsilon the approximation ceases to calculate
* further elements in the series. * further elements in the series.
* @param maxIterations Maximum number of "iterations" to complete. * @param maxIterations Maximum number of "iterations" to complete.
* @return the regularized gamma function P(a, x) * @return \( Q(a, x) \)
* @throws MaxCountExceededException if the algorithm fails to converge. * @throws MaxCountExceededException if the algorithm fails to converge.
*/ */
public static double regularizedGammaQ(final double a, public static double regularizedGammaQ(final double a,
@ -423,7 +424,9 @@ public class Gamma {
/** /**
* Computes the digamma function. * Computes the digamma function, defined as the logarithmic derivative
* of the \( \Gamma \) function:
* \( \frac{d}{dx}(\ln \Gamma(x)) = \frac{\Gamma^\prime(x)}{\Gamma(x)} \).
* *
* <p>This is an independently written implementation of the algorithm described in * <p>This is an independently written implementation of the algorithm described in
* Jose Bernardo, Algorithm AS 103: Psi (Digamma) Function, Applied Statistics, 1976. * Jose Bernardo, Algorithm AS 103: Psi (Digamma) Function, Applied Statistics, 1976.
@ -477,16 +480,17 @@ public class Gamma {
} }
/** /**
* Computes the trigamma function. * Computes the trigamma function \( \psi_1(x) = \frac{d^2}{dx^2} (\ln \Gamma(x)) \).
* This function is derived by taking the derivative of the implementation * <p>
* of digamma. * This function is the derivative of the {@link #digamma(double) digamma function}.
* </p>
* *
* @param x Argument. * @param x Argument.
* @return {@code trigamma(x)} to within \( 10^{-8} \) relative or absolute * @return \( \psi_1(x) \) to within \( 10^{-8} \) relative or absolute
* error whichever is smaller * error whichever is smaller
* *
* @see <a href="http://en.wikipedia.org/wiki/Trigamma_function">Trigamma</a> * @see <a href="http://en.wikipedia.org/wiki/Trigamma_function">Trigamma</a>
* @see Gamma#digamma(double) * @see #digamma(double)
* *
* @since 2.0 * @since 2.0
*/ */
@ -512,23 +516,26 @@ public class Gamma {
} }
/** /**
* Computes the Lanczos approximation used to compute the gamma function.
*
* <p> * <p>
* Returns the Lanczos approximation used to compute the gamma function.
* The Lanczos approximation is related to the Gamma function by the * The Lanczos approximation is related to the Gamma function by the
* following equation * following equation
* \[ * \[
* \Gamma(x) = \sqrt{2\pi} \, \frac{(x + g + 1/2)^{x + \frac{1}{2}} \, e^{-x - g - \frac{1}{2}} \, \mathrm{lanczos}(x)} * \Gamma(x) = \sqrt{2\pi} \, \frac{(g + x + \frac{1}{2})^{x + \frac{1}{2}} \, e^{-(g + x + \frac{1}{2})} \, \mathrm{lanczos}(x)}
* {x} * {x}
* \] * \]
* where \(g\) is the Lanczos constant. * where \(g\) is the Lanczos constant.
* </p> * </p>
* *
* @param x Argument. * @param x Argument.
* @return The Lanczos approximation. * @return The Lanczos approximation.
*
* @see <a href="http://mathworld.wolfram.com/LanczosApproximation.html">Lanczos Approximation</a> * @see <a href="http://mathworld.wolfram.com/LanczosApproximation.html">Lanczos Approximation</a>
* equations (1) through (5), and Paul Godfrey's * equations (1) through (5), and Paul Godfrey's
* <a href="http://my.fit.edu/~gabdo/gamma.txt">Note on the computation * <a href="http://my.fit.edu/~gabdo/gamma.txt">Note on the computation
* of the convergent Lanczos complex Gamma approximation</a> * of the convergent Lanczos complex Gamma approximation</a>
*
* @since 3.1 * @since 3.1
*/ */
public static double lanczos(final double x) { public static double lanczos(final double x) {
@ -540,14 +547,17 @@ public class Gamma {
} }
/** /**
* Returns the value of \( 1 / \Gamma(1 + x) - 1 \) for \( -0.5 \leq x \leq 1.5 \). * Computes the function \( \frac{1}{\Gamma(1 + x)} - 1 \) for \( -0.5 \leq x \leq 1.5 \).
* <p>
* This implementation is based on the double precision implementation in * This implementation is based on the double precision implementation in
* the <em>NSWC Library of Mathematics Subroutines</em>, {@code DGAM1}. * the <em>NSWC Library of Mathematics Subroutines</em>, {@code DGAM1}.
* </p>
* *
* @param x Argument. * @param x Argument.
* @return The value of {@code 1.0 / Gamma(1.0 + x) - 1.0}. * @return \( \frac{1}{\Gamma(1 + x)} - 1 \)
* @throws NumberIsTooSmallException if {@code x < -0.5} * @throws NumberIsTooSmallException if {@code x < -0.5}
* @throws NumberIsTooLargeException if {@code x > 1.5} * @throws NumberIsTooLargeException if {@code x > 1.5}
*
* @since 3.1 * @since 3.1
*/ */
public static double invGamma1pm1(final double x) { public static double invGamma1pm1(final double x) {
@ -633,12 +643,14 @@ public class Gamma {
} }
/** /**
* Returns the value of \( \log \Gamma(1 + x) \) for \( -0.5 \leq x \leq 1.5 \). * Computes the function \( \ln \Gamma(1 + x) \) for \( -0.5 \leq x \leq 1.5 \).
* <p>
* This implementation is based on the double precision implementation in * This implementation is based on the double precision implementation in
* the <em>NSWC Library of Mathematics Subroutines</em>, {@code DGMLN1}. * the <em>NSWC Library of Mathematics Subroutines</em>, {@code DGMLN1}.
* </p>
* *
* @param x Argument. * @param x Argument.
* @return The value of {@code log(Gamma(1 + x))}. * @return \( \ln \Gamma(1 + x) \)
* @throws NumberIsTooSmallException if {@code x < -0.5}. * @throws NumberIsTooSmallException if {@code x < -0.5}.
* @throws NumberIsTooLargeException if {@code x > 1.5}. * @throws NumberIsTooLargeException if {@code x > 1.5}.
* @since 3.1 * @since 3.1
@ -658,12 +670,15 @@ public class Gamma {
/** /**
* Returns the value of \( \Gamma(x) \). * Computes the value of \( \Gamma(x) \).
* <p>
* Based on the <em>NSWC Library of Mathematics Subroutines</em> double * Based on the <em>NSWC Library of Mathematics Subroutines</em> double
* precision implementation, {@code DGAMMA}. * precision implementation, {@code DGAMMA}.
* </p>
* *
* @param x Argument. * @param x Argument.
* @return the value of {@code Gamma(x)}. * @return \( \Gamma(x) \)
*
* @since 3.1 * @since 3.1
*/ */
public static double gamma(final double x) { public static double gamma(final double x) {