view artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/common/D50Processor.java @ 8964:45f1ad66560e

Code cleanup concerning calculations: improved error handling; improved interpolation; bed heights are now always used for spatial discretisation
author gernotbelger
date Thu, 29 Mar 2018 15:48:17 +0200
parents ee5ce13016ed
children b194fa64506a
line wrap: on
line source
/* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
 * Software engineering by
 *  Björnsen Beratende Ingenieure GmbH
 *  Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
 *
 * 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.common;

import java.util.HashSet;
import java.util.Set;

import org.dive4elements.artifactdatabase.state.Facet;
import org.dive4elements.artifacts.CallContext;

public final class D50Processor extends AbstractSInfoLineProcessor<AbstractTkhCalculationResult> {

    // FIXME: check: filtered or not?
    public static final String FACET_TKH_D50_FILTERED = "sinfo_facet_d50.filtered";

    private static final String I18N_AXIS_LABEL = "sinfo.chart.tkh_d50.section.yaxis.label";

    private static final String SINFO_CHART_D50_YAXIS_LABEL = "sinfo.chart.tkh_d50.yaxis.label";

    private static final String I18N_FACET_TKH_D50_FILTERED_DESCRIPTION = "sinfo.facet.tkh_d50.filtered.description";

    private static final Set<String> HANDLED_FACET_TYPES = new HashSet<>();

    static {
        HANDLED_FACET_TYPES.add(FACET_TKH_D50_FILTERED);
    }

    public D50Processor() {
        super(I18N_AXIS_LABEL, HANDLED_FACET_TYPES);
    }

    @Override
    protected double[][] doGetPoints(final AbstractTkhCalculationResult data, final String facetName) {

        if (FACET_TKH_D50_FILTERED.contentEquals(facetName))
            return data.getStationPoints(SInfoResultType.d50);

        final String error = String.format("Unknown facet name: %s", facetName);
        throw new UnsupportedOperationException(error);
    }

    public static Facet createD50Facet(final CallContext context, final String hash, final String id, final AbstractSInfoCalculationResult result,
            final int index) {
        return AbstractSInfoLineProcessor.createFacet(context, hash, id, result, index, SINFO_CHART_D50_YAXIS_LABEL, FACET_TKH_D50_FILTERED,
                I18N_FACET_TKH_D50_FILTERED_DESCRIPTION);
    }
}

http://dive4elements.wald.intevation.org