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:
Luc Maisonobe 2012-09-17 17:41:54 +00:00
parent 69f087edcb
commit be26e43b98
6 changed files with 91 additions and 18 deletions

View File

@ -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$

View File

@ -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$
*/ */

View File

@ -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
*/ */

View File

@ -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);
}

View File

@ -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);
}

View File

@ -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;