SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MSCFModel Class Reference

The car-following model abstraction. More...

#include <MSCFModel.h>

Inheritance diagram for MSCFModel:
MSCFModel_Daniel1 MSCFModel_IDM MSCFModel_Kerner MSCFModel_KraussOrig1 MSCFModel_PWag2009 MSCFModel_SmartSK MSCFModel_Wiedemann MSCFModel_Krauss MSCFModel_KraussPS

Data Structures

class  VehicleVariables

Public Member Functions

 MSCFModel (const MSVehicleType *vtype, SUMOReal accel, SUMOReal decel, SUMOReal headwayTime)
 Constructor.
virtual ~MSCFModel ()
 Destructor.
Methods to override by model implementation
virtual SUMOReal moveHelper (MSVehicle *const veh, SUMOReal vPos) const
 Applies interaction with stops and lane changing model influences.
virtual SUMOReal freeSpeed (const MSVehicle *const veh, SUMOReal speed, SUMOReal seen, SUMOReal maxSpeed) const
 Computes the vehicle's safe speed without a leader.
virtual SUMOReal followSpeed (const MSVehicle *const veh, SUMOReal speed, SUMOReal gap2pred, SUMOReal predSpeed, SUMOReal predMaxDecel) const =0
 Computes the vehicle's safe speed (no dawdling)
virtual SUMOReal stopSpeed (const MSVehicle *const veh, SUMOReal gap2pred) const =0
 Computes the vehicle's safe speed for approaching a non-moving obstacle (no dawdling)
virtual SUMOReal interactionGap (const MSVehicle *const veh, SUMOReal vL) const
 Returns the maximum gap at which an interaction between both vehicles occurs.
virtual int getModelID () const =0
 Returns the model's ID; the XML-Tag number is used.
virtual MSCFModelduplicate (const MSVehicleType *vtype) const =0
 Duplicates the car-following model.
virtual VehicleVariablescreateVehicleVariables () const
 Returns model specific values which are stored inside a vehicle and must be used with casting.
Virtual methods with default implementation
virtual SUMOReal getMaxAccel () const
 Get the vehicle type's maximum acceleration [m/s^2].
virtual SUMOReal getMaxDecel () const
 Get the vehicle type's maximum deceleration [m/s^2].
virtual SUMOReal getImperfection () const
 Get the driver's imperfection.
virtual SUMOReal getHeadwayTime () const
 Get the driver's reaction time [s].
Currently fixed methods
void leftVehicleVsafe (const MSVehicle *const ego, const MSVehicle *const neigh, SUMOReal &vSafe) const
 Incorporates the influence of the vehicle on the left lane.
virtual SUMOReal maxNextSpeed (SUMOReal speed, const MSVehicle *const veh) const
 Returns the maximum speed given the current speed.
SUMOReal brakeGap (SUMOReal speed) const
 Returns the distance the vehicle needs to halt including driver's reaction time.
SUMOReal getSecureGap (const SUMOReal speed, const SUMOReal leaderSpeed, const SUMOReal leaderMaxDecel) const
 Returns the minimum gap to reserve if the leader is braking at maximum.
SUMOReal getSpeedAfterMaxDecel (SUMOReal v) const
 Returns the velocity after maximum deceleration.
Setter methods
virtual void setMaxAccel (SUMOReal accel)
 Sets a new value for maximum acceleration [m/s^2].
virtual void setMaxDecel (SUMOReal decel)
 Sets a new value for maximum deceleration [m/s^2].
virtual void setImperfection (SUMOReal imperfection)
 Sets a new value for driver imperfection.
virtual void setHeadwayTime (SUMOReal headwayTime)
 Sets a new value for driver reaction time [s].

Protected Attributes

SUMOReal myAccel
 The vehicle's maximum acceleration [m/s^2].
SUMOReal myDecel
 The vehicle's maximum deceleration [m/s^2].
SUMOReal myHeadwayTime
 The driver's desired time headway (aka reaction time tau) [s].
const MSVehicleTypemyType
 The type to which this model definition belongs to.

Detailed Description

The car-following model abstraction.

MSCFModel is an interface for different car following Models to implement. It provides methods to compute a vehicles velocity for a simulation step.

Definition at line 58 of file MSCFModel.h.

Constructor & Destructor Documentation

MSCFModel::MSCFModel ( const MSVehicleType vtype,
SUMOReal  accel,
SUMOReal  decel,
SUMOReal  headwayTime 
)

Constructor.

Parameters
[in]rvtypea reference to the corresponding vtype

Definition at line 46 of file MSCFModel.cpp.

MSCFModel::~MSCFModel ( )
virtual

Destructor.

Definition at line 52 of file MSCFModel.cpp.

Member Function Documentation

SUMOReal MSCFModel::brakeGap ( SUMOReal  speed) const

Returns the distance the vehicle needs to halt including driver's reaction time.

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

Definition at line 104 of file MSCFModel.cpp.

References ACCEL2SPEED, getMaxDecel(), myHeadwayTime, SPEED2DIST, and SUMOReal.

Referenced by MSVehicle::addStop(), MSVehicle::checkRewindLinkLanes(), MSVehicle::executeMove(), MSLane::getLeaderOnConsecutive(), MSLaneChanger::getRealLeader(), getSecureGap(), MSLane::isInsertionSuccess(), MSVehicle::planMove(), MSLane::pWagGenericInsertion(), and MSLane::pWagSimpleInsertion().

virtual VehicleVariables* MSCFModel::createVehicleVariables ( ) const
inlinevirtual

Returns model specific values which are stored inside a vehicle and must be used with casting.

Reimplemented in MSCFModel_IDM, MSCFModel_Wiedemann, and MSCFModel_PWag2009.

Definition at line 148 of file MSCFModel.h.

Referenced by MSVehicle::MSVehicle().

virtual MSCFModel* MSCFModel::duplicate ( const MSVehicleType vtype) const
pure 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

Implemented in MSCFModel_KraussOrig1, MSCFModel_Daniel1, MSCFModel_SmartSK, MSCFModel_IDM, MSCFModel_Wiedemann, MSCFModel_PWag2009, MSCFModel_Krauss, MSCFModel_Kerner, and MSCFModel_KraussPS.

Referenced by MSVehicleType::build().

virtual SUMOReal MSCFModel::followSpeed ( const MSVehicle *const  veh,
SUMOReal  speed,
SUMOReal  gap2pred,
SUMOReal  predSpeed,
SUMOReal  predMaxDecel 
) const
pure virtual

Computes the vehicle's safe speed (no dawdling)

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 (netto) distance to the LEADER
[in]predSpeedThe speed of LEADER
Returns
EGO's safe speed

Implemented in MSCFModel_IDM, MSCFModel_Wiedemann, MSCFModel_KraussOrig1, MSCFModel_PWag2009, MSCFModel_Daniel1, MSCFModel_SmartSK, MSCFModel_Krauss, and MSCFModel_Kerner.

Referenced by MSVehicle::adaptToLeader(), MSLane::freeInsertion(), MSLCM_DK2004::informBlocker(), MSLane::isInsertionSuccess(), leftVehicleVsafe(), MSLane::pWagGenericInsertion(), MSLCM_DK2004::wantsChangeToLeft(), and MSLCM_DK2004::wantsChangeToRight().

SUMOReal MSCFModel::freeSpeed ( const MSVehicle *const  veh,
SUMOReal  speed,
SUMOReal  seen,
SUMOReal  maxSpeed 
) 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.

Parameters
[in]vehThe vehicle (EGO)
[in]speedThe vehicle's speed
[in]seenThe look ahead distance
[in]maxSpeedThe maximum allowed speed
Returns
EGO's safe speed

Definition at line 114 of file MSCFModel.cpp.

References ACCEL2SPEED, MAX2(), myDecel, SUMOReal, and UNUSED_PARAMETER.

Referenced by MSLane::isInsertionSuccess(), and MSVehicle::planMove().

virtual SUMOReal MSCFModel::getHeadwayTime ( ) const
inlinevirtual

Get the driver's reaction time [s].

Returns
The reaction time of this class' drivers in s

Definition at line 184 of file MSCFModel.h.

References myHeadwayTime.

Referenced by MSVehicle::checkRewindLinkLanes(), MSVehicle::executeMove(), TraCIServerAPI_VehicleType::getVariable(), MSLane::maxSpeedGapInsertion(), MSVehicle::planMove(), MSLane::pWagSimpleInsertion(), and MSCalibrator::remainingVehicleCapacity().

virtual SUMOReal MSCFModel::getImperfection ( ) const
inlinevirtual

Get the driver's imperfection.

Returns
The imperfection of drivers of this class

Reimplemented in MSCFModel_KraussOrig1, MSCFModel_PWag2009, MSCFModel_Daniel1, and MSCFModel_SmartSK.

Definition at line 176 of file MSCFModel.h.

Referenced by TraCIServerAPI_VehicleType::getVariable().

virtual SUMOReal MSCFModel::getMaxAccel ( ) const
inlinevirtual

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 160 of file MSCFModel.h.

References myAccel.

Referenced by TraCIServerAPI_VehicleType::getVariable(), MSCFModel_KraussPS::maxNextSpeed(), maxNextSpeed(), MSVehicle::planMove(), and MSMeanData_HBEFA::MSLaneMeanDataValues::write().

virtual int MSCFModel::getModelID ( ) const
pure virtual

Returns the model's ID; the XML-Tag number is used.

Returns
The model's ID

Implemented in MSCFModel_IDM, MSCFModel_Wiedemann, MSCFModel_KraussOrig1, MSCFModel_PWag2009, MSCFModel_Daniel1, MSCFModel_SmartSK, MSCFModel_Krauss, MSCFModel_Kerner, and MSCFModel_KraussPS.

SUMOReal MSCFModel::getSecureGap ( const SUMOReal  speed,
const SUMOReal  leaderSpeed,
const SUMOReal  leaderMaxDecel 
) const
inline

Returns the minimum gap to reserve if the leader is braking at maximum.

Parameters
[in]speedEGO's speed
[in]leaderSpeedLEADER's speed
[in]leaderMaxDecelLEADER's max. deceleration rate

Definition at line 231 of file MSCFModel.h.

References ACCEL2SPEED, brakeGap(), MAX2(), SPEED2DIST, and SUMOReal.

Referenced by MSLaneChanger::change2left(), MSLaneChanger::change2right(), MSLane::freeInsertion(), MSLane::getMissingRearGap(), MSLCM_DK2004::informBlocker(), and MSLane::isInsertionSuccess().

SUMOReal MSCFModel::getSpeedAfterMaxDecel ( SUMOReal  v) const
inline

Returns the velocity after maximum deceleration.

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

Definition at line 242 of file MSCFModel.h.

References ACCEL2SPEED, MAX2(), myDecel, and SUMOReal.

Referenced by MSCFModel_SmartSK::followSpeed(), MSCFModel_Daniel1::moveHelper(), MSCFModel_SmartSK::moveHelper(), MSCFModel_KraussOrig1::moveHelper(), moveHelper(), MSCFModel_SmartSK::stopSpeed(), and MSCFModel_Wiedemann::stopSpeed().

SUMOReal MSCFModel::interactionGap ( const MSVehicle *const  veh,
SUMOReal  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

Reimplemented in MSCFModel_IDM, and MSCFModel_Wiedemann.

Definition at line 71 of file MSCFModel.cpp.

References MSVehicle::getLane(), MSVehicle::getSpeed(), MSLane::getVehicleMaxSpeed(), MAX2(), maxNextSpeed(), MIN2(), myDecel, myHeadwayTime, SPEED2DIST, and SUMOReal.

Referenced by MSAbstractLaneChangeModel::predInteraction().

void MSCFModel::leftVehicleVsafe ( const MSVehicle *const  ego,
const MSVehicle *const  neigh,
SUMOReal vSafe 
) const

Incorporates the influence of the vehicle on the left lane.

In Germany, vehicles on the right lane must not pass a vehicle on the lane left to the if the allowed velocity>60km/h

Parameters
[in]egoThe ego vehicle
[in]neighThe neighbor vehicle on the left lane
[in,out]vSafeCurrent vSafe; may be adapted due to the left neighbor

Definition at line 86 of file MSCFModel.cpp.

References followSpeed(), MSVehicle::getCarFollowModel(), MSVehicleType::getLength(), getMaxDecel(), MSVehicleType::getMinGap(), MSVehicle::getPositionOnLane(), MSVehicle::getSpeed(), MSBaseVehicle::getVehicleType(), MAX2(), MIN2(), and SUMOReal.

Referenced by MSVehicle::planMove().

SUMOReal MSCFModel::maxNextSpeed ( SUMOReal  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]speedThe vehicle itself, for obtaining other values
Returns
The maximum possible speed for the next step

Reimplemented in MSCFModel_KraussPS.

Definition at line 98 of file MSCFModel.cpp.

References ACCEL2SPEED, getMaxAccel(), MSVehicleType::getMaxSpeed(), MIN2(), myType, and SUMOReal.

Referenced by MSVehicle::executeMove(), MSCFModel_Kerner::followSpeed(), MSCFModel_Krauss::followSpeed(), MSCFModel_Daniel1::followSpeed(), MSCFModel_SmartSK::followSpeed(), MSCFModel_KraussOrig1::followSpeed(), MSLane::getFollowerOnConsecutive(), MSLane::getMissingRearGap(), interactionGap(), MSCFModel_Daniel1::moveHelper(), MSCFModel_SmartSK::moveHelper(), MSCFModel_KraussOrig1::moveHelper(), moveHelper(), MSLCM_DK2004::patchSpeed(), MSVehicle::planMove(), MSCFModel_Kerner::stopSpeed(), MSCFModel_Krauss::stopSpeed(), MSCFModel_Daniel1::stopSpeed(), MSCFModel_SmartSK::stopSpeed(), MSCFModel_KraussOrig1::stopSpeed(), and MSCFModel_Wiedemann::stopSpeed().

SUMOReal MSCFModel::moveHelper ( MSVehicle *const  veh,
SUMOReal  vPos 
) const
virtual

Applies interaction with stops and lane changing model influences.

Parameters
[in]vehThe ego vehicle
[in]vPosThe possible velocity
Returns
The velocity after applying interactions with stops and lane change model influences

Reimplemented in MSCFModel_IDM, MSCFModel_Wiedemann, MSCFModel_KraussOrig1, MSCFModel_PWag2009, MSCFModel_Daniel1, and MSCFModel_SmartSK.

Definition at line 56 of file MSCFModel.cpp.

References MSVehicle::getLane(), MSVehicle::getLaneChangeModel(), MSVehicle::getSpeed(), getSpeedAfterMaxDecel(), MSLane::getVehicleMaxSpeed(), maxNextSpeed(), MIN2(), MIN3(), MSAbstractLaneChangeModel::patchSpeed(), MSVehicle::processNextStop(), and SUMOReal.

Referenced by MSVehicle::executeMove().

virtual void MSCFModel::setHeadwayTime ( SUMOReal  headwayTime)
inlinevirtual

Sets a new value for driver reaction time [s].

Parameters
[in]headwayTimeThe new driver reaction time (in s)

Reimplemented in MSCFModel_KraussOrig1, MSCFModel_Daniel1, and MSCFModel_SmartSK.

Definition at line 278 of file MSCFModel.h.

References myHeadwayTime.

Referenced by TraCIServerAPI_VehicleType::setVariable().

virtual void MSCFModel::setImperfection ( SUMOReal  imperfection)
inlinevirtual

Sets a new value for driver imperfection.

Parameters
[in]accelThe new driver imperfection

Reimplemented in MSCFModel_KraussOrig1, MSCFModel_Daniel1, and MSCFModel_SmartSK.

Definition at line 270 of file MSCFModel.h.

References UNUSED_PARAMETER.

Referenced by TraCIServerAPI_VehicleType::setVariable().

virtual void MSCFModel::setMaxAccel ( SUMOReal  accel)
inlinevirtual

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

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

Definition at line 254 of file MSCFModel.h.

References myAccel.

Referenced by TraCIServerAPI_VehicleType::setVariable().

virtual void MSCFModel::setMaxDecel ( SUMOReal  decel)
inlinevirtual

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

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

Reimplemented in MSCFModel_KraussOrig1, MSCFModel_Daniel1, and MSCFModel_SmartSK.

Definition at line 262 of file MSCFModel.h.

References myDecel.

Referenced by TraCIServerAPI_VehicleType::setVariable().

virtual SUMOReal MSCFModel::stopSpeed ( const MSVehicle *const  veh,
SUMOReal  gap2pred 
) const
pure virtual

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]gap2predThe (netto) distance to the the obstacle
Returns
EGO's safe speed for approaching a non-moving obstacle
Todo:
generic Interface, models can call for the values they need

Implemented in MSCFModel_IDM, MSCFModel_Wiedemann, MSCFModel_KraussOrig1, MSCFModel_PWag2009, MSCFModel_Daniel1, MSCFModel_SmartSK, MSCFModel_Krauss, and MSCFModel_Kerner.

Referenced by MSVehicle::adaptToLeader(), MSLCM_DK2004::patchSpeed(), MSVehicle::planMove(), and MSVehicle::processNextStop().

Field Documentation

const MSVehicleType* MSCFModel::myType
protected

The type to which this model definition belongs to.

Definition at line 286 of file MSCFModel.h.

Referenced by MSCFModel_Wiedemann::_v(), MSCFModel_IDM::_v(), MSCFModel_IDM::desiredSpeed(), MSCFModel_KraussPS::maxNextSpeed(), and maxNextSpeed().


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