Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/Calculation2.java @ 4270:cde9a6fe1844
Refactor ParameterList to use new InfoPanel base class
By using the base class it will be possible to show either a gauge info or a
measurement station info with only small adjustments.
author | Björn Ricks <bjoern.ricks@intevation.de> |
---|---|
date | Fri, 26 Oct 2012 12:26:01 +0200 |
parents | c1f445b94d03 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import java.util.Arrays; import org.apache.log4j.Logger; /** ComputedDischargeCurve. */ public class Calculation2 extends Calculation { private static Logger logger = Logger.getLogger(Calculation2.class); protected double km; public Calculation2() { } public Calculation2(double km) { this.km = km; } public CalculationResult calculate(WstValueTable wst) { logger.debug("Calculation2.calculate"); double [][] wqs = wst.interpolateWQ(km, this); if (wqs == null || wqs[0].length == 0) { addProblem("cannot.compute.discharge.curve"); return new CalculationResult(new WQKms[0], this); } double [] ws = wqs[0]; double [] qs = wqs[1]; double [] kms = new double[ws.length]; Arrays.fill(kms, km); WQKms wqkms = new WQKms(kms, qs, ws, String.valueOf(km)); if (hasProblems()) { logger.debug("found " + numProblems() + " problems."); wqkms.removeNaNs(); } return new CalculationResult(new WQKms[] { wqkms }, this); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :