mschaefer@9202: /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde mschaefer@9202: * Software engineering by mschaefer@9202: * Björnsen Beratende Ingenieure GmbH mschaefer@9202: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt mschaefer@9202: * mschaefer@9202: * This file is Free Software under the GNU AGPL (>=v3) mschaefer@9202: * and comes with ABSOLUTELY NO WARRANTY! Check out the mschaefer@9202: * documentation coming with Dive4Elements River for details. mschaefer@9202: */ mschaefer@9202: mschaefer@9202: package org.dive4elements.river.artifacts.sinfo.common; mschaefer@9202: mschaefer@9202: import java.util.HashSet; mschaefer@9202: import java.util.Set; mschaefer@9202: mschaefer@9202: import org.dive4elements.artifactdatabase.state.Facet; mschaefer@9202: import org.dive4elements.artifacts.CallContext; mschaefer@9202: import org.dive4elements.river.artifacts.common.AbstractCalculationResult; mschaefer@9202: import org.dive4elements.river.artifacts.resources.Resources; mschaefer@9202: import org.dive4elements.river.artifacts.sinfo.flood_duration.FloodDurationCalculationResult; mschaefer@9202: import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; mschaefer@9202: import org.dive4elements.river.exports.LongitudinalSectionGenerator; mschaefer@9202: mschaefer@9202: /** mschaefer@9202: * Processor to generate the facet and data series of infrastructure flood heights mschaefer@9202: * mschaefer@9202: * @author Matthias Schäfer mschaefer@9202: * mschaefer@9202: */ mschaefer@9202: public final class FloodHeightProcessor extends AbstractSInfoLineProcessor { mschaefer@9202: mschaefer@9202: public static final String FACET_FLOOD_HEIGHT = "sinfo_facet_flood_height"; mschaefer@9202: mschaefer@9202: public static final String FACET_FLOOD_HEIGHT_DESCRIPTION = "sinfo_facet_flood_height.description"; mschaefer@9202: mschaefer@9202: public static final String FACET_MAIN_VALUE_1_HEIGHT = "mainvalue.1.w"; mschaefer@9202: mschaefer@9202: public static final String FACET_MAIN_VALUE_2_HEIGHT = "mainvalue.2.w"; mschaefer@9202: mschaefer@9202: public static final String FACET_MAIN_VALUE_3_HEIGHT = "mainvalue.3.w"; mschaefer@9202: mschaefer@9202: public static final String FACET_MAIN_VALUE_HEIGHT_DESCRIPTION = "mainvalue.w.description"; mschaefer@9202: mschaefer@9202: private static final String I18N_AXIS_LABEL = LongitudinalSectionGenerator.I18N_YAXIS_LABEL; mschaefer@9202: mschaefer@9202: private static final Set HANDLED_FACET_TYPES = new HashSet<>(); mschaefer@9202: mschaefer@9202: static { mschaefer@9202: HANDLED_FACET_TYPES.add(FACET_FLOOD_HEIGHT); mschaefer@9202: HANDLED_FACET_TYPES.add(FACET_MAIN_VALUE_1_HEIGHT); mschaefer@9202: HANDLED_FACET_TYPES.add(FACET_MAIN_VALUE_2_HEIGHT); mschaefer@9202: HANDLED_FACET_TYPES.add(FACET_MAIN_VALUE_3_HEIGHT); mschaefer@9202: } mschaefer@9202: mschaefer@9202: public FloodHeightProcessor() { mschaefer@9202: super(I18N_AXIS_LABEL, HANDLED_FACET_TYPES); mschaefer@9202: } mschaefer@9202: mschaefer@9202: mschaefer@9202: @Override mschaefer@9202: protected double[][] doGetPoints(final AbstractCalculationResult data, final String facetName) { mschaefer@9202: if (FACET_FLOOD_HEIGHT.contentEquals(facetName)) mschaefer@9202: return ((FloodDurationCalculationResult) data).fetchInfrastructurePoints(SInfoResultType.infrastructureHeight); mschaefer@9202: mschaefer@9202: if (FACET_MAIN_VALUE_1_HEIGHT.contentEquals(facetName)) mschaefer@9202: return ((FloodDurationCalculationResult) data).fetchMainValuePoints(SInfoResultType.waterlevel1); mschaefer@9202: mschaefer@9202: if (FACET_MAIN_VALUE_2_HEIGHT.contentEquals(facetName)) mschaefer@9202: return ((FloodDurationCalculationResult) data).fetchMainValuePoints(SInfoResultType.waterlevel2); mschaefer@9202: mschaefer@9202: if (FACET_MAIN_VALUE_3_HEIGHT.contentEquals(facetName)) mschaefer@9202: return ((FloodDurationCalculationResult) data).fetchMainValuePoints(SInfoResultType.waterlevel3); mschaefer@9202: mschaefer@9202: final String error = String.format("Unknown facet name: %s", facetName); mschaefer@9202: throw new UnsupportedOperationException(error); mschaefer@9202: } mschaefer@9202: mschaefer@9202: public static Facet createFloodHeightFacet(final CallContext context, final String hash, final String id, mschaefer@9202: final AbstractCalculationResult result, final int index) { mschaefer@9202: return AbstractSInfoLineProcessor.createFacet(context, hash, id, result, index, I18N_AXIS_LABEL, mschaefer@9202: FACET_FLOOD_HEIGHT, FACET_FLOOD_HEIGHT_DESCRIPTION); mschaefer@9202: } mschaefer@9202: mschaefer@9202: public static Facet createMainValueHeightFacet(final CallContext context, final String hash, final String id, mschaefer@9202: final FloodDurationCalculationResult result, final int index) { mschaefer@9202: final String description = Resources.getMsg(context.getMeta(), FACET_MAIN_VALUE_HEIGHT_DESCRIPTION, FACET_MAIN_VALUE_HEIGHT_DESCRIPTION, mschaefer@9202: result.getMainValueLabel(index)); mschaefer@9202: assert ((index >= 0) && (index <= 2)); mschaefer@9202: final String facetName = new String[] { FACET_MAIN_VALUE_1_HEIGHT, FACET_MAIN_VALUE_2_HEIGHT, FACET_MAIN_VALUE_3_HEIGHT }[index]; mschaefer@9202: return new SInfoResultFacet(0, facetName, description, I18N_AXIS_LABEL, ComputeType.ADVANCE, id, hash); mschaefer@9202: } mschaefer@9202: }