All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.commons.math.analysis.ComposableFunction Maven / Gradle / Ivy

There is a newer version: 0.40.13
Show newest version
/*
 * 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.math.analysis;

import org.apache.commons.math.FunctionEvaluationException;
import org.apache.commons.math.util.FastMath;


/**
 * Base class for {@link UnivariateRealFunction} that can be composed with other functions.
 *
 * @since 2.1
 * @version $Revision: 1070725 $ $Date: 2011-02-15 02:31:12 +0100 (mar. 15 févr. 2011) $
 */
public abstract class ComposableFunction implements UnivariateRealFunction {

    /** The constant function always returning 0. */
    public static final ComposableFunction ZERO = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return 0;
        }
    };

    /** The constant function always returning 1. */
    public static final ComposableFunction ONE = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return 1;
        }
    };

    /** The identity function. */
    public static final ComposableFunction IDENTITY = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return d;
        }
    };

    /** The {@code FastMath.abs} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction ABS = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.abs(d);
        }
    };

    /** The - operator wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction NEGATE = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return -d;
        }
    };

    /** The invert operator wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction INVERT = new ComposableFunction () {
        /** {@inheritDoc} */
        @Override
        public double value(double d){
            return 1/d;
        }
    };

    /** The {@code FastMath.sin} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction SIN = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.sin(d);
        }
    };

    /** The {@code FastMath.sqrt} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction SQRT = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.sqrt(d);
        }
    };

    /** The {@code FastMath.sinh} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction SINH = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.sinh(d);
        }
    };

    /** The {@code FastMath.exp} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction EXP = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.exp(d);
        }
    };

    /** The {@code FastMath.expm1} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction EXPM1 = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.expm1(d);
        }
    };

    /** The {@code FastMath.asin} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction ASIN = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.asin(d);
        }
    };

    /** The {@code FastMath.atan} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction ATAN = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.atan(d);
        }
    };

    /** The {@code FastMath.tan} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction TAN = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.tan(d);
        }
    };

    /** The {@code FastMath.tanh} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction TANH = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.tanh(d);
        }
    };

    /** The {@code FastMath.cbrt} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction CBRT = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.cbrt(d);
        }
    };

    /** The {@code FastMath.ceil} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction CEIL = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.ceil(d);
        }
    };

    /** The {@code FastMath.floor} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction FLOOR = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.floor(d);
        }
    };

    /** The {@code FastMath.log} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction LOG = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.log(d);
        }
    };

    /** The {@code FastMath.log10} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction LOG10 = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.log10(d);
        }
    };

    /** The {@code FastMath.log1p} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction LOG1P = new ComposableFunction () {
        @Override
        public double value(double d){
            return FastMath.log1p(d);
        }
    };

    /** The {@code FastMath.cos} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction COS = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.cos(d);
        }
    };

    /** The {@code FastMath.abs} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction ACOS = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.acos(d);
        }
    };

    /** The {@code FastMath.cosh} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction COSH = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.cosh(d);
        }
    };

    /** The {@code FastMath.rint} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction RINT = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.rint(d);
        }
    };

    /** The {@code FastMath.signum} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction SIGNUM = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.signum(d);
        }
    };

    /** The {@code FastMath.ulp} method wrapped as a {@link ComposableFunction}. */
    public static final ComposableFunction ULP = new ComposableFunction() {
        /** {@inheritDoc} */
        @Override
        public double value(double d) {
            return FastMath.ulp(d);
        }
    };

    /** Precompose the instance with another function.
     * 

* The composed function h created by {@code h = g.of(f)} is such * that {@code h.value(x) == g.value(f.value(x))} for all x. *

* @param f function to compose with * @return a new function which computes {@code this.value(f.value(x))} * @see #postCompose(UnivariateRealFunction) */ public ComposableFunction of(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(f.value(x)); } }; } /** Postcompose the instance with another function. *

* The composed function h created by {@code h = g.postCompose(f)} is such * that {@code h.value(x) == f.value(g.value(x))} for all x. *

* @param f function to compose with * @return a new function which computes {@code f.value(this.value(x))} * @see #of(UnivariateRealFunction) */ public ComposableFunction postCompose(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return f.value(ComposableFunction.this.value(x)); } }; } /** * Return a function combining the instance and another function. *

* The function h created by {@code h = g.combine(f, combiner)} is such that * {@code h.value(x) == combiner.value(g.value(x), f.value(x))} for all x. *

* @param f function to combine with the instance * @param combiner bivariate function used for combining * @return a new function which computes {@code combine.value(this.value(x), f.value(x))} */ public ComposableFunction combine(final UnivariateRealFunction f, final BivariateRealFunction combiner) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return combiner.value(ComposableFunction.this.value(x), f.value(x)); } }; } /** * Return a function adding the instance and another function. * @param f function to combine with the instance * @return a new function which computes {@code this.value(x) + f.value(x)} */ public ComposableFunction add(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) + f.value(x); } }; } /** * Return a function adding a constant term to the instance. * @param a term to add * @return a new function which computes {@code this.value(x) + a} */ public ComposableFunction add(final double a) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) + a; } }; } /** * Return a function subtracting another function from the instance. * @param f function to combine with the instance * @return a new function which computes {@code this.value(x) - f.value(x)} */ public ComposableFunction subtract(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) - f.value(x); } }; } /** * Return a function multiplying the instance and another function. * @param f function to combine with the instance * @return a new function which computes {@code this.value(x) * f.value(x)} */ public ComposableFunction multiply(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) * f.value(x); } }; } /** * Return a function scaling the instance by a constant factor. * @param scaleFactor constant scaling factor * @return a new function which computes {@code this.value(x) * scaleFactor} */ public ComposableFunction multiply(final double scaleFactor) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) * scaleFactor; } }; } /** * Return a function dividing the instance by another function. * @param f function to combine with the instance * @return a new function which computes {@code this.value(x) / f.value(x)} */ public ComposableFunction divide(final UnivariateRealFunction f) { return new ComposableFunction() { @Override /** {@inheritDoc} */ public double value(double x) throws FunctionEvaluationException { return ComposableFunction.this.value(x) / f.value(x); } }; } /** * Generates a function that iteratively apply instance function on all * elements of an array. *

* The generated function behaves as follows: *

    *
  • initialize result = initialValue
  • *
  • iterate: {@code result = combiner.value(result, * this.value(nextMultivariateEntry));}
  • *
  • return result
  • *
*

* @param combiner combiner to use between entries * @param initialValue initial value to use before first entry * @return a new function that iteratively apply instance function on all * elements of an array. */ public MultivariateRealFunction asCollector(final BivariateRealFunction combiner, final double initialValue) { return new MultivariateRealFunction() { /** {@inheritDoc} */ public double value(double[] point) throws FunctionEvaluationException, IllegalArgumentException { double result = initialValue; for (final double entry : point) { result = combiner.value(result, ComposableFunction.this.value(entry)); } return result; } }; } /** * Generates a function that iteratively apply instance function on all * elements of an array. *

* Calling this method is equivalent to call {@link * #asCollector(BivariateRealFunction, double) asCollector(BivariateRealFunction, 0.0)}. *

* @param combiner combiner to use between entries * @return a new function that iteratively apply instance function on all * elements of an array. * @see #asCollector(BivariateRealFunction, double) */ public MultivariateRealFunction asCollector(final BivariateRealFunction combiner) { return asCollector(combiner, 0.0); } /** * Generates a function that iteratively apply instance function on all * elements of an array. *

* Calling this method is equivalent to call {@link * #asCollector(BivariateRealFunction, double) asCollector(BinaryFunction.ADD, initialValue)}. *

* @param initialValue initial value to use before first entry * @return a new function that iteratively apply instance function on all * elements of an array. * @see #asCollector(BivariateRealFunction, double) * @see BinaryFunction#ADD */ public MultivariateRealFunction asCollector(final double initialValue) { return asCollector(BinaryFunction.ADD, initialValue); } /** * Generates a function that iteratively apply instance function on all * elements of an array. *

* Calling this method is equivalent to call {@link * #asCollector(BivariateRealFunction, double) asCollector(BinaryFunction.ADD, 0.0)}. *

* @return a new function that iteratively apply instance function on all * elements of an array. * @see #asCollector(BivariateRealFunction, double) * @see BinaryFunction#ADD */ public MultivariateRealFunction asCollector() { return asCollector(BinaryFunction.ADD, 0.0); } /** {@inheritDoc} */ public abstract double value(double x) throws FunctionEvaluationException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy