/**
*
*/
package org.opentrafficsim.water.demand;
import java.io.Serializable;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;
import org.opentrafficsim.water.role.Company;
import org.opentrafficsim.water.transfer.Terminal;
import nl.tudelft.simulation.dsol.simulators.DEVSSimulatorInterface;
/**
* Demand the between terminals in an operating area (region) and other terminals.
*
* Copyright (c) 2013-2020 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
* BSD-style license. See OpenTrafficSim License.
*
*
* Based on software from the IDVV project, which is Copyright (c) 2013 Rijkswaterstaat - Dienst Water, Verkeer en Leefomgeving
* and licensed without restrictions to Delft University of Technology, including the right to sub-license sources and derived
* products to third parties.
*
* $LastChangedDate: 2015-07-24 02:58:59 +0200 (Fri, 24 Jul 2015) $, @version $Revision: 1147 $, by $Author: averbraeck $,
* initial version Nov 6, 2016
* @author Alexander Verbraeck
*/
public class TransportDemand implements Serializable
{
/** */
private static final long serialVersionUID = 1L;
/** the simulator to schedule on. */
private DEVSSimulatorInterface.TimeDoubleUnit simulator;
/** the operating area for the demand. */
private Region operatingArea;
/** the demand from and to terminals. */
private Map> demandMap = new LinkedHashMap>();
/**
* @param simulator DEVSSimulatorInterface.TimeDoubleUnit; the simulator for scheduling the demand
* @param operatingArea Region; the region for which this demand holds
*/
public TransportDemand(final DEVSSimulatorInterface.TimeDoubleUnit simulator, final Region operatingArea)
{
this.simulator = simulator;
this.operatingArea = operatingArea;
}
/**
* @return the operatingArea
*/
public final Region getOperatingArea()
{
return this.operatingArea;
}
/**
* @return the demandCells
*/
public final Map> getDemandMap()
{
return this.demandMap;
}
/**
* add a cell to the demandmap.
* @param demandCell DemandCell; the cell to add
*/
public final void addDemand(final DemandCell demandCell)
{
Map partMap = this.demandMap.get(demandCell.getTerminalFrom());
if (partMap == null)
{
partMap = new LinkedHashMap();
this.demandMap.put(demandCell.getTerminalFrom(), partMap);
}
partMap.put(demandCell.getTerminalTo(), demandCell);
}
/**
* add a cell to the demandmap.
* @param terminalFrom Terminal; origin terminal
* @param terminalTo Terminal; destination terminal
* @param numberAnnual int; annual number of containers per year
* @param fraction20ft double; fraction of 20 ft containers (rest is 40 ft)
* @param fractionEmpty double; fraction of empty containers (rest is full)
* @param fractionOwners Map<Company,Double>; map of owners with fraction (adding up to 1.0) indicating who owns the
* containers
*/
public final void addDemand(final Terminal terminalFrom, final Terminal terminalTo, final int numberAnnual,
final double fraction20ft, final double fractionEmpty, final Map fractionOwners)
{
DemandCell demandCell =
new DemandCell(terminalFrom, terminalTo, numberAnnual, fraction20ft, fractionEmpty, fractionOwners);
addDemand(demandCell);
}
/**
* @param terminalFrom Terminal; origin terminal
* @param terminalTo Terminal; destination terminal
* @return the demand between two terminals.
*/
public final DemandCell getDemand(final Terminal terminalFrom, final Terminal terminalTo)
{
if (this.demandMap.containsKey(terminalFrom))
{
return this.demandMap.get(terminalFrom).get(terminalTo);
}
return null;
}
/**
* @param terminalFrom Terminal; origin terminal
* @return the map of demands originating at a terminal.
*/
public final Map getDemandMapFrom(final Terminal terminalFrom)
{
return this.demandMap.get(terminalFrom);
}
/**
* @param terminalTo Terminal; destination terminal
* @return the map of demands for a destination terminal.
*/
public final Map getDemandMapTo(final Terminal terminalTo)
{
Map toMap = new LinkedHashMap();
for (Terminal from : this.demandMap.keySet())
{
for (Terminal to : this.demandMap.get(from).keySet())
{
if (terminalTo.equals(to))
{
toMap.put(from, this.demandMap.get(from).get(to));
}
}
}
return toMap;
}
/**
* @param terminalFrom Terminal; origin terminal
* @return the demands originating at a terminal as a set.
*/
public final Set getDemandSetFrom(final Terminal terminalFrom)
{
return new LinkedHashSet(this.demandMap.get(terminalFrom).values());
}
/**
* @param terminalTo Terminal; destination terminal
* @return the demands for a destination terminal as a set.
*/
public final Set getDemandSetTo(final Terminal terminalTo)
{
Set toSet = new LinkedHashSet();
for (Terminal from : this.demandMap.keySet())
{
for (Terminal to : this.demandMap.get(from).keySet())
{
if (terminalTo.equals(to))
{
toSet.add(this.demandMap.get(from).get(to));
}
}
}
return toSet;
}
/**
* @return the simulator
*/
public final DEVSSimulatorInterface.TimeDoubleUnit getSimulator()
{
return this.simulator;
}
/**
* A cell of demand from a terminal to a terminal.
*
* Copyright (c) 2013-2020 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
*
* BSD-style license. See OpenTrafficSim License.
*
*
* Based on software from the IDVV project, which is Copyright (c) 2013 Rijkswaterstaat - Dienst Water, Verkeer en
* Leefomgeving and licensed without restrictions to Delft University of Technology, including the right to sub-license
* sources and derived products to third parties.
*
* $LastChangedDate: 2015-07-24 02:58:59 +0200 (Fri, 24 Jul 2015) $, @version $Revision: 1147 $, by $Author: averbraeck $,
* initial version Nov 6, 2016
* @author Alexander Verbraeck
*/
public class DemandCell
{
/** origin terminal. */
private Terminal terminalFrom;
/** destination terminal. */
private Terminal terminalTo;
/** number of containers per year. */
private int numberAnnual;
/** fraction of 20 ft containers of total (rest is 40 ft). */
private double fraction20ft;
/** fraction of empty containers (rest is full). */
private double fractionEmpty;
/** table with fractions (adding up to 1.0) who owns the containers. */
private Map fractionOwners = new LinkedHashMap();
/**
* @param terminalFrom Terminal; origin terminal
* @param terminalTo Terminal; destination terminal
* @param numberAnnual int; annual number of containers per year
* @param fraction20ft double; fraction of 20 ft containers (rest is 40 ft)
* @param fractionEmpty double; fraction of empty containers (rest is full)
* @param fractionOwners Map<Company,Double>; map of owners with fraction (adding up to 1.0) indicating who owns
* the containers
*/
public DemandCell(final Terminal terminalFrom, final Terminal terminalTo, final int numberAnnual,
final double fraction20ft, final double fractionEmpty, final Map fractionOwners)
{
this.terminalFrom = terminalFrom;
this.terminalTo = terminalTo;
this.numberAnnual = numberAnnual;
this.fraction20ft = fraction20ft;
this.fractionEmpty = fractionEmpty;
this.fractionOwners = fractionOwners;
}
/**
* @return the terminalFrom
*/
public final Terminal getTerminalFrom()
{
return this.terminalFrom;
}
/**
* @return the terminalTo
*/
public final Terminal getTerminalTo()
{
return this.terminalTo;
}
/**
* @return the numberAnnual
*/
public final int getNumberAnnual()
{
return this.numberAnnual;
}
/**
* @return the fraction20ft
*/
public final double getFraction20ft()
{
return this.fraction20ft;
}
/**
* @return the fractionEmpty
*/
public final double getFractionEmpty()
{
return this.fractionEmpty;
}
/**
* @return the fractionOwners
*/
public final Map getFractionOwners()
{
return this.fractionOwners;
}
}
}