View Javadoc
1   package org.opentrafficsim.road.gtu.lane.tactical.lmrs;
2   
3   import org.djunits.value.vdouble.scalar.Acceleration;
4   import org.djunits.value.vdouble.scalar.Length;
5   import org.djunits.value.vdouble.scalar.Speed;
6   import org.opentrafficsim.base.parameters.ParameterException;
7   import org.opentrafficsim.base.parameters.ParameterTypes;
8   import org.opentrafficsim.base.parameters.Parameters;
9   import org.opentrafficsim.core.gtu.GTUException;
10  import org.opentrafficsim.core.gtu.perception.EgoPerception;
11  import org.opentrafficsim.core.gtu.plan.operational.OperationalPlanException;
12  import org.opentrafficsim.road.gtu.lane.LaneBasedGTU;
13  import org.opentrafficsim.road.gtu.lane.perception.LanePerception;
14  import org.opentrafficsim.road.gtu.lane.perception.PerceptionCollectable;
15  import org.opentrafficsim.road.gtu.lane.perception.RelativeLane;
16  import org.opentrafficsim.road.gtu.lane.perception.categories.InfrastructurePerception;
17  import org.opentrafficsim.road.gtu.lane.perception.categories.IntersectionPerception;
18  import org.opentrafficsim.road.gtu.lane.perception.categories.neighbors.NeighborsPerception;
19  import org.opentrafficsim.road.gtu.lane.perception.headway.HeadwayConflict;
20  import org.opentrafficsim.road.gtu.lane.perception.headway.HeadwayGTU;
21  import org.opentrafficsim.road.gtu.lane.plan.operational.SimpleOperationalPlan;
22  import org.opentrafficsim.road.gtu.lane.tactical.Blockable;
23  import org.opentrafficsim.road.gtu.lane.tactical.following.CarFollowingModel;
24  import org.opentrafficsim.road.gtu.lane.tactical.util.CarFollowingUtil;
25  import org.opentrafficsim.road.gtu.lane.tactical.util.ConflictUtil;
26  import org.opentrafficsim.road.gtu.lane.tactical.util.ConflictUtil.ConflictPlans;
27  import org.opentrafficsim.road.network.lane.conflict.Conflict;
28  import org.opentrafficsim.road.network.speed.SpeedLimitInfo;
29  
30  /**
31   * <p>
32   * Copyright (c) 2013-2019 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
33   * BSD-style license. See <a href="http://opentrafficsim.org/node/13">OpenTrafficSim License</a>.
34   * <p>
35   * @version $Revision$, $LastChangedDate$, by $Author$, initial version 27 jan. 2017 <br>
36   * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
37   * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
38   * @author <a href="http://www.transport.citg.tudelft.nl">Wouter Schakel</a>
39   */
40  
41  public class AccelerationConflicts implements AccelerationIncentive, Blockable
42  {
43  
44      /** Set of yield plans at conflicts with priority. Remembering for static model. */
45      private final ConflictPlans yieldPlans = new ConflictPlans();
46  
47      /** {@inheritDoc} */
48      @Override
49      public final void accelerate(final SimpleOperationalPlan simplePlan, final RelativeLane lane, final LaneBasedGTU gtu,
50              final LanePerception perception, final CarFollowingModel carFollowingModel, final Speed speed,
51              final Parameters params, final SpeedLimitInfo speedLimitInfo)
52              throws OperationalPlanException, ParameterException, GTUException
53      {
54          // TODO consider adjacent lanes before and during lane change
55          EgoPerception ego = perception.getPerceptionCategory(EgoPerception.class);
56          Acceleration acceleration = ego.getAcceleration();
57          Length length = ego.getLength();
58          Length width = ego.getWidth();
59          PerceptionCollectable<HeadwayConflict, Conflict> conflicts =
60                  perception.getPerceptionCategory(IntersectionPerception.class).getConflicts(lane);
61          PerceptionCollectable<HeadwayGTU, LaneBasedGTU> leaders =
62                  perception.getPerceptionCategory(NeighborsPerception.class).getLeaders(lane);
63  
64          Acceleration a;
65          if (lane.isCurrent())
66          {
67              a = ConflictUtil.approachConflicts(params, conflicts, leaders, carFollowingModel, length, width, speed,
68                      acceleration, speedLimitInfo, this.yieldPlans, gtu);
69              simplePlan.minimizeAcceleration(a);
70              if (this.yieldPlans.getIndicatorIntent().isLeft())
71              {
72                  simplePlan.setIndicatorIntentLeft(this.yieldPlans.getIndicatorObjectDistance());
73              }
74              else if (this.yieldPlans.getIndicatorIntent().isRight())
75              {
76                  simplePlan.setIndicatorIntentRight(this.yieldPlans.getIndicatorObjectDistance());
77              }
78          }
79          else if (!conflicts.isEmpty() && conflicts.first().getDistance().gt0())
80          {
81              // TODO this is too simple, needs to be consistent with gap-acceptance or GTU's may not change
82              Length lcDistance = perception.getPerceptionCategory(InfrastructurePerception.class)
83                      .getLegalLaneChangePossibility(RelativeLane.CURRENT, lane.getLateralDirectionality()).neg();
84              HeadwayConflict conflict = null;
85              for (HeadwayConflict c : conflicts)
86              {
87                  if (c.getDistance().gt(lcDistance))
88                  {
89                      conflict = c;
90                      break;
91                  }
92              }
93              if (conflict != null)
94              {
95                  a = CarFollowingUtil.followSingleLeader(carFollowingModel, params, speed, speedLimitInfo,
96                          conflicts.first().getDistance(), Speed.ZERO);
97                  // limit deceleration on adjacent lanes
98                  a = Acceleration.max(a, params.getParameter(ParameterTypes.BCRIT).neg());
99                  simplePlan.minimizeAcceleration(a);
100             }
101         }
102     }
103 
104     /** {@inheritDoc} */
105     @Override
106     public boolean isBlocking()
107     {
108         return this.yieldPlans.isBlocking();
109     }
110 
111     /** {@inheritDoc} */
112     @Override
113     public final String toString()
114     {
115         return "AccelerationConflicts";
116     }
117 
118 }