Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/extreme/ExtremeCurveFacet.java @ 4838:ac9a3d9576b4
merged.
author | Raimund Renkert <rrenkert@intevation.de> |
---|---|
date | Wed, 23 Jan 2013 11:15:35 +0100 |
parents | f8217f1fef2e |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.model.extreme; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.access.ExtremeAccess; import de.intevation.flys.artifacts.model.CalculationResult; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.fixings.FixingsFacet; import de.intevation.flys.artifacts.states.DefaultState.ComputeType; import de.intevation.flys.utils.KMIndex; import de.intevation.flys.utils.DoubleUtil; import org.apache.log4j.Logger; /** * Facet to show the W|Q values. */ public class ExtremeCurveFacet extends FixingsFacet implements FacetTypes { /** House logger. */ private static Logger logger = Logger.getLogger(ExtremeCurveFacet.class); /** Trivial Constructor. */ public ExtremeCurveFacet() { } /** * @param description Description of the facet. */ public ExtremeCurveFacet(String description) { super(0, EXTREME_WQ_CURVE, description, ComputeType.ADVANCE, null, null); } /** * @param description Description of the facet. * @param showBase if true, gimme different name. */ public ExtremeCurveFacet(String description, boolean showBase) { super(0, EXTREME_WQ_CURVE_BASE, description, ComputeType.ADVANCE, null, null); if (!showBase) { this.name = EXTREME_WQ_CURVE; } } public ExtremeCurveFacet(int index, String description) { super(index, EXTREME_WQ_CURVE, description, ComputeType.ADVANCE, null, null); } /** * Returns the data (a curve/function) this facet provides at km given in context. * * @param artifact the owner artifact. * @param context the CallContext. * * @return the data. */ @Override public Object getData(Artifact artifact, CallContext context) { logger.debug("ExtremeCurveFacet.getData"); if (artifact instanceof FLYSArtifact) { FLYSArtifact flys = (FLYSArtifact)artifact; CalculationResult res = (CalculationResult) flys.compute(context, ComputeType.ADVANCE, false); ExtremeResult result = (ExtremeResult) res.getData(); double currentKm = getCurrentKm(context); KMIndex<Curve> curves = result.getCurves(); KMIndex.Entry<Curve> curveEntry = curves.search(currentKm); if (curveEntry != null) { logger.debug("A curve at km = " + currentKm); Curve c = curveEntry.getValue(); // Find segment in which the curr. km is located. ExtremeAccess access = new ExtremeAccess(flys, context); double[] ds = access.getValuesForRange(currentKm); if (ds != null) { double m = DoubleUtil.maxInArray(ds); // Add 5 percent. m *= 1.05d; c.setSuggestedMaxQ(m); } return c; } else { logger.debug("No curve at km = " + currentKm); return null; } } else { logger.debug("Not an instance of FLYSArtifact / WINFOArtifact."); return null; } } /** * Create a deep copy of this Facet. * @return a deep copy. */ @Override public ExtremeCurveFacet deepCopy() { ExtremeCurveFacet copy = new ExtremeCurveFacet(); copy.set(this); return copy; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :