sascha@3412: package de.intevation.flys.artifacts.states.fixation;
sascha@3412:
raimund@3610: import java.text.DateFormat;
raimund@3610: import java.util.Date;
raimund@3610: import java.util.List;
raimund@3610:
raimund@3610: import org.apache.log4j.Logger;
raimund@3610:
sascha@3412: import de.intevation.artifactdatabase.state.Facet;
ingo@3785: import de.intevation.artifactdatabase.state.FacetActivity;
ingo@3785: import de.intevation.artifacts.Artifact;
sascha@3412: import de.intevation.artifacts.CallContext;
sascha@3412: import de.intevation.flys.artifacts.FLYSArtifact;
sascha@3412: import de.intevation.flys.artifacts.access.FixAnalysisAccess;
sascha@3412: import de.intevation.flys.artifacts.model.CalculationResult;
sascha@3412: import de.intevation.flys.artifacts.model.DataFacet;
sascha@3412: import de.intevation.flys.artifacts.model.DateRange;
sascha@3412: import de.intevation.flys.artifacts.model.FacetTypes;
sascha@3412: import de.intevation.flys.artifacts.model.ReportFacet;
raimund@3610: import de.intevation.flys.artifacts.model.fixings.FixAnalysisCalculation;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixAnalysisEventsFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixAnalysisPeriodsFacet;
raimund@3610: import de.intevation.flys.artifacts.model.fixings.FixAnalysisResult;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixAvSectorFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixDerivateFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixDeviationFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixLongitudinalAnalysisFacet;
raimund@3610: import de.intevation.flys.artifacts.model.fixings.FixLongitudinalAvSectorFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixLongitudinalDeviationFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixLongitudinalReferenceFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixOutlierFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixReferenceEventsFacet;
sascha@3412: import de.intevation.flys.artifacts.model.fixings.FixWQCurveFacet;
sascha@3412: import de.intevation.flys.artifacts.resources.Resources;
sascha@3412: import de.intevation.flys.artifacts.states.DefaultState;
sascha@3412: import de.intevation.flys.utils.IdGenerator;
sascha@3412:
sascha@3412: /**
sascha@3412: * @author Raimund Renkert
sascha@3412: */
sascha@3412: public class FixAnalysisCompute
sascha@3412: extends DefaultState
sascha@3412: implements FacetTypes
sascha@3412: {
sascha@3412: /** The log used in this class. */
sascha@3412: private static Logger log = Logger.getLogger(FixAnalysisCompute.class);
sascha@3412:
christian@3907: private static final String I18N_REFERENCEPERIOD_SHORT = "fix.reference.period.event.short";
sascha@3412:
sascha@3412: private static final String I18N_ANALYSISPERIODS = "fix.analysis.periods";
sascha@3412:
sascha@3412: private static final String I18N_DERIVATIVE = "fix.derivative";
sascha@3412:
sascha@3412: private static final String I18N_OUTLIER = "fix.outlier";
sascha@3412:
raimund@3610: private static final String I18N_ANALYSIS = "fix.analysis.short";
sascha@3412:
sascha@3412: private static final String I18N_DEVIATION = "fix.deviation";
sascha@3412:
sascha@3412: private static final String I18N_REFERENCEDEVIATION = "fix.reference.deviation";
sascha@3412:
christian@3907: private static final String I18N_REFERENCEPERIOD = "state.fix.analysis.referenceperiod";
christian@3907:
sascha@3412: public static final String [] SECTOR_LABELS = {
rrenkert@5380: "fix.mnq",
rrenkert@5380: "fix.mq",
rrenkert@5380: "fix.mhq",
rrenkert@5380: "fix.hq5"
sascha@3412: };
sascha@3412:
felix@4166: // TODO Why does this happen here? In other cases its implemented in the
felix@4166: // respective artifact, not State.
ingo@3785: static {
ingo@3785: // Active/deactivate facets.
ingo@3785: FacetActivity.Registry.getInstance().register(
ingo@3785: "fixanalysis",
ingo@3785: new FacetActivity() {
ingo@3785: @Override
ingo@3785: public Boolean isInitialActive(
ingo@3785: Artifact artifact,
ingo@3785: Facet facet,
ingo@3785: String output
ingo@3785: ) {
felix@4166: if (output.contains(FacetTypes.ChartType.FLSC.toString())) {
felix@4166: // Longitudinal section chart
christian@3913: String name = facet.getName();
ingo@3785:
christian@3913: if (name.contains(FacetTypes.FIX_ANALYSIS_EVENTS_DWT)
christian@3913: || name.contains(FacetTypes.FIX_ANALYSIS_EVENTS_LS)
christian@3913: || name.contains(FacetTypes.FIX_ANALYSIS_EVENTS_WQ)
christian@3913: || name.contains(FacetTypes.FIX_REFERENCE_EVENTS_DWT)
christian@3913: || name.contains(FacetTypes.FIX_REFERENCE_EVENTS_LS)
christian@3913: || name.contains(FacetTypes.FIX_REFERENCE_EVENTS_WQ)
christian@3913: ) {
christian@3913: return Boolean.FALSE;
christian@3913: }
ingo@3785: }
felix@4433: if (output.contains(FacetTypes.ChartType.FDWC.toString())
felix@4166: && facet.getName().contains(FacetTypes.FIX_SECTOR_AVERAGE_DWT)) {
felix@4166: return Boolean.FALSE;
felix@4166: }
ingo@3785:
ingo@3785: return Boolean.TRUE;
ingo@3785: }
ingo@3785: });
ingo@3785: }
ingo@3785:
sascha@3412: /**
sascha@3412: * The default constructor that initializes an empty State object.
sascha@3412: */
sascha@3412: public FixAnalysisCompute() {
sascha@3412: }
sascha@3412:
sascha@3412: @Override
sascha@3412: public Object computeAdvance(
sascha@3412: FLYSArtifact artifact,
sascha@3412: String hash,
sascha@3412: CallContext context,
sascha@3412: List facets,
sascha@3412: Object old
sascha@3412: ) {
sascha@3412: log.debug("FixAnalysisCompute.computeAdvance");
sascha@3412:
sascha@3412: CalculationResult res;
sascha@3412:
sascha@3412: FixAnalysisAccess access =
rrenkert@4866: new FixAnalysisAccess(artifact, context);
sascha@3412:
sascha@3412: if (old instanceof CalculationResult) {
sascha@3412: res = (CalculationResult)old;
sascha@3412: }
sascha@3412: else {
sascha@3412: FixAnalysisCalculation calc = new FixAnalysisCalculation(access);
sascha@3412: res = calc.calculate();
sascha@3412: }
sascha@3412:
sascha@3412: if (facets == null) {
sascha@3412: return res;
sascha@3412: }
sascha@3412:
sascha@3412: if (res.getReport().hasProblems()) {
sascha@3412: facets.add(new ReportFacet(ComputeType.ADVANCE, hash, id));
sascha@3412: }
sascha@3412:
sascha@3415: FixAnalysisResult fr = (FixAnalysisResult)res.getData();
sascha@3412: if (fr == null) {
sascha@3412: return res;
sascha@3412: }
sascha@3412:
sascha@3412: facets.add(
sascha@3412: new DataFacet(CSV, "CSV data", ComputeType.ADVANCE, hash, id));
sascha@3412: facets.add(
sascha@3412: new DataFacet(
sascha@3412: FIX_PARAMETERS, "parameters", ComputeType.ADVANCE, hash, id));
raimund@3599: facets.add(
raimund@3599: new DataFacet(AT, "AT data", ComputeType.ADVANCE, hash, id));
sascha@3412:
sascha@3412: int maxId = -100;
sascha@3412:
sascha@3412: int sectorMask = fr.getUsedSectorsInAnalysisPeriods();
sascha@3412:
sascha@3412: int qsS = access.getQSectorStart();
sascha@3412: int qsE = access.getQSectorEnd();
sascha@3412:
sascha@3412: // TODO: i18n
sascha@3412: DateFormat df = DateFormat.getDateInstance(DateFormat.MEDIUM);
sascha@3412:
sascha@3412: DateRange [] periods = access.getAnalysisPeriods();
sascha@3412:
sascha@3412: for (int i = 0; i < periods.length; i++) {
sascha@3412: DateRange period = periods[i];
sascha@3412: String startDate = df.format(period.getFrom());
sascha@3412: String endDate = df.format(period.getTo());
sascha@3412:
sascha@3412: for (int j = qsS; j <= qsE; j++) {
sascha@3412:
sascha@3412: // Only emit facets for sectors that really have data.
sascha@3412: if ((sectorMask & (1 << j)) == 0) {
sascha@3412: continue;
sascha@3412: }
sascha@3412:
sascha@3412: String sector = SECTOR_LABELS[j];
rrenkert@5380: String description = "\u0394W (" +
rrenkert@5380: Resources.getMsg(context.getMeta(),
rrenkert@5380: sector,
rrenkert@5380: sector) +
rrenkert@5380: ")";
sascha@3412:
sascha@3412: int sectorNdx = j - qsS;
sascha@3412: int facetNdx = i << 2;
sascha@3412: facetNdx = facetNdx | j;
sascha@3412:
sascha@3412: if (facetNdx > maxId) {
sascha@3412: maxId = facetNdx;
sascha@3412: }
sascha@3412:
sascha@3412: facets.add(
sascha@3412: new FixAvSectorFacet(
sascha@3412: facetNdx,
sascha@3412: FIX_SECTOR_AVERAGE_DWT + "_" + sectorNdx,
sascha@3412: description));
sascha@3412: facets.add(
raimund@3610: new FixLongitudinalAvSectorFacet(
sascha@3412: facetNdx,
sascha@3412: FIX_SECTOR_AVERAGE_LS + "_" + sectorNdx,
rrenkert@5380: description + ":" + startDate + " - " + endDate));
sascha@3412: // TODO: i18n
sascha@3412: String dev = "Abweichung: " + description;
sascha@3412: facets.add(
raimund@3610: new FixLongitudinalAvSectorFacet(
sascha@3412: facetNdx,
sascha@3412: FIX_SECTOR_AVERAGE_LS_DEVIATION + "_" + sectorNdx,
sascha@3412: dev));
sascha@3412: facets.add(
sascha@3412: new FixAvSectorFacet(
sascha@3412: facetNdx,
sascha@3412: FIX_SECTOR_AVERAGE_WQ + "_" + sectorNdx,
sascha@3412: description));
sascha@3412:
sascha@3412: }
sascha@3412:
sascha@3412: String eventDesc =
sascha@3412: Resources.getMsg(context.getMeta(),
sascha@3412: I18N_ANALYSIS,
raimund@3610: I18N_ANALYSIS);
raimund@3610:
raimund@3610: int k = 0;
raimund@3610: for (Date d: fr.getAnalysisEventsDates(i)) {
raimund@3610: int anaNdx = i << 8;
raimund@3610: anaNdx = anaNdx | k;
raimund@3610: facets.add(new FixAnalysisEventsFacet(anaNdx,
raimund@3610: FIX_ANALYSIS_EVENTS_DWT,
raimund@3610: eventDesc + (i+1) + " - " + df.format(d)));
raimund@3610: facets.add(new FixLongitudinalAnalysisFacet(anaNdx,
raimund@3610: FIX_ANALYSIS_EVENTS_LS,
raimund@3610: eventDesc + (i+1) + " - " + df.format(d)));
raimund@3610: facets.add(new FixAnalysisEventsFacet(anaNdx,
raimund@3610: FIX_ANALYSIS_EVENTS_WQ,
raimund@3610: eventDesc + (i+1) +" - " + df.format(d)));
raimund@3610: k++;
raimund@3610: }
sascha@3412: }
sascha@3412:
sascha@3412: IdGenerator idg = new IdGenerator(maxId + 1);
sascha@3412:
sascha@3412: String i18n_ref = Resources.getMsg(context.getMeta(),
christian@3907: I18N_REFERENCEPERIOD_SHORT,
christian@3907: I18N_REFERENCEPERIOD_SHORT);
sascha@3412: String i18n_dev = Resources.getMsg(context.getMeta(),
sascha@3412: I18N_REFERENCEDEVIATION,
sascha@3412: I18N_REFERENCEDEVIATION);
sascha@3412:
raimund@3610: int i = 0;
sascha@3730: for (Date d: fr.getReferenceEventsDates()) {
raimund@3610: int refNdx = idg.next() << 8;
raimund@3610: refNdx |= i;
raimund@3610: facets.add(new FixReferenceEventsFacet(refNdx,
raimund@3610: FIX_REFERENCE_EVENTS_DWT,
raimund@3610: i18n_ref + " - " + df.format(d)));
raimund@3610: refNdx = idg.next() << 8;
raimund@3610: refNdx = refNdx | i;
raimund@3610: facets.add(new FixLongitudinalReferenceFacet(refNdx,
raimund@3610: FIX_REFERENCE_EVENTS_LS,
raimund@3610: i18n_ref + " - " + df.format(d)));
raimund@3610: refNdx = idg.next() << 8;
raimund@3610: refNdx |= i;
raimund@3610: facets.add(new FixReferenceEventsFacet(refNdx,
raimund@3610: FIX_REFERENCE_EVENTS_WQ,
raimund@3610: i18n_ref + " - " + df.format(d)));
raimund@3610: i++;
raimund@3610: }
sascha@3412:
sascha@3412:
sascha@3412: facets.add(new FixLongitudinalDeviationFacet(idg.next(),
sascha@3412: FIX_DEVIATION_LS,
sascha@3412: i18n_dev));
sascha@3412:
sascha@3412: String i18n_ana = Resources.getMsg(context.getMeta(),
sascha@3412: I18N_ANALYSISPERIODS,
sascha@3412: I18N_ANALYSISPERIODS);
sascha@3412: facets.add(new FixAnalysisPeriodsFacet(idg.next(),
sascha@3412: FIX_ANALYSIS_PERIODS_DWT,
sascha@3412: i18n_ana));
sascha@3412: facets.add(new FixAnalysisPeriodsFacet(idg.next(),
sascha@3412: FIX_ANALYSIS_PERIODS_LS,
sascha@3412: i18n_ana));
sascha@3412: facets.add(new FixAnalysisPeriodsFacet(idg.next(),
sascha@3412: FIX_ANALYSIS_PERIODS_WQ,
sascha@3412: i18n_ana));
sascha@3412:
christian@3907: String i18n_refp = Resources.getMsg(context.getMeta(),
christian@3907: I18N_REFERENCEPERIOD,
christian@3907: I18N_REFERENCEPERIOD);
christian@3907: facets.add(new DataFacet(idg.next(),
christian@3907: FIX_REFERENCE_PERIOD_DWT,
christian@3907: i18n_refp,
christian@3907: ComputeType.ADVANCE, null, null));
sascha@3412:
sascha@3412: facets.add(new FixWQCurveFacet(idg.next(), "W/Q"));
sascha@3412:
sascha@3412: Boolean preprocessing = access.getPreprocessing();
sascha@3412:
sascha@3412: if (preprocessing != null && preprocessing) {
sascha@3412: facets.add(new FixOutlierFacet(
sascha@3412: idg.next(),
sascha@3412: FIX_OUTLIER,
sascha@3412: Resources.getMsg(
sascha@3412: context.getMeta(), I18N_OUTLIER, I18N_OUTLIER)));
sascha@3412: }
sascha@3412:
sascha@3412: facets.add(new FixDerivateFacet(
sascha@3412: idg.next(),
christian@3917: FIX_DERIVATE_CURVE,
sascha@3412: Resources.getMsg(
sascha@3412: context.getMeta(),
sascha@3412: I18N_DERIVATIVE,
sascha@3412: I18N_DERIVATIVE)));
sascha@3412:
sascha@3412: facets.add(new FixDeviationFacet(
sascha@3412: idg.next(),
sascha@3412: FIX_DEVIATION_DWT,
sascha@3412: Resources.getMsg(context.getMeta(),
sascha@3412: I18N_DEVIATION,
sascha@3412: I18N_DEVIATION)));
sascha@3412: return res;
sascha@3412: }
sascha@3412: }
sascha@3412: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :