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  
32  
33  
34  
35  
36  
37  
38  
39  
40  
41  public class AccelerationConflicts implements AccelerationIncentive, Blockable
42  {
43  
44      
45      private final ConflictPlans yieldPlans = new ConflictPlans();
46  
47      
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          
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              
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                  
98                  a = Acceleration.max(a, params.getParameter(ParameterTypes.BCRIT).neg());
99                  simplePlan.minimizeAcceleration(a);
100             }
101         }
102     }
103 
104     
105     @Override
106     public boolean isBlocking()
107     {
108         return this.yieldPlans.isBlocking();
109     }
110 
111     
112     @Override
113     public final String toString()
114     {
115         return "AccelerationConflicts";
116     }
117 
118 }