Eclipse SUMO - Simulation of Urban MObility
|
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>
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 |
VehicleVariables * | createVehicleVariables () 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 | |
MSCFModel * | duplicate (const MSVehicleType *vtype) const |
Duplicates the car-following model. | |
double | estimateSpeedAfterDistance (const double dist, const double v, const double accel) const |
MSVehicle * | findVehicle (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. | |
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]. | |
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 | |
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 | 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]. | |
double | myEmergencyDecel |
The vehicle's maximum emergency deceleration [m/s^2]. | |
double | myHeadwayTime |
The driver's desired time headway (aka reaction time tau) [s]. | |
SUMOTime | myStartupDelay |
The startup delay after halting [s]. | |
const MSVehicleType * | myType |
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_CC & | operator= (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 |
MSCFModel * | myHumanDriver |
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) |
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.
Definition at line 57 of file MSCFModel_CC.h.
|
inherited |
What the return value of stop/follow/free-Speed is used for.
Definition at line 77 of file MSCFModel.h.
MSCFModel_CC::MSCFModel_CC | ( | const MSVehicleType * | vtype | ) |
Constructor.
[in] | accel | The maximum acceleration that controllers can output (def. 1.5 m/s^2) |
[in] | decel | The maximum deceleration that ACC and CACC controllers can output (def. 6 m/s^2) |
[in] | ccDecel | The maximum deceleration that the CC can output (def. 1.5 m/s^2) |
[in] | headwayTime | the headway gap for ACC (be aware of instabilities) (def. 1.5 s) |
[in] | constantSpacing | the constant gap for CACC (def. 5 m) |
[in] | kp | design constant for CC (def. 1) |
[in] | lambda | design constant for ACC (def. 0.1) |
[in] | c1 | design constant for CACC (def. 0.5) |
[in] | xi | design constant for CACC (def. 1) |
[in] | omegaN | design constant for CACC (def. 0.2) |
[in] | tau | engine time constant used for actuation lag (def. 0.5 s) |
[in] | lanesCount | number of lanes of the highway |
[in] | ccAccel | the maximum acceleration the CC can apply |
Definition at line 44 of file MSCFModel_CC.cpp.
References myHumanDriver, myLanesCount, and TL.
MSCFModel_CC::~MSCFModel_CC | ( | ) |
Destructor.
Definition at line 74 of file MSCFModel_CC.cpp.
|
private |
controller for the ACC which computes the acceleration to be applied. the value needs to be passed to the actuator
[in] | egoSpeed | vehicle current speed |
[in] | desSpeed | vehicle desired speed |
[in] | gap2pred | the distance to preceding vehicle |
[in] | headwayTime | the headway time ACC should maintain |
Definition at line 599 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::accLambda, and MSVehicle::getCarFollowVariables().
Referenced by _v(), and getACCAcceleration().
|
private |
controller for the CACC which computes the acceleration to be applied. the value needs to be passed to the actuator
[in] | egoSpeed | vehicle current speed |
[in] | desSpeed | vehicle desired speed |
[in] | predAcceleration | acceleration of preceding vehicle |
[in] | gap2pred | the distance to preceding vehicle |
[in] | leaderSpeed | the speed of the platoon leader |
[in] | leaderAcceleration | the acceleration of the platoon leader |
[in] | spacing | the spacing to be kept |
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().
|
private |
controller for the CC which computes the acceleration to be applied. the value needs to be passed to the actuator
[in] | egoSpeed | vehicle current speed |
[in] | desSpeed | vehicle desired speed |
Definition at line 590 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::ccKp, MSVehicle::getCarFollowVariables(), myCcAccel, and myCcDecel.
Referenced by _v().
|
private |
controller based on consensus strategy
[in] | egoSpeed | vehicle current speed |
[in] | egoPosition | vehicle current position |
[in] | time | current time |
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().
|
private |
flatbed platoon towing model
[in] | egoAcceleration | vehicle current acceleration |
[in] | egoSpeed | vehicle current speed |
[in] | predSpeed | front vehicle speed |
[in] | gap2pred | distance to front vehicle |
[in] | leaderSpeed | speed 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().
|
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.
[in] | egoSpeed | vehicle current speed |
[in] | predSpeed | the speed of the front vehicle |
[in] | predAcceleration | acceleration of preceding vehicle |
[in] | gap2pred | the distance to preceding vehicle |
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().
|
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().
|
protectedinherited |
Overwrites gap2pred and predSpeed by the perceived values obtained from the vehicle's driver state,.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in,out] | gap2pred | The (net) distance to the LEADER |
[in,out] | predSpeed | The speed of LEADER |
[in] | pred | The leading vehicle (LEADER) |
Definition at line 1063 of file MSCFModel.cpp.
References DEBUG_COND, MSCFModel::followSpeed(), MSCFModel::FUTURE, MSVehicle::getDriverState(), Named::getID(), MSVehicle::hasDriverState(), SIMTIME, SPEED2ACCEL, and UNUSED_PARAMETER.
Referenced by MSCFModel_CACC::followSpeed(), MSCFModel_IDM::followSpeed(), and MSCFModel_Krauss::followSpeed().
|
protectedinherited |
Overwrites gap by the perceived value obtained from the vehicle's driver state.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in,out] | gap | The (net) distance to the obstacle |
Definition at line 1099 of file MSCFModel.cpp.
References DEBUG_COND, MSCFModel::FUTURE, MSVehicle::getDriverState(), Named::getID(), MSVehicle::hasDriverState(), SIMTIME, SPEED2ACCEL, MSCFModel::stopSpeed(), and UNUSED_PARAMETER.
Referenced by MSCFModel_IDM::stopSpeed(), MSCFModel_CACC::stopSpeed(), and MSCFModel_Krauss::stopSpeed().
|
protectedinherited |
Overwrites sped by the perceived values obtained from the vehicle's driver state,.
[in] | veh | The vehicle (EGO) |
[in,out] | speed | The vehicle's speed |
Definition at line 1054 of file MSCFModel.cpp.
References MSVehicle::getDriverState(), and MSVehicle::hasDriverState().
Referenced by MSCFModel::maximumLaneSpeedCF(), and MSCFModel_CACC::maximumLaneSpeedCF().
|
virtualinherited |
apply speed adaptation on startup
Definition at line 257 of file MSCFModel.cpp.
References DELTA_T, MSVehicle::getSpeed(), MSVehicle::getTimeSinceStartup(), MSCFModel::myStartupDelay, SUMO_const_haltingSpeed, and UNUSED_PARAMETER.
Referenced by MSCFModel::finalizeSpeed(), and MSCFModel_EIDM::finalizeSpeed().
|
staticinherited |
Computes the acceleration needed to arrive not before the given time.
[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 |
Definition at line 521 of file MSCFModel.cpp.
Referenced by MSLCM_SL2015::commitManoeuvre().
|
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.
[in] | speed | The vehicle's current speed |
Definition at line 380 of file MSCFModel.h.
References MSCFModel::brakeGap(), MSCFModel::myDecel, and MSCFModel::myHeadwayTime.
Referenced by MSCFModel_Wiedemann::_v(), MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), MSVehicle::adaptToOncomingLeader(), MSPModel_Striping::addCrossingVehs(), MSLane::addLeaders(), MSCFModel::brakeGap(), MSCFModel_EIDM::brakeGap(), MSLCHelper::canSaveBlockerLength(), MSLaneChanger::checkChange(), MSLane::checkFailure(), MSVehicle::checkReversal(), MSVehicle::checkRewindLinkLanes(), MSLaneChanger::computeSafeOppositeLength(), MSCFModel::distAfterTime(), MSCFModel::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(), MSCFModel::getSecureGap(), MSLink::getZipperSpeed(), MSLane::handleCollisionBetween(), MSLane::handleIntermodalCollisionBetween(), MSIdling_Stop::idle(), MSLCM_SL2015::informLeader(), MSLCM_LC2013::informLeader(), MSLane::isInsertionSuccess(), MSVehicle::isLeader(), MSLane::lastInsertion(), MSCFModel::maximumSafeFollowSpeed(), MSDevice_StationFinder::notifyMove(), GUIBaseVehicle::GUIBaseVehiclePopupMenu::onCmdToggleStop(), MSVehicle::planMoveInternal(), MSLCM_SL2015::preventSliding(), MSVehicle::processLinkApproaches(), MSVehicle::unsafeLinkAhead(), MSVehicle::updateBestLanes(), and MSLCHelper::updateBlockerLength().
|
virtualinherited |
Reimplemented in MSCFModel_EIDM.
Definition at line 75 of file MSCFModel.cpp.
References MSCFModel::brakeGapEuler(), and MSGlobals::gSemiImplicitEulerUpdate.
|
staticinherited |
Definition at line 90 of file MSCFModel.cpp.
References ACCEL2SPEED, and SPEED2DIST.
Referenced by MSCFModel::brakeGap(), and MSLCM_SL2015::computeSpeedLat().
|
inherited |
Returns the minimal deceleration for following the given leader safely.
[in] | gap | The (net) distance to the LEADER |
[in] | egoSpeed | The FOLLOWERS's speed |
[in] | predSpeed | The LEADER's speed |
[in] | predMaxDecel | The LEADER's maximum deceleration |
Definition at line 1002 of file MSCFModel.cpp.
References DEBUG_COND2, MSCFModel::myEmergencyDecel, and SIMTIME.
Referenced by MSCFModel::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), and MSCFModel::maximumSafeStopSpeed().
|
private |
Moves an entire platoon on an adjacent lane, calling changeLane() on all members.
veh | leader 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().
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.
veh | vehicle 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 |
left | whether we want to check the left or the right lane |
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 MSLCM_LC2013_CC::checkChangeBeforeCommitting(), and commitToLaneChange().
|
virtual |
Returns model specific values which are stored inside a vehicle and must be used with casting.
Reimplemented from MSCFModel.
Definition at line 77 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::accLambda, CC_VehicleVariables::caccAlpha1, CC_VehicleVariables::caccAlpha2, CC_VehicleVariables::caccAlpha3, CC_VehicleVariables::caccAlpha4, CC_VehicleVariables::caccAlpha5, CC_VehicleVariables::caccC1, CC_VehicleVariables::caccOmegaN, CC_VehicleVariables::caccSpacing, CC_VehicleVariables::caccXi, CC_ENGINE_MODEL_FOLM, CC_VehicleVariables::ccKp, CC_VehicleVariables::engine, CC_VehicleVariables::engineModel, CC_VehicleVariables::engineTau, CC_VehicleVariables::flatbedD, CC_VehicleVariables::flatbedH, CC_VehicleVariables::flatbedKa, CC_VehicleVariables::flatbedKp, CC_VehicleVariables::flatbedKv, FOLM_PAR_DT, FOLM_PAR_TAU, MSCFModel::myAccel, myC1, myConstantSpacing, MSCFModel::myDecel, myFlatbedD, myFlatbedH, myFlatbedKa, myFlatbedKp, myFlatbedKv, myKp, myLambda, myOmegaN, myPloegH, myPloegKd, myPloegKp, myTau, myXi, CC_VehicleVariables::ploegH, CC_VehicleVariables::ploegKd, CC_VehicleVariables::ploegKp, GenericEngineModel::setMaximumAcceleration(), GenericEngineModel::setMaximumDeceleration(), GenericEngineModel::setParameter(), and TS.
|
private |
computes the desired distance between vehicle i and vehicle j
[in] | vehicles | data about all vehicles |
[in] | h | vector of times headway |
[in] | i | index of own vehicle |
[in] | j | index of vehicle to compute distance from |
Definition at line 632 of file MSCFModel_CC.cpp.
References Plexe::VEHICLE_DATA::length, and Plexe::VEHICLE_DATA::speed.
Referenced by _consensus(), and getSecureGap().
|
virtualinherited |
calculates the distance traveled after accelerating for time t
Definition at line 403 of file MSCFModel.cpp.
References ACCEL2SPEED, MSCFModel::brakeGap(), MSGlobals::gSemiImplicitEulerUpdate, MAX2(), SPEED2DIST, and TS.
Referenced by MSCFModel::followSpeedTransient().
|
virtual |
Duplicates the car-following model.
[in] | vtype | The vehicle type this model belongs to (1:1) |
Implements MSCFModel.
Definition at line 1206 of file MSCFModel_CC.cpp.
|
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.
[in] | dist | Distance to be covered (assumed >= 0.) |
[in] | initialSpeed | Initial speed of vehicle |
[in] | arrivalSpeed | desired arrival speed of vehicle |
[in] | accel | Assumed acceleration until reaching maxspeed. |
[in] | accel | Assumed deceleration until reaching targetspeed. |
Definition at line 489 of file MSCFModel.cpp.
References UNUSED_PARAMETER.
|
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.
[in] | dist | Distance to be covered (assumed >= 0.) |
[in] | speed | Initial speed of vehicle |
[in] | accel | Assumed acceleration until reaching maxspeed or speed=0. |
Definition at line 450 of file MSCFModel.cpp.
References INVALID_DOUBLE.
Referenced by MSLCM_SL2015::commitManoeuvre(), and MSDevice_SSM::estimateConflictTimes().
|
inherited |
Definition at line 765 of file MSCFModel.cpp.
References MSVehicleType::getMaxSpeed(), MAX2(), MIN2(), and MSCFModel::myType.
Referenced by MSCFModel::getMinimalArrivalSpeed(), MSCFModel::getMinimalArrivalSpeedEuler(), MSLink::getZipperSpeed(), and MSVehicle::planMoveInternal().
|
virtual |
Applies interaction with stops and lane changing model influences.
[in] | veh | The ego vehicle |
[in] | vPos | The possible velocity |
Reimplemented from MSCFModel.
Definition at line 285 of file MSCFModel_CC.cpp.
References ACCEL2SPEED, CC_VehicleVariables::activeController, CC_VehicleVariables::autoLaneChange, CC_VehicleVariables::ccDesiredSpeed, CC_VehicleVariables::controllerAcceleration, CC_VehicleVariables::crashed, Plexe::DRIVER, CC_VehicleVariables::engine, MSCFModel::finalizeSpeed(), MSVehicle::getAcceleration(), MSVehicle::getCarFollowVariables(), MSNet::getCurrentTimeStep(), MSNet::getInstance(), MSVehicle::getLane(), GenericEngineModel::getRealAcceleration(), MSVehicle::getSpeed(), MSLane::getSpeedLimit(), MSBaseVehicle::getStops(), MAX2(), myHumanDriver, performAutoLaneChange(), performPlatoonLaneChange(), CC_VehicleVariables::platoonFixedLane, MSVehicle::processNextStop(), MSBaseVehicle::setChosenSpeedFactor(), SPEED2ACCEL, CC_VehicleVariables::uMax, CC_VehicleVariables::uMin, and CC_VehicleVariables::useFixedAcceleration.
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
id | sumo vehicle id |
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().
|
virtual |
Computes the vehicle's safe speed (no dawdling)
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in] | gap2pred | The (net) distance to the LEADER |
[in] | predSpeed | The speed of LEADER |
Implements MSCFModel.
Definition at line 334 of file MSCFModel_CC.cpp.
References _v(), CC_VehicleVariables::activeController, Plexe::DRIVER, MSCFModel::followSpeed(), MSVehicle::getCarFollowVariables(), myHumanDriver, and UNUSED_PARAMETER.
|
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.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in] | gap2pred | The (net) distance to the LEADER |
[in] | predSpeed | The speed of LEADER |
[in] | predMaxDecel | The maximum leader deceleration |
Definition at line 353 of file MSCFModel.cpp.
References ACCEL2SPEED, MSCFModel::brakeGap(), DIST2SPEED, MSCFModel::distAfterTime(), gDebugFlag2, MSCFModel::getMaxDecel(), MSGlobals::gSemiImplicitEulerUpdate, MSCFModel::myDecel, SPEED2DIST, and TS.
Referenced by MSLCM_SL2015::commitFollowSpeed().
|
staticinherited |
Definition at line 100 of file MSCFModel.cpp.
References ACCEL2DIST, ACCEL2SPEED, DIST2SPEED, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), SPEED2DIST, and TS.
|
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.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in] | seen | The look ahead distance |
[in] | maxSpeed | The maximum allowed speed |
[in] | onInsertion | whether speed at insertion is asked for |
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().
|
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'.
[in] | currentGap | (pos(veh1) - pos(veh2) at start) |
[in] | v1 | initial speed of vehicle 1 |
[in] | v2 | initial speed of vehicle 2 |
[in] | a1 | acceleration of vehicle 1 |
[in] | a2 | acceleration of vehicle 2 |
[in] | maxV1 | maximal speed of vehicle 1 |
[in] | maxV2 | maximal speed of vehicle 2 |
[in] | duration | time span for the process |
Definition at line 564 of file MSCFModel.cpp.
References MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MIN2(), and TS.
Referenced by MSLCM_SL2015::checkBlockingVehicles(), and MSLCM_LC2013::informFollower().
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().
enum Plexe::ACTIVE_CONTROLLER MSCFModel_CC::getActiveController | ( | const MSVehicle * | veh | ) | const |
return the currently active controller
[in] | veh | the vehicle for which the action is requested |
Definition at line 1173 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::activeController, and MSVehicle::getCarFollowVariables().
|
inlineinherited |
Get the vehicle type's apparent deceleration [m/s^2] (the one regarded by its followers.
Definition at line 280 of file MSCFModel.h.
References MSCFModel::myApparentDecel.
Referenced by MSVehicle::getCurrentApparentDecel(), and MSVehicleType::setApparentDecel().
double MSCFModel_CC::getCACCConstantSpacing | ( | const MSVehicle * | veh | ) | const |
returns CACC desired constant spacing
[in] | veh | the vehicle to get constant spacing of |
Definition at line 743 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::caccSpacing, and MSVehicle::getCarFollowVariables().
|
inlineinherited |
Get the factor of minGap that must be maintained to avoid a collision event.
Definition at line 293 of file MSCFModel.h.
References MSCFModel::myCollisionMinGapFactor.
Referenced by MSLane::detectCollisionBetween().
|
inlineinherited |
Get the vehicle type's maximal physically possible deceleration [m/s^2].
Definition at line 272 of file MSCFModel.h.
References MSCFModel::myEmergencyDecel.
Referenced by MSLane::checkFailure(), MSLCM_SL2015::commitManoeuvre(), MSCFModel_EIDM::finalizeSpeed(), MSLink::getZipperSpeed(), MSLane::handleCollisionBetween(), MSLane::handleIntermodalCollisionBetween(), MSVehicle::planMoveInternal(), and MSVehicleType::setEmergencyDecel().
|
inlinevirtualinherited |
Get the driver's desired headway [s].
Definition at line 311 of file MSCFModel.h.
References MSCFModel::myHeadwayTime.
Referenced by MSVehicleType::check(), MSLaneChanger::checkChange(), MSVehicle::checkRewindLinkLanes(), MSLaneChanger::computeSurplusGap(), MSVehicle::Influencer::gapControlSpeed(), MSCFModel::getMinimalArrivalSpeed(), MSCFModel::getMinimalArrivalSpeedEuler(), MSVehicle::isLeader(), LIBSUMO_NAMESPACE::Vehicle::openGap(), MESegment::receive(), MSCalibrator::remainingVehicleCapacity(), MSDevice_ToC::requestToC(), MESegment::send(), MSVehicleType::setTau(), and MSVehicle::updateBestLanes().
|
inlinevirtualinherited |
Get the driver's imperfection.
Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, MSCFModel_PWag2009, and MSCFModel_SmartSK.
Definition at line 303 of file MSCFModel.h.
Referenced by MSVehicleType::setImperfection().
|
inlineinherited |
Get the vehicle type's maximum acceleration [m/s^2].
Definition at line 256 of file MSCFModel.h.
References MSCFModel::myAccel.
Referenced by MSVehicle::accelThresholdForWaiting(), MSDevice_GLOSA::adaptSpeed(), MSVehicle::adaptToLeaders(), MSLCM_LC2013::anticipateFollowSpeed(), MSLaneChanger::checkOppositeStop(), MSLCM_SL2015::commitManoeuvre(), MSLaneChanger::computeOvertakingTime(), MSDevice_GLOSA::distance_at_continuous_accel(), MSDevice_GLOSA::earliest_arrival(), MSVehicle::estimateTimeToNextStop(), MSLaneChanger::getMaxOvertakingSpeed(), MSCFModel::getMinimalArrivalTime(), MSLink::getZipperSpeed(), MSVehicle::isLeader(), MSCFModel::maxNextSpeed(), maxNextSpeed(), MSCFModel_KraussPS::maxNextSpeed(), MSVehicle::planMoveInternal(), MSVehicleType::setAccel(), MSDevice_ToC::setState(), MSDevice_GLOSA::time_to_junction_at_continuous_accel(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), and MSMeanData_Emissions::MSLaneMeanDataValues::write().
|
inlineinherited |
Get the vehicle type's maximal comfortable deceleration [m/s^2].
Definition at line 264 of file MSCFModel.h.
References MSCFModel::myDecel.
Referenced by MSLCM_LC2013::_wantsChange(), MSDevice_GLOSA::adaptSpeed(), MSLCM_LC2013::adaptSpeedToPedestrians(), MSVehicle::adaptToOncomingLeader(), MSPModel_Striping::addCrossingVehs(), MSCriticalFollowerDistanceInfo::addFollower(), MSLCM_LC2013::anticipateFollowSpeed(), MSLink::blockedByFoe(), MSLCHelper::canSaveBlockerLength(), MSLCM_SL2015::checkBlockingVehicles(), MSLaneChanger::checkChange(), MSLane::checkForPedestrians(), MSVehicle::checkRewindLinkLanes(), MSLCM_SL2015::checkStrategicChange(), MSLCM_SL2015::commitFollowSpeed(), MSLink::computeFoeArrivalTimeBraking(), MSLaneChanger::computeOvertakingTime(), MSLaneChanger::computeSafeOppositeLength(), MSLink::couldBrakeForLeader(), MSVehicle::estimateTimeToNextStop(), MSCFModel::followSpeedTransient(), MSLane::freeInsertion(), MSLaneChanger::getColumnleader(), MSLane::getCriticalLeader(), MSLane::getLeaderOnConsecutive(), MSLaneChanger::getMaxOvertakingSpeed(), MSCFModel::getMinimalArrivalSpeed(), MSCFModel::getMinimalArrivalSpeedEuler(), MSCFModel::getMinimalArrivalTime(), MSLane::getMissingRearGap(), LIBSUMO_NAMESPACE::Vehicle::getNeighbors(), LIBSUMO_NAMESPACE::Vehicle::getNextLinks(), MSLCHelper::getSpeedPreservingSecureGap(), MSLink::getZipperSpeed(), MSIdling_Stop::idle(), MSLCM_DK2008::informBlocker(), MSLCM_SL2015::informFollower(), MSLCM_LC2013::informFollower(), MSLCM_SL2015::informLeader(), MSLCM_LC2013::informLeader(), MSLane::insertVehicle(), MSLane::isInsertionSuccess(), MSVehicle::isLeader(), MESegment::isOpen(), MSLane::lastInsertion(), MSCFModel_KraussPS::maxNextSpeed(), MSDevice_Bluelight::notifyMove(), MSLCM_LC2013::overtakeDistance(), MSVehicle::planMoveInternal(), MSVehicle::processLinkApproaches(), MSVehicle::processNextStop(), MSAbstractLaneChangeModel::remainingTime(), MSLane::safeInsertionSpeed(), GUIVehicle::selectBlockingFoes(), MSVehicleType::setDecel(), MSAbstractLaneChangeModel::setFollowerGaps(), MSAbstractLaneChangeModel::setLeaderGaps(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), MSLCM_LC2013::slowDownForBlocked(), MSLCM_SL2015::slowDownForBlocked(), MSVehicle::slowDownForSchedule(), MSLCHelper::updateBlockerLength(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), MSVehicle::updateState(), MSVehicleControl::vehicleDeparted(), MSLCM_DK2008::wantsChangeToLeft(), and MSLCM_DK2008::wantsChangeToRight().
|
inherited |
Computes the minimal possible arrival speed after covering a given distance.
[in] | dist | Distance to be covered |
[in] | currentSpeed | Actual speed of vehicle |
Definition at line 538 of file MSCFModel.cpp.
References MSCFModel::estimateSpeedAfterDistance(), MSCFModel::getHeadwayTime(), and MSCFModel::getMaxDecel().
Referenced by MSVehicle::planMoveInternal().
|
inherited |
Computes the minimal possible arrival speed after covering a given distance for Euler update.
[in] | dist | Distance to be covered |
[in] | currentSpeed | Actual speed of vehicle |
Definition at line 545 of file MSCFModel.cpp.
References MSCFModel::estimateSpeedAfterDistance(), MSCFModel::getHeadwayTime(), MSCFModel::getMaxDecel(), and INVALID_SPEED.
Referenced by MSVehicle::planMoveInternal(), and MSVehicle::registerInsertionApproach().
|
inherited |
Computes the minimal time needed to cover a distance given the desired speed at arrival.
[in] | dist | Distance to be covered |
[in] | currentSpeed | Actual speed of vehicle |
[in] | arrivalSpeed | Desired speed at arrival |
Definition at line 429 of file MSCFModel.cpp.
References MSCFModel::getMaxAccel(), MSCFModel::getMaxDecel(), MAX3(), SUMO_const_haltingSpeed, and TIME2STEPS.
Referenced by MSVehicle::getArrivalTime().
|
inlinevirtual |
Returns the model's name.
Implements MSCFModel.
Definition at line 157 of file MSCFModel_CC.h.
References SUMO_TAG_CF_CC.
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.
|
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
[in] | veh | the vehicle for which the data must be saved |
[in] | speed | the leader speed |
[in] | acceleration | the leader acceleration |
[in] | position | the position of the leader |
[in] | time | the time at which this data was read from leader's sensors |
try to get the given parameter for this carFollowingModel
[in] | veh | the vehicle from which the parameter must be retrieved |
[in] | key | the key of the 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().
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().
|
virtual |
Returns the minimum gap to reserve if the leader is braking at maximum (>=0)
[in] | veh | The vehicle itself, for obtaining other values |
[in] | pred | The leader vehicle, for obtaining other values |
[in] | speed | EGO's speed |
[in] | leaderSpeed | LEADER's speed |
[in] | leaderMaxDecel | LEADER'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(), MSCFModel::getSecureGap(), CC_VehicleVariables::h, myHumanDriver, Plexe::PLOEG, CC_VehicleVariables::ploegH, toString(), and CC_VehicleVariables::vehicles.
|
inlinevirtualinherited |
Returns the velocity after maximum deceleration.
[in] | v | The velocity |
Reimplemented in MSCFModel_Rail.
Definition at line 403 of file MSCFModel.h.
References ACCEL2SPEED, MAX2(), and MSCFModel::myDecel.
Referenced by MSLCM_LC2013::_wantsChange(), MSCFModel_Daniel1::finalizeSpeed(), MSCFModel_SmartSK::followSpeed(), and MSCFModel_SmartSK::stopSpeed().
|
inlineinherited |
Get the vehicle type's startupDelay.
Definition at line 287 of file MSCFModel.h.
References MSCFModel::myStartupDelay.
Referenced by MSRailSignal::constraintsAllow(), MSVehicle::executeMove(), and MSDriveWay::foeDriveWayOccupied().
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
[in] | veh | the vehicle for which the data is requested |
[out] | speed | where the speed is written |
[out] | acceleration | where the acceleration is written |
[out] | controllerAcceleration | the 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().
|
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.
|
virtualinherited |
Computes the vehicle's safe speed for approaching an obstacle at insertion without constraints due to acceleration capabilities and previous speeds.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in] | gap | The (net) distance to the obstacle |
Reimplemented in MSCFModel_EIDM, and MSCFModel_IDM.
Definition at line 343 of file MSCFModel.cpp.
References MSCFModel::FUTURE, MSVehicleType::getMaxSpeed(), MSGlobals::gSemiImplicitEulerUpdate, MSCFModel::maximumSafeStopSpeed(), MIN2(), MSCFModel::myDecel, MSCFModel::myType, and MSCFModel::stopSpeed().
Referenced by MSCFModel_IDM::insertionStopSpeed(), and MSLane::isInsertionSuccess().
|
virtual |
Returns the maximum gap at which an interaction between both vehicles occurs.
"interaction" means that the LEADER influences EGO's speed.
[in] | veh | The EGO vehicle |
[in] | vL | LEADER's speed |
Reimplemented from MSCFModel.
Definition at line 387 of file MSCFModel_CC.cpp.
References CC_VehicleVariables::activeController, Plexe::DRIVER, MSVehicle::getCarFollowVariables(), MSCFModel::interactionGap(), and myHumanDriver.
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.
veh | vehicle to check |
Definition at line 1211 of file MSCFModel_CC.cpp.
References MSVehicle::getCarFollowVariables().
Referenced by commitToLaneChange().
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
veh | vehicle 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 |
left | whether we want to check the left or the right lane |
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().
|
inlinevirtualinherited |
Returns the maximum velocity the CF-model wants to achieve in the next step.
[in] | maxSpeed | The maximum achievable speed in the next step |
[in] | maxSpeedLane | The maximum speed the vehicle wants to drive on this lane (Speedlimit*SpeedFactor) |
Reimplemented in MSCFModel_CACC, and MSCFModel_EIDM.
Definition at line 224 of file MSCFModel.h.
References MSCFModel::applyOwnSpeedPerceptionError(), and MIN2().
Referenced by MSVehicle::planMoveInternal().
|
inherited |
Returns the maximum safe velocity for following the given leader.
[in] | gap2pred | The (net) distance to the LEADER |
[in] | egoSpeed | The FOLLOWERS's speed |
[in] | predSpeed | The LEADER's speed |
[in] | predMaxDecel | The LEADER's maximum deceleration |
[in] | onInsertion | Indicator whether the call is triggered during vehicle insertion |
Returns the SK-vsafe.
Definition at line 922 of file MSCFModel.cpp.
References ACCEL2SPEED, MSCFModel::brakeGap(), MSCFModel::calculateEmergencyDeceleration(), DEBUG_COND2, EMERGENCY_DECEL_AMPLIFIER, MSGlobals::gComputeLC, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MSCFModel::maximumSafeStopSpeed(), MIN2(), MSCFModel::myDecel, MSCFModel::myEmergencyDecel, MSCFModel::myHeadwayTime, SIMTIME, and SPEED2ACCEL.
Referenced by MSLCM_LC2013::anticipateFollowSpeed(), MSCFModel_ACC::followSpeed(), MSCFModel_CACC::followSpeed(), MSCFModel_Krauss::followSpeed(), MSCFModel_KraussOrig1::followSpeed(), MSCFModel_CACC::insertionFollowSpeed(), and MSCFModel::insertionFollowSpeed().
|
inherited |
Returns the maximum next velocity for stopping within gap.
[in] | gap | The (net) distance to the desired stopping point |
[in] | decel | The desired deceleration rate |
[in] | currentSpeed | The current speed of the ego vehicle |
[in] | onInsertion | Indicator whether the call is triggered during vehicle insertion |
[in] | headway | The desired time headway to be included in the calculations (default argument -1 induces the use of myHeadway) |
[in] | relaxEmergency | Whether emergency deceleration should be reduced (at the cost of staying in a dangerous situation for longer) |
Definition at line 774 of file MSCFModel.cpp.
References ACCEL2SPEED, MSCFModel::calculateEmergencyDeceleration(), EMERGENCY_DECEL_AMPLIFIER, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MSCFModel::maximumSafeStopSpeedBallistic(), MSCFModel::maximumSafeStopSpeedEuler(), MIN2(), MSCFModel::myDecel, MSCFModel::myEmergencyDecel, SIMTIME, and SPEED2ACCEL.
Referenced by MSLCM_LC2013::anticipateFollowSpeed(), MSCFModel_Rail::followSpeed(), MSVehicle::handleCollisionStop(), MSCFModel::insertionStopSpeed(), MSCFModel::maximumSafeFollowSpeed(), MSVehicle::planMoveInternal(), MSCFModel_IDM::stopSpeed(), MSCFModel_Rail::stopSpeed(), MSCFModel_W99::stopSpeed(), MSCFModel_Wiedemann::stopSpeed(), MSCFModel_ACC::stopSpeed(), MSCFModel_CACC::stopSpeed(), and MSCFModel_Krauss::stopSpeed().
|
inherited |
Returns the maximum next velocity for stopping within gap when using the ballistic positional update.
[in] | gap | The (net) distance to the desired stopping point |
[in] | decel | The desired deceleration rate |
[in] | currentSpeed | The current speed of the ego vehicle |
[in] | onInsertion | Indicator whether the call is triggered during vehicle insertion |
[in] | headway | The desired time headway to be included in the calculations (default argument -1 induces the use of myHeadway) |
Definition at line 855 of file MSCFModel.cpp.
References ACCEL2SPEED, MAX2(), MSCFModel::myEmergencyDecel, MSCFModel::myHeadwayTime, and TS.
Referenced by MSCFModel_EIDM::maximumSafeStopSpeed(), MSCFModel::maximumSafeStopSpeed(), and MSCFModel_KraussOrig1::stopSpeed().
|
inherited |
Returns the maximum next velocity for stopping within gap when using the semi-implicit Euler update.
[in] | gap | The (net) distance to the LEADER |
[in] | decel | The desired deceleration rate |
[in] | onInsertion | Indicator whether the call is triggered during vehicle insertion |
[in] | headway | The desired time headway to be included in the calculations (-1 induces the use of myHeadway) |
Definition at line 827 of file MSCFModel.cpp.
References ACCEL2SPEED, MSCFModel::myHeadwayTime, and TS.
Referenced by MSCFModel::maximumSafeStopSpeed().
|
inlinevirtualinherited |
Returns the maximum speed given the current speed and regarding driving dynamics.
[in] | speed | The vehicle's current speed |
[in] | speed | The vehicle itself, for obtaining other values |
Reimplemented in MSCFModel_EIDM.
Definition at line 347 of file MSCFModel.h.
References MSCFModel::maxNextSpeed().
|
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).
[in] | speed | The vehicle's current speed |
[in] | veh | The vehicle itself, for obtaining other values |
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().
|
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.
[in] | speed | The vehicle's current speed |
[in] | speed | The vehicle itself, for obtaining other values, if needed as e.g. road conditions. |
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().
|
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.
[in] | speed | The vehicle's current speed |
[in] | speed | The vehicle itself, for obtaining other values, if needed as e.g. road conditions. |
Reimplemented in MSCFModel_Rail.
Definition at line 309 of file MSCFModel.cpp.
References ACCEL2SPEED, MSGlobals::gSemiImplicitEulerUpdate, MAX2(), and MSCFModel::myEmergencyDecel.
Referenced by MSLCM_LC2013::_patchSpeed(), MSLCM_SL2015::_patchSpeed(), MSCFModel::finalizeSpeed(), MSCFModel_EIDM::finalizeSpeed(), MSCFModel_Krauss::followSpeed(), and MSVehicle::Influencer::implicitSpeedRemote().
|
privatedelete |
Invalidated assignment operator.
|
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.
[in] | lastPos | the position at time t=0 (must be < currentPos) |
[in] | passedPos | the position for which the passing time is to be determined (has to lie within [lastPos, currentPos]!) |
[in] | currentPos | the position at time t=TS (one time-step after lastPos) (must be > lastPos) |
[in] | lastSpeed | the speed at moment t=0 |
[in] | currentSpeed | the speed at moment t=TS |
Definition at line 658 of file MSCFModel.cpp.
References MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MIN2(), SPEED2ACCEL, TS, and WRITE_ERROR.
Referenced by MSE2Collector::calculateTimeLossAndTimeOnDetector(), MSDevice_SSM::checkConflictEntryAndExit(), MSInductLoop::notifyMove(), MSInstantInductLoop::notifyMove(), MSMeanData::MeanDataValues::notifyMove(), MSE3Collector::MSE3LeaveReminder::notifyMove(), and MSE3Collector::MSE3EntryReminder::notifyMove().
|
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 102 of file MSCFModel.h.
References UNUSED_PARAMETER.
Referenced by MSCFModel::finalizeSpeed().
|
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.
veh | leader 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().
|
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.
veh | leader vehicle of the platoon |
Definition at line 212 of file MSCFModel_CC.cpp.
References changeWholePlatoonLane(), MSVehicle::getCarFollowVariables(), MSVehicle::getLaneIndex(), and isPlatoonLaneChangeSafe().
Referenced by finalizeSpeed().
|
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().
|
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.
|
inlinevirtualinherited |
Sets a new value for the apparent deceleration [m/s^2].
[in] | decel | The new deceleration in m/s^2 |
Definition at line 552 of file MSCFModel.h.
References MSCFModel::myApparentDecel.
Referenced by MSVehicleType::setApparentDecel().
|
inlineinherited |
Sets a new value for the factor of minGap that must be maintained to avoid a collision event.
[in] | factor | The new minGap factor |
Definition at line 559 of file MSCFModel.h.
References MSCFModel::myCollisionMinGapFactor.
Referenced by MSDevice_Bluelight::notifyMove().
|
inlinevirtualinherited |
Sets a new value for maximal physically possible deceleration [m/s^2].
[in] | decel | The new deceleration in m/s^2 |
Definition at line 544 of file MSCFModel.h.
References MSCFModel::myEmergencyDecel.
Referenced by MSCFModel_Rail::MSCFModel_Rail(), and MSVehicleType::setEmergencyDecel().
|
inlinevirtualinherited |
Sets a new value for desired headway [s].
[in] | headwayTime | The new desired headway (in s) |
Reimplemented in MSCFModel_CACC, MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.
Definition at line 574 of file MSCFModel.h.
References MSCFModel::myHeadwayTime.
Referenced by MSVehicle::Influencer::gapControlSpeed(), MSCFModel_CACC::MSCFModel_CACC(), MSCFModel_CACC::setHeadwayTime(), and MSVehicleType::setTau().
|
inlinevirtualinherited |
Sets a new value for driver imperfection.
[in] | accel | The new driver imperfection |
Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.
Definition at line 566 of file MSCFModel.h.
References UNUSED_PARAMETER.
Referenced by MSVehicleType::setImperfection().
void MSCFModel_CC::setLeader | ( | MSVehicle * | veh, |
MSVehicle *const | leader, | ||
std::string | leaderId | ||
) | const |
Sets the leader for a member of the platoon.
veh | platoon member |
leader | platoon leader |
leaderId | platoon leader id |
Definition at line 112 of file MSCFModel_CC.cpp.
References MSVehicle::getCarFollowVariables(), and MSVehicle::isLeader().
|
inlinevirtualinherited |
Sets a new value for maximum acceleration [m/s^2].
[in] | accel | The new acceleration in m/s^2 |
Definition at line 528 of file MSCFModel.h.
References MSCFModel::myAccel.
Referenced by MSVehicleType::setAccel(), and MSDevice_ToC::setState().
|
inlinevirtualinherited |
Sets a new value for maximal comfortable deceleration [m/s^2].
[in] | decel | The new deceleration in m/s^2 |
Reimplemented in MSCFModel_Daniel1, MSCFModel_KraussOrig1, and MSCFModel_SmartSK.
Definition at line 536 of file MSCFModel.h.
References MSCFModel::myDecel.
Referenced by MSLCM_SL2015::commitFollowSpeed(), MSCFModel_Rail::MSCFModel_Rail(), and MSVehicleType::setDecel().
|
virtual |
try to set the given parameter for this carFollowingModel
[in] | veh | the vehicle for which the parameter must be set |
[in] | key | the key of the parameter |
[in] | value | the 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, 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::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.
|
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.
[in] | t | time in [0,TS] for which the speed shall be determined |
[in] | oldSpeed | speed before the last time step (referred to as t == 0) |
[in] | distance | covered |
Definition at line 736 of file MSCFModel.cpp.
References DIST2SPEED, MSGlobals::gSemiImplicitEulerUpdate, and TS.
Referenced by MSE2Collector::calculateTimeLossAndTimeOnDetector(), MSInstantInductLoop::notifyMove(), and MSMeanData::MeanDataValues::notifyMove().
|
inlinevirtualinherited |
whether startupDelay should be applied after stopping
Reimplemented in MSCFModel_Rail.
Definition at line 316 of file MSCFModel.h.
|
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.
[in] | veh | The vehicle (EGO) |
[in] | speed | The vehicle's speed |
[in] | gap | The (net) distance to the obstacle |
[in] | usage | What the return value is used for |
Definition at line 168 of file MSCFModel.h.
References MSCFModel::myDecel, and MSCFModel::stopSpeed().
Referenced by MSLCM_LC2013::_patchSpeed(), MSLCM_SL2015::_patchSpeed(), MSLCM_LC2013::adaptSpeedToPedestrians(), MSVehicle::adaptToJunctionLeader(), MSVehicle::adaptToLeader(), MSVehicle::adaptToOncomingLeader(), MSCFModel::applyHeadwayPerceptionError(), MSLane::checkForPedestrians(), LIBSUMO_NAMESPACE::Vehicle::getStopSpeed(), MSLCM_SL2015::informLeader(), MSLCM_LC2013::informLeader(), MSLCM_SL2015::informLeaders(), MSCFModel::insertionStopSpeed(), MSLane::isInsertionSuccess(), MSLCM_DK2008::patchSpeed(), MSVehicle::planMoveInternal(), MSVehicle::processNextStop(), MSCFModel::stopSpeed(), and stopSpeed().
|
virtual |
Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling)
[in] | veh | The vehicle (EGO) |
[in] | gap2pred | The (net) distance to the obstacle |
Implements MSCFModel.
Definition at line 357 of file MSCFModel_CC.cpp.
References _v(), CC_VehicleVariables::activeController, Plexe::DRIVER, MSVehicle::getCarFollowVariables(), getRadarMeasurements(), myHumanDriver, and MSCFModel::stopSpeed().
void MSCFModel_CC::switchOnACC | ( | const MSVehicle * | veh, |
double | ccDesiredSpeed | ||
) | const |
switch on the ACC, so disabling the human driver car control
[in] | veh | the vehicle for which the ACC must be switched on |
[in] | ccDesiredSpeed | the cruise control speed |
Definition at line 1167 of file MSCFModel_CC.cpp.
References Plexe::ACC, CC_VehicleVariables::activeController, CC_VehicleVariables::ccDesiredSpeed, and MSVehicle::getCarFollowVariables().
|
protectedinherited |
The vehicle's maximum acceleration [m/s^2].
Definition at line 698 of file MSCFModel.h.
Referenced by MSCFModel_EIDM::_v(), MSCFModel_IDM::_v(), MSCFModel_Kerner::_v(), MSCFModel_Wiedemann::_v(), createVehicleVariables(), MSCFModel_Daniel1::dawdle(), MSCFModel_KraussOrig1::dawdle(), MSCFModel_SmartSK::dawdle(), MSCFModel_Krauss::dawdle2(), MSCFModel_KraussX::dawdleX(), MSCFModel_PWag2009::followSpeed(), MSCFModel_Wiedemann::fullspeed(), MSCFModel::getMaxAccel(), MSCFModel_EIDM::getSecureGap(), MSCFModel_EIDM::interactionGap(), MSCFModel_IDM::interactionGap(), MSCFModel_EIDM::internalsecuregap(), MSCFModel_EIDM::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeStopSpeed(), MSCFModel_SmartSK::MSCFModel_SmartSK(), MSCFModel_W99::MSCFModel_W99(), MSCFModel_EIDM::patchSpeedBeforeLCEIDM(), MSCFModel::setMaxAccel(), setParameter(), MSCFModel_EIDM::slowToStartTerm(), and MSCFModel_PWag2009::stopSpeed().
|
protectedinherited |
The vehicle's deceleration as expected by surrounding traffic [m/s^2].
Definition at line 705 of file MSCFModel.h.
Referenced by MSCFModel::getApparentDecel(), and MSCFModel::setApparentDecel().
|
private |
design constant for CACC
Definition at line 445 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
The maximum acceleration that the CC can output.
Definition at line 433 of file MSCFModel_CC.h.
Referenced by _cc().
|
private |
The maximum deceleration that the CC can output.
Definition at line 430 of file MSCFModel_CC.h.
Referenced by _cc().
|
protectedinherited |
The factor of minGap that must be maintained to avoid a collision event.
Definition at line 707 of file MSCFModel.h.
Referenced by MSCFModel_W99::followSpeed(), MSCFModel::getCollisionMinGapFactor(), MSCFModel_ACC::MSCFModel_ACC(), MSCFModel_CACC::MSCFModel_CACC(), MSCFModel_EIDM::MSCFModel_EIDM(), MSCFModel_IDM::MSCFModel_IDM(), MSCFModel_Kerner::MSCFModel_Kerner(), MSCFModel_PWag2009::MSCFModel_PWag2009(), MSCFModel_W99::MSCFModel_W99(), MSCFModel_Wiedemann::MSCFModel_Wiedemann(), and MSCFModel::setCollisionMinGapFactor().
|
private |
the constant gap for CACC
Definition at line 436 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
protectedinherited |
The vehicle's maximum deceleration [m/s^2].
Definition at line 701 of file MSCFModel.h.
Referenced by MSCFModel_EIDM::_v(), MSCFModel_Kerner::_v(), MSCFModel_Wiedemann::_v(), MSCFModel_SmartSK::_vsafe(), MSCFModel_Daniel1::_vsafe(), MSCFModel::brakeGap(), MSCFModel_EIDM::brakeGap(), createVehicleVariables(), MSCFModel_PWag2009::followSpeed(), MSCFModel_Rail::followSpeed(), MSCFModel::followSpeedTransient(), MSCFModel_Rail::freeSpeed(), MSCFModel::freeSpeed(), MSCFModel_EIDM::freeSpeed(), MSCFModel_IDM::freeSpeed(), MSCFModel::getMaxDecel(), MSCFModel::getSecureGap(), MSCFModel_EIDM::getSecureGap(), MSCFModel::getSpeedAfterMaxDecel(), MSCFModel::insertionStopSpeed(), MSCFModel_EIDM::insertionStopSpeed(), MSCFModel_IDM::insertionStopSpeed(), MSCFModel::interactionGap(), MSCFModel_EIDM::interactionGap(), MSCFModel_IDM::interactionGap(), MSCFModel_EIDM::internalsecuregap(), MSCFModel::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), MSCFModel::maximumSafeStopSpeed(), MSCFModel::minNextSpeed(), MSCFModel_IDM::minNextSpeed(), MSCFModel_SmartSK::MSCFModel_SmartSK(), MSCFModel_Daniel1::setHeadwayTime(), MSCFModel_KraussOrig1::setHeadwayTime(), MSCFModel_SmartSK::setHeadwayTime(), MSCFModel::setMaxDecel(), MSCFModel_Daniel1::setMaxDecel(), MSCFModel_KraussOrig1::setMaxDecel(), MSCFModel_SmartSK::setMaxDecel(), setParameter(), MSCFModel::stopSpeed(), MSCFModel_PWag2009::stopSpeed(), and MSCFModel_KraussOrig1::vsafe().
|
protectedinherited |
The vehicle's maximum emergency deceleration [m/s^2].
Definition at line 703 of file MSCFModel.h.
Referenced by MSCFModel_Wiedemann::_v(), MSCFModel::calculateEmergencyDeceleration(), MSCFModel_Wiedemann::emergency(), MSCFModel::getEmergencyDecel(), MSCFModel::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), MSCFModel::maximumSafeStopSpeed(), MSCFModel::maximumSafeStopSpeedBallistic(), MSCFModel_IDM::minNextSpeed(), MSCFModel::minNextSpeedEmergency(), and MSCFModel::setEmergencyDecel().
|
private |
Definition at line 470 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Definition at line 469 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
flatbed CACC parameters
Definition at line 466 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Definition at line 468 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Definition at line 467 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
protectedinherited |
The driver's desired time headway (aka reaction time tau) [s].
Definition at line 710 of file MSCFModel.h.
Referenced by MSCFModel_EIDM::_v(), MSCFModel_ACC::_v(), MSCFModel_IDM::_v(), MSCFModel_CACC::_v(), MSCFModel_ACC::accelGapControl(), MSCFModel::brakeGap(), MSCFModel_SmartSK::createVehicleVariables(), MSCFModel_PWag2009::followSpeed(), MSCFModel::getHeadwayTime(), MSCFModel_ACC::getSecureGap(), MSCFModel_CACC::getSecureGap(), MSCFModel_IDM::getSecureGap(), MSCFModel::getSecureGap(), MSCFModel_EIDM::getSecureGap(), MSCFModel_IDM::insertionFollowSpeed(), MSCFModel_EIDM::insertionStopSpeed(), MSCFModel::interactionGap(), MSCFModel_EIDM::internalsecuregap(), MSCFModel::maximumSafeFollowSpeed(), MSCFModel_EIDM::maximumSafeFollowSpeed(), MSCFModel::maximumSafeStopSpeedBallistic(), MSCFModel::maximumSafeStopSpeedEuler(), MSCFModel_W99::MSCFModel_W99(), MSCFModel_EIDM::patchSpeedBeforeLCEIDM(), MSCFModel::setHeadwayTime(), MSCFModel_CACC::setHeadwayTime(), MSCFModel_Daniel1::setHeadwayTime(), MSCFModel_KraussOrig1::setHeadwayTime(), MSCFModel_SmartSK::setHeadwayTime(), MSCFModel_Daniel1::setMaxDecel(), MSCFModel_KraussOrig1::setMaxDecel(), MSCFModel_SmartSK::setMaxDecel(), MSCFModel_CACC::speedGapControl(), MSCFModel_PWag2009::stopSpeed(), and MSCFModel_SmartSK::updateMyHeadway().
|
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().
|
private |
design constant for CC
Definition at line 439 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
design constant for ACC
Definition at line 442 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
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().
|
private |
design constant for CACC
Definition at line 451 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Ploeg's CACC parameters.
Definition at line 461 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Definition at line 463 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
private |
Definition at line 462 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
protectedinherited |
The startup delay after halting [s].
Definition at line 713 of file MSCFModel.h.
Referenced by MSCFModel::applyStartupDelay(), MSCFModel_EIDM::finalizeSpeed(), MSCFModel::getStartupDelay(), and MSCFModel_EIDM::slowToStartTerm().
|
private |
engine time constant used for actuation lag
Definition at line 454 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().
|
protectedinherited |
The type to which this model definition belongs to.
Definition at line 695 of file MSCFModel.h.
Referenced by MSCFModel_EIDM::_v(), MSCFModel_IDM::_v(), MSCFModel_Wiedemann::_v(), MSCFModel_W99::computeThresholds(), MSCFModel::estimateSpeedAfterDistance(), MSCFModel_W99::followSpeed(), MSCFModel_Wiedemann::getSecureGap(), MSCFModel::insertionStopSpeed(), MSCFModel_EIDM::insertionStopSpeed(), MSCFModel::maxNextSpeed(), MSCFModel_KraussPS::maxNextSpeed(), and MSCFModel_EIDM::patchSpeedBeforeLCEIDM().
|
private |
design constant for CACC
Definition at line 448 of file MSCFModel_CC.h.
Referenced by createVehicleVariables().