Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/GaugeDischargeCurveFacet.java @ 4028:b993d328f8b0
Improve debug output
author | Björn Ricks <bjoern.ricks@intevation.de> |
---|---|
date | Thu, 04 Oct 2012 14:07:33 +0200 |
parents | b7bdef1831ac |
children | a5e1ca620f15 |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import java.util.Arrays; import java.util.Map; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.artifactdatabase.state.DefaultFacet; import de.intevation.artifactdatabase.state.Facet; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.model.Gauge; import de.intevation.flys.utils.FLYSUtils; import org.apache.log4j.Logger; /** * A Facet that returns discharge curve data at a gauge * * @author <a href="mailto:bjoern.ricks@intevation.de">Björn Ricks</a> */ public class GaugeDischargeCurveFacet extends DefaultFacet { private static final Logger log = Logger.getLogger(GaugeDischargeCurveFacet.class); public GaugeDischargeCurveFacet() { super(0, "facet.gauge.discharge_curve", "facet.gauge.discharge_curve"); } @Override public Object getData(Artifact art, CallContext context) { if (!(art instanceof FLYSArtifact)) { log.warn("Invalid artifact type"); return null; } FLYSArtifact flys = (FLYSArtifact)art; String river = flys.getDataAsString("river"); Gauge gauge = FLYSUtils.getReferenceGauge(flys); if (river == null || gauge == null) { log.warn("Unknown river or gauge"); return null; } String name = gauge.getName(); DischargeTables dt = new DischargeTables(river, name); Map<String, double [][]> map = dt.getValues(100d); double [][] values = map.get(name); if (values == null) { return null; } double [] kms = new double[values[0].length]; Arrays.fill(kms, gauge.getStation().doubleValue()); return new WQKms(kms, values[0], values[1], name); } @Override public Facet deepCopy() { GaugeDischargeCurveFacet copy = new GaugeDischargeCurveFacet(); copy.set(this); return copy; } }