/* * JGrass - Free Open Source Java GIS http://www.jgrass.org * (C) HydroloGIS - www.hydrologis.com * * This library is free software; you can redistribute it and/or modify it under * the terms of the GNU Library General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) any * later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more * details. * * You should have received a copy of the GNU Library General Public License * along with this library; if not, write to the Free Foundation, Inc., 59 * Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package org.jgrasstools.hortonmachine.modules.hydrogeomorphology.adige.core; import java.io.PrintStream; import java.text.MessageFormat; import java.util.HashMap; import org.jgrasstools.gears.libs.modules.JGTConstants; import org.jgrasstools.gears.libs.monitor.IJGTProgressMonitor; /** * Utility class for handling of Offtakes mappings and data retrival. * * @author Andrea Antonello (www.hydrologis.com) */ public class Offtakes implements IDischargeContributor { private final HashMap<String, Integer> offtakes_pfaff2idMap; private HashMap<Integer, double[]> offtakes_id2valuesQMap; private final IJGTProgressMonitor out; private String pNum; /** * Constructor. * * @param offtakes_pfaff2idMap {@link HashMap map} of pfafstetter numbers versus * offtakes points id. * @param out {@link PrintStream} for warning handling. */ public Offtakes( HashMap<String, Integer> offtakes_pfaff2idMap, IJGTProgressMonitor out ) { this.offtakes_pfaff2idMap = offtakes_pfaff2idMap; this.out = out; } public Double getDischarge( String pNum ) { this.pNum = pNum; Integer damId = offtakes_pfaff2idMap.get(pNum); if (damId != null) { double[] discharges = offtakes_id2valuesQMap.get(damId); return discharges[0]; } return JGTConstants.doubleNovalue; } public void setCurrentData( HashMap<Integer, double[]> currentDataMap ) { offtakes_id2valuesQMap = currentDataMap; } public double mergeWithDischarge( double contributorDischarge, double inputDischarge ) { if (inputDischarge >= contributorDischarge) { return inputDischarge - contributorDischarge; } else { out.errorMessage(MessageFormat .format("WARNING: offtake discharge at {0} is greater than the river discharge. Offtake discharge set to 0 to continue.", pNum)); return inputDischarge; } } }