Class Tuple
- java.lang.Object
- 
- org.hipparchus.util.Tuple
 
- 
- All Implemented Interfaces:
- CalculusFieldElement<Tuple>,- FieldElement<Tuple>
 
 public class Tuple extends Object implements CalculusFieldElement<Tuple> This class allows to perform the same computation of all components of a Tuple at once.- Since:
- 1.2
 
- 
- 
Constructor SummaryConstructors Constructor Description Tuple(double... x)Creates a new instance from its components.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description Tupleabs()absolute value.Tupleacos()Arc cosine operation.Tupleacosh()Inverse hyperbolic cosine operation.Tupleadd(double a)'+' operator.Tupleadd(Tuple a)Compute this + a.Tupleasin()Arc sine operation.Tupleasinh()Inverse hyperbolic sine operation.Tupleatan()Arc tangent operation.Tupleatan2(Tuple x)Two arguments arc tangent operation.Tupleatanh()Inverse hyperbolic tangent operation.Tuplecbrt()Cubic root.Tupleceil()Get the smallest whole number larger than instance.TuplecopySign(double sign)Returns the instance with the sign of the argument.TuplecopySign(Tuple sign)Returns the instance with the sign of the argument.Tuplecos()Cosine operation.Tuplecosh()Hyperbolic cosine operation.Tupledivide(double a)'÷' operator.Tupledivide(Tuple a)Compute this ÷ a.booleanequals(Object obj)Tupleexp()Exponential.Tupleexpm1()Exponential minus 1.Tuplefloor()Get the largest whole number smaller than instance.TuplegetAddendum()Get the addendum to the real value of the number.doublegetComponent(int index)Get one component of the tuple.double[]getComponents()Get all components of the tuple.intgetDimension()Get the dimension of the tuple.Field<Tuple>getField()Get theFieldto which the instance belongs.TuplegetPi()Get the Archimedes constant π.doublegetReal()Get the real value of the number.inthashCode()Tuplehypot(Tuple y)Returns the hypotenuse of a triangle with sidesthisandy- sqrt(this2 +y2) avoiding intermediate overflow or underflow.TuplelinearCombination(double[] a, Tuple[] b)Compute a linear combination.TuplelinearCombination(double a1, Tuple b1, double a2, Tuple b2)Compute a linear combination.TuplelinearCombination(double a1, Tuple b1, double a2, Tuple b2, double a3, Tuple b3)Compute a linear combination.TuplelinearCombination(double a1, Tuple b1, double a2, Tuple b2, double a3, Tuple b3, double a4, Tuple b4)Compute a linear combination.TuplelinearCombination(Tuple[] a, Tuple[] b)Compute a linear combination.TuplelinearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2)Compute a linear combination.TuplelinearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2, Tuple a3, Tuple b3)Compute a linear combination.TuplelinearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2, Tuple a3, Tuple b3, Tuple a4, Tuple b4)Compute a linear combination.Tuplelog()Natural logarithm.Tuplelog10()Base 10 logarithm.Tuplelog1p()Shifted natural logarithm.Tuplemultiply(double a)'×' operator.Tuplemultiply(int n)Compute n × this.Tuplemultiply(Tuple a)Compute this × a.Tuplenegate()Returns the additive inverse ofthiselement.TuplenewInstance(double value)Create an instance corresponding to a constant real value.Tuplepow(double p)Power operation.Tuplepow(int n)Integer power operation.Tuplepow(Tuple e)Power operation.Tuplereciprocal()Returns the multiplicative inverse ofthiselement.Tupleremainder(double a)IEEE remainder operator.Tupleremainder(Tuple a)IEEE remainder operator.Tuplerint()Get the whole number that is the nearest to the instance, or the even one if x is exactly half way between two integers.TuplerootN(int n)Nth root.Tuplescalb(int n)Multiply the instance by a power of 2.Tuplesign()Compute the sign of the instance.Tuplesin()Sine operation.FieldSinCos<Tuple>sinCos()Combined Sine and Cosine operation.Tuplesinh()Hyperbolic sine operation.FieldSinhCosh<Tuple>sinhCosh()Combined hyperbolic sine and cosine operation.Tuplesqrt()Square root.Tuplesquare()Compute this × this.Tuplesubtract(double a)'-' operator.Tuplesubtract(Tuple a)Compute this - a.Tupletan()Tangent operation.Tupletanh()Hyperbolic tangent operation.TupletoDegrees()Convert radians to degrees, with error of less than 0.5 ULPTupletoRadians()Convert degrees to radians, with error of less than 0.5 ULPTupleulp()Compute least significant bit (Unit in Last Position) for a number.- 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.hipparchus.CalculusFieldElementgetExponent, isFinite, isInfinite, isNaN, norm, round
 - 
Methods inherited from interface org.hipparchus.FieldElementisZero
 
- 
 
- 
- 
- 
Method Detail- 
newInstancepublic Tuple newInstance(double value) Create an instance corresponding to a constant real value.- Specified by:
- newInstancein interface- CalculusFieldElement<Tuple>
- Parameters:
- value- constant real value
- Returns:
- instance corresponding to a constant real value
 
 - 
getDimensionpublic int getDimension() Get the dimension of the tuple.- Returns:
- dimension of the tuple
 
 - 
getComponentpublic double getComponent(int index) Get one component of the tuple.- Parameters:
- index- index of the component, between 0 and- getDimension()- 1
- Returns:
- value of the component
 
 - 
getComponentspublic double[] getComponents() Get all components of the tuple.- Returns:
- all components
 
 - 
getFieldpublic Field<Tuple> getField() Get theFieldto which the instance belongs.- Specified by:
- getFieldin interface- FieldElement<Tuple>
- Returns:
- Fieldto which the instance belongs
 
 - 
addpublic Tuple add(Tuple a) Compute this + a.- Specified by:
- addin interface- FieldElement<Tuple>
- Parameters:
- a- element to add
- Returns:
- a new element representing this + a
 
 - 
subtractpublic Tuple subtract(Tuple a) Compute this - a.- Specified by:
- subtractin interface- CalculusFieldElement<Tuple>
- Specified by:
- subtractin interface- FieldElement<Tuple>
- Parameters:
- a- element to subtract
- Returns:
- a new element representing this - a
 
 - 
negatepublic Tuple negate() Returns the additive inverse ofthiselement.- Specified by:
- negatein interface- FieldElement<Tuple>
- Returns:
- the opposite of this.
 
 - 
multiplypublic Tuple multiply(Tuple a) Compute this × a.- Specified by:
- multiplyin interface- FieldElement<Tuple>
- Parameters:
- a- element to multiply
- Returns:
- a new element representing this × a
 
 - 
multiplypublic Tuple multiply(int n) Compute n × this. Multiplication by an integer number is defined as the following sum \[ n \times \mathrm{this} = \sum_{i=1}^n \mathrm{this} \]- Specified by:
- multiplyin interface- CalculusFieldElement<Tuple>
- Specified by:
- multiplyin interface- FieldElement<Tuple>
- Parameters:
- n- Number of times- thismust be added to itself.
- Returns:
- A new element representing n × this.
 
 - 
squarepublic Tuple square() Compute this × this.- Specified by:
- squarein interface- CalculusFieldElement<Tuple>
- Returns:
- a new element representing this × this
 
 - 
dividepublic Tuple divide(Tuple a) Compute this ÷ a.- Specified by:
- dividein interface- CalculusFieldElement<Tuple>
- Specified by:
- dividein interface- FieldElement<Tuple>
- Parameters:
- a- element to divide by
- Returns:
- a new element representing this ÷ a
 
 - 
reciprocalpublic Tuple reciprocal() Returns the multiplicative inverse ofthiselement.- Specified by:
- reciprocalin interface- FieldElement<Tuple>
- Returns:
- the inverse of this.
 
 - 
getRealpublic double getReal() Get the real value of the number.- Specified by:
- getRealin interface- FieldElement<Tuple>
- Returns:
- real value
 
 - 
getAddendumpublic Tuple getAddendum() Get the addendum to the real value of the number.The addendum is considered to be the part that when added back to the real partrecovers the instance. This means that whene.getReal()is finite (i.e. neither infinite nor NaN), thene.getAddendum().add(e.getReal())iseande.subtract(e.getReal())ise.getAddendum(). Beware that for non-finite numbers, these two equalities may not hold. The first equality (with the addition), always holds even for infinity and NaNs if the real part is independent of the addendum (this is the case for all derivatives types, as well as for complex and Dfp, but it is not the case for Tuple and FieldTuple). The second equality (with the subtraction), generally doesn't hold for non-finite numbers, because the subtraction generates NaNs.- Specified by:
- getAddendumin interface- CalculusFieldElement<Tuple>
- Returns:
- real value
 
 - 
addpublic Tuple add(double a) '+' operator.- Specified by:
- addin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this+a
 
 - 
subtractpublic Tuple subtract(double a) '-' operator.- Specified by:
- subtractin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this-a
 
 - 
multiplypublic Tuple multiply(double a) '×' operator.- Specified by:
- multiplyin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this×a
 
 - 
dividepublic Tuple divide(double a) '÷' operator.- Specified by:
- dividein interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this÷a
 
 - 
remainderpublic Tuple remainder(double a) IEEE remainder operator.- Specified by:
- remainderin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this - n × a where n is the closest integer to this/a
 
 - 
remainderpublic Tuple remainder(Tuple a) IEEE remainder operator.- Specified by:
- remainderin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- right hand side parameter of the operator
- Returns:
- this - n × a where n is the closest integer to this/a
 
 - 
abspublic Tuple abs() absolute value.- Specified by:
- absin interface- CalculusFieldElement<Tuple>
- Returns:
- abs(this)
 
 - 
ceilpublic Tuple ceil() Get the smallest whole number larger than instance.- Specified by:
- ceilin interface- CalculusFieldElement<Tuple>
- Returns:
- ceil(this)
 
 - 
floorpublic Tuple floor() Get the largest whole number smaller than instance.- Specified by:
- floorin interface- CalculusFieldElement<Tuple>
- Returns:
- floor(this)
 
 - 
rintpublic Tuple rint() Get the whole number that is the nearest to the instance, or the even one if x is exactly half way between two integers.- Specified by:
- rintin interface- CalculusFieldElement<Tuple>
- Returns:
- a double number r such that r is an integer r - 0.5 ≤ this ≤ r + 0.5
 
 - 
signpublic Tuple sign() Compute the sign of the instance. The sign is -1 for negative numbers, +1 for positive numbers and 0 otherwise, for Complex number, it is extended on the unit circle (equivalent to z/|z|, with special handling for 0 and NaN)- Specified by:
- signin interface- CalculusFieldElement<Tuple>
- Returns:
- -1.0, -0.0, +0.0, +1.0 or NaN depending on sign of a
 
 - 
copySignpublic Tuple copySign(Tuple sign) Returns the instance with the sign of the argument. A NaNsignargument is treated as positive.- Specified by:
- copySignin interface- CalculusFieldElement<Tuple>
- Parameters:
- sign- the sign for the returned value
- Returns:
- the instance with the same sign as the signargument
 
 - 
copySignpublic Tuple copySign(double sign) Returns the instance with the sign of the argument. A NaNsignargument is treated as positive.- Specified by:
- copySignin interface- CalculusFieldElement<Tuple>
- Parameters:
- sign- the sign for the returned value
- Returns:
- the instance with the same sign as the signargument
 
 - 
scalbpublic Tuple scalb(int n) Multiply the instance by a power of 2.- Specified by:
- scalbin interface- CalculusFieldElement<Tuple>
- Parameters:
- n- power of 2
- Returns:
- this × 2n
 
 - 
ulppublic Tuple ulp() Compute least significant bit (Unit in Last Position) for a number.- Specified by:
- ulpin interface- CalculusFieldElement<Tuple>
- Returns:
- ulp(this)
 
 - 
hypotpublic Tuple hypot(Tuple 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- CalculusFieldElement<Tuple>
- Parameters:
- y- a value
- Returns:
- sqrt(this2 +y2)
 
 - 
sqrtpublic Tuple sqrt() Square root.- Specified by:
- sqrtin interface- CalculusFieldElement<Tuple>
- Returns:
- square root of the instance
 
 - 
cbrtpublic Tuple cbrt() Cubic root.- Specified by:
- cbrtin interface- CalculusFieldElement<Tuple>
- Returns:
- cubic root of the instance
 
 - 
rootNpublic Tuple rootN(int n) Nth root.- Specified by:
- rootNin interface- CalculusFieldElement<Tuple>
- Parameters:
- n- order of the root
- Returns:
- nth root of the instance
 
 - 
powpublic Tuple pow(double p) Power operation.- Specified by:
- powin interface- CalculusFieldElement<Tuple>
- Parameters:
- p- power to apply
- Returns:
- thisp
 
 - 
powpublic Tuple pow(int n) Integer power operation.- Specified by:
- powin interface- CalculusFieldElement<Tuple>
- Parameters:
- n- power to apply
- Returns:
- thisn
 
 - 
powpublic Tuple pow(Tuple e) Power operation.- Specified by:
- powin interface- CalculusFieldElement<Tuple>
- Parameters:
- e- exponent
- Returns:
- thise
 
 - 
exppublic Tuple exp() Exponential.- Specified by:
- expin interface- CalculusFieldElement<Tuple>
- Returns:
- exponential of the instance
 
 - 
expm1public Tuple expm1() Exponential minus 1.- Specified by:
- expm1in interface- CalculusFieldElement<Tuple>
- Returns:
- exponential minus one of the instance
 
 - 
logpublic Tuple log() Natural logarithm.- Specified by:
- login interface- CalculusFieldElement<Tuple>
- Returns:
- logarithm of the instance
 
 - 
log1ppublic Tuple log1p() Shifted natural logarithm.- Specified by:
- log1pin interface- CalculusFieldElement<Tuple>
- Returns:
- logarithm of one plus the instance
 
 - 
log10public Tuple log10() Base 10 logarithm.- Specified by:
- log10in interface- CalculusFieldElement<Tuple>
- Returns:
- base 10 logarithm of the instance
 
 - 
cospublic Tuple cos() Cosine operation.- Specified by:
- cosin interface- CalculusFieldElement<Tuple>
- Returns:
- cos(this)
 
 - 
sinpublic Tuple sin() Sine operation.- Specified by:
- sinin interface- CalculusFieldElement<Tuple>
- Returns:
- sin(this)
 
 - 
sinCospublic FieldSinCos<Tuple> sinCos() Combined Sine and Cosine operation.- Specified by:
- sinCosin interface- CalculusFieldElement<Tuple>
- Returns:
- [sin(this), cos(this)]
 
 - 
tanpublic Tuple tan() Tangent operation.- Specified by:
- tanin interface- CalculusFieldElement<Tuple>
- Returns:
- tan(this)
 
 - 
acospublic Tuple acos() Arc cosine operation.- Specified by:
- acosin interface- CalculusFieldElement<Tuple>
- Returns:
- acos(this)
 
 - 
asinpublic Tuple asin() Arc sine operation.- Specified by:
- asinin interface- CalculusFieldElement<Tuple>
- Returns:
- asin(this)
 
 - 
atanpublic Tuple atan() Arc tangent operation.- Specified by:
- atanin interface- CalculusFieldElement<Tuple>
- Returns:
- atan(this)
 
 - 
atan2public Tuple atan2(Tuple x) Two arguments arc tangent operation.Beware of the order or arguments! As this is based on a two-arguments functions, in order to be consistent with arguments order, the instance is the first argument and the single provided argument is the second argument. In order to be consistent with programming languages atan2, this method computesatan2(this, x), i.e. the instance represents theyargument and thexargument is the one passed as a single argument. This may seem confusing especially for users of Wolfram alpha, as this site is not consistent with programming languagesatan2two-arguments arc tangent and putsxas its first argument.- Specified by:
- atan2in interface- CalculusFieldElement<Tuple>
- Parameters:
- x- second argument of the arc tangent
- Returns:
- atan2(this, x)
 
 - 
coshpublic Tuple cosh() Hyperbolic cosine operation.- Specified by:
- coshin interface- CalculusFieldElement<Tuple>
- Returns:
- cosh(this)
 
 - 
sinhpublic Tuple sinh() Hyperbolic sine operation.- Specified by:
- sinhin interface- CalculusFieldElement<Tuple>
- Returns:
- sinh(this)
 
 - 
sinhCoshpublic FieldSinhCosh<Tuple> sinhCosh() Combined hyperbolic sine and cosine operation.- Specified by:
- sinhCoshin interface- CalculusFieldElement<Tuple>
- Returns:
- [sinh(this), cosh(this)]
 
 - 
tanhpublic Tuple tanh() Hyperbolic tangent operation.- Specified by:
- tanhin interface- CalculusFieldElement<Tuple>
- Returns:
- tanh(this)
 
 - 
acoshpublic Tuple acosh() Inverse hyperbolic cosine operation.- Specified by:
- acoshin interface- CalculusFieldElement<Tuple>
- Returns:
- acosh(this)
 
 - 
asinhpublic Tuple asinh() Inverse hyperbolic sine operation.- Specified by:
- asinhin interface- CalculusFieldElement<Tuple>
- Returns:
- asin(this)
 
 - 
atanhpublic Tuple atanh() Inverse hyperbolic tangent operation.- Specified by:
- atanhin interface- CalculusFieldElement<Tuple>
- Returns:
- atanh(this)
 
 - 
toDegreespublic Tuple toDegrees() Convert radians to degrees, with error of less than 0.5 ULP- Specified by:
- toDegreesin interface- CalculusFieldElement<Tuple>
- Returns:
- instance converted into degrees
 
 - 
toRadianspublic Tuple toRadians() Convert degrees to radians, with error of less than 0.5 ULP- Specified by:
- toRadiansin interface- CalculusFieldElement<Tuple>
- Returns:
- instance converted into radians
 
 - 
linearCombinationpublic Tuple linearCombination(Tuple[] a, Tuple[] b) throws MathIllegalArgumentException Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- Factors.
- b- Factors.
- Returns:
- Σi ai bi.
- Throws:
- MathIllegalArgumentException- if arrays dimensions don't match
 
 - 
linearCombinationpublic Tuple linearCombination(double[] a, Tuple[] b) throws MathIllegalArgumentException Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- Parameters:
- a- Factors.
- b- Factors.
- Returns:
- Σi ai bi.
- Throws:
- MathIllegalArgumentException- if arrays dimensions don't match
 
 - 
linearCombinationpublic Tuple linearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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
- See Also:
- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement),- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement)
 
 - 
linearCombinationpublic Tuple linearCombination(double a1, Tuple b1, double a2, Tuple b2) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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
- See Also:
- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement, double, FieldElement),- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement, double, FieldElement, double, FieldElement)
 
 - 
linearCombinationpublic Tuple linearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2, Tuple a3, Tuple b3) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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
- See Also:
- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement),- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement)
 
 - 
linearCombinationpublic Tuple linearCombination(double a1, Tuple b1, double a2, Tuple b2, double a3, Tuple b3) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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
- See Also:
- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement),- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement, double, FieldElement, double, FieldElement)
 
 - 
linearCombinationpublic Tuple linearCombination(Tuple a1, Tuple b1, Tuple a2, Tuple b2, Tuple a3, Tuple b3, Tuple a4, Tuple b4) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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 fourth term
- b4- second factor of the fourth term
- Returns:
- a1×b1 + a2×b2 + a3×b3 + a4×b4
- See Also:
- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement),- CalculusFieldElement.linearCombination(FieldElement, FieldElement, FieldElement, FieldElement, FieldElement, FieldElement)
 
 - 
linearCombinationpublic Tuple linearCombination(double a1, Tuple b1, double a2, Tuple b2, double a3, Tuple b3, double a4, Tuple b4) Compute a linear combination.- Specified by:
- linearCombinationin interface- CalculusFieldElement<Tuple>
- 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 fourth term
- b4- second factor of the fourth term
- Returns:
- a1×b1 + a2×b2 + a3×b3 + a4×b4
- See Also:
- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement),- CalculusFieldElement.linearCombination(double, FieldElement, double, FieldElement, double, FieldElement)
 
 - 
getPipublic Tuple getPi() Get the Archimedes constant π.Archimedes constant is the ratio of a circle's circumference to its diameter. - Specified by:
- getPiin interface- CalculusFieldElement<Tuple>
- Returns:
- Archimedes constant π
 
 
- 
 
-