View Javadoc
1   package org.opentrafficsim.road.gtu.strategical;
2   
3   import org.djunits.value.vdouble.scalar.Length;
4   import org.djunits.value.vdouble.scalar.Speed;
5   import org.opentrafficsim.base.parameters.ParameterException;
6   import org.opentrafficsim.base.parameters.Parameters;
7   import org.opentrafficsim.core.gtu.GTUException;
8   import org.opentrafficsim.core.gtu.GTUType;
9   import org.opentrafficsim.core.parameters.ParameterFactory;
10  import org.opentrafficsim.core.parameters.ParameterFactoryDefault;
11  import org.opentrafficsim.road.gtu.lane.LaneBasedGTU;
12  import org.opentrafficsim.road.gtu.lane.tactical.LaneBasedTacticalPlanner;
13  import org.opentrafficsim.road.gtu.lane.tactical.LaneBasedTacticalPlannerFactory;
14  
15  /**
16   * Factory for creating {@code LaneBasedStrategicalRoutePlanner} using any {@code LaneBasedTacticalPlannerFactory}. This
17   * abstract class deals with forwarding peeking from the GTU generator to the tactical planner factory. Parameters are set using
18   * a {@code ParameterFactory}, after the method {@code setParameters()} has been called, which subclasses need to implement.
19   * <p>
20   * Copyright (c) 2013-2022 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
21   * BSD-style license. See <a href="http://opentrafficsim.org/node/13">OpenTrafficSim License</a>.
22   * <p>
23   * @version $Revision$, $LastChangedDate$, by $Author$, initial version 12 jan. 2018 <br>
24   * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
25   * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
26   * @author <a href="http://www.transport.citg.tudelft.nl">Wouter Schakel</a>
27   * @param <T> class of the strategical planner generated
28   */
29  public abstract class AbstractLaneBasedStrategicalPlannerFactory<T extends LaneBasedStrategicalPlanner>
30          implements LaneBasedStrategicalPlannerFactory<T>
31  {
32  
33      /** Factory for tactical planners. */
34      private final LaneBasedTacticalPlannerFactory<? extends LaneBasedTacticalPlanner> tacticalPlannerFactory;
35  
36      /** Parameter factory. */
37      private final ParameterFactory parameterFactory;
38  
39      /** Peeked parameters. */
40      private Parameters peekedParameters = null;
41  
42      /**
43       * Constructor with factory for tactical planners.
44       * @param tacticalPlannerFactory LaneBasedTacticalPlannerFactory&lt;? extends LaneBasedTacticalPlanner&gt;; factory for
45       *            tactical planners
46       */
47      public AbstractLaneBasedStrategicalPlannerFactory(
48              final LaneBasedTacticalPlannerFactory<? extends LaneBasedTacticalPlanner> tacticalPlannerFactory)
49      {
50          this.tacticalPlannerFactory = tacticalPlannerFactory;
51          this.parameterFactory = new ParameterFactoryDefault();
52      }
53  
54      /**
55       * Constructor with factory for tactical planners.
56       * @param tacticalPlannerFactory LaneBasedTacticalPlannerFactory&lt;? extends LaneBasedTacticalPlanner&gt;; factory for
57       *            tactical planners
58       * @param parametersFactory ParameterFactory; factory for parameters
59       */
60      public AbstractLaneBasedStrategicalPlannerFactory(
61              final LaneBasedTacticalPlannerFactory<? extends LaneBasedTacticalPlanner> tacticalPlannerFactory,
62              final ParameterFactory parametersFactory)
63      {
64          this.tacticalPlannerFactory = tacticalPlannerFactory;
65          this.parameterFactory = parametersFactory;
66      }
67  
68      /** {@inheritDoc} */
69      @Override
70      public final Speed peekDesiredSpeed(final GTUType gtuType, final Speed speedLimit, final Speed maxGtuSpeed)
71              throws GTUException
72      {
73          return this.tacticalPlannerFactory.peekDesiredSpeed(gtuType, speedLimit, maxGtuSpeed, peekParameters(gtuType));
74      }
75  
76      /** {@inheritDoc} */
77      @Override
78      public final Length peekDesiredHeadway(final GTUType gtuType, final Speed speed) throws GTUException
79      {
80          return this.tacticalPlannerFactory.peekDesiredHeadway(gtuType, speed, peekParameters(gtuType));
81      }
82  
83      /**
84       * Determine or return the next parameter set.
85       * @param gtuType GTUType; GTU type to generate parameters for
86       * @return Parameters; next parameter set
87       * @throws GTUException on parameter exception
88       */
89      private Parameters peekParameters(final GTUType gtuType) throws GTUException
90      {
91          if (this.peekedParameters != null)
92          {
93              return this.peekedParameters;
94          }
95          try
96          {
97              this.peekedParameters = this.tacticalPlannerFactory.getParameters();
98              Parameters parameters = getParameters();
99              if (parameters != null)
100             {
101                 parameters.setAllIn(this.peekedParameters);
102             }
103             this.parameterFactory.setValues(this.peekedParameters, gtuType);
104         }
105         catch (ParameterException exception)
106         {
107             throw new GTUException("Parameter was set to illegal value.", exception);
108         }
109         return this.peekedParameters;
110     }
111 
112     /**
113      * Returns parameters specific to the strategical planner. The input already contains parameters from the tactical planner.
114      * After this method, the {@code ParameterFactory} sets or overwrites additional parameters. Hence, this method may set
115      * default (distributed) values for parameters specific to the strategical planner.
116      * @return parameters Parameters; parameters for the strategical planner, may be {@code null}
117      */
118     protected abstract Parameters getParameters();
119 
120     /**
121      * Returns the parameters for the next GTU.
122      * @param gtuType GTUType; GTU type of GTU to be generated
123      * @return Parameters; parameters for the next GTU
124      * @throws GTUException on parameter exception
125      */
126     protected final Parameters nextParameters(final GTUType gtuType) throws GTUException
127     {
128         Parameters parameters = peekParameters(gtuType);
129         this.peekedParameters = null;
130         return parameters;
131     }
132 
133     /**
134      * Returns the next tactical planner.
135      * @param gtu LaneBasedGTU; GTU to be generated
136      * @return T; next tactical planner
137      * @throws GTUException on exception during tactical planner creation
138      */
139     protected final LaneBasedTacticalPlanner nextTacticalPlanner(final LaneBasedGTU gtu) throws GTUException
140     {
141         return this.tacticalPlannerFactory.create(gtu);
142     }
143 
144     /**
145      * Returns the tactical planner factory.
146      * @return LaneBasedTacticalPlannerFactory; tactical planner factory
147      */
148     protected final LaneBasedTacticalPlannerFactory<? extends LaneBasedTacticalPlanner> getTacticalPlannerFactory()
149     {
150         return this.tacticalPlannerFactory;
151     }
152 
153 }