gernotbelger@8996: /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde gernotbelger@9069: * Software engineering by gernotbelger@9069: * Björnsen Beratende Ingenieure GmbH gernotbelger@8996: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt gernotbelger@8996: * gernotbelger@8996: * This file is Free Software under the GNU AGPL (>=v3) gernotbelger@8996: * and comes with ABSOLUTELY NO WARRANTY! Check out the gernotbelger@8996: * documentation coming with Dive4Elements River for details. gernotbelger@8996: */ gernotbelger@8996: package org.dive4elements.river.artifacts.uinfo.inundationduration; gernotbelger@8996: gernotbelger@8996: import java.util.ArrayList; gernotbelger@8996: import java.util.Collection; gernotbelger@9070: import java.util.List; gernotbelger@8996: gernotbelger@8996: import org.apache.commons.lang.math.DoubleRange; gernotbelger@8996: import org.dive4elements.artifacts.CallContext; gernotbelger@8996: import org.dive4elements.river.artifacts.access.RiverAccess; gernotbelger@8996: import org.dive4elements.river.artifacts.common.ResultRow; gernotbelger@8996: import org.dive4elements.river.artifacts.model.Calculation; gernotbelger@8996: import org.dive4elements.river.artifacts.model.CalculationResult; gernotbelger@8996: import org.dive4elements.river.artifacts.resources.Resources; gernotbelger@8996: import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType; gernotbelger@8996: import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils; gernotbelger@8996: import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; gernotbelger@8996: import org.dive4elements.river.artifacts.uinfo.UINFOArtifact; gernotbelger@9118: import org.dive4elements.river.artifacts.uinfo.vegetationzones.VegetationZone; gernotbelger@8996: import org.dive4elements.river.model.River; gernotbelger@8996: gernotbelger@8996: /** gernotbelger@8996: * @author Domenico Nardi Tironi gernotbelger@8996: * gernotbelger@8996: */ gernotbelger@8996: final class InundationDurationCalculation { gernotbelger@8996: gernotbelger@9069: private final CallContext context; gernotbelger@8996: gernotbelger@9069: public InundationDurationCalculation(final CallContext context) { gernotbelger@8996: this.context = context; gernotbelger@8996: } gernotbelger@8996: gernotbelger@9069: public CalculationResult calculate(final UINFOArtifact uinfo) { gernotbelger@8996: final Calculation problems = new Calculation(); gernotbelger@8996: gernotbelger@8996: final String calcModeLabel = Resources.getMsg(this.context.getMeta(), uinfo.getCalculationMode().name()); gernotbelger@8996: final String user = CalculationUtils.findArtifactUser(this.context, uinfo); gernotbelger@8996: gernotbelger@8996: final RiverAccess access = new RiverAccess(uinfo); gernotbelger@9069: gernotbelger@9069: final InundationDurationAccess indurax = new InundationDurationAccess(uinfo); gernotbelger@9070: final River river = indurax.getRiver(); gernotbelger@9070: final RiverInfo riverInfo = new RiverInfo(river); gernotbelger@9070: final DoubleRange calcRange = indurax.getRange(); gernotbelger@9069: final int[] totalEpoch = indurax.getTotalEpoch(); gernotbelger@9069: final Integer year = indurax.getYear(); // null bei year -> Integer.. evtl ungünstig.. evtl. anders lösen gernotbelger@9069: final DoubleRange range = indurax.getRange(); gernotbelger@9069: final Double sedimentHeight = indurax.getSedimentHeight(); gernotbelger@9070: final String zonesRaw = indurax.getVegZones(); gernotbelger@9118: final List zones = VegetationZone.parse(zonesRaw); gernotbelger@9069: gernotbelger@8996: final InundationDurationCalculationResults results = new InundationDurationCalculationResults(calcModeLabel, user, riverInfo, calcRange); gernotbelger@8996: gernotbelger@9069: final Collection rows = new ArrayList<>(); gernotbelger@9069: gernotbelger@9069: final ResultRow row1 = ResultRow.create(). // gernotbelger@8996: putValue(SInfoResultType.discharge, 100). // gernotbelger@9069: putValue(SInfoResultType.waterlevel, 2). // gernotbelger@9069: putValue(SInfoResultType.gaugeLabel, "Torgau"); gernotbelger@8996: gernotbelger@8996: rows.add(row1); gernotbelger@8996: gernotbelger@9069: final ResultRow row2 = ResultRow.create(). // gernotbelger@8996: putValue(SInfoResultType.discharge, 200). // gernotbelger@8996: putValue(SInfoResultType.waterlevel, 3). // gernotbelger@8996: putValue(SInfoResultType.gaugeLabel, "Zollenspieker"); gernotbelger@8996: gernotbelger@8996: rows.add(row2); gernotbelger@8996: gernotbelger@8996: final InundationDurationCalculationResult result = new InundationDurationCalculationResult("Ergebnis 1", null, rows); gernotbelger@9069: gernotbelger@8996: results.addResult(result, problems); gernotbelger@9069: gernotbelger@8996: return new CalculationResult(results, problems); gernotbelger@8996: } gernotbelger@8996: }