Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/fixings/FixOutlierFacet.java @ 3077:5c87d4ca1bd3
Added chart and export generator stubs for SQ relation.
flys-artifacts/trunk@4672 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Fri, 15 Jun 2012 10:17:22 +0000 |
parents | 7660cfe5e8f6 |
children | dc2765e31e1f |
line wrap: on
line source
package de.intevation.flys.artifacts.model.fixings; import org.apache.log4j.Logger; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.flys.utils.KMIndex; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.FixationArtifactAccess; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.DataFacet; import de.intevation.flys.artifacts.model.CalculationResult; import de.intevation.flys.artifacts.states.DefaultState.ComputeType; /** * Facet to show the outliers in a fix calculation. * * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> */ public class FixOutlierFacet extends DataFacet implements FacetTypes { /** House logger. */ private static Logger logger = Logger.getLogger(FixOutlierFacet.class); /** Trivial Constructor. */ public FixOutlierFacet() { } /** * @param name */ public FixOutlierFacet(String name, String description) { super(0, name, description, ComputeType.ADVANCE, null, null); } /** * Returns the data this facet requires. * * @param artifact the owner artifact. * @param context the CallContext (ignored). * * @return the data. */ @Override public Object getData(Artifact artifact, CallContext context) { logger.debug("FixOutlierFacet.getData"); if (artifact instanceof FLYSArtifact) { FLYSArtifact flys = (FLYSArtifact)artifact; FixationArtifactAccess access = new FixationArtifactAccess(flys); CalculationResult res = (CalculationResult) flys.compute(context, ComputeType.ADVANCE, false); FixResult result = (FixResult) res.getData(); double km = access.getCurrentKm(); KMIndex<QW []> kmQWs = result.getOutliers(); KMIndex.Entry<QW []> qwsEntry = kmQWs.binarySearch(km); QW[] qws = null; if(qwsEntry != null) { qws = qwsEntry.getValue(); } return qws; } else { logger.debug("Not an instance of FixationArtifact."); return null; } } /** * Create a deep copy of this Facet. * @return a deep copy. */ @Override public FixOutlierFacet deepCopy() { FixOutlierFacet copy = new FixOutlierFacet(); copy.set(this); return copy; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :