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@9067: import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils; gernotbelger@9067: import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; 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@9070: gernotbelger@9070: // TODO: mis- ups.. re-use WINFO Artifact as in TkhState gernotbelger@9070: gernotbelger@9067: final double step = access.getStep(); gernotbelger@9067: final boolean wspl = access.getWspl(); gernotbelger@9067: final Boolean wqisfree = access.getWqIsFree(); gernotbelger@9067: final Boolean wqIsQ = access.getWqIsQ(); gernotbelger@9067: final Boolean wqIsRange = access.getWqIsRange(); gernotbelger@9067: final Double wqFrom = access.getWqFrom(); gernotbelger@9067: final Double wqTo = access.getWqTo(); gernotbelger@9067: final Double wqStep = access.getWqStep(); gernotbelger@9067: final double[] wqSingle = access.getWqSingle(); gernotbelger@9067: gernotbelger@9067: return null; // new CalculationResult(results, problems); gernotbelger@9067: } gernotbelger@9067: gernotbelger@9067: }