Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
MSCFModel_CC Class Reference

A set of automatic Cruise Controllers, including classic Cruise Control (CC), Adaptive Cruise Control (ACC) and Cooperative Adaptive Cruise Control (CACC). Take as references the chapters 5, 6 and 7 of the Rajamani's book "Vehicle dynamics and control" (2011). This model is meant to be used for simulation of platooning systems in mixed scenarios, so with automatic and driver controlled vehicles. The platooning manager is a distributed application implemented for veins (so for omnet++) supported by a 802.11p based communication protocol, which will determine the actions to be performed (such as switching on the automatic controller, or the lane to move to) and communicate them to this car following models via TraCI. More...

#include <MSCFModel_CC.h>

Inheritance diagram for MSCFModel_CC:
[legend]
Collaboration diagram for MSCFModel_CC:
[legend]

Public Types

enum  CalcReason { CURRENT , FUTURE , CURRENT_WAIT , LANE_CHANGE }
 What the return value of stop/follow/free-Speed is used for. More...

Public Member Functions

double calculateEmergencyDeceleration (double gap, double egoSpeed, double predSpeed, double predMaxDecel) const
 Returns the minimal deceleration for following the given leader safely.
int commitToLaneChange (const MSVehicle *veh, bool left) const
VehicleVariablescreateVehicleVariables () const
 Returns model specific values which are stored inside a vehicle and must be used with casting.
virtual double distAfterTime (double t, double speed, double accel) const
 calculates the distance traveled after accelerating for time t
MSCFModelduplicate (const MSVehicleType *vtype) const
 Duplicates the car-following model.
double estimateSpeedAfterDistance (const double dist, const double v, const double accel) const
MSVehiclefindVehicle (std::string id) const
double getACCAcceleration (const MSVehicle *veh) const
 returns the ACC computed acceleration when the faked CACC is controlling the car. This can be used to check for vehicles in front
enum Plexe::ACTIVE_CONTROLLER getActiveController (const MSVehicle *veh) const
 return the currently active controller
double getApparentDecel () const
 Get the vehicle type's apparent deceleration [m/s^2] (the one regarded by its followers.
double getCACCConstantSpacing (const MSVehicle *veh) const
 returns CACC desired constant spacing
double getCollisionMinGapFactor () const
 Get the factor of minGap that must be maintained to avoid a collision event.
virtual double getCurrentAccel (const double speed) const
 Get the vehicle type's maximum acceleration [m/s^2].
LinearApproxHelpers::LinearApproxMap getDesAccelProfile () const
 Get the vehicle type's desired acceleration profile depending on the velocity [m/s^2].
double getEmergencyDecel () const
 Get the vehicle type's maximal physically possible deceleration [m/s^2].
double getMaxAccel () const
 Get the vehicle type's maximum acceleration [m/s^2].
LinearApproxHelpers::LinearApproxMap getMaxAccelProfile () const
 Get the vehicle type's maximum acceleration profile depending on the velocity [m/s^2].
double getMaxDecel () const
 Get the vehicle type's maximal comfortable deceleration [m/s^2].
double getMinimalArrivalSpeed (double dist, double currentSpeed) const
 Computes the minimal possible arrival speed after covering a given distance.
double getMinimalArrivalSpeedEuler (double dist, double currentSpeed) const
 Computes the minimal possible arrival speed after covering a given distance for Euler update.
SUMOTime getMinimalArrivalTime (double dist, double currentSpeed, double arrivalSpeed) const
 Computes the minimal time needed to cover a distance given the desired speed at arrival.
int getMyLanesCount () const
 returns the number of lanes set in the configuration file
virtual std::string getParameter (const MSVehicle *veh, const std::string &key) const
 set the information about a generic car. This method should be invoked by TraCI when a wireless message with such data is received. For testing, it might be also invoked from SUMO source code
void getRadarMeasurements (const MSVehicle *veh, double &distance, double &relativeSpeed) const
 return the data that is currently being measured by the radar
virtual double getSecureGap (const MSVehicle *const veh, const MSVehicle *const, const double speed, const double leaderSpeed, const double leaderMaxDecel) const
 Returns the minimum gap to reserve if the leader is braking at maximum (>=0).
SUMOTime getStartupDelay () const
 Get the vehicle type's startupDelay.
void getVehicleInformation (const MSVehicle *veh, double &speed, double &acceleration, double &controllerAcceleration, Position &position, double &time) const
 get the information about a vehicle. This can be used by TraCI in order to get speed and acceleration of the platoon leader before sending them to other vehicles
bool isLeader (const MSVehicle *veh) const
 Returns whether a vehicle is a leader of a platoon or not. By default, a vehicle on its own using an ACC is a leader of itself.
int isPlatoonLaneChangeSafe (const MSVehicle *veh, bool left) const
 computes whether a lane change for a whole platoon is safe or not. This is done by checking the lane change state and neighbors of all vehicles in the platoon added through the addPlatoonMember API. If the adjacent lane is free and there is enough safe gap for the platoon, the method returns 0, otherwise it returns the blocking reason
double maximumSafeFollowSpeed (double gap, double egoSpeed, double predSpeed, double predMaxDecel, bool onInsertion=false) const
 Returns the maximum safe velocity for following the given leader.
double maximumSafeStopSpeed (double gap, double decel, double currentSpeed, bool onInsertion=false, double headway=-1, bool relaxEmergency=true) const
 Returns the maximum next velocity for stopping within gap.
double maximumSafeStopSpeedBallistic (double gap, double decel, double currentSpeed, bool onInsertion=false, double headway=-1) const
 Returns the maximum next velocity for stopping within gap when using the ballistic positional update.
double maximumSafeStopSpeedEuler (double gap, double decel, bool onInsertion, double headway) const
 Returns the maximum next velocity for stopping within gap when using the semi-implicit Euler update.
 MSCFModel_CC (const MSVehicleType *vtype)
 Constructor.
void setLeader (MSVehicle *veh, MSVehicle *const leader, std::string leaderId) const
 Sets the leader for a member of the platoon.
virtual void setParameter (MSVehicle *veh, const std::string &key, const std::string &value) const
 try to set the given parameter for this carFollowingModel
void switchOnACC (const MSVehicle *veh, double ccDesiredSpeed) const
 switch on the ACC, so disabling the human driver car control
 ~MSCFModel_CC ()
 Destructor.
Implementations of the MSCFModel interface
virtual double finalizeSpeed (MSVehicle *const veh, double vPos) const
 Applies interaction with stops and lane changing model influences.
double followSpeed (const MSVehicle *const veh, double speed, double gap2pred, double predSpeed, double predMaxDecel, const MSVehicle *const pred=0, const CalcReason usage=CalcReason::CURRENT) const
 Computes the vehicle's safe speed (no dawdling).
virtual double insertionFollowSpeed (const MSVehicle *const veh, double speed, double gap2pred, double predSpeed, double predMaxDecel, const MSVehicle *const pred=0) const
 Overload base MSCFModel::insertionFollowSpeed method to inject automated vehicles as soon as they are requested, without checking for safe speed constraints.
double stopSpeed (const MSVehicle *const veh, const double speed, double gap2pred, double decel, const CalcReason usage=CalcReason::CURRENT) const
 Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling).
virtual double freeSpeed (const MSVehicle *const veh, double speed, double seen, double maxSpeed, const bool onInsertion=false, const CalcReason usage=CalcReason::CURRENT) const
 Computes the vehicle's safe speed without a leader.
virtual double maxNextSpeed (double speed, const MSVehicle *const veh) const
 Returns the maximum speed given the current speed.
virtual double minNextSpeed (double speed, const MSVehicle *const veh=0) const
 Returns the minimum speed given the current speed (depends on the numerical update scheme and its step width) Note that it wouldn't have to depend on the numerical update scheme if the semantics would rely on acceleration instead of velocity.
double interactionGap (const MSVehicle *const, double vL) const
 Returns the maximum gap at which an interaction between both vehicles occurs.
int getModelID () const
 Returns the model's name.
Methods to override by model implementation
virtual double patchSpeedBeforeLC (const MSVehicle *veh, double vMin, double vMax) const
 apply custom speed adaptations within the given speed bounds
virtual double applyStartupDelay (const MSVehicle *veh, const double vMin, const double vMax, const SUMOTime addTime=0) const
 apply speed adaptation on startup
virtual double interpolateProfile (const double speed, const std::vector< std::pair< double, double > > profile) const
 Get current interpolated value from a profile.
double stopSpeed (const MSVehicle *const veh, const double speed, double gap, const CalcReason usage=CalcReason::CURRENT) const
 Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling).
virtual double insertionStopSpeed (const MSVehicle *const veh, double speed, double gap) const
 Computes the vehicle's safe speed for approaching an obstacle at insertion without constraints due to acceleration capabilities and previous speeds.
virtual double followSpeedTransient (double duration, const MSVehicle *const veh, double speed, double gap2pred, double predSpeed, double predMaxDecel) const
 Computes the vehicle's follow speed that avoids a collision for the given amount of time.
virtual double maximumLaneSpeedCF (const MSVehicle *const veh, double maxSpeed, double maxSpeedLane) const
 Returns the maximum velocity the CF-model wants to achieve in the next step.
Virtual methods with default implementation
virtual double getImperfection () const
 Get the driver's imperfection.
virtual double getHeadwayTime () const
 Get the driver's desired headway [s].
virtual bool startupDelayStopped () const
 whether startupDelay should be applied after stopping
Setter methods
virtual void setMaxAccel (double accel)
 Sets a new value for maximum acceleration [m/s^2].
virtual void setMaxDecel (double decel)
 Sets a new value for maximal comfortable deceleration [m/s^2].
virtual void setEmergencyDecel (double decel)
 Sets a new value for maximal physically possible deceleration [m/s^2].
virtual void setApparentDecel (double decel)
 Sets a new value for the apparent deceleration [m/s^2].
void setCollisionMinGapFactor (const double factor)
 Sets a new value for the factor of minGap that must be maintained to avoid a collision event.
virtual void setMaxAccelProfile (const LinearApproxHelpers::LinearApproxMap &accelProfile)
 Sets a new value for maximum acceleration profile [m/s^2].
virtual void setDesAccelProfile (const LinearApproxHelpers::LinearApproxMap &accelProfile)
 Sets a new value for desired acceleration profile [m/s^2].
virtual void setImperfection (double imperfection)
 Sets a new value for driver imperfection.
virtual void setHeadwayTime (double headwayTime)
 Sets a new value for desired headway [s].

Static Public Member Functions

static double avoidArrivalAccel (double dist, double time, double speed, double maxDecel)
 Computes the acceleration needed to arrive not before the given time.
static double estimateArrivalTime (double dist, double initialSpeed, double arrivalSpeed, double maxSpeed, double accel, double decel)
 Computes the time needed to travel a distance dist given an initial speed, arrival speed, constant acceleration and deceleration. The speed during traveling is assumed not to exceed the max speed.
static double estimateArrivalTime (double dist, double speed, double maxSpeed, double accel)
 Computes the time needed to travel a distance dist given an initial speed and constant acceleration. The speed during traveling is assumed not to exceed the max speed.
static double gapExtrapolation (const double duration, const double currentGap, double v1, double v2, double a1=0, double a2=0, const double maxV1=std::numeric_limits< double >::max(), const double maxV2=std::numeric_limits< double >::max())
 return the resulting gap if, starting with gap currentGap, two vehicles continue with constant accelerations (velocities bounded by 0 and maxSpeed) for a given timespan of length 'duration'.
static double passingTime (const double lastPos, const double passedPos, const double currentPos, const double lastSpeed, const double currentSpeed)
 Calculates the time at which the position passedPosition has been passed In case of a ballistic update, the possibility of a stop within a time step requires more information about the last time-step than in case of the euler update to determine the last position if the currentSpeed is zero.
static double speedAfterTime (const double t, const double oldSpeed, const double dist)
 Calculates the speed after a time t \in [0,TS] given the initial speed and the distance traveled in an interval of step length TS.

Protected Member Functions

void applyHeadwayAndSpeedDifferencePerceptionErrors (const MSVehicle *const veh, double speed, double &gap, double &predSpeed, double predMaxDecel, const MSVehicle *const pred) const
 Overwrites gap2pred and predSpeed by the perceived values obtained from the vehicle's driver state,.
void applyHeadwayPerceptionError (const MSVehicle *const veh, double speed, double &gap) const
 Overwrites gap by the perceived value obtained from the vehicle's driver state.
void applyOwnSpeedPerceptionError (const MSVehicle *const veh, double &speed) const
 Overwrites sped by the perceived values obtained from the vehicle's driver state,.

Protected Attributes

double myAccel
 The vehicle's maximum acceleration [m/s^2].
double myApparentDecel
 The vehicle's deceleration as expected by surrounding traffic [m/s^2].
double myCollisionMinGapFactor
 The factor of minGap that must be maintained to avoid a collision event.
double myDecel
 The vehicle's maximum deceleration [m/s^2].
LinearApproxHelpers::LinearApproxMap myDesAccelProfile
 The vehicle's desired acceleration profile [m/s^2].
double myEmergencyDecel
 The vehicle's maximum emergency deceleration [m/s^2].
double myHeadwayTime
 The driver's desired time headway (aka reaction time tau) [s].
LinearApproxHelpers::LinearApproxMap myMaxAccelProfile
 The vehicle's maximum acceleration profile [m/s^2].
SUMOTime myStartupDelay
 The startup delay after halting [s].
const MSVehicleTypemyType
 The type to which this model definition belongs to.

Private Member Functions

double _acc (const MSVehicle *veh, double egoSpeed, double predSpeed, double gap2pred, double headwayTime) const
 controller for the ACC which computes the acceleration to be applied. the value needs to be passed to the actuator
double _cacc (const MSVehicle *veh, double egoSpeed, double predSpeed, double predAcceleration, double gap2pred, double leaderSpeed, double leaderAcceleration, double spacing) const
 controller for the CACC which computes the acceleration to be applied. the value needs to be passed to the actuator
double _cc (const MSVehicle *veh, double egoSpeed, double desSpeed) const
 controller for the CC which computes the acceleration to be applied. the value needs to be passed to the actuator
double _consensus (const MSVehicle *veh, double egoSpeed, Position egoPosition, double time) const
 controller based on consensus strategy
double _flatbed (const MSVehicle *veh, double egoAcceleration, double egoSpeed, double predSpeed, double gap2pred, double leaderSpeed) const
 flatbed platoon towing model
double _ploeg (const MSVehicle *veh, double egoSpeed, double predSpeed, double predAcceleration, double gap2pred) const
 controller for the Ploeg's CACC which computes the control input variation. Opposed to other controllers, this method returns a value which needs to be summed to the previous desired acceleration.
double _v (const MSVehicle *const veh, double gap2pred, double egoSpeed, double predSpeed) const
void changeWholePlatoonLane (MSVehicle *const veh, int direction) const
 Moves an entire platoon on an adjacent lane, calling changeLane() on all members.
double d_i_j (const struct Plexe::VEHICLE_DATA *vehicles, const double h[MAX_N_CARS], int i, int j) const
 computes the desired distance between vehicle i and vehicle j
MSCFModel_CCoperator= (const MSCFModel_CC &)=delete
 Invalidated assignment operator.
void performAutoLaneChange (MSVehicle *const veh) const
 Check whether a platoon would gain speed by moving to the left or whether it should move to the right after an overtake and, if safe, do so. This method is invoked when the platoon auto lane change mechanism is enabled through the enableAutoLaneChanging API.
void performPlatoonLaneChange (MSVehicle *const veh) const
 If safe to do so, moves a platoon to a user-desired lane. If not safe, this method continues to try at each simulation step. This method is invoked when the user requests a platoon to change lane through the performPlatoonLaneChange API, or when invoking the old setFixedLane API on a single vehicle.
void recomputeParameters (const MSVehicle *veh) const
 Recomputes controller related parameters after setting them.
void resetConsensus (const MSVehicle *veh) const
 Resets the consensus controller. In particular, sets the "initialized" vector all to false. This might be useful when changing topology.

Private Attributes

const double myC1
 design constant for CACC
const double myCcAccel
 The maximum acceleration that the CC can output.
const double myCcDecel
 The maximum deceleration that the CC can output.
const double myConstantSpacing
 the constant gap for CACC
const double myFlatbedD
const double myFlatbedH
const double myFlatbedKa
 flatbed CACC parameters
const double myFlatbedKp
const double myFlatbedKv
MSCFModelmyHumanDriver
 the car following model which drives the car when automated cruising is disabled, i.e., the human driver
const double myKp
 design constant for CC
const double myLambda
 design constant for ACC
const int myLanesCount
 number of lanes in the highway, in the absence of on-/off-ramps. This is used to move to the correct lane even when a lane is added for on-/off-ramps
const double myOmegaN
 design constant for CACC
const double myPloegH
 Ploeg's CACC parameters.
const double myPloegKd
const double myPloegKp
const double myTau
 engine time constant used for actuation lag
const double myXi
 design constant for CACC

Currently fixed methods

virtual double maxNextSafeMin (double speed, const MSVehicle *const veh=0) const
 Returns the maximum speed given the current speed and regarding driving dynamics.
virtual double minNextSpeedEmergency (double speed, const MSVehicle *const veh=0) const
 Returns the minimum speed after emergency braking, given the current speed (depends on the numerical update scheme and its step width) Note that it wouldn't have to depend on the numerical update scheme if the semantics would rely on acceleration instead of velocity.
double brakeGap (const double speed) const
 Returns the distance the vehicle needs to halt including driver's reaction time tau (i.e. desired headway), assuming that during the reaction time, the speed remains constant.
virtual double brakeGap (const double speed, const double decel, const double headwayTime) const
virtual double getSpeedAfterMaxDecel (double v) const
 Returns the velocity after maximum deceleration.
static double freeSpeed (const double currentSpeed, const double decel, const double dist, const double maxSpeed, const bool onInsertion, const double actionStepLength)
static double brakeGapEuler (const double speed, const double decel, const double headwayTime)

Detailed Description

A set of automatic Cruise Controllers, including classic Cruise Control (CC), Adaptive Cruise Control (ACC) and Cooperative Adaptive Cruise Control (CACC). Take as references the chapters 5, 6 and 7 of the Rajamani's book "Vehicle dynamics and control" (2011). This model is meant to be used for simulation of platooning systems in mixed scenarios, so with automatic and driver controlled vehicles. The platooning manager is a distributed application implemented for veins (so for omnet++) supported by a 802.11p based communication protocol, which will determine the actions to be performed (such as switching on the automatic controller, or the lane to move to) and communicate them to this car following models via TraCI.

See also
MSCFModel

Definition at line 57 of file MSCFModel_CC.h.

Member Enumeration Documentation

◆ CalcReason

enum MSCFModel::CalcReason
inherited

What the return value of stop/follow/free-Speed is used for.

Enumerator
CURRENT 

the return value is used for calculating the next speed

FUTURE 

the return value is used for calculating future speeds

CURRENT_WAIT 

the return value is used for calculating junction stop speeds

LANE_CHANGE 

the return value is used for lane change calculations

Definition at line 79 of file MSCFModel.h.

Constructor & Destructor Documentation

◆ MSCFModel_CC()

MSCFModel_CC::MSCFModel_CC ( const MSVehicleType * vtype)

Constructor.

Parameters
[in]accelThe maximum acceleration that controllers can output (def. 1.5 m/s^2)
[in]decelThe maximum deceleration that ACC and CACC controllers can output (def. 6 m/s^2)
[in]ccDecelThe maximum deceleration that the CC can output (def. 1.5 m/s^2)
[in]headwayTimethe headway gap for ACC (be aware of instabilities) (def. 1.5 s)
[in]constantSpacingthe constant gap for CACC (def. 5 m)
[in]kpdesign constant for CC (def. 1)
[in]lambdadesign constant for ACC (def. 0.1)
[in]c1design constant for CACC (def. 0.5)
[in]xidesign constant for CACC (def. 1)
[in]omegaNdesign constant for CACC (def. 0.2)
[in]tauengine time constant used for actuation lag (def. 0.5 s)
[in]lanesCountnumber of lanes of the highway
[in]ccAccelthe maximum acceleration the CC can apply

Definition at line 44 of file MSCFModel_CC.cpp.

References getParameter(), MSCFModel::MSCFModel(), myC1, myCcAccel, myCcDecel, myConstantSpacing, myFlatbedD, myFlatbedH, myFlatbedKa, myFlatbedKp, myFlatbedKv, myHumanDriver, myKp, myLambda, myLanesCount, myOmegaN, myPloegH, myPloegKd, myPloegKp, myTau, myXi, SUMO_ATTR_CF_CC_C1, SUMO_ATTR_CF_CC_CCACCEL, SUMO_ATTR_CF_CC_CCDECEL, SUMO_ATTR_CF_CC_CONSTSPACING, SUMO_ATTR_CF_CC_FLATBED_D, SUMO_ATTR_CF_CC_FLATBED_H, SUMO_ATTR_CF_CC_FLATBED_KA, SUMO_ATTR_CF_CC_FLATBED_KP, SUMO_ATTR_CF_CC_FLATBED_KV, SUMO_ATTR_CF_CC_KP, SUMO_ATTR_CF_CC_LAMBDA, SUMO_ATTR_CF_CC_LANES_COUNT, SUMO_ATTR_CF_CC_OMEGAN, SUMO_ATTR_CF_CC_PLOEG_H, SUMO_ATTR_CF_CC_PLOEG_KD, SUMO_ATTR_CF_CC_PLOEG_KP, SUMO_ATTR_CF_CC_TAU, SUMO_ATTR_CF_CC_XI, and TL.

Referenced by duplicate(), operator=(), and setParameter().

Here is the caller graph for this function:

◆ ~MSCFModel_CC()

MSCFModel_CC::~MSCFModel_CC ( )

Destructor.

Definition at line 74 of file MSCFModel_CC.cpp.

Member Function Documentation

◆ _acc()

double MSCFModel_CC::_acc ( const MSVehicle * veh,
double egoSpeed,
double predSpeed,
double gap2pred,
double headwayTime ) const
private

controller for the ACC which computes the acceleration to be applied. the value needs to be passed to the actuator

Parameters
[in]egoSpeedvehicle current speed
[in]desSpeedvehicle desired speed
[in]gap2predthe distance to preceding vehicle
[in]headwayTimethe headway time ACC should maintain
Returns
the acceleration to be given to the actuator

Definition at line 599 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::accLambda, and MSVehicle::getCarFollowVariables().

Referenced by _v(), and getACCAcceleration().

Here is the caller graph for this function:

◆ _cacc()

double MSCFModel_CC::_cacc ( const MSVehicle * veh,
double egoSpeed,
double predSpeed,
double predAcceleration,
double gap2pred,
double leaderSpeed,
double leaderAcceleration,
double spacing ) const
private

controller for the CACC which computes the acceleration to be applied. the value needs to be passed to the actuator

Parameters
[in]egoSpeedvehicle current speed
[in]desSpeedvehicle desired speed
[in]predAccelerationacceleration of preceding vehicle
[in]gap2predthe distance to preceding vehicle
[in]leaderSpeedthe speed of the platoon leader
[in]leaderAccelerationthe acceleration of the platoon leader
[in]spacingthe spacing to be kept
Returns
the acceleration to be given to the actuator

Definition at line 608 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::caccAlpha1, CC_VehicleVariables::caccAlpha2, CC_VehicleVariables::caccAlpha3, CC_VehicleVariables::caccAlpha4, CC_VehicleVariables::caccAlpha5, and MSVehicle::getCarFollowVariables().

Referenced by _v().

Here is the caller graph for this function:

◆ _cc()

double MSCFModel_CC::_cc ( const MSVehicle * veh,
double egoSpeed,
double desSpeed ) const
private

controller for the CC which computes the acceleration to be applied. the value needs to be passed to the actuator

Parameters
[in]egoSpeedvehicle current speed
[in]desSpeedvehicle desired speed
Returns
the acceleration to be given to the actuator

Definition at line 590 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::ccKp, MSVehicle::getCarFollowVariables(), myCcAccel, and myCcDecel.

Referenced by _v().

Here is the caller graph for this function:

◆ _consensus()

double MSCFModel_CC::_consensus ( const MSVehicle * veh,
double egoSpeed,
Position egoPosition,
double time ) const
private

controller based on consensus strategy

Parameters
[in]egoSpeedvehicle current speed
[in]egoPositionvehicle current position
[in]timecurrent time
Returns
the acceleration to be given to the actuator

Definition at line 658 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::b, d_i_j(), DELTA_T, Position::distanceTo2D(), MSVehicle::getCarFollowVariables(), MSVehicle::getVelocityVector(), CC_VehicleVariables::h, CC_VehicleVariables::K, CC_VehicleVariables::L, CC_VehicleVariables::nCars, CC_VehicleVariables::nInitialized, CC_VehicleVariables::position, Plexe::VEHICLE_DATA::positionX, Plexe::VEHICLE_DATA::positionY, Position::set(), Position::setx(), Position::sety(), sgn, Plexe::VEHICLE_DATA::speed, STEPS2TIME, Plexe::VEHICLE_DATA::time, CC_VehicleVariables::vehicles, Position::x(), and Position::y().

Referenced by _v().

Here is the caller graph for this function:

◆ _flatbed()

double MSCFModel_CC::_flatbed ( const MSVehicle * veh,
double egoAcceleration,
double egoSpeed,
double predSpeed,
double gap2pred,
double leaderSpeed ) const
private

flatbed platoon towing model

Parameters
[in]egoAccelerationvehicle current acceleration
[in]egoSpeedvehicle current speed
[in]predSpeedfront vehicle speed
[in]gap2preddistance to front vehicle
[in]leaderSpeedspeed of leading vehicle

Definition at line 732 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::flatbedD, CC_VehicleVariables::flatbedH, CC_VehicleVariables::flatbedKa, CC_VehicleVariables::flatbedKp, CC_VehicleVariables::flatbedKv, and MSVehicle::getCarFollowVariables().

Referenced by _v().

Here is the caller graph for this function:

◆ _ploeg()

double MSCFModel_CC::_ploeg ( const MSVehicle * veh,
double egoSpeed,
double predSpeed,
double predAcceleration,
double gap2pred ) const
private

controller for the Ploeg's CACC which computes the control input variation. Opposed to other controllers, this method returns a value which needs to be summed to the previous desired acceleration.

Parameters
[in]egoSpeedvehicle current speed
[in]predSpeedthe speed of the front vehicle
[in]predAccelerationacceleration of preceding vehicle
[in]gap2predthe distance to preceding vehicle
Returns
the variation of desired acceleration

Definition at line 621 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::controllerAcceleration, MSVehicle::getAcceleration(), MSVehicle::getCarFollowVariables(), CC_VehicleVariables::ploegH, CC_VehicleVariables::ploegKd, CC_VehicleVariables::ploegKp, and TS.

Referenced by _v().

Here is the caller graph for this function:

◆ _v()

double MSCFModel_CC::_v ( const MSVehicle *const veh,
double gap2pred,
double egoSpeed,
double predSpeed ) const
private

Definition at line 420 of file MSCFModel_CC.cpp.

References _acc(), _cacc(), _cc(), _consensus(), _flatbed(), _ploeg(), Plexe::ACC, ACCEL2SPEED, CC_VehicleVariables::accHeadwayTime, CC_VehicleVariables::activeController, CC_VehicleVariables::autoFeed, Plexe::CACC, CC_VehicleVariables::caccInitialized, CC_VehicleVariables::caccSpacing, CC_VehicleVariables::ccDesiredSpeed, Plexe::CONSENSUS, CC_VehicleVariables::controllerAcceleration, CC_VehicleVariables::crashed, DELTA_T, Position::distanceTo2D(), Plexe::DRIVER, Plexe::FAKED_CACC, CC_VehicleVariables::fakeData, findVehicle(), CC_VehicleVariables::fixedAcceleration, Plexe::FLATBED, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontAcceleration, CC_VehicleVariables::frontAcceleration, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontControllerAcceleration, CC_VehicleVariables::frontControllerAcceleration, CC_VehicleVariables::frontDataReadTime, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontDistance, CC_VehicleVariables::frontInitialized, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontSpeed, CC_VehicleVariables::frontSpeed, CC_VehicleVariables::frontVehicle, CC_VehicleVariables::frontVehicleId, MSVehicle::getAcceleration(), MSVehicle::getCarFollowVariables(), MSNet::getInstance(), MSVehicle::getPosition(), getVehicleInformation(), CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderAcceleration, CC_VehicleVariables::leaderAcceleration, CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderControllerAcceleration, CC_VehicleVariables::leaderControllerAcceleration, CC_VehicleVariables::leaderDataReadTime, CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderSpeed, CC_VehicleVariables::leaderSpeed, CC_VehicleVariables::leaderVehicle, CC_VehicleVariables::leaderVehicleId, MAX2(), Plexe::PLOEG, STEPS2TIME, CC_VehicleVariables::useControllerAcceleration, CC_VehicleVariables::useFixedAcceleration, and CC_VehicleVariables::usePrediction.

Referenced by followSpeed(), freeSpeed(), and stopSpeed().

Here is the caller graph for this function:

◆ applyHeadwayAndSpeedDifferencePerceptionErrors()

void MSCFModel::applyHeadwayAndSpeedDifferencePerceptionErrors ( const MSVehicle *const veh,
double speed,
double & gap,
double & predSpeed,
double predMaxDecel,
const MSVehicle *const pred ) const
protectedinherited

Overwrites gap2pred and predSpeed by the perceived values obtained from the vehicle's driver state,.

See also
MSCFModel_Krauss::stopSpeed() and MSCFModel_Krauss::followSpeed() for integration into a CF model
Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in,out]gap2predThe (net) distance to the LEADER
[in,out]predSpeedThe speed of LEADER
[in]predThe leading vehicle (LEADER)

Definition at line 1088 of file MSCFModel.cpp.

References DEBUG_COND, followSpeed(), FUTURE, MSVehicle::getDriverState(), Named::getID(), MSVehicle::hasDriverState(), SIMTIME, SPEED2ACCEL, and UNUSED_PARAMETER.

Referenced by MSCFModel_CACC::followSpeed(), MSCFModel_IDM::followSpeed(), and MSCFModel_Krauss::followSpeed().

Here is the caller graph for this function:

◆ applyHeadwayPerceptionError()

void MSCFModel::applyHeadwayPerceptionError ( const MSVehicle *const veh,
double speed,
double & gap ) const
protectedinherited

Overwrites gap by the perceived value obtained from the vehicle's driver state.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in,out]gapThe (net) distance to the obstacle

Definition at line 1124 of file MSCFModel.cpp.

References DEBUG_COND, FUTURE, MSVehicle::getDriverState(), Named::getID(), MSVehicle::hasDriverState(), SIMTIME, SPEED2ACCEL, stopSpeed(), and UNUSED_PARAMETER.

Referenced by MSCFModel_CACC::stopSpeed(), MSCFModel_IDM::stopSpeed(), and MSCFModel_Krauss::stopSpeed().

Here is the caller graph for this function:

◆ applyOwnSpeedPerceptionError()

void MSCFModel::applyOwnSpeedPerceptionError ( const MSVehicle *const veh,
double & speed ) const
protectedinherited

Overwrites sped by the perceived values obtained from the vehicle's driver state,.

See also
MSCFModel_Krauss::freeSpeed()
Parameters
[in]vehThe vehicle (EGO)
[in,out]speedThe vehicle's speed

Definition at line 1079 of file MSCFModel.cpp.

References MSVehicle::getDriverState(), and MSVehicle::hasDriverState().

Referenced by maximumLaneSpeedCF(), and MSCFModel_CACC::maximumLaneSpeedCF().

Here is the caller graph for this function:

◆ applyStartupDelay()

double MSCFModel::applyStartupDelay ( const MSVehicle * veh,
const double vMin,
const double vMax,
const SUMOTime addTime = 0 ) const
virtualinherited

apply speed adaptation on startup

Definition at line 259 of file MSCFModel.cpp.

References DELTA_T, MSVehicle::getSpeed(), MSVehicle::getTimeSinceStartup(), myStartupDelay, SUMO_const_haltingSpeed, and UNUSED_PARAMETER.

Referenced by finalizeSpeed(), and MSCFModel_EIDM::finalizeSpeed().

Here is the caller graph for this function:

◆ avoidArrivalAccel()

double MSCFModel::avoidArrivalAccel ( double dist,
double time,
double speed,
double maxDecel )
staticinherited

Computes the acceleration needed to arrive not before the given time.

Parameters
[in]dist- the distance of the critical point
[in]time- the time after which an arrival at dist is allowed
[in]speed- the current speed
Returns
Returns the acceleration which would ensure an arrival at distance dist earliest for the given time

Definition at line 543 of file MSCFModel.cpp.

Referenced by MSLCM_SL2015::commitManoeuvre(), and MSLink::getZipperSpeed().

Here is the caller graph for this function:

◆ brakeGap() [1/2]

double MSCFModel::brakeGap ( const double speed) const
inlineinherited

Returns the distance the vehicle needs to halt including driver's reaction time tau (i.e. desired headway), assuming that during the reaction time, the speed remains constant.

Parameters
[in]speedThe vehicle's current speed
Returns
The distance needed to halt

Definition at line 408 of file MSCFModel.h.

References brakeGap(), myDecel, and myHeadwayTime.

Referenced by MSCFModel_Wiedemann::_v(), MSVehicle::adaptToOncomingLeader(), MSLane::addLeaders(), brakeGap(), MSCFModel_EIDM::brakeGap(), MSLCHelper::canSaveBlockerLength(), MSLaneChanger::checkChange(), MSLane::checkFailure(), MSVehicle::checkReversal(), MSVehicle::checkRewindLinkLanes(), MSLaneChanger::computeSafeOppositeLength(), distAfterTime(), followSpeedTransient(), MSVehicle::getBrakeGap(), MSLaneChanger::getColumnleader(), MSLane::getCriticalLeader(), MSVehicle::getFollower(), LIBSUMO_NAMESPACE::Vehicle::getJunctionFoes(), MSLane::getLeader(), MSVehicle::getLeader(), MSLink::getLeaderInfo(), MSLane::getLeaderOnConsecutive(), MSLane::getLeadersOnConsecutive(), MSLaneChanger::getRealLeader(), getSecureGap(), MSLink::getZipperSpeed(), MSLane::handleCollisionBetween(), MSLane::handleIntermodalCollisionBetween(), MSIdling_Stop::idle(), MSLane::isInsertionSuccess(), MSVehicle::isLeader(), MSLane::lastInsertion(), maximumSafeFollowSpeed(), GUIBaseVehicle::GUIBaseVehiclePopupMenu::onCmdToggleStop(), MSVehicle::planMoveInternal(), MSVehicle::processLinkApproaches(), MSVehicle::updateBestLanes(), and MSLCHelper::updateBlockerLength().

Here is the caller graph for this function:

◆ brakeGap() [2/2]

double MSCFModel::brakeGap ( const double speed,
const double decel,
const double headwayTime ) const
virtualinherited

Reimplemented in MSCFModel_EIDM.

Definition at line 77 of file MSCFModel.cpp.

References brakeGapEuler(), and MSGlobals::gSemiImplicitEulerUpdate.

◆ brakeGapEuler()

double MSCFModel::brakeGapEuler ( const double speed,
const double decel,
const double headwayTime )
staticinherited

Definition at line 92 of file MSCFModel.cpp.

References ACCEL2SPEED, and SPEED2DIST.

Referenced by brakeGap(), and MSLCM_SL2015::computeSpeedLat().

Here is the caller graph for this function:

◆ calculateEmergencyDeceleration()

double MSCFModel::calculateEmergencyDeceleration ( double gap,
double egoSpeed,
double predSpeed,
double predMaxDecel ) const
inherited

Returns the minimal deceleration for following the given leader safely.

Parameters
[in]gapThe (net) distance to the LEADER
[in]egoSpeedThe FOLLOWERS's speed
[in]predSpeedThe LEADER's speed
[in]predMaxDecelThe LEADER's maximum deceleration
Returns
The minimal deceleration b>0 that, if applied constantly until a full stop, asserts that the vehicle does not crash into the leader.
Note
If b > predMaxDecel, this function actually does not calculate the tangency for the trajectories, i.e. a double root for the gap, but applies a simpler approach following the spirit of maximumSafeFollowSpeed, where the leader's decel is assumed as maximum of its actual value and the followers decel.

Definition at line 1027 of file MSCFModel.cpp.

References DEBUG_COND2, myEmergencyDecel, and SIMTIME.

Referenced by maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), and maximumSafeStopSpeed().

Here is the caller graph for this function:

◆ changeWholePlatoonLane()

void MSCFModel_CC::changeWholePlatoonLane ( MSVehicle *const veh,
int direction ) const
private

Moves an entire platoon on an adjacent lane, calling changeLane() on all members.

Parameters
vehleader vehicle of the platoon
direction+1 for left adjacent lane, -1 for right adjacent lane

Definition at line 181 of file MSCFModel_CC.cpp.

References MSVehicle::getCarFollowVariables(), Named::getID(), MSVehicle::getLaneIndex(), and CC_VehicleVariables::members.

Referenced by performAutoLaneChange(), and performPlatoonLaneChange().

Here is the caller graph for this function:

◆ commitToLaneChange()

int MSCFModel_CC::commitToLaneChange ( const MSVehicle * veh,
bool left ) const

This method can be invoked by the lane change model to do a final check on the safety of a platoon lane change maneuver. This method will cause the leader to check once again the safety status of all members. This might have changed since the decision of changing lane because two platoons might have decided to change lane exactly at the same time, when the lane was free for both, but changing lane would cause a side-to-side collision. SUMO will call this method on one platoon which will answer "still safe" and cause SUMO to start moving the vehicles on the adjacent lane. On the second platoon, calling this method will cause the platoon to find out about the vehicles that have just been moved and indicate the lane as busy, aborting the lane change.

Parameters
vehvehicle for which the check should be made. If the method is invoked on a member, such member invokes the same method recursively on its leader. The leader in turn asks all member for their status
leftwhether we want to check the left or the right lane
Returns
0 if it is safe to change lane, the blocking reason otherwise

Definition at line 251 of file MSCFModel_CC.cpp.

References commitToLaneChange(), findVehicle(), MSVehicle::getCarFollowVariables(), MSNet::getCurrentTimeStep(), MSNet::getInstance(), isLeader(), isPlatoonLaneChangeSafe(), and LCA_BLOCKED.

Referenced by commitToLaneChange().

Here is the caller graph for this function:

◆ createVehicleVariables()

◆ d_i_j()

double MSCFModel_CC::d_i_j ( const struct Plexe::VEHICLE_DATA * vehicles,
const double h[MAX_N_CARS],
int i,
int j ) const
private

computes the desired distance between vehicle i and vehicle j

Parameters
[in]vehiclesdata about all vehicles
[in]hvector of times headway
[in]iindex of own vehicle
[in]jindex of vehicle to compute distance from
Returns
the desired distance between vehicle i and j

Definition at line 632 of file MSCFModel_CC.cpp.

References Plexe::VEHICLE_DATA::length, MAX_N_CARS, and Plexe::VEHICLE_DATA::speed.

Referenced by _consensus(), and getSecureGap().

Here is the caller graph for this function:

◆ distAfterTime()

double MSCFModel::distAfterTime ( double t,
double speed,
double accel ) const
virtualinherited

calculates the distance traveled after accelerating for time t

Definition at line 425 of file MSCFModel.cpp.

References ACCEL2SPEED, brakeGap(), MSGlobals::gSemiImplicitEulerUpdate, MAX2(), SPEED2DIST, and TS.

Referenced by followSpeedTransient().

Here is the caller graph for this function:

◆ duplicate()

MSCFModel * MSCFModel_CC::duplicate ( const MSVehicleType * vtype) const
virtual

Duplicates the car-following model.

Parameters
[in]vtypeThe vehicle type this model belongs to (1:1)
Returns
A duplicate of this car-following model

Implements MSCFModel.

Definition at line 1206 of file MSCFModel_CC.cpp.

References MSCFModel_CC().

◆ estimateArrivalTime() [1/2]

double MSCFModel::estimateArrivalTime ( double dist,
double initialSpeed,
double arrivalSpeed,
double maxSpeed,
double accel,
double decel )
staticinherited

Computes the time needed to travel a distance dist given an initial speed, arrival speed, constant acceleration and deceleration. The speed during traveling is assumed not to exceed the max speed.

Parameters
[in]distDistance to be covered (assumed >= 0.)
[in]initialSpeedInitial speed of vehicle
[in]arrivalSpeeddesired arrival speed of vehicle
[in]accelAssumed acceleration until reaching maxspeed.
[in]accelAssumed deceleration until reaching targetspeed.
Returns
Returns the estimated time needed to cover the given distance If distance will never be covered with the given parameters INVALID_DOUBLE (from MSLink.h) is returned.
Note
Currently, this is still a stub for actually very special situations in LC context: It is assumed that 0==initialSpeed==arrivalSpeed<=maxspeed, accel==decel>0 (because currently this is only used for lane change purposes, where lateral accel == lateral decel)

Definition at line 511 of file MSCFModel.cpp.

References UNUSED_PARAMETER.

◆ estimateArrivalTime() [2/2]

double MSCFModel::estimateArrivalTime ( double dist,
double speed,
double maxSpeed,
double accel )
staticinherited

Computes the time needed to travel a distance dist given an initial speed and constant acceleration. The speed during traveling is assumed not to exceed the max speed.

Parameters
[in]distDistance to be covered (assumed >= 0.)
[in]speedInitial speed of vehicle
[in]accelAssumed acceleration until reaching maxspeed or speed=0.
Returns
Returns the estimated time needed to cover the given distance If distance will never be covered with the given parameters INVALID_DOUBLE (from MSLink.h) is returned.

Definition at line 472 of file MSCFModel.cpp.

References INVALID_DOUBLE.

Referenced by MSLCM_SL2015::commitManoeuvre(), and MSDevice_SSM::estimateConflictTimes().

Here is the caller graph for this function:

◆ estimateSpeedAfterDistance()

double MSCFModel::estimateSpeedAfterDistance ( const double dist,
const double v,
const double accel ) const
inherited

Definition at line 787 of file MSCFModel.cpp.

References MAX2(), MIN2(), and myType.

Referenced by getMinimalArrivalSpeed(), getMinimalArrivalSpeedEuler(), MSLink::getZipperSpeed(), and MSVehicle::planMoveInternal().

Here is the caller graph for this function:

◆ finalizeSpeed()

◆ findVehicle()

MSVehicle * MSCFModel_CC::findVehicle ( std::string id) const

Searches for a vehicle given its sumo id. Differently from libsumo's getVehicle, this call does not throw an exception if the vehicle does not exist, so we can check for its existence

Parameters
idsumo vehicle id
Returns
a pointer to the vehicle if found, nullptr otherwise

Definition at line 280 of file MSCFModel_CC.cpp.

References MSNet::getInstance(), MSVehicleControl::getVehicle(), and MSNet::getVehicleControl().

Referenced by _v(), commitToLaneChange(), getRadarMeasurements(), isPlatoonLaneChangeSafe(), and setParameter().

Here is the caller graph for this function:

◆ followSpeed()

double MSCFModel_CC::followSpeed ( const MSVehicle *const veh,
double speed,
double gap2pred,
double predSpeed,
double predMaxDecel,
const MSVehicle *const pred = 0,
const CalcReason usage = CalcReason::CURRENT ) const
virtual

Computes the vehicle's safe speed (no dawdling).

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]gap2predThe (net) distance to the LEADER
[in]predSpeedThe speed of LEADER
Returns
EGO's safe speed
See also
MSCFModel::ffeV

Implements MSCFModel.

Definition at line 334 of file MSCFModel_CC.cpp.

References _v(), CC_VehicleVariables::activeController, Plexe::DRIVER, MSVehicle::getCarFollowVariables(), myHumanDriver, and UNUSED_PARAMETER.

◆ followSpeedTransient()

double MSCFModel::followSpeedTransient ( double duration,
const MSVehicle *const veh,
double speed,
double gap2pred,
double predSpeed,
double predMaxDecel ) const
virtualinherited

Computes the vehicle's follow speed that avoids a collision for the given amount of time.

Returns the velocity of the vehicle in dependence to the vehicle's and its leader's values and the distance between them.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]gap2predThe (net) distance to the LEADER
[in]predSpeedThe speed of LEADER
[in]predMaxDecelThe maximum leader deceleration
Returns
EGO's safe speed

Definition at line 375 of file MSCFModel.cpp.

References ACCEL2SPEED, brakeGap(), DIST2SPEED, distAfterTime(), gDebugFlag2, getMaxDecel(), MSGlobals::gSemiImplicitEulerUpdate, myDecel, SPEED2DIST, and TS.

◆ freeSpeed() [1/2]

double MSCFModel::freeSpeed ( const double currentSpeed,
const double decel,
const double dist,
const double maxSpeed,
const bool onInsertion,
const double actionStepLength )
staticinherited

◆ freeSpeed() [2/2]

double MSCFModel_CC::freeSpeed ( const MSVehicle *const veh,
double speed,
double seen,
double maxSpeed,
const bool onInsertion = false,
const CalcReason usage = CalcReason::CURRENT ) const
virtual

Computes the vehicle's safe speed without a leader.

Returns the velocity of the vehicle in dependence to the length of the free street and the target velocity at the end of the free range. If onInsertion is true, the vehicle may still brake before the next movement.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]seenThe look ahead distance
[in]maxSpeedThe maximum allowed speed
[in]onInsertionwhether speed at insertion is asked for
Returns
EGO's safe speed

Reimplemented from MSCFModel.

Definition at line 372 of file MSCFModel_CC.cpp.

References _v(), CC_VehicleVariables::activeController, Plexe::DRIVER, MSCFModel::freeSpeed(), MSVehicle::getCarFollowVariables(), and getRadarMeasurements().

◆ gapExtrapolation()

double MSCFModel::gapExtrapolation ( const double duration,
const double currentGap,
double v1,
double v2,
double a1 = 0,
double a2 = 0,
const double maxV1 = std::numeric_limits<double>::max(),
const double maxV2 = std::numeric_limits<double>::max() )
staticinherited

return the resulting gap if, starting with gap currentGap, two vehicles continue with constant accelerations (velocities bounded by 0 and maxSpeed) for a given timespan of length 'duration'.

Parameters
[in]currentGap(pos(veh1) - pos(veh2) at start)
[in]v1initial speed of vehicle 1
[in]v2initial speed of vehicle 2
[in]a1acceleration of vehicle 1
[in]a2acceleration of vehicle 2
[in]maxV1maximal speed of vehicle 1
[in]maxV2maximal speed of vehicle 2
[in]durationtime span for the process
Returns
estimated gap after 'duration' seconds

Definition at line 586 of file MSCFModel.cpp.

References MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MIN2(), and TS.

Referenced by MSLCM_SL2015::checkBlockingVehicles(), and MSLCM_LC2013::informFollower().

Here is the caller graph for this function:

◆ getACCAcceleration()

double MSCFModel_CC::getACCAcceleration ( const MSVehicle * veh) const

returns the ACC computed acceleration when the faked CACC is controlling the car. This can be used to check for vehicles in front

Definition at line 1190 of file MSCFModel_CC.cpp.

References _acc(), CC_VehicleVariables::accHeadwayTime, MSVehicle::getCarFollowVariables(), getRadarMeasurements(), and MSVehicle::getSpeed().

Referenced by getParameter().

Here is the caller graph for this function:

◆ getActiveController()

enum Plexe::ACTIVE_CONTROLLER MSCFModel_CC::getActiveController ( const MSVehicle * veh) const

return the currently active controller

Parameters
[in]vehthe vehicle for which the action is requested
Returns
the currently active controller

Definition at line 1173 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::activeController, and MSVehicle::getCarFollowVariables().

◆ getApparentDecel()

double MSCFModel::getApparentDecel ( ) const
inlineinherited

Get the vehicle type's apparent deceleration [m/s^2] (the one regarded by its followers.

Returns
The apparent deceleration (in m/s^2) of vehicles of this class

Definition at line 285 of file MSCFModel.h.

References myApparentDecel.

Referenced by MSVehicle::getCurrentApparentDecel().

Here is the caller graph for this function:

◆ getCACCConstantSpacing()

double MSCFModel_CC::getCACCConstantSpacing ( const MSVehicle * veh) const

returns CACC desired constant spacing

Parameters
[in]vehthe vehicle to get constant spacing of
Returns
spacing the spacing in meters

Definition at line 743 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::caccSpacing, and MSVehicle::getCarFollowVariables().

◆ getCollisionMinGapFactor()

double MSCFModel::getCollisionMinGapFactor ( ) const
inlineinherited

Get the factor of minGap that must be maintained to avoid a collision event.

Definition at line 321 of file MSCFModel.h.

References myCollisionMinGapFactor.

Referenced by MSLane::detectCollisionBetween().

Here is the caller graph for this function:

◆ getCurrentAccel()

double MSCFModel::getCurrentAccel ( const double speed) const
virtualinherited

Get the vehicle type's maximum acceleration [m/s^2].

Returns
The maximum acceleration (in m/s^2) of vehicles of this class

Definition at line 1156 of file MSCFModel.cpp.

References LinearApproxHelpers::getInterpolatedValue(), MIN2(), myAccel, myDesAccelProfile, and myMaxAccelProfile.

Referenced by MSCFModel_EIDM::_v(), MSCFModel_EIDM::getSecureGap(), MSCFModel_EIDM::interactionGap(), MSCFModel_EIDM::internalsecuregap(), MSCFModel_EIDM::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeStopSpeed(), maxNextSpeed(), MSCFModel_KraussPS::maxNextSpeed(), MSCFModel_EIDM::patchSpeedBeforeLCEIDM(), and MSCFModel_EIDM::slowToStartTerm().

Here is the caller graph for this function:

◆ getDesAccelProfile()

LinearApproxHelpers::LinearApproxMap MSCFModel::getDesAccelProfile ( ) const
inlineinherited

Get the vehicle type's desired acceleration profile depending on the velocity [m/s^2].

Returns
The desired acceleration profile (in m/s^2) of vehicles of this class

Definition at line 314 of file MSCFModel.h.

References myDesAccelProfile.

◆ getEmergencyDecel()

double MSCFModel::getEmergencyDecel ( ) const
inlineinherited

Get the vehicle type's maximal physically possible deceleration [m/s^2].

Returns
The maximal physically possible deceleration (in m/s^2) of vehicles of this class

Definition at line 277 of file MSCFModel.h.

References myEmergencyDecel.

Referenced by MSLane::checkFailure(), MSCFModel_EIDM::finalizeSpeed(), MSLink::getZipperSpeed(), MSLane::handleCollisionBetween(), MSLane::handleIntermodalCollisionBetween(), and MSVehicle::planMoveInternal().

Here is the caller graph for this function:

◆ getHeadwayTime()

virtual double MSCFModel::getHeadwayTime ( ) const
inlinevirtualinherited

Get the driver's desired headway [s].

Returns
The desired headway of this class' drivers in s

Definition at line 339 of file MSCFModel.h.

References myHeadwayTime.

Referenced by MSVehicleType::check(), MSLaneChanger::checkChange(), MSVehicle::checkRewindLinkLanes(), MSLaneChanger::computeSurplusGap(), MSVehicle::Influencer::gapControlSpeed(), getMinimalArrivalSpeed(), getMinimalArrivalSpeedEuler(), MSLink::getZipperSpeed(), MSVehicle::isLeader(), LIBSUMO_NAMESPACE::Vehicle::openGap(), MESegment::receive(), MSCalibrator::remainingVehicleCapacity(), MESegment::send(), MESegment::setSpeedForQueue(), and MSVehicle::updateBestLanes().

Here is the caller graph for this function:

◆ getImperfection()

virtual double MSCFModel::getImperfection ( ) const
inlinevirtualinherited

Get the driver's imperfection.

Returns
The imperfection of drivers of this class

Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, MSCFModel_PWag2009, and MSCFModel_SmartSK.

Definition at line 331 of file MSCFModel.h.

◆ getMaxAccel()

double MSCFModel::getMaxAccel ( ) const
inlineinherited

Get the vehicle type's maximum acceleration [m/s^2].

Returns
The maximum acceleration (in m/s^2) of vehicles of this class

Definition at line 261 of file MSCFModel.h.

References myAccel.

Referenced by MSVehicle::accelThresholdForWaiting(), MSVehicle::adaptToLeaders(), MSLaneChanger::checkOppositeStop(), MSLaneChanger::computeOvertakingTime(), MSVehicle::estimateTimeToNextStop(), MSLaneChanger::getMaxOvertakingSpeed(), getMinimalArrivalTime(), MSLink::getZipperSpeed(), MSVehicle::isLeader(), MSCFModel_CC::maxNextSpeed(), MSCFModel_KraussPS::maxNextSpeed(), MSTriggeredRerouter::overtakingTrain(), MSVehicle::planMoveInternal(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), and MSMeanData_Emissions::MSLaneMeanDataValues::write().

Here is the caller graph for this function:

◆ getMaxAccelProfile()

LinearApproxHelpers::LinearApproxMap MSCFModel::getMaxAccelProfile ( ) const
inlineinherited

Get the vehicle type's maximum acceleration profile depending on the velocity [m/s^2].

Returns
The maximum acceleration profile (in m/s^2) of vehicles of this class

Definition at line 306 of file MSCFModel.h.

References myMaxAccelProfile.

◆ getMaxDecel()

double MSCFModel::getMaxDecel ( ) const
inlineinherited

Get the vehicle type's maximal comfortable deceleration [m/s^2].

Returns
The maximal comfortable deceleration (in m/s^2) of vehicles of this class

Definition at line 269 of file MSCFModel.h.

References myDecel.

Referenced by MSLCM_LC2013::_wantsChange(), MSVehicle::adaptToOncomingLeader(), MSPModel_Striping::addCrossingVehs(), MSCriticalFollowerDistanceInfo::addFollower(), MSLCM_LC2013::anticipateFollowSpeed(), MSLink::blockedByFoe(), MSLCHelper::canSaveBlockerLength(), MSLCM_SL2015::checkBlockingVehicles(), MSLaneChanger::checkChange(), MSLane::checkForPedestrians(), MSLCM_SL2015::checkStrategicChange(), MSLCM_SL2015::commitFollowSpeed(), MSLink::computeFoeArrivalTimeBraking(), MSLaneChanger::computeOvertakingTime(), MSLaneChanger::computeSafeOppositeLength(), MSLink::couldBrakeForLeader(), MSVehicle::estimateTimeToNextStop(), followSpeedTransient(), MSLane::freeInsertion(), MSLaneChanger::getColumnleader(), MSLane::getCriticalLeader(), MSLane::getLeaderOnConsecutive(), MSLaneChanger::getMaxOvertakingSpeed(), getMinimalArrivalSpeed(), getMinimalArrivalSpeedEuler(), getMinimalArrivalTime(), MSLane::getMissingRearGap(), LIBSUMO_NAMESPACE::Vehicle::getNeighbors(), LIBSUMO_NAMESPACE::Vehicle::getNextLinks(), MSLCHelper::getSpeedPreservingSecureGap(), MSLink::getZipperSpeed(), MSIdling_Stop::idle(), MSLCM_DK2008::informBlocker(), MSLCM_LC2013::informFollower(), MSLCM_SL2015::informFollower(), MSLCM_LC2013::informLeader(), MSLCM_SL2015::informLeader(), MSLane::insertVehicle(), MSLane::isInsertionSuccess(), MSVehicle::isLeader(), MESegment::isOpen(), MSLane::lastInsertion(), MSCFModel_KraussPS::maxNextSpeed(), MSDevice_Bluelight::notifyMove(), MSLCM_LC2013::overtakeDistance(), MSVehicle::planMoveInternal(), MSVehicle::processNextStop(), MSLane::safeInsertionSpeed(), MSAbstractLaneChangeModel::setFollowerGaps(), MSAbstractLaneChangeModel::setLeaderGaps(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), MSLCM_LC2013::slowDownForBlocked(), MSVehicle::slowDownForSchedule(), MSLCHelper::updateBlockerLength(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), MSVehicle::updateState(), and MSVehicleControl::vehicleDeparted().

◆ getMinimalArrivalSpeed()

double MSCFModel::getMinimalArrivalSpeed ( double dist,
double currentSpeed ) const
inherited

Computes the minimal possible arrival speed after covering a given distance.

Parameters
[in]distDistance to be covered
[in]currentSpeedActual speed of vehicle

Definition at line 560 of file MSCFModel.cpp.

References estimateSpeedAfterDistance(), getHeadwayTime(), and getMaxDecel().

Referenced by MSVehicle::planMoveInternal().

Here is the caller graph for this function:

◆ getMinimalArrivalSpeedEuler()

double MSCFModel::getMinimalArrivalSpeedEuler ( double dist,
double currentSpeed ) const
inherited

Computes the minimal possible arrival speed after covering a given distance for Euler update.

Parameters
[in]distDistance to be covered
[in]currentSpeedActual speed of vehicle

Definition at line 567 of file MSCFModel.cpp.

References estimateSpeedAfterDistance(), getHeadwayTime(), getMaxDecel(), and INVALID_SPEED.

Referenced by MSVehicle::planMoveInternal(), and MSVehicle::registerInsertionApproach().

Here is the caller graph for this function:

◆ getMinimalArrivalTime()

SUMOTime MSCFModel::getMinimalArrivalTime ( double dist,
double currentSpeed,
double arrivalSpeed ) const
inherited

Computes the minimal time needed to cover a distance given the desired speed at arrival.

Parameters
[in]distDistance to be covered
[in]currentSpeedActual speed of vehicle
[in]arrivalSpeedDesired speed at arrival

Definition at line 451 of file MSCFModel.cpp.

References getMaxAccel(), getMaxDecel(), MAX3(), SUMO_const_haltingSpeed, and TIME2STEPS.

Referenced by MSVehicle::getArrivalTime().

Here is the caller graph for this function:

◆ getModelID()

int MSCFModel_CC::getModelID ( ) const
inlinevirtual

Returns the model's name.

Returns
The model's name
See also
MSCFModel::getModelName

Implements MSCFModel.

Definition at line 157 of file MSCFModel_CC.h.

References SUMO_TAG_CF_CC.

◆ getMyLanesCount()

int MSCFModel_CC::getMyLanesCount ( ) const

returns the number of lanes set in the configuration file

Definition at line 1201 of file MSCFModel_CC.cpp.

References myLanesCount.

◆ getParameter()

std::string MSCFModel_CC::getParameter ( const MSVehicle * veh,
const std::string & key ) const
virtual

set the information about a generic car. This method should be invoked by TraCI when a wireless message with such data is received. For testing, it might be also invoked from SUMO source code

Parameters
[in]vehthe vehicle for which the data must be saved
[in]speedthe leader speed
[in]accelerationthe leader acceleration
[in]positionthe position of the leader
[in]timethe time at which this data was read from leader's sensors

try to get the given parameter for this carFollowingModel

Parameters
[in]vehthe vehicle from which the parameter must be retrieved
[in]keythe key of the parameter
Returns
the value of the requested parameter

Reimplemented from MSCFModel.

Definition at line 1052 of file MSCFModel_CC.cpp.

References Plexe::VEHICLE_DATA::acceleration, CC_VehicleVariables::accHeadwayTime, CC_VehicleVariables::activeController, Plexe::VEHICLE_DATA::angle, CC_VehicleVariables::caccSpacing, CC_PAR_VEHICLE_DATA, CC_VehicleVariables::ccDesiredSpeed, CC_VehicleVariables::controllerAcceleration, CC_VehicleVariables::crashed, CC_VehicleVariables::engine, getACCAcceleration(), MSVehicle::getAcceleration(), MSVehicle::getAngle(), MSVehicle::getCarFollowVariables(), MSLane::getEdge(), RealisticEngineModel::getEngineData(), MSNet::getInstance(), MSVehicle::getLane(), MSEdge::getLanes(), MSLane::getLength(), MSVehicle::getPosition(), MSVehicle::getPositionOnLane(), getRadarMeasurements(), MSBaseVehicle::getRoutePtr(), MSVehicle::getSpeed(), MSVehicle::getVelocityVector(), Plexe::VEHICLE_DATA::index, Plexe::VEHICLE_DATA::length, CC_VehicleVariables::nCars, PAR_ACC_ACCELERATION, PAR_ACC_HEADWAY_TIME, PAR_ACTIVE_CONTROLLER, PAR_CACC_SPACING, PAR_CC_DESIRED_SPEED, PAR_CRASHED, PAR_DISTANCE_FROM_BEGIN, PAR_DISTANCE_TO_END, PAR_ENGINE_DATA, PAR_LANES_COUNT, PAR_RADAR_DATA, PAR_SPEED_AND_ACCELERATION, Plexe::VEHICLE_DATA::positionX, Plexe::VEHICLE_DATA::positionY, Plexe::VEHICLE_DATA::speed, Plexe::VEHICLE_DATA::speedX, Plexe::VEHICLE_DATA::speedY, STEPS2TIME, ParBuffer::str(), Plexe::VEHICLE_DATA::time, Plexe::VEHICLE_DATA::u, CC_VehicleVariables::vehicles, Position::x(), and Position::y().

Referenced by MSCFModel_CC().

Here is the caller graph for this function:

◆ getRadarMeasurements()

void MSCFModel_CC::getRadarMeasurements ( const MSVehicle * veh,
double & distance,
double & relativeSpeed ) const

return the data that is currently being measured by the radar

Definition at line 1178 of file MSCFModel_CC.cpp.

References findVehicle(), Named::getID(), MSVehicle::getSpeed(), and SUMOTrafficObject::getSpeed().

Referenced by freeSpeed(), getACCAcceleration(), getParameter(), and stopSpeed().

Here is the caller graph for this function:

◆ getSecureGap()

double MSCFModel_CC::getSecureGap ( const MSVehicle *const veh,
const MSVehicle * const ,
const double speed,
const double leaderSpeed,
const double leaderMaxDecel ) const
virtual

Returns the minimum gap to reserve if the leader is braking at maximum (>=0).

Parameters
[in]vehThe vehicle itself, for obtaining other values
[in]predThe leader vehicle, for obtaining other values
[in]speedEGO's speed
[in]leaderSpeedLEADER's speed
[in]leaderMaxDecelLEADER's max. deceleration rate

Reimplemented from MSCFModel.

Definition at line 227 of file MSCFModel_CC.cpp.

References Plexe::ACC, CC_VehicleVariables::accHeadwayTime, CC_VehicleVariables::activeController, Plexe::CACC, CC_VehicleVariables::caccSpacing, Plexe::CONSENSUS, d_i_j(), Plexe::DRIVER, Plexe::FAKED_CACC, Plexe::FLATBED, CC_VehicleVariables::flatbedD, CC_VehicleVariables::flatbedH, MSVehicle::getCarFollowVariables(), CC_VehicleVariables::h, myHumanDriver, Plexe::PLOEG, CC_VehicleVariables::ploegH, toString(), and CC_VehicleVariables::vehicles.

◆ getSpeedAfterMaxDecel()

virtual double MSCFModel::getSpeedAfterMaxDecel ( double v) const
inlinevirtualinherited

Returns the velocity after maximum deceleration.

Parameters
[in]vThe velocity
Returns
The velocity after maximum deceleration

Reimplemented in MSCFModel_Rail.

Definition at line 431 of file MSCFModel.h.

References ACCEL2SPEED, MAX2(), and myDecel.

Referenced by MSLCM_LC2013::_wantsChange(), MSCFModel_Daniel1::finalizeSpeed(), MSCFModel_SmartSK::followSpeed(), and MSCFModel_SmartSK::stopSpeed().

Here is the caller graph for this function:

◆ getStartupDelay()

SUMOTime MSCFModel::getStartupDelay ( ) const
inlineinherited

Get the vehicle type's startupDelay.

Returns
The startupDelay

Definition at line 293 of file MSCFModel.h.

References myStartupDelay.

Referenced by MSRailSignal::constraintsAllow(), MSVehicle::enterLaneAtInsertion(), MSVehicle::executeMove(), and MSDriveWay::foeDriveWayOccupied().

Here is the caller graph for this function:

◆ getVehicleInformation()

void MSCFModel_CC::getVehicleInformation ( const MSVehicle * veh,
double & speed,
double & acceleration,
double & controllerAcceleration,
Position & position,
double & time ) const

get the information about a vehicle. This can be used by TraCI in order to get speed and acceleration of the platoon leader before sending them to other vehicles

Parameters
[in]vehthe vehicle for which the data is requested
[out]speedwhere the speed is written
[out]accelerationwhere the acceleration is written
[out]controllerAccelerationthe last acceleration value computed by the controller will be written in this variable. This might be different from acceleration because of actuation lag

Definition at line 749 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::controllerAcceleration, MSVehicle::getAcceleration(), MSVehicle::getCarFollowVariables(), MSNet::getInstance(), MSVehicle::getPosition(), MSVehicle::getSpeed(), and STEPS2TIME.

Referenced by _v().

Here is the caller graph for this function:

◆ insertionFollowSpeed()

double MSCFModel_CC::insertionFollowSpeed ( const MSVehicle *const veh,
double speed,
double gap2pred,
double predSpeed,
double predMaxDecel,
const MSVehicle *const pred = 0 ) const
virtual

Overload base MSCFModel::insertionFollowSpeed method to inject automated vehicles as soon as they are requested, without checking for safe speed constraints.

Reimplemented from MSCFModel.

Definition at line 347 of file MSCFModel_CC.cpp.

References UNUSED_PARAMETER.

◆ insertionStopSpeed()

double MSCFModel::insertionStopSpeed ( const MSVehicle *const veh,
double speed,
double gap ) const
virtualinherited

Computes the vehicle's safe speed for approaching an obstacle at insertion without constraints due to acceleration capabilities and previous speeds.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]gapThe (net) distance to the obstacle
Returns
EGO's safe speed for approaching a non-moving obstacle at insertion
See also
stopSpeed() and insertionFollowSpeed()

Reimplemented in MSCFModel_EIDM, and MSCFModel_IDM.

Definition at line 365 of file MSCFModel.cpp.

References FUTURE, MSGlobals::gSemiImplicitEulerUpdate, maximumSafeStopSpeed(), MIN2(), myDecel, myType, and stopSpeed().

Referenced by MSCFModel_IDM::insertionStopSpeed(), and MSLane::isInsertionSuccess().

Here is the caller graph for this function:

◆ interactionGap()

double MSCFModel_CC::interactionGap ( const MSVehicle * const veh,
double vL ) const
virtual

Returns the maximum gap at which an interaction between both vehicles occurs.

"interaction" means that the LEADER influences EGO's speed.

Parameters
[in]vehThe EGO vehicle
[in]vLLEADER's speed
Returns
The interaction gap
Todo
evaluate signature
See also
MSCFModel::interactionGap

Reimplemented from MSCFModel.

Definition at line 387 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::activeController, Plexe::DRIVER, MSVehicle::getCarFollowVariables(), and myHumanDriver.

◆ interpolateProfile()

double MSCFModel::interpolateProfile ( const double speed,
const std::vector< std::pair< double, double > > profile ) const
virtualinherited

Get current interpolated value from a profile.

Definition at line 279 of file MSCFModel.cpp.

◆ isLeader()

bool MSCFModel_CC::isLeader ( const MSVehicle * veh) const

Returns whether a vehicle is a leader of a platoon or not. By default, a vehicle on its own using an ACC is a leader of itself.

Parameters
vehvehicle to check
Returns
true if leader

Definition at line 1211 of file MSCFModel_CC.cpp.

References MSVehicle::getCarFollowVariables().

Referenced by commitToLaneChange().

Here is the caller graph for this function:

◆ isPlatoonLaneChangeSafe()

int MSCFModel_CC::isPlatoonLaneChangeSafe ( const MSVehicle * veh,
bool left ) const

computes whether a lane change for a whole platoon is safe or not. This is done by checking the lane change state and neighbors of all vehicles in the platoon added through the addPlatoonMember API. If the adjacent lane is free and there is enough safe gap for the platoon, the method returns 0, otherwise it returns the blocking reason

Parameters
vehvehicle for which the check should be made. If the method is invoked on a member, such member invokes the same method recursively on its leader. The leader in turn asks all member for their status
leftwhether we want to check the left or the right lane
Returns
0 if it is safe to change lane, the blocking reason otherwise

Definition at line 126 of file MSCFModel_CC.cpp.

References findVehicle(), MSVehicle::getCarFollowVariables(), Named::getID(), CC_VehicleVariables::isLeader, isPlatoonLaneChangeSafe(), LCA_BLOCKED, LCA_BLOCKED_BY_LEFT_FOLLOWER, LCA_BLOCKED_BY_LEFT_LEADER, LCA_BLOCKED_BY_RIGHT_FOLLOWER, LCA_BLOCKED_BY_RIGHT_LEADER, CC_VehicleVariables::leaderVehicle, CC_VehicleVariables::leaderVehicleId, and CC_VehicleVariables::members.

Referenced by commitToLaneChange(), isPlatoonLaneChangeSafe(), performAutoLaneChange(), and performPlatoonLaneChange().

Here is the caller graph for this function:

◆ maximumLaneSpeedCF()

virtual double MSCFModel::maximumLaneSpeedCF ( const MSVehicle *const veh,
double maxSpeed,
double maxSpeedLane ) const
inlinevirtualinherited

Returns the maximum velocity the CF-model wants to achieve in the next step.

Parameters
[in]maxSpeedThe maximum achievable speed in the next step
[in]maxSpeedLaneThe maximum speed the vehicle wants to drive on this lane (Speedlimit*SpeedFactor)

Reimplemented in MSCFModel_CACC, and MSCFModel_EIDM.

Definition at line 229 of file MSCFModel.h.

References applyOwnSpeedPerceptionError(), and MIN2().

Referenced by MSVehicle::planMoveInternal().

Here is the caller graph for this function:

◆ maximumSafeFollowSpeed()

double MSCFModel::maximumSafeFollowSpeed ( double gap,
double egoSpeed,
double predSpeed,
double predMaxDecel,
bool onInsertion = false ) const
inherited

Returns the maximum safe velocity for following the given leader.

Parameters
[in]gap2predThe (net) distance to the LEADER
[in]egoSpeedThe FOLLOWERS's speed
[in]predSpeedThe LEADER's speed
[in]predMaxDecelThe LEADER's maximum deceleration
[in]onInsertionIndicator whether the call is triggered during vehicle insertion
Returns
the safe velocity

Returns the SK-vsafe.

Definition at line 947 of file MSCFModel.cpp.

References ACCEL2SPEED, brakeGap(), calculateEmergencyDeceleration(), DEBUG_COND2, EMERGENCY_DECEL_AMPLIFIER, MSGlobals::gComputeLC, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), maximumSafeStopSpeed(), MIN2(), myDecel, myEmergencyDecel, myHeadwayTime, SIMTIME, and SPEED2ACCEL.

Referenced by MSLCM_LC2013::anticipateFollowSpeed(), MSCFModel_ACC::followSpeed(), MSCFModel_CACC::followSpeed(), MSCFModel_Krauss::followSpeed(), MSCFModel_KraussOrig1::followSpeed(), insertionFollowSpeed(), and MSCFModel_CACC::insertionFollowSpeed().

Here is the caller graph for this function:

◆ maximumSafeStopSpeed()

double MSCFModel::maximumSafeStopSpeed ( double gap,
double decel,
double currentSpeed,
bool onInsertion = false,
double headway = -1,
bool relaxEmergency = true ) const
inherited

Returns the maximum next velocity for stopping within gap.

Parameters
[in]gapThe (net) distance to the desired stopping point
[in]decelThe desired deceleration rate
[in]currentSpeedThe current speed of the ego vehicle
[in]onInsertionIndicator whether the call is triggered during vehicle insertion
[in]headwayThe desired time headway to be included in the calculations (default argument -1 induces the use of myHeadway)
[in]relaxEmergencyWhether emergency deceleration should be reduced (at the cost of staying in a dangerous situation for longer)

Definition at line 796 of file MSCFModel.cpp.

References ACCEL2SPEED, calculateEmergencyDeceleration(), EMERGENCY_DECEL_AMPLIFIER, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), maximumSafeStopSpeedBallistic(), maximumSafeStopSpeedEuler(), MIN2(), myDecel, myEmergencyDecel, SIMTIME, and SPEED2ACCEL.

Referenced by MSLCM_LC2013::anticipateFollowSpeed(), MSCFModel_Rail::followSpeed(), MSVehicle::handleCollisionStop(), insertionStopSpeed(), maximumSafeFollowSpeed(), MSVehicle::planMoveInternal(), MSCFModel_ACC::stopSpeed(), MSCFModel_CACC::stopSpeed(), MSCFModel_IDM::stopSpeed(), MSCFModel_Krauss::stopSpeed(), MSCFModel_Rail::stopSpeed(), MSCFModel_W99::stopSpeed(), and MSCFModel_Wiedemann::stopSpeed().

Here is the caller graph for this function:

◆ maximumSafeStopSpeedBallistic()

double MSCFModel::maximumSafeStopSpeedBallistic ( double gap,
double decel,
double currentSpeed,
bool onInsertion = false,
double headway = -1 ) const
inherited

Returns the maximum next velocity for stopping within gap when using the ballistic positional update.

Note
This takes into account the driver's reaction time tau (i.e. the desired headway) and the car's current speed. (The latter is required to calculate the distance covered in the following timestep.)
Parameters
[in]gapThe (net) distance to the desired stopping point
[in]decelThe desired deceleration rate
[in]currentSpeedThe current speed of the ego vehicle
[in]onInsertionIndicator whether the call is triggered during vehicle insertion
[in]headwayThe desired time headway to be included in the calculations (default argument -1 induces the use of myHeadway)
Returns
the safe velocity (to be attained at the end of the following time step) that assures the possibility of stopping within gap. If a negative value is returned, the required stop has to take place before the end of the time step.

Definition at line 877 of file MSCFModel.cpp.

References ACCEL2SPEED, MAX2(), myEmergencyDecel, myHeadwayTime, and TS.

Referenced by maximumSafeStopSpeed(), MSCFModel_EIDM::maximumSafeStopSpeed(), and MSCFModel_KraussOrig1::stopSpeed().

Here is the caller graph for this function:

◆ maximumSafeStopSpeedEuler()

double MSCFModel::maximumSafeStopSpeedEuler ( double gap,
double decel,
bool onInsertion,
double headway ) const
inherited

Returns the maximum next velocity for stopping within gap when using the semi-implicit Euler update.

Parameters
[in]gapThe (net) distance to the LEADER
[in]decelThe desired deceleration rate
[in]onInsertionIndicator whether the call is triggered during vehicle insertion
[in]headwayThe desired time headway to be included in the calculations (-1 induces the use of myHeadway)

Definition at line 849 of file MSCFModel.cpp.

References ACCEL2SPEED, myHeadwayTime, n, and TS.

Referenced by maximumSafeStopSpeed().

Here is the caller graph for this function:

◆ maxNextSafeMin()

virtual double MSCFModel::maxNextSafeMin ( double speed,
const MSVehicle *const veh = 0 ) const
inlinevirtualinherited

Returns the maximum speed given the current speed and regarding driving dynamics.

Parameters
[in]speedThe vehicle's current speed
[in]speedThe vehicle itself, for obtaining other values
Returns
The maximum possible speed for the next step taking driving dynamics into account

Reimplemented in MSCFModel_EIDM.

Definition at line 375 of file MSCFModel.h.

References maxNextSpeed().

◆ maxNextSpeed()

double MSCFModel_CC::maxNextSpeed ( double speed,
const MSVehicle *const veh ) const
virtual

Returns the maximum speed given the current speed.

The implementation of this method must take into account the time step duration.

Justification: Due to air brake or other influences, the vehicle's next maximum speed may depend on the vehicle's current speed (given).

Parameters
[in]speedThe vehicle's current speed
[in]vehThe vehicle itself, for obtaining other values
Returns
The maximum possible speed for the next step

Reimplemented from MSCFModel.

Definition at line 400 of file MSCFModel_CC.cpp.

References ACCEL2SPEED, CC_ENGINE_MODEL_FOLM, CC_VehicleVariables::engineModel, MSVehicle::getCarFollowVariables(), and MSCFModel::getMaxAccel().

◆ minNextSpeed()

double MSCFModel_CC::minNextSpeed ( double speed,
const MSVehicle *const veh = 0 ) const
virtual

Returns the minimum speed given the current speed (depends on the numerical update scheme and its step width) Note that it wouldn't have to depend on the numerical update scheme if the semantics would rely on acceleration instead of velocity.

Parameters
[in]speedThe vehicle's current speed
[in]speedThe vehicle itself, for obtaining other values, if needed as e.g. road conditions.
Returns
The minimum possible speed for the next step

Reimplemented from MSCFModel.

Definition at line 410 of file MSCFModel_CC.cpp.

References ACCEL2SPEED, CC_ENGINE_MODEL_FOLM, CC_VehicleVariables::engineModel, MSVehicle::getCarFollowVariables(), MAX2(), and MSCFModel::minNextSpeed().

◆ minNextSpeedEmergency()

double MSCFModel::minNextSpeedEmergency ( double speed,
const MSVehicle *const veh = 0 ) const
virtualinherited

Returns the minimum speed after emergency braking, given the current speed (depends on the numerical update scheme and its step width) Note that it wouldn't have to depend on the numerical update scheme if the semantics would rely on acceleration instead of velocity.

Parameters
[in]speedThe vehicle's current speed
[in]speedThe vehicle itself, for obtaining other values, if needed as e.g. road conditions.
Returns
The minimum possible speed for the next step

Reimplemented in MSCFModel_Rail.

Definition at line 331 of file MSCFModel.cpp.

References ACCEL2SPEED, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), and myEmergencyDecel.

Referenced by finalizeSpeed(), MSCFModel_EIDM::finalizeSpeed(), MSCFModel_Krauss::followSpeed(), and MSVehicle::Influencer::implicitSpeedRemote().

Here is the caller graph for this function:

◆ operator=()

MSCFModel_CC & MSCFModel_CC::operator= ( const MSCFModel_CC & )
privatedelete

Invalidated assignment operator.

References MSCFModel_CC().

◆ passingTime()

double MSCFModel::passingTime ( const double lastPos,
const double passedPos,
const double currentPos,
const double lastSpeed,
const double currentSpeed )
staticinherited

Calculates the time at which the position passedPosition has been passed In case of a ballistic update, the possibility of a stop within a time step requires more information about the last time-step than in case of the euler update to determine the last position if the currentSpeed is zero.

Parameters
[in]lastPosthe position at time t=0 (must be < currentPos)
[in]passedPosthe position for which the passing time is to be determined (has to lie within [lastPos, currentPos]!)
[in]currentPosthe position at time t=TS (one time-step after lastPos) (must be > lastPos)
[in]lastSpeedthe speed at moment t=0
[in]currentSpeedthe speed at moment t=TS
Returns
time t in [0,TS] at which passedPos in [lastPos, currentPos] was passed.

Definition at line 680 of file MSCFModel.cpp.

References MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MIN2(), SPEED2ACCEL, TS, and WRITE_ERROR.

Referenced by MSE2Collector::calculateTimeLossAndTimeOnDetector(), MSDevice_SSM::checkConflictEntryAndExit(), MSE3Collector::MSE3EntryReminder::notifyMove(), MSE3Collector::MSE3LeaveReminder::notifyMove(), MSInductLoop::notifyMove(), MSInstantInductLoop::notifyMove(), and MSMeanData::MeanDataValues::notifyMove().

Here is the caller graph for this function:

◆ patchSpeedBeforeLC()

virtual double MSCFModel::patchSpeedBeforeLC ( const MSVehicle * veh,
double vMin,
double vMax ) const
inlinevirtualinherited

apply custom speed adaptations within the given speed bounds

Reimplemented in MSCFModel_Krauss, MSCFModel_KraussOrig1, MSCFModel_KraussX, MSCFModel_PWag2009, and MSCFModel_SmartSK.

Definition at line 104 of file MSCFModel.h.

References UNUSED_PARAMETER.

Referenced by finalizeSpeed().

Here is the caller graph for this function:

◆ performAutoLaneChange()

void MSCFModel_CC::performAutoLaneChange ( MSVehicle *const veh) const
private

Check whether a platoon would gain speed by moving to the left or whether it should move to the right after an overtake and, if safe, do so. This method is invoked when the platoon auto lane change mechanism is enabled through the enableAutoLaneChanging API.

Parameters
vehleader vehicle of the platoon

Definition at line 190 of file MSCFModel_CC.cpp.

References changeWholePlatoonLane(), Named::getID(), isPlatoonLaneChangeSafe(), LCA_KEEPRIGHT, LCA_LEFT, LCA_RIGHT, and LCA_SPEEDGAIN.

Referenced by finalizeSpeed().

Here is the caller graph for this function:

◆ performPlatoonLaneChange()

void MSCFModel_CC::performPlatoonLaneChange ( MSVehicle *const veh) const
private

If safe to do so, moves a platoon to a user-desired lane. If not safe, this method continues to try at each simulation step. This method is invoked when the user requests a platoon to change lane through the performPlatoonLaneChange API, or when invoking the old setFixedLane API on a single vehicle.

Parameters
vehleader vehicle of the platoon

Definition at line 212 of file MSCFModel_CC.cpp.

References changeWholePlatoonLane(), MSVehicle::getCarFollowVariables(), MSVehicle::getLaneIndex(), and isPlatoonLaneChangeSafe().

Referenced by finalizeSpeed().

Here is the caller graph for this function:

◆ recomputeParameters()

void MSCFModel_CC::recomputeParameters ( const MSVehicle * veh) const
private

Recomputes controller related parameters after setting them.

Definition at line 1150 of file MSCFModel_CC.cpp.

References CC_VehicleVariables::caccAlpha1, CC_VehicleVariables::caccAlpha2, CC_VehicleVariables::caccAlpha3, CC_VehicleVariables::caccAlpha4, CC_VehicleVariables::caccAlpha5, CC_VehicleVariables::caccC1, CC_VehicleVariables::caccOmegaN, CC_VehicleVariables::caccXi, and MSVehicle::getCarFollowVariables().

Referenced by setParameter().

Here is the caller graph for this function:

◆ resetConsensus()

void MSCFModel_CC::resetConsensus ( const MSVehicle * veh) const
private

Resets the consensus controller. In particular, sets the "initialized" vector all to false. This might be useful when changing topology.

Definition at line 1159 of file MSCFModel_CC.cpp.

References MSVehicle::getCarFollowVariables(), CC_VehicleVariables::initialized, MAX_N_CARS, and CC_VehicleVariables::nInitialized.

◆ setApparentDecel()

virtual void MSCFModel::setApparentDecel ( double decel)
inlinevirtualinherited

Sets a new value for the apparent deceleration [m/s^2].

Parameters
[in]decelThe new deceleration in m/s^2

Definition at line 580 of file MSCFModel.h.

References myApparentDecel.

◆ setCollisionMinGapFactor()

void MSCFModel::setCollisionMinGapFactor ( const double factor)
inlineinherited

Sets a new value for the factor of minGap that must be maintained to avoid a collision event.

Parameters
[in]factorThe new minGap factor

Definition at line 588 of file MSCFModel.h.

References myCollisionMinGapFactor.

Referenced by MSDevice_Bluelight::notifyMove().

Here is the caller graph for this function:

◆ setDesAccelProfile()

virtual void MSCFModel::setDesAccelProfile ( const LinearApproxHelpers::LinearApproxMap & accelProfile)
inlinevirtualinherited

Sets a new value for desired acceleration profile [m/s^2].

Parameters
[in]accelProfileThe new acceleration profile in m/s^2

Definition at line 603 of file MSCFModel.h.

References myDesAccelProfile.

◆ setEmergencyDecel()

virtual void MSCFModel::setEmergencyDecel ( double decel)
inlinevirtualinherited

Sets a new value for maximal physically possible deceleration [m/s^2].

Parameters
[in]decelThe new deceleration in m/s^2

Definition at line 572 of file MSCFModel.h.

References myEmergencyDecel.

Referenced by MSCFModel_Rail::MSCFModel_Rail().

Here is the caller graph for this function:

◆ setHeadwayTime()

virtual void MSCFModel::setHeadwayTime ( double headwayTime)
inlinevirtualinherited

Sets a new value for desired headway [s].

Parameters
[in]headwayTimeThe new desired headway (in s)

Reimplemented in MSCFModel_CACC, MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.

Definition at line 619 of file MSCFModel.h.

References myHeadwayTime.

Referenced by MSVehicle::Influencer::gapControlSpeed().

Here is the caller graph for this function:

◆ setImperfection()

virtual void MSCFModel::setImperfection ( double imperfection)
inlinevirtualinherited

Sets a new value for driver imperfection.

Parameters
[in]accelThe new driver imperfection

Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.

Definition at line 611 of file MSCFModel.h.

References UNUSED_PARAMETER.

◆ setLeader()

void MSCFModel_CC::setLeader ( MSVehicle * veh,
MSVehicle *const leader,
std::string leaderId ) const

Sets the leader for a member of the platoon.

Parameters
vehplatoon member
leaderplatoon leader
leaderIdplatoon leader id

Definition at line 112 of file MSCFModel_CC.cpp.

References MSVehicle::getCarFollowVariables().

◆ setMaxAccel()

virtual void MSCFModel::setMaxAccel ( double accel)
inlinevirtualinherited

Sets a new value for maximum acceleration [m/s^2].

Parameters
[in]accelThe new acceleration in m/s^2

Definition at line 556 of file MSCFModel.h.

References myAccel.

◆ setMaxAccelProfile()

virtual void MSCFModel::setMaxAccelProfile ( const LinearApproxHelpers::LinearApproxMap & accelProfile)
inlinevirtualinherited

Sets a new value for maximum acceleration profile [m/s^2].

Parameters
[in]accelProfileThe new acceleration profile in m/s^2

Definition at line 596 of file MSCFModel.h.

References myMaxAccelProfile.

◆ setMaxDecel()

virtual void MSCFModel::setMaxDecel ( double decel)
inlinevirtualinherited

Sets a new value for maximal comfortable deceleration [m/s^2].

Parameters
[in]decelThe new deceleration in m/s^2

Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.

Definition at line 564 of file MSCFModel.h.

References myDecel.

Referenced by MSLCM_SL2015::commitFollowSpeed(), and MSCFModel_Rail::MSCFModel_Rail().

Here is the caller graph for this function:

◆ setParameter()

void MSCFModel_CC::setParameter ( MSVehicle * veh,
const std::string & key,
const std::string & value ) const
virtual

try to set the given parameter for this carFollowingModel

Parameters
[in]vehthe vehicle for which the parameter must be set
[in]keythe key of the parameter
[in]valuethe value to be set for the given parameter

Reimplemented from MSCFModel.

Definition at line 758 of file MSCFModel_CC.cpp.

References Plexe::VEHICLE_DATA::acceleration, CC_VehicleVariables::accHeadwayTime, CC_VehicleVariables::activeController, Plexe::VEHICLE_DATA::angle, CC_VehicleVariables::autoFeed, CC_VehicleVariables::autoLaneChange, CC_VehicleVariables::caccC1, CC_VehicleVariables::caccInitialized, CC_VehicleVariables::caccOmegaN, CC_VehicleVariables::caccSpacing, CC_VehicleVariables::caccXi, CC_ENGINE_MODEL_FOLM, CC_ENGINE_MODEL_REALISTIC, CC_PAR_CACC_C1, CC_PAR_CACC_OMEGA_N, CC_PAR_CACC_XI, CC_PAR_ENGINE_TAU, CC_PAR_FLATBED_D, CC_PAR_FLATBED_H, CC_PAR_FLATBED_KA, CC_PAR_FLATBED_KP, CC_PAR_FLATBED_KV, CC_PAR_PLATOON_SIZE, CC_PAR_PLOEG_H, CC_PAR_PLOEG_KD, CC_PAR_PLOEG_KP, CC_PAR_UMAX, CC_PAR_UMIN, CC_PAR_VEHICLE_DATA, CC_PAR_VEHICLE_ENGINE_MODEL, CC_PAR_VEHICLE_MODEL, CC_PAR_VEHICLE_POSITION, CC_PAR_VEHICLES_FILE, CC_VehicleVariables::ccDesiredSpeed, CC_VehicleVariables::engine, ENGINE_PAR_DT, ENGINE_PAR_VEHICLE, ENGINE_PAR_XMLFILE, CC_VehicleVariables::engineModel, CC_VehicleVariables::engineTau, CC_VehicleVariables::fakeData, findVehicle(), CC_VehicleVariables::fixedAcceleration, CC_VehicleVariables::flatbedD, CC_VehicleVariables::flatbedH, CC_VehicleVariables::flatbedKa, CC_VehicleVariables::flatbedKp, CC_VehicleVariables::flatbedKv, FOLM_PAR_DT, FOLM_PAR_TAU, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontAcceleration, CC_VehicleVariables::frontAcceleration, CC_VehicleVariables::frontAngle, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontControllerAcceleration, CC_VehicleVariables::frontControllerAcceleration, CC_VehicleVariables::frontDataReadTime, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontDistance, CC_VehicleVariables::frontInitialized, CC_VehicleVariables::frontPosition, CC_VehicleVariables::FAKE_CONTROLLER_DATA::frontSpeed, CC_VehicleVariables::frontSpeed, CC_VehicleVariables::frontVehicle, CC_VehicleVariables::frontVehicleId, CC_VehicleVariables::frontVelocity, MSVehicle::getCarFollowVariables(), Named::getID(), MSVehicle::getInfluencer(), Plexe::VEHICLE_DATA::index, CC_VehicleVariables::initialized, invalid_return< std::string >::value, CC_VehicleVariables::isLeader, ParBuffer::last_empty(), CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderAcceleration, CC_VehicleVariables::leaderAcceleration, CC_VehicleVariables::leaderAngle, CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderControllerAcceleration, CC_VehicleVariables::leaderControllerAcceleration, CC_VehicleVariables::leaderDataReadTime, CC_VehicleVariables::leaderInitialized, CC_VehicleVariables::leaderPosition, CC_VehicleVariables::FAKE_CONTROLLER_DATA::leaderSpeed, CC_VehicleVariables::leaderSpeed, CC_VehicleVariables::leaderVehicle, CC_VehicleVariables::leaderVehicleId, CC_VehicleVariables::leaderVelocity, Plexe::VEHICLE_DATA::length, MAX_N_CARS, CC_VehicleVariables::members, MSCFModel_CC(), MSCFModel::myAccel, MSCFModel::myDecel, CC_VehicleVariables::nCars, CC_VehicleVariables::nInitialized, PAR_ACC_HEADWAY_TIME, PAR_ACTIVE_CONTROLLER, PAR_ADD_MEMBER, PAR_CACC_SPACING, PAR_CC_DESIRED_SPEED, PAR_ENABLE_AUTO_LANE_CHANGE, PAR_FIXED_ACCELERATION, PAR_FRONT_FAKE_DATA, PAR_LEADER_FAKE_DATA, PAR_LEADER_SPEED_AND_ACCELERATION, PAR_PLATOON_FIXED_LANE, PAR_PRECEDING_SPEED_AND_ACCELERATION, PAR_REMOVE_MEMBER, PAR_USE_AUTO_FEEDING, PAR_USE_CONTROLLER_ACCELERATION, PAR_USE_PREDICTION, CC_VehicleVariables::platoonFixedLane, CC_VehicleVariables::ploegH, CC_VehicleVariables::ploegKd, CC_VehicleVariables::ploegKp, CC_VehicleVariables::position, Plexe::VEHICLE_DATA::positionX, Plexe::VEHICLE_DATA::positionY, recomputeParameters(), GenericEngineModel::setMaximumAcceleration(), GenericEngineModel::setMaximumDeceleration(), GenericEngineModel::setParameter(), MSVehicle::Influencer::setSpeedMode(), Plexe::VEHICLE_DATA::speed, Plexe::VEHICLE_DATA::speedX, Plexe::VEHICLE_DATA::speedY, Plexe::VEHICLE_DATA::time, StringUtils::toDouble(), StringUtils::toInt(), TS, Plexe::VEHICLE_DATA::u, CC_VehicleVariables::uMax, CC_VehicleVariables::uMin, CC_VehicleVariables::useControllerAcceleration, CC_VehicleVariables::useFixedAcceleration, CC_VehicleVariables::usePrediction, CC_VehicleVariables::vehicles, and WRITE_WARNING.

◆ speedAfterTime()

double MSCFModel::speedAfterTime ( const double t,
const double oldSpeed,
const double dist )
staticinherited

Calculates the speed after a time t \in [0,TS] given the initial speed and the distance traveled in an interval of step length TS.

Note
If the acceleration were known, this would be much nicer, but in this way we need to reconstruct it (for the ballistic update at least, where we assume that a stop may occur within the interval)
Parameters
[in]ttime in [0,TS] for which the speed shall be determined
[in]oldSpeedspeed before the last time step (referred to as t == 0)
[in]distancecovered
Returns
speed at time t

Definition at line 758 of file MSCFModel.cpp.

References DIST2SPEED, MSGlobals::gSemiImplicitEulerUpdate, and TS.

Referenced by MSE2Collector::calculateTimeLossAndTimeOnDetector(), MSInstantInductLoop::notifyMove(), and MSMeanData::MeanDataValues::notifyMove().

Here is the caller graph for this function:

◆ startupDelayStopped()

virtual bool MSCFModel::startupDelayStopped ( ) const
inlinevirtualinherited

whether startupDelay should be applied after stopping

Reimplemented in MSCFModel_Rail.

Definition at line 344 of file MSCFModel.h.

◆ stopSpeed() [1/2]

double MSCFModel::stopSpeed ( const MSVehicle *const veh,
const double speed,
double gap,
const CalcReason usage = CalcReason::CURRENT ) const
inlineinherited

Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling).

Returns the velocity of the vehicle when approaching a static object (such as the end of a lane) assuming no reaction time is needed.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]gapThe (net) distance to the obstacle
[in]usageWhat the return value is used for
Returns
EGO's safe speed for approaching a non-moving obstacle
Todo
generic Interface, models can call for the values they need

Definition at line 173 of file MSCFModel.h.

References CURRENT, myDecel, and stopSpeed().

Referenced by MSLCM_LC2013::_patchSpeed(), MSLCM_SL2015::_patchSpeed(), MSVehicle::adaptToJunctionLeader(), MSVehicle::adaptToLeader(), MSVehicle::adaptToOncomingLeader(), applyHeadwayPerceptionError(), MSLane::checkForPedestrians(), LIBSUMO_NAMESPACE::Vehicle::getStopSpeed(), insertionStopSpeed(), MSLane::isInsertionSuccess(), MSLCM_DK2008::patchSpeed(), MSVehicle::planMoveInternal(), MSVehicle::processNextStop(), and stopSpeed().

Here is the caller graph for this function:

◆ stopSpeed() [2/2]

double MSCFModel_CC::stopSpeed ( const MSVehicle *const veh,
const double speed,
double gap2pred,
double decel,
const CalcReason usage = CalcReason::CURRENT ) const
virtual

Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling).

Parameters
[in]vehThe vehicle (EGO)
[in]gap2predThe (net) distance to the obstacle
Returns
EGO's safe speed for approaching a non-moving obstacle
See also
MSCFModel::ffeS
Todo
generic Interface, models can call for the values they need

Implements MSCFModel.

Definition at line 357 of file MSCFModel_CC.cpp.

References _v(), CC_VehicleVariables::activeController, Plexe::DRIVER, MSVehicle::getCarFollowVariables(), getRadarMeasurements(), and myHumanDriver.

◆ switchOnACC()

void MSCFModel_CC::switchOnACC ( const MSVehicle * veh,
double ccDesiredSpeed ) const

switch on the ACC, so disabling the human driver car control

Parameters
[in]vehthe vehicle for which the ACC must be switched on
[in]ccDesiredSpeedthe cruise control speed

Definition at line 1167 of file MSCFModel_CC.cpp.

References Plexe::ACC, CC_VehicleVariables::activeController, CC_VehicleVariables::ccDesiredSpeed, and MSVehicle::getCarFollowVariables().

Field Documentation

◆ myAccel

◆ myApparentDecel

double MSCFModel::myApparentDecel
protectedinherited

The vehicle's deceleration as expected by surrounding traffic [m/s^2].

Definition at line 750 of file MSCFModel.h.

Referenced by getApparentDecel(), MSCFModel(), and setApparentDecel().

◆ myC1

const double MSCFModel_CC::myC1
private

design constant for CACC

Definition at line 445 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myCcAccel

const double MSCFModel_CC::myCcAccel
private

The maximum acceleration that the CC can output.

Definition at line 433 of file MSCFModel_CC.h.

Referenced by _cc(), and MSCFModel_CC().

◆ myCcDecel

const double MSCFModel_CC::myCcDecel
private

The maximum deceleration that the CC can output.

Definition at line 430 of file MSCFModel_CC.h.

Referenced by _cc(), and MSCFModel_CC().

◆ myCollisionMinGapFactor

◆ myConstantSpacing

const double MSCFModel_CC::myConstantSpacing
private

the constant gap for CACC

Definition at line 436 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myDecel

double MSCFModel::myDecel
protectedinherited

The vehicle's maximum deceleration [m/s^2].

Definition at line 746 of file MSCFModel.h.

Referenced by MSCFModel_EIDM::_v(), MSCFModel_Kerner::_v(), MSCFModel_Wiedemann::_v(), MSCFModel_Daniel1::_vsafe(), MSCFModel_SmartSK::_vsafe(), brakeGap(), MSCFModel_EIDM::brakeGap(), MSCFModel_CC::createVehicleVariables(), MSCFModel_PWag2009::followSpeed(), MSCFModel_Rail::followSpeed(), followSpeedTransient(), freeSpeed(), MSCFModel_EIDM::freeSpeed(), MSCFModel_IDM::freeSpeed(), MSCFModel_Rail::freeSpeed(), getMaxDecel(), getSecureGap(), MSCFModel_EIDM::getSecureGap(), getSpeedAfterMaxDecel(), insertionStopSpeed(), MSCFModel_EIDM::insertionStopSpeed(), MSCFModel_IDM::insertionStopSpeed(), interactionGap(), MSCFModel_EIDM::interactionGap(), MSCFModel_IDM::interactionGap(), MSCFModel_EIDM::internalsecuregap(), maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), maximumSafeStopSpeed(), MSCFModel_EIDM::maximumSafeStopSpeed(), minNextSpeed(), MSCFModel_IDM::minNextSpeed(), MSCFModel(), MSCFModel_Daniel1::MSCFModel_Daniel1(), MSCFModel_IDM::MSCFModel_IDM(), MSCFModel_Kerner::MSCFModel_Kerner(), MSCFModel_KraussOrig1::MSCFModel_KraussOrig1(), MSCFModel_PWag2009::MSCFModel_PWag2009(), MSCFModel_SmartSK::MSCFModel_SmartSK(), MSCFModel_Wiedemann::MSCFModel_Wiedemann(), MSCFModel_EIDM::patchSpeedBeforeLCEIDM(), MSCFModel_Daniel1::setHeadwayTime(), MSCFModel_KraussOrig1::setHeadwayTime(), MSCFModel_SmartSK::setHeadwayTime(), setMaxDecel(), MSCFModel_Daniel1::setMaxDecel(), MSCFModel_KraussOrig1::setMaxDecel(), MSCFModel_SmartSK::setMaxDecel(), MSCFModel_CC::setParameter(), stopSpeed(), MSCFModel_PWag2009::stopSpeed(), and MSCFModel_KraussOrig1::vsafe().

◆ myDesAccelProfile

LinearApproxHelpers::LinearApproxMap MSCFModel::myDesAccelProfile
protectedinherited

The vehicle's desired acceleration profile [m/s^2].

Definition at line 764 of file MSCFModel.h.

Referenced by getCurrentAccel(), getDesAccelProfile(), MSCFModel(), and setDesAccelProfile().

◆ myEmergencyDecel

◆ myFlatbedD

const double MSCFModel_CC::myFlatbedD
private

Definition at line 470 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myFlatbedH

const double MSCFModel_CC::myFlatbedH
private

Definition at line 469 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myFlatbedKa

const double MSCFModel_CC::myFlatbedKa
private

flatbed CACC parameters

Definition at line 466 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myFlatbedKp

const double MSCFModel_CC::myFlatbedKp
private

Definition at line 468 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myFlatbedKv

const double MSCFModel_CC::myFlatbedKv
private

Definition at line 467 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myHeadwayTime

◆ myHumanDriver

MSCFModel* MSCFModel_CC::myHumanDriver
private

the car following model which drives the car when automated cruising is disabled, i.e., the human driver

Definition at line 427 of file MSCFModel_CC.h.

Referenced by finalizeSpeed(), followSpeed(), getSecureGap(), interactionGap(), MSCFModel_CC(), and stopSpeed().

◆ myKp

const double MSCFModel_CC::myKp
private

design constant for CC

Definition at line 439 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myLambda

const double MSCFModel_CC::myLambda
private

design constant for ACC

Definition at line 442 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myLanesCount

const int MSCFModel_CC::myLanesCount
private

number of lanes in the highway, in the absence of on-/off-ramps. This is used to move to the correct lane even when a lane is added for on-/off-ramps

Definition at line 458 of file MSCFModel_CC.h.

Referenced by getMyLanesCount(), and MSCFModel_CC().

◆ myMaxAccelProfile

LinearApproxHelpers::LinearApproxMap MSCFModel::myMaxAccelProfile
protectedinherited

The vehicle's maximum acceleration profile [m/s^2].

Definition at line 761 of file MSCFModel.h.

Referenced by getCurrentAccel(), getMaxAccelProfile(), MSCFModel(), and setMaxAccelProfile().

◆ myOmegaN

const double MSCFModel_CC::myOmegaN
private

design constant for CACC

Definition at line 451 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myPloegH

const double MSCFModel_CC::myPloegH
private

Ploeg's CACC parameters.

Definition at line 461 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myPloegKd

const double MSCFModel_CC::myPloegKd
private

Definition at line 463 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myPloegKp

const double MSCFModel_CC::myPloegKp
private

Definition at line 462 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myStartupDelay

SUMOTime MSCFModel::myStartupDelay
protectedinherited

The startup delay after halting [s].

Definition at line 758 of file MSCFModel.h.

Referenced by applyStartupDelay(), MSCFModel_EIDM::finalizeSpeed(), getStartupDelay(), MSCFModel(), and MSCFModel_EIDM::slowToStartTerm().

◆ myTau

const double MSCFModel_CC::myTau
private

engine time constant used for actuation lag

Definition at line 454 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().

◆ myType

◆ myXi

const double MSCFModel_CC::myXi
private

design constant for CACC

Definition at line 448 of file MSCFModel_CC.h.

Referenced by createVehicleVariables(), and MSCFModel_CC().


The documentation for this class was generated from the following files: