Class Dfp
- java.lang.Object
- 
- org.apache.commons.math4.legacy.core.dfp.Dfp
 
- 
- All Implemented Interfaces:
- FieldElement<Dfp>,- RealFieldElement<Dfp>
 - Direct Known Subclasses:
- DfpDec
 
 public class Dfp extends Object implements RealFieldElement<Dfp> Decimal floating point library for JavaAnother floating point class. This one is built using radix 10000 which is 104, so its almost decimal. The design goals here are: - Decimal math, or close to it
- Settable precision (but no mix between numbers using different settings)
- Portability. Code should be kept as portable as possible.
- Performance
- Accuracy - Results should always be +/- 1 ULP for basic algebraic operation
- Comply with IEEE 854-1987 as much as possible. (See IEEE 854-1987 notes below)
 Trade offs: - Memory foot print. I'm using more memory than necessary to represent numbers to get better performance.
- Digits are bigger, so rounding is a greater loss. So, if you really need 12 decimal digits, better use 4 base 10000 digits there can be one partially filled.
 Numbers are represented in the following form: where sign is ±1, mantissa represents a fractional number between zero and one. mant[0] is the least significant digit. exp is in the range of -32767 to 32768n = sign × mant × (radix)exp;IEEE 854-1987 Notes and differences IEEE 854 requires the radix to be either 2 or 10. The radix here is 10000, so that requirement is not met, but it is possible that a subclassed can be made to make it behave as a radix 10 number. It is my opinion that if it looks and behaves as a radix 10 number then it is one and that requirement would be met. The radix of 10000 was chosen because it should be faster to operate on 4 decimal digits at once instead of one at a time. Radix 10 behavior can be realized by adding an additional rounding step to ensure that the number of decimal digits represented is constant. The IEEE standard specifically leaves out internal data encoding, so it is reasonable to conclude that such a subclass of this radix 10000 system is merely an encoding of a radix 10 system. IEEE 854 also specifies the existence of "sub-normal" numbers. This class does not contain any such entities. The most significant radix 10000 digit is always non-zero. Instead, we support "gradual underflow" by raising the underflow flag for numbers less with exponent less than expMin, but don't flush to zero until the exponent reaches MIN_EXP-digits. Thus the smallest number we can represent would be: 1E(-(MIN_EXP-digits-1)*4), eg, for digits=5, MIN_EXP=-32767, that would be 1e-131092. IEEE 854 defines that the implied radix point lies just to the right of the most significant digit and to the left of the remaining digits. This implementation puts the implied radix point to the left of all digits including the most significant one. The most significant digit here is the one just to the right of the radix point. This is a fine detail and is really only a matter of definition. Any side effects of this can be rendered invisible by a subclass. - Since:
- 2.2
- See Also:
- DfpField
 
- 
- 
Field SummaryFields Modifier and Type Field Description static intERR_SCALEThe amount under/overflows are scaled by before going to trap handler.protected intexpExponent.static byteFINITEIndicator value for normal finite numbers.static byteINFINITEIndicator value for Infinity.protected int[]mantMantissa.static intMAX_EXPThe maximum exponent before overflow is signaled and results flushed to infinity.static intMIN_EXPThe minimum exponent before underflow is signaled.protected bytenansIndicator for non-finite / non-number values.static byteQNANIndicator value for quiet NaN.static intRADIXThe radix, or base of this system.protected bytesignSign bit: 1 for positive, -1 for negative.static byteSNANIndicator value for signaling NaN.
 - 
Constructor SummaryConstructors Modifier Constructor Description Dfp(Dfp d)Copy constructor.protectedDfp(DfpField field)Makes an instance with a value of zero.protectedDfp(DfpField field, byte x)Create an instance from a byte value.protectedDfp(DfpField field, byte sign, byte nans)Creates an instance with a non-finite value.protectedDfp(DfpField field, double x)Create an instance from a double value.protectedDfp(DfpField field, int x)Create an instance from an int value.protectedDfp(DfpField field, long x)Create an instance from a long value.protectedDfp(DfpField field, String s)Create an instance from a String representation.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Dfpabs()Get the absolute value of instance.Dfpacos()Arc cosine operation.Dfpacosh()Inverse hyperbolic cosine operation.Dfpadd(double a)'+' operator.Dfpadd(Dfp x)Add x to this.protected intalign(int e)Make our exp equal to the supplied one, this may cause rounding.Dfpasin()Arc sine operation.Dfpasinh()Inverse hyperbolic sine operation.Dfpatan()Arc tangent operation.Dfpatan2(Dfp x)Two arguments arc tangent operation.Dfpatanh()Inverse hyperbolic tangent operation.Dfpcbrt()Cubic root.Dfpceil()Round to an integer using the round ceil mode.intclassify()Returns the type - one of FINITE, INFINITE, SNAN, QNAN.protected intcomplement(int extra)Negate the mantissa of this by computing the complement.DfpcopySign(double s)Returns the instance with the sign of the argument.DfpcopySign(Dfp s)Returns the instance with the sign of the argument.static DfpcopySign(Dfp x, Dfp y)Creates an instance that is the same as x except that it has the sign of y.Dfpcos()Cosine operation.Dfpcosh()Hyperbolic cosine operation.protected Stringdfp2sci()Convert an instance to a string using scientific notation.protected Stringdfp2string()Convert an instance to a string using normal notation.Dfpdivide(double a)'÷' operator.Dfpdivide(int divisor)Divide by a single digit less than radix.Dfpdivide(Dfp divisor)Divide this by divisor.Dfpdotrap(int type, String what, Dfp oper, Dfp result)Raises a trap.booleanequals(Object other)Check if instance is equal to x.Dfpexp()Exponential.Dfpexpm1()Exponential minus 1.Dfpfloor()Round to an integer using the round floor mode.DfpFieldgetField()DfpgetOne()Get the constant 1.intgetRadixDigits()Get the number of radix digits of the instance.doublegetReal()Get the real value of the number.DfpgetTwo()Get the constant 2.DfpgetZero()Get the constant 0.booleangreaterThan(Dfp x)Check if instance is greater than x.inthashCode()Gets a hashCode for the instance.Dfphypot(Dfp y)Returns the hypotenuse of a triangle with sidesthisandy- sqrt(this2 +y2) avoiding intermediate overflow or underflow.intintLog10()Get the exponent of the greatest power of 10 that is less than or equal to abs(this).intintValue()Convert this to an integer.booleanisInfinite()Check if instance is infinite.booleanisNaN()Check if instance is not a number.booleanisZero()Check if instance is equal to zero.booleanlessThan(Dfp x)Check if instance is less than x.DfplinearCombination(double[] a, Dfp[] b)Compute a linear combination.DfplinearCombination(double a1, Dfp b1, double a2, Dfp b2)Compute a linear combination.DfplinearCombination(double a1, Dfp b1, double a2, Dfp b2, double a3, Dfp b3)Compute a linear combination.DfplinearCombination(double a1, Dfp b1, double a2, Dfp b2, double a3, Dfp b3, double a4, Dfp b4)Compute a linear combination.DfplinearCombination(Dfp[] a, Dfp[] b)Compute a linear combination.DfplinearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2)Compute a linear combination.DfplinearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2, Dfp a3, Dfp b3)Compute a linear combination.DfplinearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2, Dfp a3, Dfp b3, Dfp a4, Dfp b4)Compute a linear combination.Dfplog()Natural logarithm.Dfplog10()Base 10 logarithm.intlog10K()Get the exponent of the greatest power of 10000 that is less than or equal to the absolute value of this.Dfplog1p()Shifted natural logarithm.Dfpmultiply(double a)'×' operator.Dfpmultiply(int x)Multiply this by a single digit x.Dfpmultiply(Dfp x)Multiply this by x.Dfpnegate()Returns a number that is this number with the sign bit reversed.booleannegativeOrNull()Check if instance is less than or equal to 0.DfpnewInstance()Create an instance with a value of 0.DfpnewInstance(byte x)Create an instance from a byte value.DfpnewInstance(byte sig, byte code)Creates an instance with a non-finite value.DfpnewInstance(double x)Create an instance from a double value.DfpnewInstance(int x)Create an instance from an int value.DfpnewInstance(long x)Create an instance from a long value.DfpnewInstance(String s)Create an instance from a String representation.DfpnewInstance(Dfp d)Create an instance by copying an existing one.DfpnextAfter(Dfp x)Returns the next number greater than this one in the direction of x.booleanpositiveOrNull()Check if instance is greater than or equal to 0.Dfppow(double p)Power operation.Dfppow(int n)Integer power operation.Dfppow(Dfp e)Power operation.Dfppower10(int e)Return the specified power of 10.Dfppower10K(int e)Get the specified power of 10000.Dfpreciprocal()Returns the multiplicative inverse ofthiselement.Dfpremainder(double a)IEEE remainder operator.Dfpremainder(Dfp d)Returns the IEEE remainder.Dfprint()Round to nearest integer using the round-half-even method.DfprootN(int n)Nth root.longround()Get the closest long to instance value.protected intround(int n)Round this given the next digit n using the current rounding mode.Dfpscalb(int n)Multiply the instance by a power of 2.protected voidshiftLeft()Shift the mantissa left, and adjust the exponent to compensate.protected voidshiftRight()Shift the mantissa right, and adjust the exponent to compensate.Dfpsignum()Compute the signum of the instance.Dfpsin()Sine operation.Dfpsinh()Hyperbolic sine operation.Dfpsqrt()Compute the square root.booleanstrictlyNegative()Check if instance is strictly less than 0.booleanstrictlyPositive()Check if instance is strictly greater than 0.Dfpsubtract(double a)'-' operator.Dfpsubtract(Dfp x)Subtract x from this.Dfptan()Tangent operation.Dfptanh()Hyperbolic tangent operation.doubletoDouble()Convert the instance into a double.double[]toSplitDouble()Convert the instance into a split double.StringtoString()Get a string representation of the instance.protected Dfptrap(int type, String what, Dfp oper, Dfp def, Dfp result)Trap handler.protected Dfptrunc(DfpField.RoundingMode rmode)Does the integer conversions with the specified rounding.booleanunequal(Dfp x)Check if instance is not equal to x.
 
- 
- 
- 
Field Detail- 
RADIXpublic static final int RADIX The radix, or base of this system. Set to 10000- See Also:
- Constant Field Values
 
 - 
MIN_EXPpublic static final int MIN_EXP The minimum exponent before underflow is signaled. Flush to zero occurs at minExp-DIGITS- See Also:
- Constant Field Values
 
 - 
MAX_EXPpublic static final int MAX_EXP The maximum exponent before overflow is signaled and results flushed to infinity.- See Also:
- Constant Field Values
 
 - 
ERR_SCALEpublic static final int ERR_SCALE The amount under/overflows are scaled by before going to trap handler.- See Also:
- Constant Field Values
 
 - 
FINITEpublic static final byte FINITE Indicator value for normal finite numbers.- See Also:
- Constant Field Values
 
 - 
INFINITEpublic static final byte INFINITE Indicator value for Infinity.- See Also:
- Constant Field Values
 
 - 
SNANpublic static final byte SNAN Indicator value for signaling NaN.- See Also:
- Constant Field Values
 
 - 
QNANpublic static final byte QNAN Indicator value for quiet NaN.- See Also:
- Constant Field Values
 
 - 
mantprotected int[] mant Mantissa.
 - 
signprotected byte sign Sign bit: 1 for positive, -1 for negative.
 - 
expprotected int exp Exponent.
 - 
nansprotected byte nans Indicator for non-finite / non-number values.
 
- 
 - 
Constructor Detail- 
Dfpprotected Dfp(DfpField field) Makes an instance with a value of zero.- Parameters:
- field- field to which this instance belongs
 
 - 
Dfpprotected Dfp(DfpField field, byte x) Create an instance from a byte value.- Parameters:
- field- field to which this instance belongs
- x- value to convert to an instance
 
 - 
Dfpprotected Dfp(DfpField field, int x) Create an instance from an int value.- Parameters:
- field- field to which this instance belongs
- x- value to convert to an instance
 
 - 
Dfpprotected Dfp(DfpField field, long x) Create an instance from a long value.- Parameters:
- field- field to which this instance belongs
- x- value to convert to an instance
 
 - 
Dfpprotected Dfp(DfpField field, double x) Create an instance from a double value.- Parameters:
- field- field to which this instance belongs
- x- value to convert to an instance
 
 - 
Dfpprotected Dfp(DfpField field, String s) Create an instance from a String representation.- Parameters:
- field- field to which this instance belongs
- s- string representation of the instance
 
 
- 
 - 
Method Detail- 
newInstancepublic Dfp newInstance() Create an instance with a value of 0. Use this internally in preference to constructors to facilitate subclasses- Returns:
- a new instance with a value of 0
 
 - 
newInstancepublic Dfp newInstance(byte x) Create an instance from a byte value.- Parameters:
- x- value to convert to an instance
- Returns:
- a new instance with value x
 
 - 
newInstancepublic Dfp newInstance(int x) Create an instance from an int value.- Parameters:
- x- value to convert to an instance
- Returns:
- a new instance with value x
 
 - 
newInstancepublic Dfp newInstance(long x) Create an instance from a long value.- Parameters:
- x- value to convert to an instance
- Returns:
- a new instance with value x
 
 - 
newInstancepublic Dfp newInstance(double x) Create an instance from a double value.- Parameters:
- x- value to convert to an instance
- Returns:
- a new instance with value x
 
 - 
newInstancepublic Dfp newInstance(Dfp d) Create an instance by copying an existing one. Use this internally in preference to constructors to facilitate subclasses.- Parameters:
- d- instance to copy
- Returns:
- a new instance with the same value as d
 
 - 
newInstancepublic Dfp newInstance(String s) Create an instance from a String representation. Use this internally in preference to constructors to facilitate subclasses.- Parameters:
- s- string representation of the instance
- Returns:
- a new instance parsed from specified string
 
 - 
newInstancepublic Dfp newInstance(byte sig, byte code) Creates an instance with a non-finite value.
 - 
getFieldpublic DfpField getField() Get theField(really aDfpField) to which the instance belongs.The field is linked to the number of digits and acts as a factory for Dfpinstances.- Specified by:
- getFieldin interface- FieldElement<Dfp>
- Returns:
- Field(really a- DfpField) to which the instance belongs
 
 - 
getRadixDigitspublic int getRadixDigits() Get the number of radix digits of the instance.- Returns:
- number of radix digits
 
 - 
shiftLeftprotected void shiftLeft() Shift the mantissa left, and adjust the exponent to compensate.
 - 
shiftRightprotected void shiftRight() Shift the mantissa right, and adjust the exponent to compensate.
 - 
alignprotected int align(int e) Make our exp equal to the supplied one, this may cause rounding. Also causes de-normalized numbers. These numbers are generally dangerous because most routines assume normalized numbers. Align doesn't round, so it will return the last digit destroyed by shifting right.- Parameters:
- e- desired exponent
- Returns:
- last digit destroyed by shifting right
 
 - 
lessThanpublic boolean lessThan(Dfp x) Check if instance is less than x.- Parameters:
- x- number to check instance against
- Returns:
- true if instance is less than x and neither are NaN, false otherwise
 
 - 
greaterThanpublic boolean greaterThan(Dfp x) Check if instance is greater than x.- Parameters:
- x- number to check instance against
- Returns:
- true if instance is greater than x and neither are NaN, false otherwise
 
 - 
negativeOrNullpublic boolean negativeOrNull() Check if instance is less than or equal to 0.- Returns:
- true if instance is not NaN and less than or equal to 0, false otherwise
 
 - 
strictlyNegativepublic boolean strictlyNegative() Check if instance is strictly less than 0.- Returns:
- true if instance is not NaN and less than or equal to 0, false otherwise
 
 - 
positiveOrNullpublic boolean positiveOrNull() Check if instance is greater than or equal to 0.- Returns:
- true if instance is not NaN and greater than or equal to 0, false otherwise
 
 - 
strictlyPositivepublic boolean strictlyPositive() Check if instance is strictly greater than 0.- Returns:
- true if instance is not NaN and greater than or equal to 0, false otherwise
 
 - 
abspublic Dfp abs() Get the absolute value of instance.- Specified by:
- absin interface- RealFieldElement<Dfp>
- Returns:
- absolute value of instance
- Since:
- 3.2
 
 - 
isInfinitepublic boolean isInfinite() Check if instance is infinite.- Returns:
- true if instance is infinite
 
 - 
isNaNpublic boolean isNaN() Check if instance is not a number.- Returns:
- true if instance is not a number
 
 - 
isZeropublic boolean isZero() Check if instance is equal to zero.- Returns:
- true if instance is equal to zero
 
 - 
hashCodepublic int hashCode() Gets a hashCode for the instance.
 - 
unequalpublic boolean unequal(Dfp x) Check if instance is not equal to x.- Parameters:
- x- number to check instance against
- Returns:
- true if instance is not equal to x and neither are NaN, false otherwise
 
 - 
rintpublic Dfp rint() Round to nearest integer using the round-half-even method. That is round to nearest integer unless both are equidistant. In which case round to the even one.- Specified by:
- rintin interface- RealFieldElement<Dfp>
- Returns:
- rounded value
- Since:
- 3.2
 
 - 
floorpublic Dfp floor() Round to an integer using the round floor mode. That is, round toward -Infinity- Specified by:
- floorin interface- RealFieldElement<Dfp>
- Returns:
- rounded value
- Since:
- 3.2
 
 - 
ceilpublic Dfp ceil() Round to an integer using the round ceil mode. That is, round toward +Infinity- Specified by:
- ceilin interface- RealFieldElement<Dfp>
- Returns:
- rounded value
- Since:
- 3.2
 
 - 
remainderpublic Dfp remainder(Dfp d) Returns the IEEE remainder.- Specified by:
- remainderin interface- RealFieldElement<Dfp>
- Parameters:
- d- divisor
- Returns:
- this less n × d, where n is the integer closest to this/d
- Since:
- 3.2
 
 - 
truncprotected Dfp trunc(DfpField.RoundingMode rmode) Does the integer conversions with the specified rounding.- Parameters:
- rmode- rounding mode to use
- Returns:
- truncated value
 
 - 
intValuepublic int intValue() Convert this to an integer. If greater than 2147483647, it returns 2147483647. If less than -2147483648 it returns -2147483648.- Returns:
- converted number
 
 - 
log10Kpublic int log10K() Get the exponent of the greatest power of 10000 that is less than or equal to the absolute value of this. I.E. if this is 106 then log10K would return 1.- Returns:
- integer base 10000 logarithm
 
 - 
power10Kpublic Dfp power10K(int e) Get the specified power of 10000.- Parameters:
- e- desired power
- Returns:
- 10000e
 
 - 
intLog10public int intLog10() Get the exponent of the greatest power of 10 that is less than or equal to abs(this).- Returns:
- integer base 10 logarithm
- Since:
- 3.2
 
 - 
power10public Dfp power10(int e) Return the specified power of 10.- Parameters:
- e- desired power
- Returns:
- 10e
 
 - 
complementprotected int complement(int extra) Negate the mantissa of this by computing the complement. Leaves the sign bit unchanged, used internally by add. Denormalized numbers are handled properly here.- Parameters:
- extra- ???
- Returns:
- ???
 
 - 
addpublic Dfp add(Dfp x) Add x to this.- Specified by:
- addin interface- FieldElement<Dfp>
- Parameters:
- x- number to add
- Returns:
- sum of this and x
 
 - 
negatepublic Dfp negate() Returns a number that is this number with the sign bit reversed.- Specified by:
- negatein interface- FieldElement<Dfp>
- Returns:
- the opposite of this
 
 - 
subtractpublic Dfp subtract(Dfp x) Subtract x from this.- Specified by:
- subtractin interface- FieldElement<Dfp>
- Parameters:
- x- number to subtract
- Returns:
- difference of this and a
 
 - 
roundprotected int round(int n) Round this given the next digit n using the current rounding mode.- Parameters:
- n- ???
- Returns:
- the IEEE flag if an exception occurred
 
 - 
multiplypublic Dfp multiply(Dfp x) Multiply this by x.- Specified by:
- multiplyin interface- FieldElement<Dfp>
- Parameters:
- x- multiplicand
- Returns:
- product of this and x
 
 - 
multiplypublic Dfp multiply(int x) Multiply this by a single digit x.- Specified by:
- multiplyin interface- FieldElement<Dfp>
- Parameters:
- x- multiplicand
- Returns:
- product of this and x
 
 - 
dividepublic Dfp divide(Dfp divisor) Divide this by divisor.- Specified by:
- dividein interface- FieldElement<Dfp>
- Parameters:
- divisor- divisor
- Returns:
- quotient of this by divisor
 
 - 
dividepublic Dfp divide(int divisor) Divide by a single digit less than radix. Special case, so there are speed advantages. 0 <= divisor < radix- Parameters:
- divisor- divisor
- Returns:
- quotient of this by divisor
 
 - 
reciprocalpublic Dfp reciprocal() Returns the multiplicative inverse ofthiselement.- Specified by:
- reciprocalin interface- FieldElement<Dfp>
- Specified by:
- reciprocalin interface- RealFieldElement<Dfp>
- Returns:
- the inverse of this.
 
 - 
sqrtpublic Dfp sqrt() Compute the square root.- Specified by:
- sqrtin interface- RealFieldElement<Dfp>
- Returns:
- square root of the instance
- Since:
- 3.2
 
 - 
dfp2sciprotected String dfp2sci() Convert an instance to a string using scientific notation.- Returns:
- string representation of the instance in scientific notation
 
 - 
dfp2stringprotected String dfp2string() Convert an instance to a string using normal notation.- Returns:
- string representation of the instance in normal notation
 
 - 
dotrappublic Dfp dotrap(int type, String what, Dfp oper, Dfp result) Raises a trap. This does not set the corresponding flag however.- Parameters:
- type- the trap type
- what- - name of routine trap occurred in
- oper- - input operator to function
- result- - the result computed prior to the trap
- Returns:
- The suggested return value from the trap handler
 
 - 
trapprotected Dfp trap(int type, String what, Dfp oper, Dfp def, Dfp result) Trap handler. Subclasses may override this to provide trap functionality per IEEE 854-1987.- Parameters:
- type- The exception type - e.g. FLAG_OVERFLOW
- what- The name of the routine we were in e.g. divide()
- oper- An operand to this function if any
- def- The default return value if trap not enabled
- result- The result that is specified to be delivered per IEEE 854, if any
- Returns:
- the value that should be return by the operation triggering the trap
 
 - 
classifypublic int classify() Returns the type - one of FINITE, INFINITE, SNAN, QNAN.- Returns:
- type of the number
 
 - 
copySignpublic static Dfp copySign(Dfp x, Dfp y) Creates an instance that is the same as x except that it has the sign of y. abs(x) = dfp.copysign(x, dfp.one)- Parameters:
- x- number to get the value from
- y- number to get the sign from
- Returns:
- a number with the value of x and the sign of y
 
 - 
nextAfterpublic Dfp nextAfter(Dfp x) Returns the next number greater than this one in the direction of x. If this==x then simply returns this.- Parameters:
- x- direction where to look at
- Returns:
- closest number next to instance in the direction of x
 
 - 
toDoublepublic double toDouble() Convert the instance into a double.- Returns:
- a double approximating the instance
- See Also:
- toSplitDouble()
 
 - 
toSplitDoublepublic double[] toSplitDouble() Convert the instance into a split double.- Returns:
- an array of two doubles which sum represent the instance
- See Also:
- toDouble()
 
 - 
getRealpublic double getReal() Get the real value of the number.- Specified by:
- getRealin interface- RealFieldElement<Dfp>
- Returns:
- real value
- Since:
- 3.2
 
 - 
addpublic Dfp add(double a) '+' operator.- Specified by:
- addin interface- RealFieldElement<Dfp>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this+a
- Since:
- 3.2
 
 - 
subtractpublic Dfp subtract(double a) '-' operator.- Specified by:
- subtractin interface- RealFieldElement<Dfp>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this-a
- Since:
- 3.2
 
 - 
multiplypublic Dfp multiply(double a) '×' operator.- Specified by:
- multiplyin interface- RealFieldElement<Dfp>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this×a
- Since:
- 3.2
 
 - 
dividepublic Dfp divide(double a) '÷' operator.- Specified by:
- dividein interface- RealFieldElement<Dfp>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this÷a
- Since:
- 3.2
 
 - 
remainderpublic Dfp remainder(double a) IEEE remainder operator.- Specified by:
- remainderin interface- RealFieldElement<Dfp>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this - n × a where n is the closest integer to this/a (the even integer is chosen for n if this/a is halfway between two integers)
- Since:
- 3.2
 
 - 
roundpublic long round() Get the closest long to instance value.- Specified by:
- roundin interface- RealFieldElement<Dfp>
- Returns:
- closest long to RealFieldElement.getReal()
- Since:
- 3.2
 
 - 
signumpublic Dfp signum() Compute the signum of the instance. The signum is -1 for negative numbers, +1 for positive numbers and 0 otherwise- Specified by:
- signumin interface- RealFieldElement<Dfp>
- Returns:
- -1.0, -0.0, +0.0, +1.0 or NaN depending on sign of a
- Since:
- 3.2
 
 - 
copySignpublic Dfp copySign(Dfp s) Returns the instance with the sign of the argument. A NaNsignargument is treated as positive.- Specified by:
- copySignin interface- RealFieldElement<Dfp>
- Parameters:
- s- the sign for the returned value
- Returns:
- the instance with the same sign as the signargument
- Since:
- 3.2
 
 - 
copySignpublic Dfp copySign(double s) Returns the instance with the sign of the argument. A NaNsignargument is treated as positive.- Specified by:
- copySignin interface- RealFieldElement<Dfp>
- Parameters:
- s- the sign for the returned value
- Returns:
- the instance with the same sign as the signargument
- Since:
- 3.2
 
 - 
scalbpublic Dfp scalb(int n) Multiply the instance by a power of 2.- Specified by:
- scalbin interface- RealFieldElement<Dfp>
- Parameters:
- n- power of 2
- Returns:
- this × 2n
- Since:
- 3.2
 
 - 
hypotpublic Dfp hypot(Dfp y) Returns the hypotenuse of a triangle with sidesthisandy- sqrt(this2 +y2) avoiding intermediate overflow or underflow.- If either argument is infinite, then the result is positive infinity.
- else, if either argument is NaN then the result is NaN.
 - Specified by:
- hypotin interface- RealFieldElement<Dfp>
- Parameters:
- y- a value
- Returns:
- sqrt(this2 +y2)
- Since:
- 3.2
 
 - 
cbrtpublic Dfp cbrt() Cubic root.- Specified by:
- cbrtin interface- RealFieldElement<Dfp>
- Returns:
- cubic root of the instance
- Since:
- 3.2
 
 - 
rootNpublic Dfp rootN(int n) Nth root.- Specified by:
- rootNin interface- RealFieldElement<Dfp>
- Parameters:
- n- order of the root
- Returns:
- nth root of the instance
- Since:
- 3.2
 
 - 
powpublic Dfp pow(double p) Power operation.- Specified by:
- powin interface- RealFieldElement<Dfp>
- Parameters:
- p- power to apply
- Returns:
- thisp
- Since:
- 3.2
 
 - 
powpublic Dfp pow(int n) Integer power operation.- Specified by:
- powin interface- RealFieldElement<Dfp>
- Parameters:
- n- power to apply
- Returns:
- thisn
- Since:
- 3.2
 
 - 
powpublic Dfp pow(Dfp e) Power operation.- Specified by:
- powin interface- RealFieldElement<Dfp>
- Parameters:
- e- exponent
- Returns:
- thise
- Since:
- 3.2
 
 - 
exppublic Dfp exp() Exponential.- Specified by:
- expin interface- RealFieldElement<Dfp>
- Returns:
- exponential of the instance
- Since:
- 3.2
 
 - 
expm1public Dfp expm1() Exponential minus 1.- Specified by:
- expm1in interface- RealFieldElement<Dfp>
- Returns:
- exponential minus one of the instance
- Since:
- 3.2
 
 - 
logpublic Dfp log() Natural logarithm.- Specified by:
- login interface- RealFieldElement<Dfp>
- Returns:
- logarithm of the instance
- Since:
- 3.2
 
 - 
log1ppublic Dfp log1p() Shifted natural logarithm.- Specified by:
- log1pin interface- RealFieldElement<Dfp>
- Returns:
- logarithm of one plus the instance
- Since:
- 3.2
 
 - 
log10public Dfp log10() Base 10 logarithm.- Specified by:
- log10in interface- RealFieldElement<Dfp>
- Returns:
- base 10 logarithm of the instance
- Since:
- 3.2, return type changed to Dfpin 4.0
 
 - 
cospublic Dfp cos() Cosine operation.- Specified by:
- cosin interface- RealFieldElement<Dfp>
- Returns:
- cos(this)
- Since:
- 3.2
 
 - 
sinpublic Dfp sin() Sine operation.- Specified by:
- sinin interface- RealFieldElement<Dfp>
- Returns:
- sin(this)
- Since:
- 3.2
 
 - 
tanpublic Dfp tan() Tangent operation.- Specified by:
- tanin interface- RealFieldElement<Dfp>
- Returns:
- tan(this)
- Since:
- 3.2
 
 - 
acospublic Dfp acos() Arc cosine operation.- Specified by:
- acosin interface- RealFieldElement<Dfp>
- Returns:
- acos(this)
- Since:
- 3.2
 
 - 
asinpublic Dfp asin() Arc sine operation.- Specified by:
- asinin interface- RealFieldElement<Dfp>
- Returns:
- asin(this)
- Since:
- 3.2
 
 - 
atanpublic Dfp atan() Arc tangent operation.- Specified by:
- atanin interface- RealFieldElement<Dfp>
- Returns:
- atan(this)
- Since:
- 3.2
 
 - 
atan2public Dfp atan2(Dfp x) throws DimensionMismatchException Two arguments arc tangent operation.- Specified by:
- atan2in interface- RealFieldElement<Dfp>
- Parameters:
- x- second argument of the arc tangent
- Returns:
- atan2(this, x)
- Throws:
- DimensionMismatchException- if number of free parameters or orders are inconsistent
- Since:
- 3.2
 
 - 
coshpublic Dfp cosh() Hyperbolic cosine operation.- Specified by:
- coshin interface- RealFieldElement<Dfp>
- Returns:
- cosh(this)
- Since:
- 3.2
 
 - 
sinhpublic Dfp sinh() Hyperbolic sine operation.- Specified by:
- sinhin interface- RealFieldElement<Dfp>
- Returns:
- sinh(this)
- Since:
- 3.2
 
 - 
tanhpublic Dfp tanh() Hyperbolic tangent operation.- Specified by:
- tanhin interface- RealFieldElement<Dfp>
- Returns:
- tanh(this)
- Since:
- 3.2
 
 - 
acoshpublic Dfp acosh() Inverse hyperbolic cosine operation.- Specified by:
- acoshin interface- RealFieldElement<Dfp>
- Returns:
- acosh(this)
- Since:
- 3.2
 
 - 
asinhpublic Dfp asinh() Inverse hyperbolic sine operation.- Specified by:
- asinhin interface- RealFieldElement<Dfp>
- Returns:
- asin(this)
- Since:
- 3.2
 
 - 
atanhpublic Dfp atanh() Inverse hyperbolic tangent operation.- Specified by:
- atanhin interface- RealFieldElement<Dfp>
- Returns:
- atanh(this)
- Since:
- 3.2
 
 - 
linearCombinationpublic Dfp linearCombination(Dfp[] a, Dfp[] b) throws DimensionMismatchException Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a- Factors.
- b- Factors.
- Returns:
- Σi ai bi.
- Throws:
- DimensionMismatchException- if arrays dimensions don't match
- Since:
- 3.2
 
 - 
linearCombinationpublic Dfp linearCombination(double[] a, Dfp[] b) throws DimensionMismatchException Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a- Factors.
- b- Factors.
- Returns:
- Σi ai bi.
- Throws:
- DimensionMismatchException- if arrays dimensions don't match
- Since:
- 3.2
 
 - 
linearCombinationpublic Dfp linearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- Returns:
- a1×b1 + a2×b2
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(Object, Object, Object, Object, Object, Object),- RealFieldElement.linearCombination(Object, Object, Object, Object, Object, Object, Object, Object)
 
 - 
linearCombinationpublic Dfp linearCombination(double a1, Dfp b1, double a2, Dfp b2) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- Returns:
- a1×b1 + a2×b2
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(double, Object, double, Object, double, Object),- RealFieldElement.linearCombination(double, Object, double, Object, double, Object, double, Object)
 
 - 
linearCombinationpublic Dfp linearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2, Dfp a3, Dfp b3) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- a3- first factor of the third term
- b3- second factor of the third term
- Returns:
- a1×b1 + a2×b2 + a3×b3
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(Object, Object, Object, Object),- RealFieldElement.linearCombination(Object, Object, Object, Object, Object, Object, Object, Object)
 
 - 
linearCombinationpublic Dfp linearCombination(double a1, Dfp b1, double a2, Dfp b2, double a3, Dfp b3) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- a3- first factor of the third term
- b3- second factor of the third term
- Returns:
- a1×b1 + a2×b2 + a3×b3
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(double, Object, double, Object),- RealFieldElement.linearCombination(double, Object, double, Object, double, Object, double, Object)
 
 - 
linearCombinationpublic Dfp linearCombination(Dfp a1, Dfp b1, Dfp a2, Dfp b2, Dfp a3, Dfp b3, Dfp a4, Dfp b4) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- a3- first factor of the third term
- b3- second factor of the third term
- a4- first factor of the third term
- b4- second factor of the third term
- Returns:
- a1×b1 + a2×b2 + a3×b3 + a4×b4
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(Object, Object, Object, Object),- RealFieldElement.linearCombination(Object, Object, Object, Object, Object, Object)
 
 - 
linearCombinationpublic Dfp linearCombination(double a1, Dfp b1, double a2, Dfp b2, double a3, Dfp b3, double a4, Dfp b4) Compute a linear combination.- Specified by:
- linearCombinationin interface- RealFieldElement<Dfp>
- Parameters:
- a1- first factor of the first term
- b1- second factor of the first term
- a2- first factor of the second term
- b2- second factor of the second term
- a3- first factor of the third term
- b3- second factor of the third term
- a4- first factor of the third term
- b4- second factor of the third term
- Returns:
- a1×b1 + a2×b2 + a3×b3 + a4×b4
- Since:
- 3.2
- See Also:
- RealFieldElement.linearCombination(double, Object, double, Object),- RealFieldElement.linearCombination(double, Object, double, Object, double, Object)
 
 
- 
 
-