mschaefer@9252: /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde mschaefer@9252: * Software engineering by mschaefer@9252: * Björnsen Beratende Ingenieure GmbH mschaefer@9252: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt mschaefer@9252: * mschaefer@9252: * This file is Free Software under the GNU AGPL (>=v3) mschaefer@9252: * and comes with ABSOLUTELY NO WARRANTY! Check out the mschaefer@9252: * documentation coming with Dive4Elements River for details. mschaefer@9252: */ mschaefer@9252: mschaefer@9252: package org.dive4elements.river.artifacts.sinfo.flood_duration; mschaefer@9252: mschaefer@9252: import java.util.HashSet; mschaefer@9252: import java.util.Set; mschaefer@9252: mschaefer@9252: import org.dive4elements.artifactdatabase.state.Facet; mschaefer@9252: import org.dive4elements.artifacts.CallContext; mschaefer@9252: import org.dive4elements.river.artifacts.common.AbstractCalculationResult; mschaefer@9259: import org.dive4elements.river.artifacts.model.FacetTypes; mschaefer@9252: import org.dive4elements.river.exports.DiagramGenerator; mschaefer@9252: import org.dive4elements.river.exports.DurationCurveGenerator; mschaefer@9252: import org.dive4elements.river.exports.process.DefaultProcessor; mschaefer@9376: import org.dive4elements.river.model.Attribute.AttributeKey; mschaefer@9252: mschaefer@9252: /** mschaefer@9252: * Processor to generate the facet and data series of a flood duration curve mschaefer@9252: * mschaefer@9252: * @author Matthias Schäfer mschaefer@9252: * mschaefer@9252: */ mschaefer@9252: public final class FloodDurationCurveProcessor extends DefaultProcessor { mschaefer@9252: mschaefer@9259: private static final String FACET_FLOOD_DURATION_W = FacetTypes.DURATION_W; // "duration_curve.w"; mschaefer@9252: mschaefer@9259: private static final String FACET_FLOOD_DURATION_Q = FacetTypes.DURATION_Q; // "duration_curve.q"; mschaefer@9252: mschaefer@9259: public static final String FACET_FLOOD_DURATION_MAINVALUES_W = "sinfo.mainvalues.w"; mschaefer@9257: mschaefer@9259: public static final String FACET_FLOOD_DURATION_MAINVALUES_Q = "sinfo.mainvalues.q"; mschaefer@9259: mschaefer@9376: public static final String FACET_FLOOD_DURATION_INFRASTRUCTURE_W_LEFT = "infrastructure.w.left"; mschaefer@9376: mschaefer@9376: public static final String FACET_FLOOD_DURATION_INFRASTRUCTURE_W_RIGHT = "infrastructure.w.right"; mschaefer@9376: mschaefer@9376: public static final String FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_LEFT = "infrastructure.q.left"; mschaefer@9376: mschaefer@9376: public static final String FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_RIGHT = "infrastructure.q.right"; mschaefer@9257: mschaefer@9252: private static final Set HANDLED_FACET_TYPES = new HashSet<>(); mschaefer@9252: mschaefer@9252: static { mschaefer@9252: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_W); mschaefer@9252: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_Q); mschaefer@9257: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_MAINVALUES_W); mschaefer@9257: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_MAINVALUES_Q); mschaefer@9376: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_LEFT); mschaefer@9376: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_RIGHT); mschaefer@9376: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_LEFT); mschaefer@9376: HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_RIGHT); mschaefer@9376: } mschaefer@9376: mschaefer@9376: public static boolean isInfrastructureFacet(final String name) { mschaefer@9376: return name.equals(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_LEFT) || name.equals(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_RIGHT) mschaefer@9376: || name.equals(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_LEFT) || name.equals(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_RIGHT); mschaefer@9252: } mschaefer@9252: mschaefer@9252: public static Facet createFloodDurationWCurveFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, mschaefer@9252: final int facetIndex, final int resultIndex, final String description) { mschaefer@9252: mschaefer@9252: return new FloodDurationCurveFacet(FACET_FLOOD_DURATION_W, description); mschaefer@9252: } mschaefer@9252: mschaefer@9252: public static Facet createFloodDurationQCurveFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, mschaefer@9252: final int facetIndex, final int resultIndex, final String description) { mschaefer@9252: mschaefer@9252: return new FloodDurationCurveFacet(FACET_FLOOD_DURATION_Q, description); mschaefer@9252: } mschaefer@9252: mschaefer@9257: public static Facet createMainValuesWFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, mschaefer@9257: final int facetIndex, final int resultIndex, final String description) { mschaefer@9257: mschaefer@9257: return new FloodDurationMainValuesWFacet(FACET_FLOOD_DURATION_MAINVALUES_W, description); mschaefer@9257: } mschaefer@9257: mschaefer@9257: public static Facet createMainValuesQFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, mschaefer@9257: final int facetIndex, final int resultIndex, final String description) { mschaefer@9257: mschaefer@9257: return new FloodDurationMainValuesQFacet(FACET_FLOOD_DURATION_MAINVALUES_Q, description); mschaefer@9257: } mschaefer@9257: mschaefer@9376: public static Facet createInfrastructureFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, mschaefer@9376: final int facetIndex, final int resultIndex, final String description, final AttributeKey riverside, final boolean isW) { mschaefer@9252: mschaefer@9376: if (riverside == AttributeKey.LEFT) { mschaefer@9376: if (isW) mschaefer@9376: return new FloodDurationInfrastructureFacet(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_LEFT, description, riverside, isW); mschaefer@9376: else mschaefer@9376: return new FloodDurationInfrastructureFacet(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_LEFT, description, riverside, isW); mschaefer@9376: } mschaefer@9376: else { mschaefer@9376: if (isW) mschaefer@9376: return new FloodDurationInfrastructureFacet(FACET_FLOOD_DURATION_INFRASTRUCTURE_W_RIGHT, description, riverside, isW); mschaefer@9376: else mschaefer@9376: return new FloodDurationInfrastructureFacet(FACET_FLOOD_DURATION_INFRASTRUCTURE_Q_RIGHT, description, riverside, isW); mschaefer@9376: } mschaefer@9252: } mschaefer@9252: mschaefer@9252: @Override mschaefer@9252: public final String getAxisLabel(final DiagramGenerator generator) { mschaefer@9252: return generator.msg(DurationCurveGenerator.I18N_YAXIS_LABEL_W); mschaefer@9252: } mschaefer@9252: mschaefer@9252: @Override mschaefer@9252: public final boolean canHandle(final String facettype) { mschaefer@9252: return HANDLED_FACET_TYPES.contains(facettype); mschaefer@9252: } mschaefer@9252: }