20 #ifndef MSCFModel_Daniel1_h 21 #define MSCFModel_Daniel1_h 54 double decel,
double emergencyDecel,
double apparentDecel,
55 double dawdle,
double headwayTime,
56 double tmp1,
double tmp2,
double tmp3,
double tmp4,
double tmp5);
82 virtual double followSpeed(
const MSVehicle*
const veh,
double speed,
double gap2pred,
double predSpeed,
double predMaxDecel)
const;
92 virtual double stopSpeed(
const MSVehicle*
const veh,
const double speed,
double gap2pred)
const;
155 virtual double _vsafe(
double gap,
double predSpeed)
const;
162 virtual double dawdle(
double speed)
const;
double myTmp1
temporary (testing) parameter
Representation of a vehicle in the micro simulation.
double myTauDecel
The precomputed value for myDecel*myTau.
double moveHelper(MSVehicle *const veh, double vPos) const
Applies interaction with stops and lane changing model influences.
void setHeadwayTime(double headwayTime)
Sets a new value for driver reaction time [s].
The car-following model abstraction.
virtual double dawdle(double speed) const
Applies driver imperfection (dawdling / sigma)
double myDawdle
The vehicle's dawdle-parameter. 0 for no dawdling, 1 for max.
The car-following model and parameter.
virtual MSCFModel * duplicate(const MSVehicleType *vtype) const
Duplicates the car-following model.
double myDecel
The vehicle's maximum deceleration [m/s^2].
The original Krauss (1998) car-following model and parameter.
virtual double followSpeed(const MSVehicle *const veh, double speed, double gap2pred, double predSpeed, double predMaxDecel) const
Computes the vehicle's safe speed (no dawdling)
virtual double _vsafe(double gap, double predSpeed) const
Returns the "safe" velocity.
double getImperfection() const
Get the driver's imperfection.
void setMaxDecel(double decel)
Sets a new value for maximum deceleration [m/s^2].
virtual double stopSpeed(const MSVehicle *const veh, const double speed, double gap2pred) const
Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling) ...
virtual int getModelID() const
Returns the model's name.
double myHeadwayTime
The driver's desired time headway (aka reaction time tau) [s].
void setImperfection(double imperfection)
Sets a new value for driver imperfection.
MSCFModel_Daniel1(const MSVehicleType *vtype, double accel, double decel, double emergencyDecel, double apparentDecel, double dawdle, double headwayTime, double tmp1, double tmp2, double tmp3, double tmp4, double tmp5)
Constructor.
~MSCFModel_Daniel1()
Destructor.