Mercurial > dive4elements > gnv-client
view gnv-artifacts/src/main/java/de/intevation/gnv/math/LinearFunction.java @ 469:62fc63d0f71d
Added a new State in Product Verticalprofile in Timeseriespoints.
Now it will be displayed the Years where measurements happened and than only the dates of the chosen Year will be fetched and displayed.
gnv-artifacts/trunk@532 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Tim Englich <tim.englich@intevation.de> |
---|---|
date | Tue, 12 Jan 2010 12:42:53 +0000 |
parents | 828df3ddb758 |
children | d9d933e06875 |
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 */ 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: