Package org.apache.lucene.util
Class MathUtil
java.lang.Object
org.apache.lucene.util.MathUtil
Math static utility methods.
- 
Method SummaryModifier and TypeMethodDescriptionstatic doubleacosh(double a) Calculates inverse hyperbolic cosine of adoublevalue.static doubleasinh(double a) Calculates inverse hyperbolic sine of adoublevalue.static doubleatanh(double a) Calculates inverse hyperbolic tangent of adoublevalue.static longgcd(long a, long b) static doublelog(double base, double x) Calculates logarithm in a given base with doubles.static intlog(long x, int base) Returnsx <= 0 ? 0 : Math.floor(Math.log(x) / Math.log(base))static doublesumRelativeErrorBound(int numValues) Return a relative error bound for a sum ofnumValuespositive doubles, computed using recursive summation, ie.static doublesumUpperBound(double sum, int numValues) Return the maximum possible sum acrossnumValuesnon-negative doubles, assuming one sum yieldedsum.
- 
Method Details- 
logpublic static int log(long x, int base) Returnsx <= 0 ? 0 : Math.floor(Math.log(x) / Math.log(base))- Parameters:
- base- must be- > 1
 
- 
logpublic static double log(double base, double x) Calculates logarithm in a given base with doubles.
- 
gcdpublic static long gcd(long a, long b) Return the greatest common divisor ofaandb, consistently withBigInteger.gcd(BigInteger).NOTE: A greatest common divisor must be positive, but 2^64cannot be expressed as a long although it is the GCD ofLong.MIN_VALUEand0and the GCD ofLong.MIN_VALUEandLong.MIN_VALUE. So in these 2 cases, and only them, this method will returnLong.MIN_VALUE.
- 
asinhpublic static double asinh(double a) Calculates inverse hyperbolic sine of adoublevalue.Special cases: - If the argument is NaN, then the result is NaN.
- If the argument is zero, then the result is a zero with the same sign as the argument.
- If the argument is infinite, then the result is infinity with the same sign as the argument.
 
- 
acoshpublic static double acosh(double a) Calculates inverse hyperbolic cosine of adoublevalue.Special cases: - If the argument is NaN, then the result is NaN.
- If the argument is +1, then the result is a zero.
- If the argument is positive infinity, then the result is positive infinity.
- If the argument is less than 1, then the result is NaN.
 
- 
atanhpublic static double atanh(double a) Calculates inverse hyperbolic tangent of adoublevalue.Special cases: - If the argument is NaN, then the result is NaN.
- If the argument is zero, then the result is a zero with the same sign as the argument.
- If the argument is +1, then the result is positive infinity.
- If the argument is -1, then the result is negative infinity.
- If the argument's absolute value is greater than 1, then the result is NaN.
 
- 
sumRelativeErrorBoundpublic static double sumRelativeErrorBound(int numValues) Return a relative error bound for a sum ofnumValuespositive doubles, computed using recursive summation, ie. sum = x1 + ... + xn. NOTE: This only works if all values are POSITIVE so that Σ |xi| == |Σ xi|. This uses formula 3.5 from Higham, Nicholas J. (1993), "The accuracy of floating point summation", SIAM Journal on Scientific Computing.
- 
sumUpperBoundpublic static double sumUpperBound(double sum, int numValues) Return the maximum possible sum acrossnumValuesnon-negative doubles, assuming one sum yieldedsum.- See Also:
 
 
-