Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/fixation/FixationCompute.java @ 3060:94d78e0dc5e9
Removed superfluous imports.
flys-artifacts/trunk@4639 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Mon, 11 Jun 2012 14:55:03 +0000 |
parents | 5e9533687a0c |
children | bac0b2721451 |
line wrap: on
line source
package de.intevation.flys.artifacts.states.fixation; import java.text.DateFormat; import de.intevation.artifactdatabase.state.Facet; import de.intevation.artifacts.CallContext; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.FixationArtifactAccess; import de.intevation.flys.artifacts.model.CalculationResult; import de.intevation.flys.artifacts.model.DataFacet; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.ReportFacet; import de.intevation.flys.artifacts.model.fixings.FixCalculation; import de.intevation.flys.artifacts.model.fixings.FixAvSectorFacet; import de.intevation.flys.artifacts.model.fixings.FixAnalysisEventsFacet; import de.intevation.flys.artifacts.model.fixings.FixAnalysisPeriodsFacet; import de.intevation.flys.artifacts.model.fixings.FixReferenceEventsFacet; import de.intevation.flys.artifacts.model.fixings.FixOutlierFacet; import de.intevation.flys.artifacts.model.fixings.FixWQCurveFacet; import de.intevation.flys.artifacts.model.fixings.FixDerivateFacet; import de.intevation.flys.artifacts.model.fixings.DateRange; import de.intevation.flys.artifacts.states.DefaultState; import de.intevation.flys.artifacts.resources.Resources; import java.util.List; import org.apache.log4j.Logger; /** * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> */ public class FixationCompute extends DefaultState implements FacetTypes { /** The log used in this class. */ private static Logger log = Logger.getLogger(FixationCompute.class); private static final String I18N_REFERENCEPERIOD = "fix.reference.period"; private static final String I18N_ANALYSISPERIODS = "fix.analysis.periods"; private static final String I18N_DERIVATIVE = "fix.derivative"; private static final String I18N_OUTLIER = "fix.outlier"; /** * The default constructor that initializes an empty State object. */ public FixationCompute() { } @Override public Object computeAdvance( FLYSArtifact artifact, String hash, CallContext context, List<Facet> facets, Object old ) { log.debug("FixationCompute.computeAdvance"); CalculationResult res; FixationArtifactAccess access = new FixationArtifactAccess(artifact); if (old instanceof CalculationResult) { res = (CalculationResult)old; } else { FixCalculation calc = new FixCalculation(access); res = calc.calculate(); } if (facets == null) { return res; } if (res.getReport().hasProblems()) { facets.add(new ReportFacet(ComputeType.ADVANCE, hash, id)); } facets.add( new DataFacet(CSV, "CSV data", ComputeType.ADVANCE, hash, id)); int count = access.getAnalysisPeriods().length; for (int i = 0; i < count; i++) { DateRange period = access.getAnalysisPeriods()[i]; for (int j = access.getQSectorStart().intValue(); j <= access.getQSectorEnd().intValue(); j++) { DateFormat df = DateFormat.getDateInstance(DateFormat.MEDIUM); String startDate = df.format(period.getFrom()); String endDate = df.format(period.getTo()); String sector = ""; switch (j) { case 0: sector = "[0 - (MNQ+MQ)/2)"; break; case 1: sector = "[(MNQ+MQ)/2 - (MQ+MHQ)/2)"; break; case 2: sector = "[(MQ+MHQ)/2 - HQ5)"; break; case 3: sector = "[HQ5 - \u221e)"; break; } String description = sector + ": " + startDate + " - " + endDate; facets.add( new FixAvSectorFacet(j - access.getQSectorStart().intValue(), FIX_SECTOR_AVERAGE_DWT, description)); facets.add( new FixAvSectorFacet(j - access.getQSectorStart().intValue(), FIX_SECTOR_AVERAGE_LS, description)); facets.add( new FixAvSectorFacet(j - access.getQSectorStart().intValue(), FIX_SECTOR_AVERAGE_WQ, description)); } String eventDesc = period.getFrom().toString() + " - " + period.getTo().toString(); facets.add(new FixAnalysisEventsFacet(i, FIX_ANALYSIS_EVENTS_DWT, eventDesc)); facets.add(new FixAnalysisEventsFacet(i, FIX_ANALYSIS_EVENTS_LS, eventDesc)); facets.add(new FixAnalysisEventsFacet(i, FIX_ANALYSIS_EVENTS_WQ, eventDesc)); } String i18n_ref = Resources.getMsg(context.getMeta(), I18N_REFERENCEPERIOD, I18N_REFERENCEPERIOD); facets.add(new FixReferenceEventsFacet(0, FIX_REFERENCE_EVENTS_DWT, i18n_ref)); facets.add(new FixReferenceEventsFacet(1, FIX_REFERENCE_EVENTS_LS, i18n_ref)); facets.add(new FixReferenceEventsFacet(2, FIX_REFERENCE_EVENTS_WQ, i18n_ref)); String i18n_ana = Resources.getMsg(context.getMeta(), I18N_ANALYSISPERIODS, I18N_ANALYSISPERIODS); facets.add(new FixAnalysisPeriodsFacet(0, FIX_ANALYSIS_PERIODS_DWT, i18n_ana)); facets.add(new FixAnalysisPeriodsFacet(1, FIX_ANALYSIS_PERIODS_LS, i18n_ana)); facets.add(new FixAnalysisPeriodsFacet(2, FIX_ANALYSIS_PERIODS_WQ, i18n_ana)); facets.add(new FixWQCurveFacet("W/Q")); facets.add(new FixOutlierFacet(FIX_OUTLIER, Resources.getMsg(context.getMeta(), I18N_OUTLIER, I18N_OUTLIER))); facets.add(new FixDerivateFacet(FIX_DERIVATE, Resources.getMsg(context.getMeta(), I18N_DERIVATIVE, I18N_DERIVATIVE))); return res; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :