1 package org.opentrafficsim.road.gtu.lane.perception.mental;
2
3 import static org.opentrafficsim.base.parameters.constraint.NumericConstraint.POSITIVEZERO;
4
5 import org.opentrafficsim.base.parameters.ParameterException;
6 import org.opentrafficsim.base.parameters.ParameterTypeDouble;
7 import org.opentrafficsim.base.parameters.ParameterTypes;
8 import org.opentrafficsim.base.parameters.Parameters;
9 import org.opentrafficsim.road.gtu.lane.perception.mental.channel.AdaptationSpeedChannel;
10
11
12
13
14
15
16
17
18
19
20
21
22 public class AdaptationSpeed implements BehavioralAdaptation
23 {
24
25
26 public static final ParameterTypeDouble BETA_V0 =
27 new ParameterTypeDouble("Beta_v0", "max desired speed scaling", 1.0, POSITIVEZERO);
28
29
30 private Double fSpeed0;
31
32
33
34
35 public AdaptationSpeed()
36 {
37
38 }
39
40 @Override
41 public void adapt(final Parameters parameters) throws ParameterException
42 {
43 if (this.fSpeed0 == null)
44 {
45 this.fSpeed0 = parameters.getParameter(ParameterTypes.FSPEED);
46 }
47 double tsCrit = parameters.getOptionalParameter(SumFuller.TS_CRIT).orElse(1.0);
48 double eps = parameters.getParameter(Fuller.TS) - tsCrit;
49 eps = eps < 0.0 ? 0.0 : (eps >= 0.999 ? 0.999 : eps);
50 double factor = 1.0 - parameters.getParameter(BETA_V0) * eps;
51 parameters.setClaimedParameter(ParameterTypes.FSPEED, this.fSpeed0 * factor, this);
52 }
53
54 }