Mercurial > dive4elements > gnv-client
view gnv-artifacts/src/main/java/de/intevation/gnv/math/LinearFunction.java @ 605:e8ebdbc7f1e3
First step of removing the cache blob. The static part of the describe document will be created by using the input data stored at each state. Some TODOs left (see ChangeLog).
gnv-artifacts/trunk@671 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Tue, 09 Feb 2010 14:27:55 +0000 |
parents | d9d933e06875 |
children | 9a828e5a2390 |
line wrap: on
line source
package de.intevation.gnv.math; import org.apache.commons.math.optimization.fitting.ParametricRealFunction; import org.apache.commons.math.FunctionEvaluationException; import org.apache.commons.math.analysis.UnivariateRealFunction; /** * @author Sascha L. Teichmann (sascha.teichmann@intevation.de) */ public class LinearFunction implements ParametricRealFunction { public static final LinearFunction INSTANCE = new LinearFunction(); public static class Univariate implements UnivariateRealFunction { protected double m; protected double b; public Univariate() { } public Univariate(double x1, double y1, double x2, double y2) { if (y1 == y2) { m = 0d; b = (x1 + x2)*0.5d; } else { m = (x1 - x2)/(y1 - y2); b = y1 - m*x1; } } public double value(double x) { return m*x + b; } } // class Univariate public LinearFunction() { } public double value(double x, double [] parameters) throws FunctionEvaluationException { return x*parameters[0] + parameters[1]; } public double [] gradient(double x, double [] parameters) throws FunctionEvaluationException { return new double [] { x, 1f }; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :