Added differentiator interfaces for vector and matrix functions.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1386742 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
69f087edcb
commit
be26e43b98
|
@ -32,19 +32,24 @@ import org.apache.commons.math3.util.FastMath;
|
||||||
* Recursive Multivariate Automatic Differentiation</a>, Mathematics Magazine, vol. 75,
|
* Recursive Multivariate Automatic Differentiation</a>, Mathematics Magazine, vol. 75,
|
||||||
* no. 3, June 2002.</p>. Rall's numbers are an extension to the real numbers used
|
* no. 3, June 2002.</p>. Rall's numbers are an extension to the real numbers used
|
||||||
* throughout mathematical expressions; they hold the derivative together with the
|
* throughout mathematical expressions; they hold the derivative together with the
|
||||||
* value of a function. Dan Kalman's derivative structures holds all partial derivatives
|
* 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 variables. Rall's
|
* up to any specified order, with respect to any number of free parameters. Rall's
|
||||||
* number therefore can be seen as derivative structures for order one derivative and
|
* numbers therefore can be seen as derivative structures for order one derivative and
|
||||||
* one free variable, and real numbers can be seen as derivative structures with zero
|
* one free parameter, and real numbers can be seen as derivative structures with zero
|
||||||
* order derivative and no free variables.</p>
|
* order derivative and no free parameters.</p>
|
||||||
* <p>{@link DerivativeStructure} instances can be used directly thanks to
|
* <p>{@link DerivativeStructure} instances can be used directly thanks to
|
||||||
* the arithmetic operators to the mathematical functions provided as static
|
* the arithmetic operators to the mathematical functions provided as static
|
||||||
* methods by this class (+, -, *, /, %, sin, cos ...).</p>
|
* methods by this class (+, -, *, /, %, sin, cos ...).</p>
|
||||||
* <p>Implementing complex expressions by hand using these classes is
|
* <p>Implementing complex expressions by hand using these classes is
|
||||||
* however a complex and error-prone task, so the classical use is
|
* a tedious and error-prone task but has the advantage of having no limitation
|
||||||
* simply to develop computation code using standard primitive double
|
* on the derivation order despite no requiring users to compute the derivatives by
|
||||||
* values and to use {@link UnivariateDifferentiator differentiators} to create
|
* themselves. Implementing complex expression can also be done by developing computation
|
||||||
* the {@link DerivativeStructure}-based instances.</p>
|
* code using standard primitive double values and to use {@link
|
||||||
|
* UnivariateFunctionDifferentiator differentiators} to create the {@link
|
||||||
|
* DerivativeStructure}-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 for {@link FiniteDifferencesDifferentiator finite differences
|
||||||
|
* differentiator).</p>
|
||||||
* <p>Instances of this class are guaranteed to be immutable.</p>
|
* <p>Instances of this class are guaranteed to be immutable.</p>
|
||||||
* @see DSCompiler
|
* @see DSCompiler
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
|
|
|
@ -24,7 +24,7 @@ import org.apache.commons.math3.exception.MathIllegalArgumentException;
|
||||||
* both the value and the first derivative of a mathematical function.
|
* both the value and the first derivative of a mathematical function.
|
||||||
* The derivative is computed with respect to the input variable.</p>
|
* The derivative is computed with respect to the input variable.</p>
|
||||||
* @see UnivariateDifferentiableFunction
|
* @see UnivariateDifferentiableFunction
|
||||||
* @see UnivariateDifferentiator
|
* @see UnivariateFunctionDifferentiator
|
||||||
* @since 3.1
|
* @since 3.1
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -22,10 +22,10 @@ import org.apache.commons.math3.analysis.UnivariateFunction;
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
* @since 3.1
|
* @since 3.1
|
||||||
*/
|
*/
|
||||||
public interface UnivariateDifferentiator {
|
public interface UnivariateFunctionDifferentiator {
|
||||||
|
|
||||||
/** Create an implementation of a differential for a
|
/** Create an implementation of a {@link UnivariateDifferentiableFunction
|
||||||
* {@link UnivariateDifferentiableFunction differentiable function}.
|
* differential} from a regular {@link UnivariateFunction function}.
|
||||||
* @param function function to differentiate
|
* @param function function to differentiate
|
||||||
* @return differential function
|
* @return differential function
|
||||||
*/
|
*/
|
|
@ -0,0 +1,34 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.commons.math3.analysis.differentiation;
|
||||||
|
|
||||||
|
import org.apache.commons.math3.analysis.UnivariateMatrixFunction;
|
||||||
|
|
||||||
|
/** Interface defining the function differentiation operation.
|
||||||
|
* @version $Id$
|
||||||
|
* @since 3.1
|
||||||
|
*/
|
||||||
|
public interface UnivariateMatrixFunctionDifferentiator {
|
||||||
|
|
||||||
|
/** Create an implementation of a {@link UnivariateDifferentiableMatrixFunction
|
||||||
|
* differential} from a regular {@link UnivariateMatrixFunction matrix function}.
|
||||||
|
* @param function function to differentiate
|
||||||
|
* @return differential function
|
||||||
|
*/
|
||||||
|
UnivariateDifferentiableMatrixFunction differentiate(UnivariateMatrixFunction function);
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.commons.math3.analysis.differentiation;
|
||||||
|
|
||||||
|
import org.apache.commons.math3.analysis.UnivariateVectorFunction;
|
||||||
|
|
||||||
|
/** Interface defining the function differentiation operation.
|
||||||
|
* @version $Id$
|
||||||
|
* @since 3.1
|
||||||
|
*/
|
||||||
|
public interface UnivariateVectorFunctionDifferentiator {
|
||||||
|
|
||||||
|
/** Create an implementation of a {@link UnivariateDifferentiableVectorFunction
|
||||||
|
* differential} from a regular {@link UnivariateVectorFunction vector function}.
|
||||||
|
* @param function function to differentiate
|
||||||
|
* @return differential function
|
||||||
|
*/
|
||||||
|
UnivariateDifferentiableVectorFunction differentiate(UnivariateVectorFunction function);
|
||||||
|
|
||||||
|
}
|
|
@ -26,14 +26,14 @@
|
||||||
* interface. Any differentiable function should implement this interface.
|
* interface. Any differentiable function should implement this interface.
|
||||||
* </p>
|
* </p>
|
||||||
* <p>
|
* <p>
|
||||||
* Similar interfaces also exist for multivariate functions and for vector or
|
* The {@link UnivariateFunctionDifferentiator} interface defines a way to differentiation
|
||||||
* matrix valued functions.
|
|
||||||
* </p>
|
|
||||||
* <p>
|
|
||||||
* The {@link UnivariateDifferentiator} interface defines a way to differentiation
|
|
||||||
* a simple {@link org.apache.commons.math3.analysis.UnivariateFunction
|
* a simple {@link org.apache.commons.math3.analysis.UnivariateFunction
|
||||||
* univariate function} and get a {@link differential function}.
|
* univariate function} and get a {@link differential function}.
|
||||||
* </p>
|
* </p>
|
||||||
|
* <p>
|
||||||
|
* Similar interfaces also exist for multivariate functions and for vector or
|
||||||
|
* matrix valued functions.
|
||||||
|
* </p>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
package org.apache.commons.math3.analysis.differentiation;
|
package org.apache.commons.math3.analysis.differentiation;
|
||||||
|
|
Loading…
Reference in New Issue