view artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkh/TkhState.java @ 8914:e3519c3e7a0a

Workflow for SINFO-Transport bodies heights inclduing winfo calculation
author gernotbelger
date Tue, 27 Feb 2018 18:06:52 +0100
parents
children
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
 * Software engineering by Intevation GmbH
 *
 * This file is Free Software under the GNU AGPL (>=v3)
 * and comes with ABSOLUTELY NO WARRANTY! Check out the
 * documentation coming with Dive4Elements River for details.
 */

package org.dive4elements.river.artifacts.sinfo.tkh;

import java.util.List;

import org.dive4elements.artifactdatabase.state.Facet;
import org.dive4elements.artifacts.CallContext;
import org.dive4elements.river.artifacts.ChartArtifact;
import org.dive4elements.river.artifacts.D4EArtifact;
import org.dive4elements.river.artifacts.WINFOArtifact;
import org.dive4elements.river.artifacts.model.Calculation;
import org.dive4elements.river.artifacts.model.CalculationResult;
import org.dive4elements.river.artifacts.model.EmptyFacet;
import org.dive4elements.river.artifacts.model.WQKms;
import org.dive4elements.river.artifacts.sinfo.SINFOArtifact;
import org.dive4elements.river.artifacts.states.DefaultState;

/** State in which a waterlevel has been calculated. */
public class TkhState extends DefaultState {

    /// ** The log that is used in this state. */
    // private static Logger log = Logger.getLogger(FlowDepthState.class);

    private static final long serialVersionUID = 1L;

    private static final String I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION = "sinfo.facet.flow_depth.filtered.description";

    private static final String I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION = "sinfo.facet.flow_depth.tkh.filtered.description";

    private static final String I18N_FACET_TKH_DESCRIPTION = "sinfo.facet.tkh.description";

    private static final String SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL = "sinfo.chart.flow_depth.yaxis.label";

    private static final String SINFO_CHART_TKX_YAXIS_LABEL = "sinfo.chart.tkh.yaxis.label";

    /**
     * From this state can only be continued trivially.
     */
    @Override
    protected String getUIProvider() {
        return "continue";
    }

    @Override
    public Object computeFeed(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) {
        // FIXME: why is this necessary?
        if (artifact instanceof ChartArtifact) {
            facets.add(new EmptyFacet());
            return null;
        }

        return compute((SINFOArtifact) artifact, context, hash, facets, old);
    }

    @Override
    public Object computeAdvance(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) {
        if (artifact instanceof ChartArtifact) {
            facets.add(new EmptyFacet());
            return null;
        }
        return compute((SINFOArtifact) artifact, context, hash, facets, old);
    }

    /**
     * Compute result or returned object from cache, create facets.
     *
     * @param old
     *            Object that was cached.
     */
    private Object compute(final SINFOArtifact sinfo, final CallContext context, final String hash, final List<Facet> facets, final Object old) {

        final CalculationResult res = doCompute(sinfo, context, old);

        if (facets == null)
            return res;

        // final FlowDepthCalculationResults results = (FlowDepthCalculationResults) res.getData();
        //
        // /* add themes for chart, for each result */
        // final List<FlowDepthCalculationResult> resultList = results.getResults();
        // for (int index = 0; index < resultList.size(); index++) {
        //
        // final FlowDepthCalculationResult result = resultList.get(index);
        //
        // /* filtered (zoom dependent mean) flow depth */
        // final String facetFlowDepthFilteredDescription = Resources.getMsg(context.getMeta(),
        // I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION,
        // I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION, result.getLabel());
        // facets.add(new FlowDepthFacet(index, FlowDepthProcessor.FACET_FLOW_DEPTH_FILTERED, facetFlowDepthFilteredDescription,
        // SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL, ComputeType.ADVANCE, this.id, hash));
        //
        // if (results.isUseTkh()) {
        // /* filtered (zoom dependent mean) flow depth including tkh */
        // final String facetFlowDepthTkhFilteredDescription = Resources.getMsg(context.getMeta(),
        // I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION,
        // I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION, result.getLabel());
        // facets.add(new FlowDepthFacet(index, FlowDepthProcessor.FACET_FLOW_DEPTH_TKH_FILTERED,
        // facetFlowDepthTkhFilteredDescription,
        // SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL, ComputeType.ADVANCE, this.id, hash));
        //
        // // FIXME: add other themes
        // // - Streckenfavoriten
        //
        // // FIXME:
        // // - Gemittelte Linie der Fließtiefe mitsamt TKH
        // // - Transportkörperhöhen (oben/unten/schraffur)
        // final String facetTkhDescription = Resources.getMsg(context.getMeta(), I18N_FACET_TKH_DESCRIPTION,
        // I18N_FACET_TKH_DESCRIPTION,
        // result.getLabel());
        // facets.add(new FlowDepthFacet(index, TkhProcessor.FACET_TKH, facetTkhDescription, SINFO_CHART_TKX_YAXIS_LABEL,
        // ComputeType.ADVANCE, this.id,
        // hash));
        // }
        //
        // // FIXME: Datenkorbkonfiguration
        // }
        //
        // if (!resultList.isEmpty()) {
        // final Facet csv = new DataFacet(FacetTypes.CSV, "CSV data", ComputeType.ADVANCE, hash, this.id);
        // final Facet pdf = new DataFacet(FacetTypes.PDF, "PDF data", ComputeType.ADVANCE, hash, this.id);
        //
        // facets.add(csv);
        // facets.add(pdf);
        // }
        //
        // final Calculation report = res.getReport();
        //
        // if (report.hasProblems()) {
        // facets.add(new ReportFacet(ComputeType.ADVANCE, hash, this.id));
        // }
        //
        // return res;
        return null;
    }

    private CalculationResult doCompute(final SINFOArtifact sinfo, final CallContext context, final Object old) {
        if (old instanceof CalculationResult)
            return (CalculationResult) old;

        // res = new FlowDepthCalculation(context).calculate(sinfo);

        final WINFOArtifact winfo = new WinfoArtifactWrapper(sinfo);

        final CalculationResult waterlevelData = winfo.getWaterlevelData(context);
        final Calculation winfoProblems = waterlevelData.getReport();

        final WQKms[] kms = (WQKms[]) waterlevelData.getData();

        final Object result = new Object();
        final Calculation problems = new Calculation();

        return new CalculationResult(result, problems);
    }
}

http://dive4elements.wald.intevation.org