Class DerivativeStructure
- java.lang.Object
- 
- org.apache.commons.math4.legacy.analysis.differentiation.DerivativeStructure
 
- 
- All Implemented Interfaces:
- FieldElement<DerivativeStructure>,- RealFieldElement<DerivativeStructure>
 
 public class DerivativeStructure extends Object implements RealFieldElement<DerivativeStructure> Class representing both the value and the differentials of a function.This class is the workhorse of the differentiation package. This class is an implementation of the extension to Rall's numbers described in Dan Kalman's paper Doubly Recursive Multivariate Automatic Differentiation, Mathematics Magazine, vol. 75, no. 3, June 2002. Rall's numbers are an extension to the real numbers used throughout mathematical expressions; they hold the derivative together with the value of a function. Dan Kalman's derivative structures hold all partial derivatives up to any specified order, with respect to any number of free parameters. Rall's numbers therefore can be seen as derivative structures for order one derivative and one free parameter, and real numbers can be seen as derivative structures with zero order derivative and no free parameters. DerivativeStructureinstances can be used directly thanks to the arithmetic operators to the mathematical functions provided as methods by this class (+, -, *, /, %, sin, cos ...).Implementing complex expressions by hand using these classes is a tedious and error-prone task but has the advantage of having no limitation on the derivation order despite not requiring users to compute the derivatives by themselves. Implementing complex expression can also be done by developing computation code using standard primitive double values and to use differentiatorsto create theDerivativeStructure-based instances. This method is simpler but may be limited in the accuracy and derivation orders and may be computationally intensive (this is typically the case forfinite differences differentiator.Instances of this class are guaranteed to be immutable. - Since:
- 3.1
- See Also:
- DSCompiler
 
- 
- 
Constructor SummaryConstructors Constructor Description DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2)Linear combination constructor.DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2, double a3, DerivativeStructure ds3)Linear combination constructor.DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2, double a3, DerivativeStructure ds3, double a4, DerivativeStructure ds4)Linear combination constructor.DerivativeStructure(int parameters, int order)Build an instance with all values and derivatives set to 0.DerivativeStructure(int parameters, int order, double value)Build an instance representing a constant value.DerivativeStructure(int parameters, int order, double... derivatives)Build an instance from all its derivatives.DerivativeStructure(int parameters, int order, int index, double value)Build an instance representing a variable.
 - 
Method Summary
 
- 
- 
- 
Constructor Detail- 
DerivativeStructurepublic DerivativeStructure(int parameters, int order) Build an instance with all values and derivatives set to 0.- Parameters:
- parameters- number of free parameters
- order- derivation order
- Throws:
- NumberIsTooLargeException- if order is too large.
 
 - 
DerivativeStructurepublic DerivativeStructure(int parameters, int order, double value) Build an instance representing a constant value.- Parameters:
- parameters- number of free parameters
- order- derivation order
- value- value of the constant
- Throws:
- NumberIsTooLargeException- if order is too large.
- See Also:
- DerivativeStructure(int, int, int, double)
 
 - 
DerivativeStructurepublic DerivativeStructure(int parameters, int order, int index, double value) Build an instance representing a variable.Instances built using this constructor are considered to be the free variables with respect to which differentials are computed. As such, their differential with respect to themselves is +1. - Parameters:
- parameters- number of free parameters
- order- derivation order
- index- index of the variable (from 0 to- parameters - 1)
- value- value of the variable
- Throws:
- NumberIsTooLargeException- if- index ≥ parameters.
- See Also:
- DerivativeStructure(int, int, double)
 
 - 
DerivativeStructurepublic DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2) Linear combination constructor. The derivative structure built will be a1 * ds1 + a2 * ds2- Parameters:
- a1- first scale factor
- ds1- first base (unscaled) derivative structure
- a2- second scale factor
- ds2- second base (unscaled) derivative structure
- Throws:
- DimensionMismatchException- if number of free parameters or orders are inconsistent
 
 - 
DerivativeStructurepublic DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2, double a3, DerivativeStructure ds3) Linear combination constructor. The derivative structure built will be a1 * ds1 + a2 * ds2 + a3 * ds3- Parameters:
- a1- first scale factor
- ds1- first base (unscaled) derivative structure
- a2- second scale factor
- ds2- second base (unscaled) derivative structure
- a3- third scale factor
- ds3- third base (unscaled) derivative structure
- Throws:
- DimensionMismatchException- if number of free parameters or orders are inconsistent.
 
 - 
DerivativeStructurepublic DerivativeStructure(double a1, DerivativeStructure ds1, double a2, DerivativeStructure ds2, double a3, DerivativeStructure ds3, double a4, DerivativeStructure ds4) Linear combination constructor. The derivative structure built will be a1 * ds1 + a2 * ds2 + a3 * ds3 + a4 * ds4- Parameters:
- a1- first scale factor
- ds1- first base (unscaled) derivative structure
- a2- second scale factor
- ds2- second base (unscaled) derivative structure
- a3- third scale factor
- ds3- third base (unscaled) derivative structure
- a4- fourth scale factor
- ds4- fourth base (unscaled) derivative structure
- Throws:
- DimensionMismatchException- if number of free parameters or orders are inconsistent.
 
 - 
DerivativeStructurepublic DerivativeStructure(int parameters, int order, double... derivatives) Build an instance from all its derivatives.- Parameters:
- parameters- number of free parameters
- order- derivation order
- derivatives- derivatives sorted according to- DSCompiler.getPartialDerivativeIndex(int...)
- Throws:
- DimensionMismatchException- if derivatives array does not match the- sizeexpected by the compiler.
- NumberIsTooLargeException- if order is too large.
- See Also:
- getAllDerivatives()
 
 
- 
 - 
Method Detail- 
getFreeParameterspublic int getFreeParameters() Get the number of free parameters.- Returns:
- number of free parameters
 
 - 
getOrderpublic int getOrder() Get the derivation order.- Returns:
- derivation order
 
 - 
createConstantpublic DerivativeStructure createConstant(double c) Create a constant compatible with instance order and number of parameters.This method is a convenience factory method, it simply calls new DerivativeStructure(getFreeParameters(), getOrder(), c)- Parameters:
- c- value of the constant
- Returns:
- a constant compatible with instance order and number of parameters
- Since:
- 3.3
- See Also:
- DerivativeStructure(int, int, double)
 
 - 
getRealpublic double getReal() - Specified by:
- getRealin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
getValuepublic double getValue() Get the value part of the derivative structure.- Returns:
- value part of the derivative structure
- See Also:
- getPartialDerivative(int...)
 
 - 
getPartialDerivativepublic double getPartialDerivative(int... orders) Get a partial derivative.- Parameters:
- orders- derivation orders with respect to each variable (if all orders are 0, the value is returned)
- Returns:
- partial derivative
- Throws:
- DimensionMismatchException- if the numbers of variables does not match the instance.
- NumberIsTooLargeException- if the sum of derivation orders is larger than the instance limits.
- See Also:
- getValue()
 
 - 
getAllDerivativespublic double[] getAllDerivatives() Get all partial derivatives.- Returns:
- a fresh copy of partial derivatives, in an array sorted according to
 DSCompiler.getPartialDerivativeIndex(int...)
 
 - 
addpublic DerivativeStructure add(double a) - Specified by:
- addin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
addpublic DerivativeStructure add(DerivativeStructure a) - Specified by:
- addin interface- FieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match.
 
 - 
subtractpublic DerivativeStructure subtract(double a) - Specified by:
- subtractin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
subtractpublic DerivativeStructure subtract(DerivativeStructure a) - Specified by:
- subtractin interface- FieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
 
 - 
multiplypublic DerivativeStructure multiply(int n) - Specified by:
- multiplyin interface- FieldElement<DerivativeStructure>
 
 - 
multiplypublic DerivativeStructure multiply(double a) - Specified by:
- multiplyin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
multiplypublic DerivativeStructure multiply(DerivativeStructure a) - Specified by:
- multiplyin interface- FieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
 
 - 
dividepublic DerivativeStructure divide(double a) - Specified by:
- dividein interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
dividepublic DerivativeStructure divide(DerivativeStructure a) - Specified by:
- dividein interface- FieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
 
 - 
remainderpublic DerivativeStructure remainder(double a) - Specified by:
- remainderin interface- RealFieldElement<DerivativeStructure>
 
 - 
remainderpublic DerivativeStructure remainder(DerivativeStructure a) - Specified by:
- remainderin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
negatepublic DerivativeStructure negate() - Specified by:
- negatein interface- FieldElement<DerivativeStructure>
 
 - 
abspublic DerivativeStructure abs() - Specified by:
- absin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
ceilpublic DerivativeStructure ceil() - Specified by:
- ceilin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
floorpublic DerivativeStructure floor() - Specified by:
- floorin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
rintpublic DerivativeStructure rint() - Specified by:
- rintin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
roundpublic long round() - Specified by:
- roundin interface- RealFieldElement<DerivativeStructure>
 
 - 
signumpublic DerivativeStructure signum() - Specified by:
- signumin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
copySignpublic DerivativeStructure copySign(DerivativeStructure sign) - Specified by:
- copySignin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
copySignpublic DerivativeStructure copySign(double sign) - Specified by:
- copySignin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
getExponentpublic int getExponent() Return the exponent of the instance value, removing the bias.For double numbers of the form 2x, the unbiased exponent is exactly x. - Returns:
- exponent for instance in IEEE754 representation, without bias
 
 - 
scalbpublic DerivativeStructure scalb(int n) - Specified by:
- scalbin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
hypotpublic DerivativeStructure hypot(DerivativeStructure y) - Specified by:
- hypotin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
hypotpublic static DerivativeStructure hypot(DerivativeStructure x, DerivativeStructure y) Returns the hypotenuse of a triangle with sidesxandy- sqrt(x2 +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.
 - Parameters:
- x- a value
- y- a value
- Returns:
- sqrt(x2 +y2)
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
composepublic DerivativeStructure compose(double... f) Compute composition of the instance by a univariate function.- Parameters:
- f- array of value and derivatives of the function at the current point (i.e. [f(- getValue()), f'(- getValue()), f''(- getValue())...]).
- Returns:
- f(this)
- Throws:
- DimensionMismatchException- if the number of derivatives in the array is not equal to- order+ 1
 
 - 
reciprocalpublic DerivativeStructure reciprocal() - Specified by:
- reciprocalin interface- FieldElement<DerivativeStructure>
- Specified by:
- reciprocalin interface- RealFieldElement<DerivativeStructure>
 
 - 
sqrtpublic DerivativeStructure sqrt() - Specified by:
- sqrtin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
cbrtpublic DerivativeStructure cbrt() - Specified by:
- cbrtin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
rootNpublic DerivativeStructure rootN(int n) - Specified by:
- rootNin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
getFieldpublic Field<DerivativeStructure> getField() - Specified by:
- getFieldin interface- FieldElement<DerivativeStructure>
 
 - 
powpublic static DerivativeStructure pow(double a, DerivativeStructure x) Compute ax where a is a double and x aDerivativeStructure.- Parameters:
- a- number to exponentiate
- x- power to apply
- Returns:
- ax
- Since:
- 3.3
 
 - 
powpublic DerivativeStructure pow(double p) - Specified by:
- powin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
powpublic DerivativeStructure pow(int n) - Specified by:
- powin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
powpublic DerivativeStructure pow(DerivativeStructure e) - Specified by:
- powin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
exppublic DerivativeStructure exp() - Specified by:
- expin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
expm1public DerivativeStructure expm1() - Specified by:
- expm1in interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
logpublic DerivativeStructure log() - Specified by:
- login interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
log1ppublic DerivativeStructure log1p() - Specified by:
- log1pin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
log10public DerivativeStructure log10() Base 10 logarithm.- Specified by:
- log10in interface- RealFieldElement<DerivativeStructure>
- Returns:
- base 10 logarithm of the instance
 
 - 
cospublic DerivativeStructure cos() - Specified by:
- cosin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
sinpublic DerivativeStructure sin() - Specified by:
- sinin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
tanpublic DerivativeStructure tan() - Specified by:
- tanin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
acospublic DerivativeStructure acos() - Specified by:
- acosin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
asinpublic DerivativeStructure asin() - Specified by:
- asinin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
atanpublic DerivativeStructure atan() - Specified by:
- atanin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
atan2public DerivativeStructure atan2(DerivativeStructure x) - Specified by:
- atan2in interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
atan2public static DerivativeStructure atan2(DerivativeStructure y, DerivativeStructure x) Two arguments arc tangent operation.- Parameters:
- y- first argument of the arc tangent
- x- second argument of the arc tangent
- Returns:
- atan2(y, x)
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
coshpublic DerivativeStructure cosh() - Specified by:
- coshin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
sinhpublic DerivativeStructure sinh() - Specified by:
- sinhin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
tanhpublic DerivativeStructure tanh() - Specified by:
- tanhin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
acoshpublic DerivativeStructure acosh() - Specified by:
- acoshin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
asinhpublic DerivativeStructure asinh() - Specified by:
- asinhin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
atanhpublic DerivativeStructure atanh() - Specified by:
- atanhin interface- RealFieldElement<DerivativeStructure>
- Since:
- 3.2
 
 - 
toDegreespublic DerivativeStructure toDegrees() Convert radians to degrees, with error of less than 0.5 ULP.- Returns:
- instance converted into degrees
 
 - 
toRadianspublic DerivativeStructure toRadians() Convert degrees to radians, with error of less than 0.5 ULP.- Returns:
- instance converted into radians
 
 - 
taylorpublic double taylor(double... delta) Evaluate Taylor expansion a derivative structure.- Parameters:
- delta- parameters offsets (Δx, Δy, ...)
- Returns:
- value of the Taylor expansion at x + Δx, y + Δy, ...
- Throws:
- MathArithmeticException- if factorials becomes too large
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(DerivativeStructure[] a, DerivativeStructure[] b) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(double[] a, DerivativeStructure[] b) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(DerivativeStructure a1, DerivativeStructure b1, DerivativeStructure a2, DerivativeStructure b2) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(double a1, DerivativeStructure b1, double a2, DerivativeStructure b2) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(DerivativeStructure a1, DerivativeStructure b1, DerivativeStructure a2, DerivativeStructure b2, DerivativeStructure a3, DerivativeStructure b3) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(double a1, DerivativeStructure b1, double a2, DerivativeStructure b2, double a3, DerivativeStructure b3) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(DerivativeStructure a1, DerivativeStructure b1, DerivativeStructure a2, DerivativeStructure b2, DerivativeStructure a3, DerivativeStructure b3, DerivativeStructure a4, DerivativeStructure b4) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
linearCombinationpublic DerivativeStructure linearCombination(double a1, DerivativeStructure b1, double a2, DerivativeStructure b2, double a3, DerivativeStructure b3, double a4, DerivativeStructure b4) - Specified by:
- linearCombinationin interface- RealFieldElement<DerivativeStructure>
- Throws:
- DimensionMismatchException- if number of free parameters or orders do not match
- Since:
- 3.2
 
 - 
equalspublic boolean equals(Object other) Test for the equality of two derivative structures.Derivative structures are considered equal if they have the same number of free parameters, the same derivation order, and the same derivatives. 
 
- 
 
-