Mercurial > dive4elements > gnv-client
view gnv-artifacts/src/main/java/de/intevation/gnv/math/LinearFunction.java @ 638:c580666a843f
Removed CallMeta object from state which should not be serialized. Implemented a little workarround instead to save localized strings for axes descriptions of horizontal profile charts (issue180).
gnv-artifacts/trunk@721 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Tue, 02 Mar 2010 08:43:50 +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 :