gernotbelger@9067: /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde gernotbelger@9067: * Software engineering by gernotbelger@9067: * Björnsen Beratende Ingenieure GmbH gernotbelger@9067: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt gernotbelger@9067: * gernotbelger@9067: * This file is Free Software under the GNU AGPL (>=v3) gernotbelger@9067: * and comes with ABSOLUTELY NO WARRANTY! Check out the gernotbelger@9067: * documentation coming with Dive4Elements River for details. gernotbelger@9067: */ gernotbelger@9067: package org.dive4elements.river.artifacts.sinfo.flood_duration; gernotbelger@9067: gernotbelger@9067: import org.apache.commons.lang.math.DoubleRange; gernotbelger@9067: import org.dive4elements.artifacts.CallContext; gernotbelger@9067: import org.dive4elements.river.artifacts.model.Calculation; gernotbelger@9067: import org.dive4elements.river.artifacts.model.CalculationResult; gernotbelger@9067: import org.dive4elements.river.artifacts.resources.Resources; gernotbelger@9067: import org.dive4elements.river.artifacts.sinfo.SINFOArtifact; gernotbelger@9067: import org.dive4elements.river.artifacts.sinfo.common.RiverInfoProvider; gernotbelger@9145: import org.dive4elements.river.artifacts.sinfo.tkhstate.WinfoArtifactWrapper; gernotbelger@9067: import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils; gernotbelger@9067: import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; gernotbelger@9145: import org.dive4elements.river.artifacts.sinfo.util.WstInfo; gernotbelger@9067: import org.dive4elements.river.model.River; gernotbelger@9067: gernotbelger@9067: class FloodDurationCalculation { gernotbelger@9067: gernotbelger@9067: // private static Logger log = Logger.getLogger(FloodDurationCalculation.class); gernotbelger@9067: gernotbelger@9067: private final CallContext context; gernotbelger@9067: gernotbelger@9067: public FloodDurationCalculation(final CallContext context) { gernotbelger@9067: this.context = context; gernotbelger@9067: } gernotbelger@9067: gernotbelger@9067: public CalculationResult calculate(final SINFOArtifact sinfo) { gernotbelger@9067: gernotbelger@9067: final String user = CalculationUtils.findArtifactUser(this.context, sinfo); gernotbelger@9067: gernotbelger@9067: /* access input data */ gernotbelger@9067: final FloodDurationAccess access = new FloodDurationAccess(sinfo); gernotbelger@9067: final River river = access.getRiver(); gernotbelger@9067: final RiverInfo riverInfo = new RiverInfo(river); gernotbelger@9067: gernotbelger@9067: final DoubleRange calcRange = access.getRange(); gernotbelger@9067: gernotbelger@9067: /* calculate results for each diff pair */ gernotbelger@9067: final Calculation problems = new Calculation(); gernotbelger@9067: gernotbelger@9067: final RiverInfoProvider infoProvider = RiverInfoProvider.forRange(this.context, river, calcRange); gernotbelger@9067: gernotbelger@9067: final String calcModeLabel = Resources.getMsg(this.context.getMeta(), sinfo.getCalculationMode().name()); gernotbelger@9067: gernotbelger@9067: final String riverside = access.getRiverside(); gernotbelger@9145: final FloodDurationCalculationResults results = new FloodDurationCalculationResults(calcModeLabel, user, riverInfo, calcRange, riverside); // TODO: add gernotbelger@9145: // more gernotbelger@9070: // TODO: mis- ups.. re-use WINFO Artifact as in TkhState gernotbelger@9145: final WinfoArtifactWrapper winfo = new WinfoArtifactWrapper(sinfo); gernotbelger@9145: // winfo.computeWaterlevelData(); gernotbelger@9145: final FloodDurationCalculationResult result = calculateResult(calcRange, infoProvider, problems); gernotbelger@9070: gernotbelger@9145: results.addResult(result, problems); gernotbelger@9067: gernotbelger@9145: return new CalculationResult(results, problems); gernotbelger@9145: } gernotbelger@9145: gernotbelger@9145: /** gernotbelger@9145: * Calculates FAKE Flood Duration gernotbelger@9145: * gernotbelger@9145: * @param infoProvider gernotbelger@9145: */ gernotbelger@9145: private FloodDurationCalculationResult calculateResult(final DoubleRange calcRange, final RiverInfoProvider riverInfoProvider, final Calculation problems) { gernotbelger@9145: gernotbelger@9145: final FloodDurationCalculator calculator = new FloodDurationCalculator(riverInfoProvider); gernotbelger@9145: final String wspLabel = "WSP-Name";// wstKms.getName(); gernotbelger@9145: final int wspYear = 9999; // waterlevel.getYear(); gernotbelger@9145: final WstInfo wstInfo = new WstInfo(wspLabel, wspYear, riverInfoProvider.getReferenceGauge()); gernotbelger@9145: final String label = String.format("%s - %s", wspLabel, " soundingLabel"); gernotbelger@9145: return calculator.execute(label, wstInfo, calcRange); gernotbelger@9067: } gernotbelger@9067: gernotbelger@9067: }