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

A lane change model developed by D. Krajzewicz, J. Erdmann et al. between 2004 and 2013. More...

#include <MSLCM_LC2013.h>

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

Public Member Functions

bool alreadyChanged () const
 reset the flag whether a vehicle already moved to false
 
double calcAngleOffset ()
 return the angle offset during a continuous change maneuver
 
void changed () override
 
void changedToOpposite ()
 called when a vehicle changes between lanes in opposite directions
 
virtual int checkChangeBeforeCommitting (const MSVehicle *veh, int state) const
 Informs the vehicle that it is about to be moved on an adjacent lane. The method can be used to re-evaluate the state of the vehicle and potentially abort the lane change. By default, if the method is not overridden by the lane change model implementation, nothing is altered and the vehicle will perform the lane change.
 
void checkTraCICommands ()
 Check for commands issued for the vehicle via TraCI and apply the appropriate state changes For the sublane case, this includes setting a new maneuver distance if appropriate.
 
void cleanupShadowLane ()
 
void cleanupTargetLane ()
 
void clearGapsAtLCInit ()
 
void clearNeighbors ()
 Clear info on neighboring vehicle from previous step.
 
double computeSpeedLat (double latDist, double &maneuverDist, bool urgent) const override
 decides the next lateral speed (for continuous lane changing)
 
bool debugVehicle () const override
 whether the current vehicles shall be debugged
 
virtual StateAndDist decideDirection (StateAndDist sd1, StateAndDist sd2) const
 decide in which direction to move in case both directions are desirable
 
MSLanedetermineTargetLane (int &targetDir) const
 
void endLaneChangeManeuver (const MSMoveReminder::Notification reason=MSMoveReminder::NOTIFICATION_LANE_CHANGE)
 
virtual double estimateLCDuration (const double speed, const double remainingManeuverDist, const double decel, bool urgent) const
 Calculates the maximal time needed to complete a lane change maneuver if lcMaxSpeedLatFactor and lcMaxSpeedStanding are set and the vehicle breaks not harder than decel. LC when the vehicle starts breaking now. If lcMaxSpeedStanding==0 the completion may be impossible,.
 
double getAccelerationLat () const
 return the lateral speed of the current lane change maneuver
 
double getAngleOffset () const
 return the angle offset resulting from lane change and sigma
 
virtual double getAssumedDecelForLaneChangeDuration () const
 Returns a deceleration value which is used for the estimation of the duration of a lane change.
 
int & getCanceledState (const int dir)
 
double getCommittedSpeed () const
 
virtual LatAlignmentDefinition getDesiredAlignment () const
 
double getExtraReservation (int bestLaneOffset) const override
 reserve extra space for unseen blockers when more tnan one lane change is required
 
const std::shared_ptr< MSLeaderDistanceInfogetFollowers (const int dir)
 Returns the neighboring, lc-relevant followers for the last step in the requested direction.
 
double getForwardPos () const
 get vehicle position relative to the forward direction lane
 
const std::vector< MSLane * > & getFurtherTargetLanes () const
 
double getLaneChangeCompletion () const
 Get the current lane change completion ratio.
 
int getLaneChangeDirection () const
 return the direction of the current lane change maneuver
 
SUMOTime getLastLaneChangeOffset () const
 
const std::shared_ptr< MSLeaderDistanceInfogetLeaders (const int dir)
 Returns the neighboring, lc-relevant leaders for the last step in the requested direction.
 
double getManeuverDist () const
 Returns the remaining unblocked distance for the current maneuver. (only used by sublane model)
 
LaneChangeModel getModelID () const override
 Returns the model's id.
 
int getNormalizedLaneIndex ()
 brief return lane index that treats opposite lanes like normal lanes to the left of the forward lanes
 
double getOppositeSafetyFactor () const override
 return factor for modifying the safety constraints for opposite-diretction overtaking of the car-following model
 
int getOwnState () const
 
std::string getParameter (const std::string &key) const override
 try to retrieve the given parameter from this device. Throw exception for unsupported key
 
double getPreviousManeuverDist () const
 
int getPrevState () const
 
double getSafetyFactor () const override
 return factor for modifying the safety constraints of the car-following model
 
const std::pair< int, int > & getSavedState (const int dir) const
 
int getShadowDirection () const
 return the direction in which the current shadow lane lies
 
const std::vector< MSLane * > & getShadowFurtherLanes () const
 
const std::vector< double > & getShadowFurtherLanesPosLat () const
 
MSLanegetShadowLane () const
 Returns the lane the vehicle's shadow is on during continuous/sublane lane change.
 
MSLanegetShadowLane (const MSLane *lane) const
 return the shadow lane for the given lane
 
MSLanegetShadowLane (const MSLane *lane, double posLat) const
 return the shadow lane for the given lane and lateral offset
 
double getSpeedLat () const
 return the lateral speed of the current lane change maneuver
 
MSLanegetTargetLane () const
 Returns the lane the vehicle has committed to enter during a sublane lane change.
 
bool hasBlueLight () const
 
void * inform (void *info, MSVehicle *sender) override
 
void initDerivedParameters ()
 init cached parameters derived directly from model parameters
 
bool isChangingLanes () const
 return true if the vehicle currently performs a lane change maneuver
 
bool isOpposite () const
 
bool isStrategicBlocked () const
 
void laneChangeOutput (const std::string &tag, MSLane *source, MSLane *target, int direction, double maneuverDist=0)
 called once the vehicle ends a lane change manoeuvre (non-instant)
 
virtual void loadState (const SUMOSAXAttributes &attrs)
 Loads the state of the laneChangeModel from the given attributes.
 
void memorizeGapsAtLCInit ()
 Control for resetting the memorized values for LC relevant gaps until the LC output is triggered in the case of continuous LC.
 
 MSLCM_LC2013 (MSVehicle &v)
 
bool pastMidpoint () const
 return whether the vehicle passed the midpoint of a continuous lane change maneuver
 
double patchSpeed (const double min, const double wanted, const double max, const MSCFModel &cfModel) override
 Called to adapt the speed in order to allow a lane change. It uses information on LC-related desired speed-changes from the call to wantsChange() at the end of the previous simulation step.
 
void prepareStep () override
 
void primaryLaneChanged (MSLane *source, MSLane *target, int direction)
 called once when the vehicles primary lane changes
 
SUMOTime remainingTime () const
 Compute the remaining time until LC completion.
 
void removeShadowApproachingInformation () const
 
void resetChanged ()
 reset the flag whether a vehicle already moved to false
 
virtual void resetSpeedLat ()
 
void resetState () override
 
void saveLCState (const int dir, int stateWithoutTraCI, const int state)
 
void saveNeighbors (const int dir, const MSLeaderDistanceInfo &followers, const MSLeaderDistanceInfo &leaders)
 Saves the lane change relevant vehicles, which are currently on neighboring lanes in the given direction (as detected in wantsChangeSublane()). -> SL2015 case.
 
void saveNeighbors (const int dir, const std::pair< MSVehicle *const, double > &follower, const std::pair< MSVehicle *const, double > &leader)
 Saves the lane change relevant vehicles, which are currently on neighboring lanes in the given direction (as detected in wantsChange()). -> LC2013 case.
 
virtual void saveState (OutputDevice &out) const
 Save the state of the laneChangeModel.
 
void setAngleOffset (const double angleOffset)
 set the angle offset resulting from lane change and sigma
 
void setFollowerGaps (CLeaderDist follower, double secGap)
 
void setFollowerGaps (const MSLeaderDistanceInfo &vehicles)
 
void setLeaderGaps (CLeaderDist, double secGap)
 
void setLeaderGaps (const MSLeaderDistanceInfo &vehicles)
 
void setManeuverDist (const double dist)
 Updates the remaining distance for the current maneuver while it is continued within non-action steps (only used by sublane model)
 
void setNoShadowPartialOccupator (MSLane *lane)
 
void setOrigLeaderGaps (CLeaderDist, double secGap)
 
void setOrigLeaderGaps (const MSLeaderDistanceInfo &vehicles)
 
virtual void setOwnState (const int state)
 
void setParameter (const std::string &key, const std::string &value) override
 try to set the given parameter for this laneChangeModel. Throw exception for unsupported key
 
void setPreviousAngleOffset (const double angleOffset)
 set the angle offset of the previous time step
 
void setShadowApproachingInformation (MSLink *link) const
 set approach information for the shadow vehicle
 
void setShadowPartialOccupator (MSLane *lane)
 
void setSpeedLat (double speedLat)
 set the lateral speed and update lateral acceleraton
 
bool startLaneChangeManeuver (MSLane *source, MSLane *target, int direction)
 start the lane change maneuver and return whether it continues
 
virtual bool sublaneChangeCompleted (const double latDist) const
 whether the current change completes the manoeuvre
 
void unchanged ()
 
bool updateCompletion ()
 
virtual void updateExpectedSublaneSpeeds (const MSLeaderDistanceInfo &ahead, int sublaneOffset, int laneIndex)
 update expected speeds for each sublane of the current edge
 
virtual void updateSafeLatDist (const double travelledLatDist)
 Updates the value of safe lateral distances (in SL2015) during maneuver continuation in non-action steps.
 
void updateShadowLane ()
 
MSLaneupdateTargetLane ()
 
int wantsChange (int laneOffset, MSAbstractLaneChangeModel::MSLCMessager &msgPass, int blocked, const std::pair< MSVehicle *, double > &leader, const std::pair< MSVehicle *, double > &follower, const std::pair< MSVehicle *, double > &neighLead, const std::pair< MSVehicle *, double > &neighFollow, const MSLane &neighLane, const std::vector< MSVehicle::LaneQ > &preb, MSVehicle **lastBlocked, MSVehicle **firstBlocked) override
 Called to examine whether the vehicle wants to change using the given laneOffset. This method gets the information about the surrounding vehicles and whether another lane may be more preferable.
 
virtual int wantsChangeSublane (int laneOffset, LaneChangeAction alternatives, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &followers, const MSLeaderDistanceInfo &blockers, const MSLeaderDistanceInfo &neighLeaders, const MSLeaderDistanceInfo &neighFollowers, const MSLeaderDistanceInfo &neighBlockers, const MSLane &neighLane, const std::vector< MSVehicle::LaneQ > &preb, MSVehicle **lastBlocked, MSVehicle **firstBlocked, double &latDist, double &targetDistLat, int &blocked)
 
virtual ~MSLCM_LC2013 ()
 

Static Public Member Functions

static MSAbstractLaneChangeModelbuild (LaneChangeModel lcm, MSVehicle &vehicle)
 Factory method for instantiating new lane changing models.
 
static bool haveLCOutput ()
 whether lanechange-output is active
 
static void initGlobalOptions (const OptionsCont &oc)
 init global model parameters
 
static bool outputLCEnded ()
 whether start of maneuvers shall be recorede
 
static bool outputLCStarted ()
 whether start of maneuvers shall be recorede
 

Static Public Attributes

static const double NO_NEIGHBOR
 

Protected Types

typedef std::pair< double, int > Info
 information regarding save velocity (unused) and state flags of the ego vehicle
 

Protected Member Functions

double _patchSpeed (double min, const double wanted, double max, const MSCFModel &cfModel)
 
int _wantsChange (int laneOffset, MSAbstractLaneChangeModel::MSLCMessager &msgPass, int blocked, const std::pair< MSVehicle *, double > &leader, const std::pair< MSVehicle *, double > &follower, const std::pair< MSVehicle *, double > &neighLead, const std::pair< MSVehicle *, double > &neighFollow, const MSLane &neighLane, const std::vector< MSVehicle::LaneQ > &preb, MSVehicle **lastBlocked, MSVehicle **firstBlocked)
 helper function for doing the actual work
 
void adaptSpeedToPedestrians (const MSLane *lane, double &v)
 react to pedestrians on the given lane
 
void addLCSpeedAdvice (const double vSafe, bool ownAdvice=true)
 Takes a vSafe (speed advice for speed in the next simulation step), converts it into an acceleration and stores it into myLCAccelerationAdvices.
 
bool amBlockingFollower ()
 
bool amBlockingFollowerNB ()
 
bool amBlockingFollowerPlusNB ()
 
bool amBlockingLeader ()
 
double anticipateFollowSpeed (const std::pair< MSVehicle *, double > &leaderDist, double dist, double vMax, bool acceleratingLeader)
 anticipate future follow speed for the given leader
 
virtual bool avoidOvertakeRight () const
 
bool cancelRequest (int state, int laneOffset)
 whether the influencer cancels the given request
 
virtual bool congested (const MSVehicle *const neighLeader)
 
bool currentDistAllows (double dist, int laneOffset, double lookForwardDist)
 
bool currentDistDisallows (double dist, int laneOffset, double lookForwardDist)
 
const MSCFModelgetCarFollowModel () const
 The vehicle's car following model.
 
double getMaxSpeedLat2 () const
 return the max of maxSpeedLat and lcMaxSpeedLatStanding
 
void informFollower (MSAbstractLaneChangeModel::MSLCMessager &msgPass, int blocked, int dir, const std::pair< MSVehicle *, double > &neighFollow, double remainingSeconds, double plannedSpeed)
 decide whether we will try cut in before the follower or allow to be overtaken
 
double informLeader (MSAbstractLaneChangeModel::MSLCMessager &msgPass, int blocked, int dir, const std::pair< MSVehicle *, double > &neighLead, double remainingSeconds)
 
void initLastLaneChangeOffset (int dir)
 
virtual bool predInteraction (const std::pair< MSVehicle *, double > &leader)
 
bool saveBlockerLength (double length, double foeLeftSpace) override
 reserve space at the end of the lane to avoid dead locks
 
int slowDownForBlocked (MSVehicle **blocked, int state)
 compute useful slowdowns for blocked vehicles
 

Static Protected Member Functions

static double overtakeDistance (const MSVehicle *follower, const MSVehicle *leader, const double gap, double followerSpeed=INVALID_SPEED, double leaderSpeed=INVALID_SPEED)
 

Protected Attributes

double myAccelerationLat
 the current lateral acceleration
 
bool myAlreadyChanged
 whether the vehicle has already moved this step
 
double myAngleOffset
 the current angle offset resulting from lane change and sigma
 
int myCanceledStateCenter
 
int myCanceledStateLeft
 
int myCanceledStateRight
 
double myCommittedSpeed
 the speed when committing to a change maneuver
 
bool myDontBrake
 
bool myDontResetLCGaps
 Flag to prevent resetting the memorized values for LC relevant gaps until the LC output is triggered in the case of continuous LC.
 
std::vector< MSLane * > myFurtherTargetLanes
 
bool myHaveBlueLight
 whether this vehicle is driving with special permissions and behavior
 
double myKeepRightProbability
 
double myLaneChangeCompletion
 progress of the lane change maneuver 0:started, 1:complete
 
int myLaneChangeDirection
 direction of the lane change maneuver -1 means right, 1 means left
 
double myLastFollowerGap
 
double myLastFollowerSecureGap
 
double myLastFollowerSpeed
 
double myLastLateralGapLeft
 the minimum lateral gaps to other vehicles that were found when last changing to the left and right
 
double myLastLateralGapRight
 
double myLastLeaderGap
 the actual minimum longitudinal distances to vehicles on the target lane
 
double myLastLeaderSecureGap
 the minimum longitudinal distances to vehicles on the target lane that would be necessary for stringent security
 
double myLastLeaderSpeed
 speeds of surrounding vehicles at the time of lane change
 
double myLastOrigLeaderGap
 acutal and secure distance to closest leader vehicle on the original when performing lane change
 
double myLastOrigLeaderSecureGap
 
double myLastOrigLeaderSpeed
 
std::vector< std::pair< double, bool > > myLCAccelerationAdvices
 
double myLeadingBlockerLength
 
double myLeftSpace
 
double myLookAheadSpeed
 
double myMaxDistLatStanding
 
double myMaxSpeedLatFactor
 
double myMaxSpeedLatStanding
 
const LaneChangeModel myModel
 the type of this model
 
std::vector< MSLane * > myNoPartiallyOccupatedByShadow
 
double myOvertakeRightParam
 
int myOwnState
 The current state of the vehicle.
 
std::vector< MSLane * > myPartiallyOccupatedByShadow
 list of lanes where the shadow vehicle is partial occupator
 
double myPreviousAngleOffset
 the angle offset of the previous time step resulting from lane change and sigma
 
int myPreviousState
 lane changing state from the previous simulation step
 
int myPreviousState2
 lane changing state from step before the previous simulation step
 
std::pair< int, int > mySavedStateCenter
 
std::pair< int, int > mySavedStateLeft
 
std::pair< int, int > mySavedStateRight
 
std::vector< MSLane * > myShadowFurtherLanes
 
std::vector< double > myShadowFurtherLanesPosLat
 
MSLanemyShadowLane
 A lane that is partially occupied by the front of the vehicle but that is not the primary lane.
 
double mySigma
 
double mySpeedGainProbability
 a value for tracking the probability that a change to the offset with the same sign is beneficial
 
double mySpeedLat
 the current lateral speed
 
MSLanemyTargetLane
 The target lane for the vehicle's current maneuver.
 
MSVehiclemyVehicle
 The vehicle this lane-changer belongs to.
 
user configurable model parameters (can be changed via TraCI)
double myStrategicParam
 
double myCooperativeParam
 
double mySpeedGainParam
 
double myKeepRightParam
 
double myOppositeParam
 
double myLookaheadLeft
 
double mySpeedGainRight
 
double myAssertive
 
double mySpeedGainLookahead
 
double myRoundaboutBonus
 
double myCooperativeSpeed
 
double myKeepRightAcceptanceTime
 
double myOvertakeDeltaSpeedFactor
 
const double myExperimentalParam1
 
derived parameters
double myChangeProbThresholdRight
 
double myChangeProbThresholdLeft
 
std::shared_ptr< MSLeaderDistanceInfomyLeftFollowers
 Cached info on lc-relevant neighboring vehicles.
 
std::shared_ptr< MSLeaderDistanceInfomyLeftLeaders
 
std::shared_ptr< MSLeaderDistanceInfomyRightFollowers
 
std::shared_ptr< MSLeaderDistanceInfomyRightLeaders
 

Static Protected Attributes

static bool myAllowOvertakingRight
 whether overtaking on the right is permitted
 
static bool myLCEndedOutput
 
static bool myLCOutput
 whether to record lane-changing
 
static bool myLCStartedOutput
 
static bool myLCXYOutput
 

Private Attributes

bool myAmOpposite
 whether the vehicle is driving in the opposite direction
 
std::vector< MSLink * > myApproachedByShadow
 links which are approached by the shadow vehicle
 
SUMOTime myLastLaneChangeOffset
 
double myManeuverDist
 The complete lateral distance the vehicle wants to travel to finish its maneuver Only used by sublane model, currently.
 
double myPreviousManeuverDist
 Maneuver distance from the previous simulation step.
 

Detailed Description

A lane change model developed by D. Krajzewicz, J. Erdmann et al. between 2004 and 2013.

Definition at line 45 of file MSLCM_LC2013.h.

Member Typedef Documentation

◆ Info

typedef std::pair<double, int> MSLCM_LC2013::Info
protected

information regarding save velocity (unused) and state flags of the ego vehicle

Definition at line 199 of file MSLCM_LC2013.h.

Constructor & Destructor Documentation

◆ MSLCM_LC2013()

◆ ~MSLCM_LC2013()

MSLCM_LC2013::~MSLCM_LC2013 ( )
virtual

Definition at line 132 of file MSLCM_LC2013.cpp.

References changed().

Member Function Documentation

◆ _patchSpeed()

◆ _wantsChange()

int MSLCM_LC2013::_wantsChange ( int  laneOffset,
MSAbstractLaneChangeModel::MSLCMessager msgPass,
int  blocked,
const std::pair< MSVehicle *, double > &  leader,
const std::pair< MSVehicle *, double > &  follower,
const std::pair< MSVehicle *, double > &  neighLead,
const std::pair< MSVehicle *, double > &  neighFollow,
const MSLane neighLane,
const std::vector< MSVehicle::LaneQ > &  preb,
MSVehicle **  lastBlocked,
MSVehicle **  firstBlocked 
)
protected

helper function for doing the actual work

we urgently need to change lanes to follow our route

Definition at line 1097 of file MSLCM_LC2013.cpp.

References adaptSpeedToPedestrians(), MSAbstractLaneChangeModel::addLCSpeedAdvice(), amBlockingFollowerPlusNB(), anticipateFollowSpeed(), MSAbstractLaneChangeModel::avoidOvertakeRight(), MSVehicle::LaneQ::bestContinuations, MSVehicle::LaneQ::bestLaneOffset, MSCFModel::brakeGap(), MSAbstractLaneChangeModel::cancelRequest(), MSVehicle::Influencer::changeRequestRemainingSeconds(), currentDistAllows(), currentDistDisallows(), DEBUG_COND, MSCFModel::followSpeed(), MSVehicle::getActionStepLengthSecs(), MSLane::getBidiLane(), MSLane::getBruttoOccupancy(), MSAbstractLaneChangeModel::getCanceledState(), MSAbstractLaneChangeModel::getCarFollowModel(), MSVehicle::getCarFollowModel(), MSNet::getCurrentTimeStep(), MSLane::getEdge(), MSAbstractLaneChangeModel::getForwardPos(), Named::getID(), Named::getIDSecure(), MSVehicle::getInfluencer(), MSNet::getInstance(), MSVehicle::getLane(), MSVehicle::getLastStepDist(), MSVehicleType::getLength(), MSVehicleType::getLengthWithGap(), MSLane::getLinkCont(), MSCFModel::getMaxDecel(), MSBaseVehicle::getNextStop(), MSLane::getNormalPredecessorLane(), MSEdge::getPersons(), MSVehicle::getPositionOnLane(), MSLCHelper::getRoundaboutDistBonus(), MSCFModel::getSecureGap(), MSVehicle::getSpeed(), MSCFModel::getSpeedAfterMaxDecel(), MSLane::getSpeedLimit(), MSLane::getVehicleMaxSpeed(), MSBaseVehicle::getVehicleType(), gPrecision, MSGlobals::gSemiImplicitEulerUpdate, HELP_OVERTAKE, MSVehicle::influenceChangeDecision(), informFollower(), informLeader(), MSLCHelper::isBidiFollower(), MSLCHelper::isBidiLeader(), MSEdge::isInternal(), MSAbstractLaneChangeModel::isOpposite(), JAM_FACTOR, KEEP_RIGHT_TIME, MSStop::lane, MSVehicle::LaneQ::lane, LCA_COOPERATIVE, LCA_KEEPRIGHT, LCA_LEFT, LCA_MLEFT, LCA_MRIGHT, LCA_RIGHT, LCA_SPEEDGAIN, LCA_STAY, LCA_STRATEGIC, LCA_TRACI, LCA_URGENT, MSVehicle::LaneQ::length, LOOK_AHEAD_MIN_SPEED, LOOK_AHEAD_SPEED_MEMORY, LOOK_FORWARD, MAGIC_OFFSET, MAX2(), MIN2(), myChangeProbThresholdLeft, myChangeProbThresholdRight, myCooperativeParam, myDontBrake, myKeepRightAcceptanceTime, myKeepRightParam, myKeepRightProbability, MSAbstractLaneChangeModel::myLCAccelerationAdvices, myLeadingBlockerLength, myLeftSpace, myLookaheadLeft, myLookAheadSpeed, MSAbstractLaneChangeModel::myOwnState, myRoundaboutBonus, mySpeedGainProbability, myStrategicParam, MSAbstractLaneChangeModel::myVehicle, MSVehicle::nextStopDist(), MSVehicle::LaneQ::occupation, OPPOSITE_URGENCY, REACT_TO_STOPPED_DISTANCE, RELGAIN_NORMALIZATION_MIN_SPEED, SIMTIME, slowDownForBlocked(), STEPS2TIME, SUMO_const_haltingSpeed, toString(), TS, TURN_LANE_DIST, MSLCHelper::updateBlockerLength(), and URGENCY.

Referenced by wantsChange().

Here is the caller graph for this function:

◆ adaptSpeedToPedestrians()

void MSLCM_LC2013::adaptSpeedToPedestrians ( const MSLane lane,
double &  v 
)
protected

react to pedestrians on the given lane

Definition at line 2011 of file MSLCM_LC2013.cpp.

References DEBUG_COND, MSVehicle::getCarFollowModel(), Named::getID(), MSCFModel::getMaxDecel(), MSVehicleType::getMinGap(), MSVehicle::getPositionOnLane(), MSVehicle::getRightSideOnLane(), MSVehicle::getSpeed(), MSBaseVehicle::getVehicleType(), MSVehicleType::getWidth(), MSLane::hasPedestrians(), MIN2(), MSAbstractLaneChangeModel::myVehicle, MSLane::nextBlocking(), SIMTIME, and MSCFModel::stopSpeed().

Referenced by _wantsChange().

Here is the caller graph for this function:

◆ addLCSpeedAdvice()

void MSAbstractLaneChangeModel::addLCSpeedAdvice ( const double  vSafe,
bool  ownAdvice = true 
)
protectedinherited

Takes a vSafe (speed advice for speed in the next simulation step), converts it into an acceleration and stores it into myLCAccelerationAdvices.

Note
This construction was introduced to deal with action step lengths, where operation on the speed in the next sim step had to be replaced by acceleration throughout the next action step.

Definition at line 1101 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::getSpeed(), MSAbstractLaneChangeModel::myLCAccelerationAdvices, MSAbstractLaneChangeModel::myVehicle, and SPEED2ACCEL.

Referenced by _wantsChange(), MSLCM_SL2015::checkStrategicChange(), inform(), MSLCM_SL2015::inform(), MSLCM_SL2015::informFollower(), informFollower(), MSLCM_SL2015::informLeader(), informLeader(), slowDownForBlocked(), and MSLCM_SL2015::slowDownForBlocked().

Here is the caller graph for this function:

◆ alreadyChanged()

bool MSAbstractLaneChangeModel::alreadyChanged ( ) const
inlineinherited

reset the flag whether a vehicle already moved to false

Definition at line 503 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAlreadyChanged.

Referenced by MSLaneChanger::change(), and MSLaneChangerSublane::change().

Here is the caller graph for this function:

◆ amBlockingFollower()

bool MSLCM_LC2013::amBlockingFollower ( )
inlineprotected

◆ amBlockingFollowerNB()

bool MSLCM_LC2013::amBlockingFollowerNB ( )
inlineprotected

◆ amBlockingFollowerPlusNB()

bool MSLCM_LC2013::amBlockingFollowerPlusNB ( )
inlineprotected

Definition at line 186 of file MSLCM_LC2013.h.

References LCA_AMBLOCKINGFOLLOWER, LCA_AMBLOCKINGFOLLOWER_DONTBRAKE, and MSAbstractLaneChangeModel::myOwnState.

Referenced by _wantsChange().

Here is the caller graph for this function:

◆ amBlockingLeader()

bool MSLCM_LC2013::amBlockingLeader ( )
inlineprotected

Definition at line 177 of file MSLCM_LC2013.h.

References LCA_AMBLOCKINGLEADER, and MSAbstractLaneChangeModel::myOwnState.

◆ anticipateFollowSpeed()

double MSLCM_LC2013::anticipateFollowSpeed ( const std::pair< MSVehicle *, double > &  leaderDist,
double  dist,
double  vMax,
bool  acceleratingLeader 
)
protected

◆ avoidOvertakeRight()

bool MSAbstractLaneChangeModel::avoidOvertakeRight ( ) const
protectedvirtualinherited

◆ build()

MSAbstractLaneChangeModel * MSAbstractLaneChangeModel::build ( LaneChangeModel  lcm,
MSVehicle vehicle 
)
staticinherited

Factory method for instantiating new lane changing models.

Parameters
[in]lcmThe type of model to build
[in]vehicleThe vehicle for which this model shall be built

Definition at line 81 of file MSAbstractLaneChangeModel.cpp.

References DEFAULT, DK2008, MSGlobals::gLateralResolution, LC2013, LC2013_CC, SL2015, TLF, and toString().

Referenced by MSVehicle::initDevices().

Here is the caller graph for this function:

◆ calcAngleOffset()

double MSAbstractLaneChangeModel::calcAngleOffset ( )
inherited

return the angle offset during a continuous change maneuver

Definition at line 743 of file MSAbstractLaneChangeModel.cpp.

References MSBaseVehicle::getLength(), MSVehicle::getSpeed(), M_PI, MSAbstractLaneChangeModel::myAngleOffset, MSAbstractLaneChangeModel::myPreviousAngleOffset, MSAbstractLaneChangeModel::mySpeedLat, MSAbstractLaneChangeModel::myVehicle, and SPEED2DIST.

Referenced by MSVehicle::computeAngle().

Here is the caller graph for this function:

◆ cancelRequest()

bool MSAbstractLaneChangeModel::cancelRequest ( int  state,
int  laneOffset 
)
protectedinherited

whether the influencer cancels the given request

Definition at line 558 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::getCanceledState(), MSVehicle::influenceChangeDecision(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChange(), and MSLCM_SL2015::_wantsChangeSublane().

Here is the caller graph for this function:

◆ changed()

void MSLCM_LC2013::changed ( )
overridevirtual

Implements MSAbstractLaneChangeModel.

Definition at line 1067 of file MSLCM_LC2013.cpp.

References MSVehicle::getBestLaneOffset(), LOOK_AHEAD_MIN_SPEED, myDontBrake, myKeepRightProbability, MSAbstractLaneChangeModel::myLCAccelerationAdvices, myLeadingBlockerLength, myLeftSpace, myLookAheadSpeed, MSAbstractLaneChangeModel::myOwnState, mySpeedGainProbability, and MSAbstractLaneChangeModel::myVehicle.

Referenced by _patchSpeed(), and ~MSLCM_LC2013().

Here is the caller graph for this function:

◆ changedToOpposite()

void MSAbstractLaneChangeModel::changedToOpposite ( )
inherited

called when a vehicle changes between lanes in opposite directions

Definition at line 948 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myAlreadyChanged, and MSAbstractLaneChangeModel::myAmOpposite.

Referenced by MSAbstractLaneChangeModel::endLaneChangeManeuver(), MSVehicle::executeMove(), and MSAbstractLaneChangeModel::primaryLaneChanged().

Here is the caller graph for this function:

◆ checkChangeBeforeCommitting()

virtual int MSAbstractLaneChangeModel::checkChangeBeforeCommitting ( const MSVehicle veh,
int  state 
) const
inlinevirtualinherited

Informs the vehicle that it is about to be moved on an adjacent lane. The method can be used to re-evaluate the state of the vehicle and potentially abort the lane change. By default, if the method is not overridden by the lane change model implementation, nothing is altered and the vehicle will perform the lane change.

Parameters
vehthe lane changing vehicle
statecurrent lane change state
Returns
the blocked status of the vehicle. If the vehicle should perform the lane change, the method should return 0, corresponding to non-blocked. Otherwise the method should return a non-zero state, corresponding to the type of blockage.

Reimplemented in MSLCM_LC2013_CC.

Definition at line 155 of file MSAbstractLaneChangeModel.h.

References UNUSED_PARAMETER.

Referenced by MSLaneChanger::checkChange().

Here is the caller graph for this function:

◆ checkTraCICommands()

void MSAbstractLaneChangeModel::checkTraCICommands ( )
inherited

Check for commands issued for the vehicle via TraCI and apply the appropriate state changes For the sublane case, this includes setting a new maneuver distance if appropriate.

Definition at line 902 of file MSAbstractLaneChangeModel.cpp.

References gDebugFlag2, Named::getID(), MSVehicle::getInfluencer(), MSVehicle::getLaneChangeModel(), MSVehicle::Influencer::getLatDist(), MSAbstractLaneChangeModel::getOwnState(), MSGlobals::gLateralResolution, MSVehicle::hasInfluencer(), MSVehicle::influenceChangeDecision(), MSVehicle::lateralDistanceToLane(), LCA_LEFT, LCA_RIGHT, LCA_STAY, LCA_TRACI, MSAbstractLaneChangeModel::myOwnState, MSAbstractLaneChangeModel::myVehicle, MSVehicle::Influencer::resetLatDist(), MSAbstractLaneChangeModel::setManeuverDist(), MSAbstractLaneChangeModel::setOwnState(), SIMTIME, and toString().

Referenced by MSLaneChanger::checkTraCICommands().

Here is the caller graph for this function:

◆ cleanupShadowLane()

void MSAbstractLaneChangeModel::cleanupShadowLane ( )
inherited

◆ cleanupTargetLane()

void MSAbstractLaneChangeModel::cleanupTargetLane ( )
inherited

◆ clearGapsAtLCInit()

void MSAbstractLaneChangeModel::clearGapsAtLCInit ( )
inherited

Definition at line 327 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myDontResetLCGaps.

Referenced by MSAbstractLaneChangeModel::laneChangeOutput().

Here is the caller graph for this function:

◆ clearNeighbors()

void MSAbstractLaneChangeModel::clearNeighbors ( )
inherited

Clear info on neighboring vehicle from previous step.

Definition at line 228 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLeftFollowers, MSAbstractLaneChangeModel::myLeftLeaders, MSAbstractLaneChangeModel::myRightFollowers, and MSAbstractLaneChangeModel::myRightLeaders.

Referenced by MSLaneChanger::change(), and MSLaneChangerSublane::change().

Here is the caller graph for this function:

◆ computeSpeedLat()

double MSLCM_LC2013::computeSpeedLat ( double  latDist,
double &  maneuverDist,
bool  urgent 
) const
overridevirtual

◆ congested()

bool MSAbstractLaneChangeModel::congested ( const MSVehicle *const  neighLeader)
protectedvirtualinherited

Definition at line 264 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::congested(), MSVehicle::getLane(), MSLane::getSpeedLimit(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLCM_DK2008::wantsChangeToLeft(), and MSLCM_DK2008::wantsChangeToRight().

Here is the caller graph for this function:

◆ currentDistAllows()

bool MSLCM_LC2013::currentDistAllows ( double  dist,
int  laneOffset,
double  lookForwardDist 
)
inlineprotected

Definition at line 192 of file MSLCM_LC2013.h.

Referenced by _wantsChange().

Here is the caller graph for this function:

◆ currentDistDisallows()

bool MSLCM_LC2013::currentDistDisallows ( double  dist,
int  laneOffset,
double  lookForwardDist 
)
inlineprotected

Definition at line 189 of file MSLCM_LC2013.h.

Referenced by _wantsChange().

Here is the caller graph for this function:

◆ debugVehicle()

bool MSLCM_LC2013::debugVehicle ( ) const
overridevirtual

whether the current vehicles shall be debugged

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 150 of file MSLCM_LC2013.cpp.

References DEBUG_COND.

◆ decideDirection()

virtual StateAndDist MSAbstractLaneChangeModel::decideDirection ( StateAndDist  sd1,
StateAndDist  sd2 
) const
inlinevirtualinherited

decide in which direction to move in case both directions are desirable

Reimplemented in MSLCM_SL2015.

Definition at line 350 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myModel, toString(), and UNUSED_PARAMETER.

Referenced by MSLaneChangerSublane::change().

Here is the caller graph for this function:

◆ determineTargetLane()

MSLane * MSAbstractLaneChangeModel::determineTargetLane ( int &  targetDir) const
inherited

Definition at line 711 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::getLane(), MSVehicle::getLateralPositionOnLane(), MSLane::getParallelLane(), MSBaseVehicle::getWidth(), MSLane::getWidth(), MSAbstractLaneChangeModel::myManeuverDist, MSAbstractLaneChangeModel::myShadowLane, and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSAbstractLaneChangeModel::updateTargetLane().

Here is the caller graph for this function:

◆ endLaneChangeManeuver()

◆ estimateLCDuration()

double MSAbstractLaneChangeModel::estimateLCDuration ( const double  speed,
const double  remainingManeuverDist,
const double  decel,
bool  urgent 
) const
virtualinherited

Calculates the maximal time needed to complete a lane change maneuver if lcMaxSpeedLatFactor and lcMaxSpeedStanding are set and the vehicle breaks not harder than decel. LC when the vehicle starts breaking now. If lcMaxSpeedStanding==0 the completion may be impossible,.

Parameters
[in]speedCurrent longitudinal speed of the changing vehicle.
[in]remainingManeuverDistdist which is still to be covered until LC is completed
[in]decelMaximal assumed deceleration rate applied during the LC.
Returns
maximal LC duration (or -1) if it is possible that it can't be completed.
Note
1) For the calculation it is assumed that the vehicle starts breaking with decel (>=0) immediately. If lcMaxSpeedStanding==0 the completion may be impossible, and -1 is returned. 2) In case that no maxSpeedLat is used to control lane changing, this is only called prior to a lane change, and the duration is MSGlobals::gLaneChangeDuration.

Definition at line 759 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::computeSpeedLat(), MSVehicle::getAcceleration(), SUMOVTypeParameter::getLCParams(), MSVehicleType::getMaxSpeedLat(), MSVehicleType::getParameter(), MSBaseVehicle::getVehicleType(), MSGlobals::gLaneChangeDuration, MSAbstractLaneChangeModel::myMaxSpeedLatFactor, MSAbstractLaneChangeModel::myMaxSpeedLatStanding, MSAbstractLaneChangeModel::myVehicle, STEPS2TIME, SUMO_ATTR_LCA_MAXSPEEDLATFACTOR, SUMO_ATTR_LCA_MAXSPEEDLATSTANDING, SUMO_const_haltingSpeed, VTYPEPARS_MAXSPEED_LAT_SET, and MSVehicleType::wasSet().

Referenced by MSLaneChanger::checkChange(), and MSAbstractLaneChangeModel::remainingTime().

Here is the caller graph for this function:

◆ getAccelerationLat()

double MSAbstractLaneChangeModel::getAccelerationLat ( ) const
inlineinherited

return the lateral speed of the current lane change maneuver

Definition at line 597 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAccelerationLat.

Referenced by MSFCDExport::write().

Here is the caller graph for this function:

◆ getAngleOffset()

double MSAbstractLaneChangeModel::getAngleOffset ( ) const
inlineinherited

return the angle offset resulting from lane change and sigma

Definition at line 488 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAngleOffset.

Referenced by MSVehicle::executeMove(), and GUIVehicle::getVisualAngle().

Here is the caller graph for this function:

◆ getAssumedDecelForLaneChangeDuration()

double MSAbstractLaneChangeModel::getAssumedDecelForLaneChangeDuration ( ) const
virtualinherited

Returns a deceleration value which is used for the estimation of the duration of a lane change.

Note
Effective only for continuous lane-changing when using attributes myMaxSpeedLatFactor and myMaxSpeedLatStanding. See #3771

Definition at line 427 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::getAcceleration(), LC_ASSUMED_DECEL, MAX2(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLaneChanger::checkChange().

Here is the caller graph for this function:

◆ getCanceledState()

int & MSAbstractLaneChangeModel::getCanceledState ( const int  dir)
inlineinherited

◆ getCarFollowModel()

const MSCFModel & MSAbstractLaneChangeModel::getCarFollowModel ( ) const
inlineprotectedinherited

◆ getCommittedSpeed()

double MSAbstractLaneChangeModel::getCommittedSpeed ( ) const
inlineinherited

Definition at line 583 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myCommittedSpeed.

Referenced by MSVehicle::planMoveInternal(), and MSLaneChangerSublane::startChangeSublane().

Here is the caller graph for this function:

◆ getDesiredAlignment()

virtual LatAlignmentDefinition MSAbstractLaneChangeModel::getDesiredAlignment ( ) const
inlinevirtualinherited

Reimplemented in MSLCM_SL2015.

Definition at line 639 of file MSAbstractLaneChangeModel.h.

References MSVehicleType::getPreferredLateralAlignment(), MSBaseVehicle::getVehicleType(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLCM_SL2015::getDesiredAlignment().

Here is the caller graph for this function:

◆ getExtraReservation()

double MSLCM_LC2013::getExtraReservation ( int  ) const
overridevirtual

reserve extra space for unseen blockers when more tnan one lane change is required

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 1057 of file MSLCM_LC2013.cpp.

◆ getFollowers()

const std::shared_ptr< MSLeaderDistanceInfo > MSAbstractLaneChangeModel::getFollowers ( const int  dir)
inherited

Returns the neighboring, lc-relevant followers for the last step in the requested direction.

Definition at line 237 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLeftFollowers, and MSAbstractLaneChangeModel::myRightFollowers.

◆ getForwardPos()

double MSAbstractLaneChangeModel::getForwardPos ( ) const
inherited

get vehicle position relative to the forward direction lane

Definition at line 1085 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::getLane(), MSLane::getLength(), MSVehicle::getPositionOnLane(), MSAbstractLaneChangeModel::myAmOpposite, and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), MSLCM_SL2015::checkStrategicChange(), and MSLaneChanger::getBestLanesOpposite().

Here is the caller graph for this function:

◆ getFurtherTargetLanes()

const std::vector< MSLane * > & MSAbstractLaneChangeModel::getFurtherTargetLanes ( ) const
inlineinherited

Definition at line 436 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myFurtherTargetLanes.

Referenced by MSVehicle::getBackPositionOnLane(), and MSVehicle::getLatOffset().

Here is the caller graph for this function:

◆ getLaneChangeCompletion()

double MSAbstractLaneChangeModel::getLaneChangeCompletion ( ) const
inlineinherited

Get the current lane change completion ratio.

Definition at line 472 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLaneChangeCompletion.

Referenced by MSLaneChanger::continueChange(), and MSVehicle::planMoveInternal().

Here is the caller graph for this function:

◆ getLaneChangeDirection()

int MSAbstractLaneChangeModel::getLaneChangeDirection ( ) const
inlineinherited

return the direction of the current lane change maneuver

Definition at line 477 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLaneChangeDirection.

Referenced by MSLaneChanger::continueChange(), and MSVehicle::setBlinkerInformation().

Here is the caller graph for this function:

◆ getLastLaneChangeOffset()

SUMOTime MSAbstractLaneChangeModel::getLastLaneChangeOffset ( ) const
inlineinherited

◆ getLeaders()

const std::shared_ptr< MSLeaderDistanceInfo > MSAbstractLaneChangeModel::getLeaders ( const int  dir)
inherited

Returns the neighboring, lc-relevant leaders for the last step in the requested direction.

Definition at line 250 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLeftLeaders, and MSAbstractLaneChangeModel::myRightLeaders.

◆ getManeuverDist()

double MSAbstractLaneChangeModel::getManeuverDist ( ) const
inherited

Returns the remaining unblocked distance for the current maneuver. (only used by sublane model)

Definition at line 188 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myManeuverDist.

Referenced by MSLCM_SL2015::_wantsChangeSublane(), MSLaneChangerSublane::change(), MSLCM_SL2015::changed(), MSLaneChangerSublane::continueChangeSublane(), MSVehicle::getLatOffset(), MSLink::getLeaderInfo(), GUIVehicle::getManeuverDist(), MSLeaderInfo::getSubLanes(), MSLaneChangerSublane::startChangeSublane(), MSAbstractLaneChangeModel::updateCompletion(), and MSLCM_SL2015::updateGaps().

Here is the caller graph for this function:

◆ getMaxSpeedLat2()

double MSAbstractLaneChangeModel::getMaxSpeedLat2 ( ) const
protectedinherited

return the max of maxSpeedLat and lcMaxSpeedLatStanding

Definition at line 566 of file MSAbstractLaneChangeModel.cpp.

References MSVehicleType::getMaxSpeedLat(), MSBaseVehicle::getVehicleType(), MAX2(), MSAbstractLaneChangeModel::myMaxSpeedLatStanding, and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLCM_SL2015::checkBlocking().

Here is the caller graph for this function:

◆ getModelID()

LaneChangeModel MSLCM_LC2013::getModelID ( ) const
inlineoverridevirtual

Returns the model's id.

Implements MSAbstractLaneChangeModel.

Reimplemented in MSLCM_LC2013_CC.

Definition at line 53 of file MSLCM_LC2013.h.

References LC2013.

◆ getNormalizedLaneIndex()

int MSAbstractLaneChangeModel::getNormalizedLaneIndex ( )
inherited

brief return lane index that treats opposite lanes like normal lanes to the left of the forward lanes

Definition at line 1091 of file MSAbstractLaneChangeModel.cpp.

References MSLane::getEdge(), MSLane::getIndex(), MSVehicle::getLane(), MSEdge::getNumLanes(), MSLane::getParallelOpposite(), MSAbstractLaneChangeModel::myAmOpposite, and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLaneChanger::checkOppositeStop().

Here is the caller graph for this function:

◆ getOppositeSafetyFactor()

double MSLCM_LC2013::getOppositeSafetyFactor ( ) const
overridevirtual

return factor for modifying the safety constraints for opposite-diretction overtaking of the car-following model

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 2059 of file MSLCM_LC2013.cpp.

References myOppositeParam.

◆ getOwnState()

◆ getParameter()

std::string MSLCM_LC2013::getParameter ( const std::string &  key) const
overridevirtual

◆ getPreviousManeuverDist()

double MSAbstractLaneChangeModel::getPreviousManeuverDist ( ) const
inherited

Definition at line 193 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myPreviousManeuverDist.

Referenced by MSLCM_SL2015::_wantsChangeSublane(), MSLaneChangerSublane::abortLCManeuver(), and MSLaneChangerSublane::startChangeSublane().

Here is the caller graph for this function:

◆ getPrevState()

int MSAbstractLaneChangeModel::getPrevState ( ) const
inlineinherited

at the time of this call myPreviousState already holds the new value

Definition at line 199 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myPreviousState2.

Referenced by MSLaneChangerSublane::abortLCManeuver(), MSLaneChangerSublane::outputLCStarted(), and MSLaneChangerSublane::startChangeSublane().

Here is the caller graph for this function:

◆ getSafetyFactor()

double MSLCM_LC2013::getSafetyFactor ( ) const
overridevirtual

return factor for modifying the safety constraints of the car-following model

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 2054 of file MSLCM_LC2013.cpp.

References myAssertive.

◆ getSavedState()

const std::pair< int, int > & MSAbstractLaneChangeModel::getSavedState ( const int  dir) const
inlineinherited

◆ getShadowDirection()

int MSAbstractLaneChangeModel::getShadowDirection ( ) const
inherited

◆ getShadowFurtherLanes()

const std::vector< MSLane * > & MSAbstractLaneChangeModel::getShadowFurtherLanes ( ) const
inlineinherited

Definition at line 421 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myShadowFurtherLanes.

Referenced by MSVehicle::getBackPositionOnLane(), MSVehicle::getCenterOnEdge(), and MSVehicle::getLatOffset().

Here is the caller graph for this function:

◆ getShadowFurtherLanesPosLat()

const std::vector< double > & MSAbstractLaneChangeModel::getShadowFurtherLanesPosLat ( ) const
inlineinherited

Definition at line 425 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myShadowFurtherLanesPosLat.

Referenced by MSVehicle::getBackPositionOnLane(), MSVehicle::getCenterOnEdge(), and MSVehicle::getLatOffset().

Here is the caller graph for this function:

◆ getShadowLane() [1/3]

◆ getShadowLane() [2/3]

MSLane * MSAbstractLaneChangeModel::getShadowLane ( const MSLane lane) const
inherited

◆ getShadowLane() [3/3]

◆ getSpeedLat()

double MSAbstractLaneChangeModel::getSpeedLat ( ) const
inlineinherited

return the lateral speed of the current lane change maneuver

Definition at line 588 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::mySpeedLat.

Referenced by MSLaneChangerSublane::abortLCManeuver(), MSLaneChangerSublane::change(), MSLaneChanger::continueChange(), GUIVehicle::getColorValue(), MSLink::getLeaderInfo(), GUIVehicle::getParameterWindow(), MSLeaderInfo::getSubLanes(), MSFCDExport::write(), and MSXMLRawOut::writeVehicle().

Here is the caller graph for this function:

◆ getTargetLane()

MSLane * MSAbstractLaneChangeModel::getTargetLane ( ) const
inlineinherited

Returns the lane the vehicle has committed to enter during a sublane lane change.

Returns
The vehicle's target lane.

Definition at line 432 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myTargetLane.

Referenced by MSVehicle::getBackPositionOnLane(), and MSVehicle::getLatOffset().

Here is the caller graph for this function:

◆ hasBlueLight()

bool MSAbstractLaneChangeModel::hasBlueLight ( ) const
inlineinherited

Definition at line 635 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myHaveBlueLight.

Referenced by anticipateFollowSpeed(), MSVehicle::executeMove(), MSVehicle::isLeader(), MSVehicle::planMoveInternal(), MSLane::resetPartialOccupation(), and MSLCM_SL2015::updateExpectedSublaneSpeeds().

Here is the caller graph for this function:

◆ haveLCOutput()

static bool MSAbstractLaneChangeModel::haveLCOutput ( )
inlinestaticinherited

whether lanechange-output is active

Definition at line 172 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLCOutput.

Referenced by MSLaneChangerSublane::checkChangeToNewLane(), MSLaneChangerSublane::outputLCEnded(), and MSLaneChangerSublane::outputLCStarted().

Here is the caller graph for this function:

◆ inform()

◆ informFollower()

void MSLCM_LC2013::informFollower ( MSAbstractLaneChangeModel::MSLCMessager msgPass,
int  blocked,
int  dir,
const std::pair< MSVehicle *, double > &  neighFollow,
double  remainingSeconds,
double  plannedSpeed 
)
protected

◆ informLeader()

double MSLCM_LC2013::informLeader ( MSAbstractLaneChangeModel::MSLCMessager msgPass,
int  blocked,
int  dir,
const std::pair< MSVehicle *, double > &  neighLead,
double  remainingSeconds 
)
protected

◆ initDerivedParameters()

void MSLCM_LC2013::initDerivedParameters ( )

init cached parameters derived directly from model parameters

Definition at line 138 of file MSLCM_LC2013.cpp.

References myChangeProbThresholdLeft, myChangeProbThresholdRight, mySpeedGainParam, and mySpeedGainRight.

Referenced by MSLCM_LC2013(), and setParameter().

Here is the caller graph for this function:

◆ initGlobalOptions()

void MSAbstractLaneChangeModel::initGlobalOptions ( const OptionsCont oc)
staticinherited

init global model parameters

Definition at line 71 of file MSAbstractLaneChangeModel.cpp.

References OptionsCont::getBool(), OptionsCont::isSet(), MSAbstractLaneChangeModel::myAllowOvertakingRight, MSAbstractLaneChangeModel::myLCEndedOutput, MSAbstractLaneChangeModel::myLCOutput, MSAbstractLaneChangeModel::myLCStartedOutput, and MSAbstractLaneChangeModel::myLCXYOutput.

Referenced by MSFrame::setMSGlobals().

Here is the caller graph for this function:

◆ initLastLaneChangeOffset()

void MSAbstractLaneChangeModel::initLastLaneChangeOffset ( int  dir)
protectedinherited

Definition at line 571 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLastLaneChangeOffset.

Referenced by MSAbstractLaneChangeModel::primaryLaneChanged().

Here is the caller graph for this function:

◆ isChangingLanes()

◆ isOpposite()

bool MSAbstractLaneChangeModel::isOpposite ( ) const
inlineinherited

Definition at line 576 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAmOpposite.

Referenced by _wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), MSVehicle::adaptToLeaders(), libsumo::Helper::applySubscriptionFilterLateralDistance(), MSLane::appropriate(), MSLaneChanger::avoidDeadlock(), MSLaneChanger::change(), MSLaneChangerSublane::change(), MSLaneChanger::changeOpposite(), MSLaneChanger::checkChange(), MSLaneChangerSublane::checkChangeHelper(), MSLaneChanger::checkChangeOpposite(), MSLaneChangerSublane::checkChangeOpposite(), MSLaneChangerSublane::checkChangeToNewLane(), MSLaneChanger::checkOppositeStop(), MSVehicle::checkRewindLinkLanes(), MSDevice_SSM::classifyEncounter(), MSTrainHelper::computeCarriages(), MSVehicle::computeFurtherLanes(), MSLaneChanger::computeSafeOppositeLength(), MSLaneChanger::computeSurplusGap(), MSLaneChanger::continueChange(), MSLane::detectCollisionBetween(), MSVehicle::enterLaneAtInsertion(), MSVehicle::enterLaneAtMove(), MSVehicle::executeMove(), MSDevice_SSM::findFoeConflictLane(), MSDevice_SSM::findSurroundingVehicles(), MSVehicle::getBackPositionOnLane(), MSLaneChanger::getBestLanesOpposite(), MSVehicle::getCenterOnEdge(), GUIVehicle::getColorValue(), MSLane::getFollowersOnConsecutive(), MSLane::getLeader(), MSLink::getLeaderInfo(), LIBSUMO_NAMESPACE::Vehicle::getNeighbors(), MSLCM_SL2015::getNeighRight(), MSLane::getOppositeFollower(), MSLane::getOppositeLeader(), MSVehicle::getPastLanesUntil(), MSVehicle::getPositionAlongBestLanes(), MSLCHelper::getRoundaboutDistBonus(), GUIBaseVehicle::getScaleValue(), MSVehicle::getUpcomingLanesUntil(), MSLCM_SL2015::getVehicleCenter(), MSLane::handleCollisionBetween(), MSVehicle::handleCollisionStop(), MSVehicle::hasArrivedInternal(), MSLCM_SL2015::informLeader(), informLeader(), MSLCM_SL2015::keepLatGap(), MSVehicle::lateralDistanceToLane(), MSVehicle::planMoveInternal(), MSLCM_SL2015::prepareStep(), MSLeaderInfo::removeOpposite(), saveBlockerLength(), MSLCM_SL2015::saveBlockerLength(), MSVehicle::setApproachingForAllLinks(), MSLaneChangerSublane::startChangeSublane(), MSVehicle::updateBestLanes(), and MSLCM_SL2015::updateExpectedSublaneSpeeds().

◆ isStrategicBlocked()

bool MSAbstractLaneChangeModel::isStrategicBlocked ( ) const
inherited
Returns
whether this vehicle is blocked from performing a strategic change

Definition at line 1066 of file MSAbstractLaneChangeModel.cpp.

References LCA_BLOCKED, LCA_LEFT, LCA_RIGHT, LCA_STRATEGIC, MSAbstractLaneChangeModel::mySavedStateLeft, and MSAbstractLaneChangeModel::mySavedStateRight.

Referenced by MSLink::getLeaderInfo().

Here is the caller graph for this function:

◆ laneChangeOutput()

void MSAbstractLaneChangeModel::laneChangeOutput ( const std::string &  tag,
MSLane source,
MSLane target,
int  direction,
double  maneuverDist = 0 
)
inherited

called once the vehicle ends a lane change manoeuvre (non-instant)

Definition at line 370 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::clearGapsAtLCInit(), OutputDevice::closeTag(), DELTA_T, OutputDevice::getDeviceByOption(), MSVehicleType::getID(), Named::getID(), MSNet::getInstance(), MSBaseVehicle::getParameter(), Parameterised::getParameter(), MSVehicle::getPosition(), MSVehicle::getPositionOnLane(), MSVehicle::getSpeed(), MSBaseVehicle::getVehicleType(), MSGlobals::gLaneChangeDuration, MSGlobals::gLateralResolution, LCA_AMBACKBLOCKER, LCA_AMBACKBLOCKER_STANDING, LCA_AMBLOCKINGFOLLOWER, LCA_AMBLOCKINGLEADER, LCA_LEFT, LCA_MLEFT, LCA_MRIGHT, LCA_RIGHT, MSAbstractLaneChangeModel::myLastFollowerGap, MSAbstractLaneChangeModel::myLastFollowerSecureGap, MSAbstractLaneChangeModel::myLastFollowerSpeed, MSAbstractLaneChangeModel::myLastLateralGapLeft, MSAbstractLaneChangeModel::myLastLateralGapRight, MSAbstractLaneChangeModel::myLastLeaderGap, MSAbstractLaneChangeModel::myLastLeaderSecureGap, MSAbstractLaneChangeModel::myLastLeaderSpeed, MSAbstractLaneChangeModel::myLastOrigLeaderGap, MSAbstractLaneChangeModel::myLastOrigLeaderSecureGap, MSAbstractLaneChangeModel::myLastOrigLeaderSpeed, MSAbstractLaneChangeModel::myLCOutput, MSAbstractLaneChangeModel::myLCXYOutput, MSAbstractLaneChangeModel::myOwnState, MSAbstractLaneChangeModel::myVehicle, MSAbstractLaneChangeModel::NO_NEIGHBOR, OutputDevice::openTag(), SUMO_ATTR_DIR, SUMO_ATTR_FROM, SUMO_ATTR_ID, SUMO_ATTR_POSITION, SUMO_ATTR_SPEED, SUMO_ATTR_TIME, SUMO_ATTR_TO, SUMO_ATTR_TYPE, SUMO_ATTR_X, SUMO_ATTR_Y, time2string(), toString(), OutputDevice::writeAttr(), Position::x(), and Position::y().

Referenced by MSLaneChangerSublane::outputLCEnded(), MSLaneChangerSublane::outputLCStarted(), and MSAbstractLaneChangeModel::primaryLaneChanged().

Here is the caller graph for this function:

◆ loadState()

void MSAbstractLaneChangeModel::loadState ( const SUMOSAXAttributes attrs)
virtualinherited

Loads the state of the laneChangeModel from the given attributes.

Parameters
[in]attrsXML attributes describing the current state

Definition at line 1121 of file MSAbstractLaneChangeModel.cpp.

References SUMOSAXAttributes::getString(), SUMOSAXAttributes::hasAttribute(), MSAbstractLaneChangeModel::myLaneChangeCompletion, MSAbstractLaneChangeModel::myLaneChangeDirection, MSAbstractLaneChangeModel::mySpeedLat, and SUMO_ATTR_LCSTATE.

Referenced by MSVehicle::loadState().

Here is the caller graph for this function:

◆ memorizeGapsAtLCInit()

void MSAbstractLaneChangeModel::memorizeGapsAtLCInit ( )
inherited

Control for resetting the memorized values for LC relevant gaps until the LC output is triggered in the case of continuous LC.

Definition at line 322 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myDontResetLCGaps.

Referenced by MSAbstractLaneChangeModel::startLaneChangeManeuver().

Here is the caller graph for this function:

◆ outputLCEnded()

static bool MSAbstractLaneChangeModel::outputLCEnded ( )
inlinestaticinherited

whether start of maneuvers shall be recorede

Definition at line 182 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLCEndedOutput.

Referenced by MSLaneChangerSublane::outputLCEnded().

Here is the caller graph for this function:

◆ outputLCStarted()

static bool MSAbstractLaneChangeModel::outputLCStarted ( )
inlinestaticinherited

whether start of maneuvers shall be recorede

Definition at line 177 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLCStartedOutput.

Referenced by MSLaneChangerSublane::outputLCStarted().

Here is the caller graph for this function:

◆ overtakeDistance()

double MSLCM_LC2013::overtakeDistance ( const MSVehicle follower,
const MSVehicle leader,
const double  gap,
double  followerSpeed = INVALID_SPEED,
double  leaderSpeed = INVALID_SPEED 
)
staticprotected

Definition at line 452 of file MSLCM_LC2013.cpp.

References MSVehicle::getCarFollowModel(), MSVehicleType::getLength(), MSVehicleType::getLengthWithGap(), MSCFModel::getMaxDecel(), MSCFModel::getSecureGap(), MSVehicle::getSpeed(), MSBaseVehicle::getVehicleType(), INVALID_SPEED, and MAX2().

Referenced by informFollower(), and informLeader().

Here is the caller graph for this function:

◆ pastMidpoint()

bool MSAbstractLaneChangeModel::pastMidpoint ( ) const
inlineinherited

return whether the vehicle passed the midpoint of a continuous lane change maneuver

Definition at line 446 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myLaneChangeCompletion.

Referenced by MSAbstractLaneChangeModel::getShadowDirection(), and MSAbstractLaneChangeModel::updateCompletion().

Here is the caller graph for this function:

◆ patchSpeed()

double MSLCM_LC2013::patchSpeed ( const double  min,
const double  wanted,
const double  max,
const MSCFModel cfModel 
)
overridevirtual

Called to adapt the speed in order to allow a lane change. It uses information on LC-related desired speed-changes from the call to wantsChange() at the end of the previous simulation step.

Parameters
minThe minimum resulting speed
wantedThe aspired speed of the car following model
maxThe maximum resulting speed
cfModelThe model used
Returns
the new speed of the vehicle as proposed by the lane changer

Implements MSAbstractLaneChangeModel.

Definition at line 196 of file MSLCM_LC2013.cpp.

References _patchSpeed(), DEBUG_COND, Named::getID(), MSVehicle::getLane(), MSVehicle::getPositionOnLane(), MSVehicle::getSpeed(), MAX2(), MSAbstractLaneChangeModel::myVehicle, SIMTIME, and toString().

◆ predInteraction()

bool MSAbstractLaneChangeModel::predInteraction ( const std::pair< MSVehicle *, double > &  leader)
protectedvirtualinherited

Definition at line 291 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::getCarFollowModel(), MSVehicle::getSpeed(), MSCFModel::interactionGap(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSLCM_DK2008::wantsChangeToLeft(), and MSLCM_DK2008::wantsChangeToRight().

Here is the caller graph for this function:

◆ prepareStep()

◆ primaryLaneChanged()

◆ remainingTime()

◆ removeShadowApproachingInformation()

void MSAbstractLaneChangeModel::removeShadowApproachingInformation ( ) const
inherited

Definition at line 891 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myApproachedByShadow, and MSAbstractLaneChangeModel::myVehicle.

Referenced by MSVehicle::removeApproachingInformation().

Here is the caller graph for this function:

◆ resetChanged()

void MSAbstractLaneChangeModel::resetChanged ( )
inlineinherited

reset the flag whether a vehicle already moved to false

Definition at line 508 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAlreadyChanged.

Referenced by MSVehicle::planMove().

Here is the caller graph for this function:

◆ resetSpeedLat()

void MSAbstractLaneChangeModel::resetSpeedLat ( )
virtualinherited

Definition at line 439 of file MSAbstractLaneChangeModel.cpp.

References MSGlobals::gLaneChangeDuration, MSAbstractLaneChangeModel::isChangingLanes(), and MSAbstractLaneChangeModel::setSpeedLat().

Referenced by MSVehicle::executeMove(), MSLCM_DK2008::prepareStep(), and prepareStep().

Here is the caller graph for this function:

◆ resetState()

◆ saveBlockerLength()

bool MSLCM_LC2013::saveBlockerLength ( double  length,
double  foeLeftSpace 
)
overrideprotectedvirtual

◆ saveLCState()

void MSAbstractLaneChangeModel::saveLCState ( const int  dir,
int  stateWithoutTraCI,
const int  state 
)
inlineinherited

◆ saveNeighbors() [1/2]

void MSAbstractLaneChangeModel::saveNeighbors ( const int  dir,
const MSLeaderDistanceInfo followers,
const MSLeaderDistanceInfo leaders 
)
inherited

Saves the lane change relevant vehicles, which are currently on neighboring lanes in the given direction (as detected in wantsChangeSublane()). -> SL2015 case.

Definition at line 198 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLeftFollowers, MSAbstractLaneChangeModel::myLeftLeaders, MSAbstractLaneChangeModel::myRightFollowers, and MSAbstractLaneChangeModel::myRightLeaders.

Referenced by MSLaneChanger::checkChange(), MSLaneChangerSublane::checkChangeOpposite(), and MSLaneChangerSublane::checkChangeSublane().

Here is the caller graph for this function:

◆ saveNeighbors() [2/2]

void MSAbstractLaneChangeModel::saveNeighbors ( const int  dir,
const std::pair< MSVehicle *const, double > &  follower,
const std::pair< MSVehicle *const, double > &  leader 
)
inherited

Saves the lane change relevant vehicles, which are currently on neighboring lanes in the given direction (as detected in wantsChange()). -> LC2013 case.

Definition at line 213 of file MSAbstractLaneChangeModel.cpp.

References MSVehicle::getLane(), MSLane::getWidth(), MSAbstractLaneChangeModel::myLeftFollowers, MSAbstractLaneChangeModel::myLeftLeaders, MSAbstractLaneChangeModel::myRightFollowers, MSAbstractLaneChangeModel::myRightLeaders, and MSAbstractLaneChangeModel::myVehicle.

◆ saveState()

void MSAbstractLaneChangeModel::saveState ( OutputDevice out) const
virtualinherited

Save the state of the laneChangeModel.

Parameters
[in]outThe OutputDevice to write the information into

Definition at line 1108 of file MSAbstractLaneChangeModel.cpp.

References MSGlobals::gLaneChangeDuration, MSAbstractLaneChangeModel::myLaneChangeCompletion, MSAbstractLaneChangeModel::myLaneChangeDirection, MSAbstractLaneChangeModel::mySpeedLat, SUMO_ATTR_LCSTATE, toString(), and OutputDevice::writeAttr().

Referenced by MSVehicle::saveState().

Here is the caller graph for this function:

◆ setAngleOffset()

void MSAbstractLaneChangeModel::setAngleOffset ( const double  angleOffset)
inlineinherited

set the angle offset resulting from lane change and sigma

Definition at line 493 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myAngleOffset.

◆ setFollowerGaps() [1/2]

void MSAbstractLaneChangeModel::setFollowerGaps ( CLeaderDist  follower,
double  secGap 
)
inherited

Definition at line 954 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myLastFollowerGap, MSAbstractLaneChangeModel::myLastFollowerSecureGap, and MSAbstractLaneChangeModel::myLastFollowerSpeed.

Referenced by MSLaneChanger::checkChange(), MSLaneChangerSublane::checkChangeToNewLane(), MSLaneChangerSublane::outputLCEnded(), and MSLaneChangerSublane::outputLCStarted().

Here is the caller graph for this function:

◆ setFollowerGaps() [2/2]

◆ setLeaderGaps() [1/2]

void MSAbstractLaneChangeModel::setLeaderGaps ( CLeaderDist  leader,
double  secGap 
)
inherited

◆ setLeaderGaps() [2/2]

◆ setManeuverDist()

void MSAbstractLaneChangeModel::setManeuverDist ( const double  dist)
inherited

Updates the remaining distance for the current maneuver while it is continued within non-action steps (only used by sublane model)

Definition at line 172 of file MSAbstractLaneChangeModel.cpp.

References DEBUG_COND, Named::getID(), MSAbstractLaneChangeModel::myManeuverDist, MSAbstractLaneChangeModel::myPreviousManeuverDist, MSAbstractLaneChangeModel::myVehicle, and SIMTIME.

Referenced by MSLaneChangerSublane::abortLCManeuver(), MSAbstractLaneChangeModel::checkTraCICommands(), MSLaneChangerSublane::startChangeSublane(), and MSAbstractLaneChangeModel::startLaneChangeManeuver().

Here is the caller graph for this function:

◆ setNoShadowPartialOccupator()

void MSAbstractLaneChangeModel::setNoShadowPartialOccupator ( MSLane lane)
inlineinherited

Definition at line 556 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myNoPartiallyOccupatedByShadow.

Referenced by MSVehicle::enterLaneAtLaneChange().

Here is the caller graph for this function:

◆ setOrigLeaderGaps() [1/2]

void MSAbstractLaneChangeModel::setOrigLeaderGaps ( CLeaderDist  leader,
double  secGap 
)
inherited

◆ setOrigLeaderGaps() [2/2]

◆ setOwnState()

void MSAbstractLaneChangeModel::setOwnState ( const int  state)
virtualinherited

◆ setParameter()

void MSLCM_LC2013::setParameter ( const std::string &  key,
const std::string &  value 
)
overridevirtual

◆ setPreviousAngleOffset()

void MSAbstractLaneChangeModel::setPreviousAngleOffset ( const double  angleOffset)
inlineinherited

set the angle offset of the previous time step

Definition at line 498 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myPreviousAngleOffset.

Referenced by MSVehicle::executeMove().

Here is the caller graph for this function:

◆ setShadowApproachingInformation()

void MSAbstractLaneChangeModel::setShadowApproachingInformation ( MSLink link) const
inherited

set approach information for the shadow vehicle

Definition at line 885 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myApproachedByShadow.

Referenced by MSVehicle::setApproachingForAllLinks().

Here is the caller graph for this function:

◆ setShadowPartialOccupator()

void MSAbstractLaneChangeModel::setShadowPartialOccupator ( MSLane lane)
inlineinherited

◆ setSpeedLat()

void MSAbstractLaneChangeModel::setSpeedLat ( double  speedLat)
inherited

set the lateral speed and update lateral acceleraton

Definition at line 432 of file MSAbstractLaneChangeModel.cpp.

References MSAbstractLaneChangeModel::myAccelerationLat, MSAbstractLaneChangeModel::mySpeedLat, and SPEED2ACCEL.

Referenced by MSLaneChangerSublane::abortLCManeuver(), MSLaneChangerSublane::checkChangeOpposite(), prepareStep(), MSAbstractLaneChangeModel::resetSpeedLat(), MSLaneChangerSublane::startChangeSublane(), and MSAbstractLaneChangeModel::updateCompletion().

Here is the caller graph for this function:

◆ slowDownForBlocked()

int MSLCM_LC2013::slowDownForBlocked ( MSVehicle **  blocked,
int  state 
)
protected

◆ startLaneChangeManeuver()

◆ sublaneChangeCompleted()

virtual bool MSAbstractLaneChangeModel::sublaneChangeCompleted ( const double  latDist) const
inlinevirtualinherited

whether the current change completes the manoeuvre

Definition at line 567 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myModel, toString(), and UNUSED_PARAMETER.

◆ unchanged()

void MSAbstractLaneChangeModel::unchanged ( )
inlineinherited

Definition at line 400 of file MSAbstractLaneChangeModel.h.

References DELTA_T, and MSAbstractLaneChangeModel::myLastLaneChangeOffset.

Referenced by MSLaneChanger::registerUnchanged().

Here is the caller graph for this function:

◆ updateCompletion()

bool MSAbstractLaneChangeModel::updateCompletion ( )
inherited

◆ updateExpectedSublaneSpeeds()

virtual void MSAbstractLaneChangeModel::updateExpectedSublaneSpeeds ( const MSLeaderDistanceInfo ahead,
int  sublaneOffset,
int  laneIndex 
)
inlinevirtualinherited

update expected speeds for each sublane of the current edge

Reimplemented in MSLCM_SL2015.

Definition at line 342 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myModel, toString(), and UNUSED_PARAMETER.

Referenced by MSLaneChangerSublane::change(), and MSLaneChangerSublane::checkChangeOpposite().

Here is the caller graph for this function:

◆ updateSafeLatDist()

void MSAbstractLaneChangeModel::updateSafeLatDist ( const double  travelledLatDist)
virtualinherited

Updates the value of safe lateral distances (in SL2015) during maneuver continuation in non-action steps.

Reimplemented in MSLCM_SL2015.

Definition at line 166 of file MSAbstractLaneChangeModel.cpp.

References UNUSED_PARAMETER.

Referenced by MSLaneChangerSublane::startChangeSublane().

Here is the caller graph for this function:

◆ updateShadowLane()

◆ updateTargetLane()

◆ wantsChange()

int MSLCM_LC2013::wantsChange ( int  laneOffset,
MSAbstractLaneChangeModel::MSLCMessager msgPass,
int  blocked,
const std::pair< MSVehicle *, double > &  leader,
const std::pair< MSVehicle *, double > &  follower,
const std::pair< MSVehicle *, double > &  neighLead,
const std::pair< MSVehicle *, double > &  neighFollow,
const MSLane neighLane,
const std::vector< MSVehicle::LaneQ > &  preb,
MSVehicle **  lastBlocked,
MSVehicle **  firstBlocked 
)
overridevirtual

Called to examine whether the vehicle wants to change using the given laneOffset. This method gets the information about the surrounding vehicles and whether another lane may be more preferable.

TODO: better documentation, refs #2

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 156 of file MSLCM_LC2013.cpp.

References _wantsChange(), DEBUG_COND, Named::getID(), MSVehicle::getLane(), MSVehicle::getLateralPositionOnLane(), MSVehicle::getPositionOnLane(), MSVehicle::getSpeed(), gPrecision, MSAbstractLaneChangeModel::myVehicle, SIMTIME, and toString().

◆ wantsChangeSublane()

virtual int MSAbstractLaneChangeModel::wantsChangeSublane ( int  laneOffset,
LaneChangeAction  alternatives,
const MSLeaderDistanceInfo leaders,
const MSLeaderDistanceInfo followers,
const MSLeaderDistanceInfo blockers,
const MSLeaderDistanceInfo neighLeaders,
const MSLeaderDistanceInfo neighFollowers,
const MSLeaderDistanceInfo neighBlockers,
const MSLane neighLane,
const std::vector< MSVehicle::LaneQ > &  preb,
MSVehicle **  lastBlocked,
MSVehicle **  firstBlocked,
double &  latDist,
double &  targetDistLat,
int &  blocked 
)
inlinevirtualinherited

Reimplemented in MSLCM_SL2015.

Definition at line 309 of file MSAbstractLaneChangeModel.h.

References MSAbstractLaneChangeModel::myModel, toString(), and UNUSED_PARAMETER.

Referenced by MSLaneChangerSublane::checkChangeOpposite(), and MSLaneChangerSublane::checkChangeSublane().

Here is the caller graph for this function:

Field Documentation

◆ myAccelerationLat

double MSAbstractLaneChangeModel::myAccelerationLat
protectedinherited

the current lateral acceleration

Definition at line 697 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::getAccelerationLat(), and MSAbstractLaneChangeModel::setSpeedLat().

◆ myAllowOvertakingRight

bool MSAbstractLaneChangeModel::myAllowOvertakingRight
staticprotectedinherited

◆ myAlreadyChanged

bool MSAbstractLaneChangeModel::myAlreadyChanged
protectedinherited

◆ myAmOpposite

◆ myAngleOffset

double MSAbstractLaneChangeModel::myAngleOffset
protectedinherited

the current angle offset resulting from lane change and sigma

Definition at line 700 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::calcAngleOffset(), MSAbstractLaneChangeModel::getAngleOffset(), and MSAbstractLaneChangeModel::setAngleOffset().

◆ myApproachedByShadow

std::vector<MSLink*> MSAbstractLaneChangeModel::myApproachedByShadow
mutableprivateinherited

links which are approached by the shadow vehicle

Definition at line 819 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::removeShadowApproachingInformation(), and MSAbstractLaneChangeModel::setShadowApproachingInformation().

◆ myAssertive

double MSLCM_LC2013::myAssertive
protected

Definition at line 231 of file MSLCM_LC2013.h.

Referenced by getParameter(), getSafetyFactor(), and setParameter().

◆ myCanceledStateCenter

int MSAbstractLaneChangeModel::myCanceledStateCenter
protectedinherited

◆ myCanceledStateLeft

int MSAbstractLaneChangeModel::myCanceledStateLeft
protectedinherited

◆ myCanceledStateRight

int MSAbstractLaneChangeModel::myCanceledStateRight
protectedinherited

◆ myChangeProbThresholdLeft

double MSLCM_LC2013::myChangeProbThresholdLeft
protected

Definition at line 254 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), and initDerivedParameters().

◆ myChangeProbThresholdRight

double MSLCM_LC2013::myChangeProbThresholdRight
protected

Definition at line 253 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), and initDerivedParameters().

◆ myCommittedSpeed

double MSAbstractLaneChangeModel::myCommittedSpeed
protectedinherited

the speed when committing to a change maneuver

Definition at line 706 of file MSAbstractLaneChangeModel.h.

Referenced by MSLCM_SL2015::commitManoeuvre(), MSAbstractLaneChangeModel::getCommittedSpeed(), and MSAbstractLaneChangeModel::prepareStep().

◆ myCooperativeParam

double MSLCM_LC2013::myCooperativeParam
protected

Definition at line 220 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), MSLCM_LC2013(), and setParameter().

◆ myCooperativeSpeed

double MSLCM_LC2013::myCooperativeSpeed
protected

Definition at line 237 of file MSLCM_LC2013.h.

Referenced by _patchSpeed(), getParameter(), and setParameter().

◆ myDontBrake

bool MSLCM_LC2013::myDontBrake
protected

Definition at line 215 of file MSLCM_LC2013.h.

Referenced by _patchSpeed(), _wantsChange(), changed(), prepareStep(), and resetState().

◆ myDontResetLCGaps

bool MSAbstractLaneChangeModel::myDontResetLCGaps
protectedinherited

Flag to prevent resetting the memorized values for LC relevant gaps until the LC output is triggered in the case of continuous LC.

Definition at line 777 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::clearGapsAtLCInit(), MSAbstractLaneChangeModel::memorizeGapsAtLCInit(), and MSAbstractLaneChangeModel::prepareStep().

◆ myExperimentalParam1

const double MSLCM_LC2013::myExperimentalParam1
protected

Definition at line 246 of file MSLCM_LC2013.h.

Referenced by informFollower().

◆ myFurtherTargetLanes

std::vector<MSLane*> MSAbstractLaneChangeModel::myFurtherTargetLanes
protectedinherited

◆ myHaveBlueLight

bool MSAbstractLaneChangeModel::myHaveBlueLight
protectedinherited

whether this vehicle is driving with special permissions and behavior

Definition at line 791 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::hasBlueLight().

◆ myKeepRightAcceptanceTime

double MSLCM_LC2013::myKeepRightAcceptanceTime
protected

Definition at line 240 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), and setParameter().

◆ myKeepRightParam

double MSLCM_LC2013::myKeepRightParam
protected

Definition at line 222 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), MSLCM_LC2013(), and setParameter().

◆ myKeepRightProbability

double MSLCM_LC2013::myKeepRightProbability
protected

◆ myLaneChangeCompletion

◆ myLaneChangeDirection

int MSAbstractLaneChangeModel::myLaneChangeDirection
protectedinherited

◆ myLastFollowerGap

◆ myLastFollowerSecureGap

◆ myLastFollowerSpeed

◆ myLastLaneChangeOffset

SUMOTime MSAbstractLaneChangeModel::myLastLaneChangeOffset
privateinherited

◆ myLastLateralGapLeft

double MSAbstractLaneChangeModel::myLastLateralGapLeft
protectedinherited

the minimum lateral gaps to other vehicles that were found when last changing to the left and right

Definition at line 758 of file MSAbstractLaneChangeModel.h.

Referenced by MSLCM_SL2015::keepLatGap(), MSAbstractLaneChangeModel::laneChangeOutput(), MSAbstractLaneChangeModel::prepareStep(), and MSLCM_SL2015::updateGaps().

◆ myLastLateralGapRight

double MSAbstractLaneChangeModel::myLastLateralGapRight
protectedinherited

◆ myLastLeaderGap

double MSAbstractLaneChangeModel::myLastLeaderGap
protectedinherited

◆ myLastLeaderSecureGap

double MSAbstractLaneChangeModel::myLastLeaderSecureGap
protectedinherited

the minimum longitudinal distances to vehicles on the target lane that would be necessary for stringent security

Definition at line 765 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::laneChangeOutput(), MSAbstractLaneChangeModel::prepareStep(), MSAbstractLaneChangeModel::setLeaderGaps(), and MSAbstractLaneChangeModel::setLeaderGaps().

◆ myLastLeaderSpeed

double MSAbstractLaneChangeModel::myLastLeaderSpeed
protectedinherited

◆ myLastOrigLeaderGap

double MSAbstractLaneChangeModel::myLastOrigLeaderGap
protectedinherited

acutal and secure distance to closest leader vehicle on the original when performing lane change

Definition at line 768 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::laneChangeOutput(), MSAbstractLaneChangeModel::prepareStep(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), and MSAbstractLaneChangeModel::setOrigLeaderGaps().

◆ myLastOrigLeaderSecureGap

◆ myLastOrigLeaderSpeed

◆ myLCAccelerationAdvices

◆ myLCEndedOutput

bool MSAbstractLaneChangeModel::myLCEndedOutput
staticprotectedinherited

◆ myLCOutput

bool MSAbstractLaneChangeModel::myLCOutput
staticprotectedinherited

◆ myLCStartedOutput

bool MSAbstractLaneChangeModel::myLCStartedOutput
staticprotectedinherited

◆ myLCXYOutput

bool MSAbstractLaneChangeModel::myLCXYOutput
staticprotectedinherited

◆ myLeadingBlockerLength

double MSLCM_LC2013::myLeadingBlockerLength
protected

◆ myLeftFollowers

std::shared_ptr<MSLeaderDistanceInfo> MSAbstractLaneChangeModel::myLeftFollowers
protectedinherited

◆ myLeftLeaders

◆ myLeftSpace

double MSLCM_LC2013::myLeftSpace
protected

◆ myLookaheadLeft

double MSLCM_LC2013::myLookaheadLeft
protected

Definition at line 226 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), and setParameter().

◆ myLookAheadSpeed

double MSLCM_LC2013::myLookAheadSpeed
protected

◆ myManeuverDist

double MSAbstractLaneChangeModel::myManeuverDist
privateinherited

◆ myMaxDistLatStanding

double MSAbstractLaneChangeModel::myMaxDistLatStanding
protectedinherited

◆ myMaxSpeedLatFactor

◆ myMaxSpeedLatStanding

◆ myModel

◆ myNoPartiallyOccupatedByShadow

◆ myOppositeParam

double MSLCM_LC2013::myOppositeParam
protected

Definition at line 223 of file MSLCM_LC2013.h.

Referenced by getOppositeSafetyFactor(), getParameter(), and setParameter().

◆ myOvertakeDeltaSpeedFactor

double MSLCM_LC2013::myOvertakeDeltaSpeedFactor
protected

Definition at line 243 of file MSLCM_LC2013.h.

Referenced by getParameter(), informLeader(), and setParameter().

◆ myOvertakeRightParam

double MSAbstractLaneChangeModel::myOvertakeRightParam
protectedinherited

◆ myOwnState

◆ myPartiallyOccupatedByShadow

std::vector<MSLane*> MSAbstractLaneChangeModel::myPartiallyOccupatedByShadow
protectedinherited

list of lanes where the shadow vehicle is partial occupator

Definition at line 751 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::setShadowPartialOccupator().

◆ myPreviousAngleOffset

double MSAbstractLaneChangeModel::myPreviousAngleOffset
protectedinherited

the angle offset of the previous time step resulting from lane change and sigma

Definition at line 703 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::calcAngleOffset(), and MSAbstractLaneChangeModel::setPreviousAngleOffset().

◆ myPreviousManeuverDist

double MSAbstractLaneChangeModel::myPreviousManeuverDist
privateinherited

Maneuver distance from the previous simulation step.

Definition at line 829 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::getPreviousManeuverDist(), and MSAbstractLaneChangeModel::setManeuverDist().

◆ myPreviousState

int MSAbstractLaneChangeModel::myPreviousState
protectedinherited

lane changing state from the previous simulation step

Definition at line 674 of file MSAbstractLaneChangeModel.h.

Referenced by MSLCM_SL2015::_wantsChangeSublane(), and MSAbstractLaneChangeModel::setOwnState().

◆ myPreviousState2

int MSAbstractLaneChangeModel::myPreviousState2
protectedinherited

lane changing state from step before the previous simulation step

Definition at line 676 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::getPrevState(), and MSAbstractLaneChangeModel::setOwnState().

◆ myRightFollowers

◆ myRightLeaders

◆ myRoundaboutBonus

double MSLCM_LC2013::myRoundaboutBonus
protected

Definition at line 235 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), and setParameter().

◆ mySavedStateCenter

std::pair<int, int> MSAbstractLaneChangeModel::mySavedStateCenter
protectedinherited

◆ mySavedStateLeft

std::pair<int, int> MSAbstractLaneChangeModel::mySavedStateLeft
protectedinherited

◆ mySavedStateRight

std::pair<int, int> MSAbstractLaneChangeModel::mySavedStateRight
protectedinherited

◆ myShadowFurtherLanes

std::vector<MSLane*> MSAbstractLaneChangeModel::myShadowFurtherLanes
protectedinherited

◆ myShadowFurtherLanesPosLat

std::vector<double> MSAbstractLaneChangeModel::myShadowFurtherLanesPosLat
protectedinherited

◆ myShadowLane

MSLane* MSAbstractLaneChangeModel::myShadowLane
protectedinherited

◆ mySigma

double MSAbstractLaneChangeModel::mySigma
protectedinherited

◆ mySpeedGainLookahead

double MSLCM_LC2013::mySpeedGainLookahead
protected

Definition at line 233 of file MSLCM_LC2013.h.

Referenced by anticipateFollowSpeed(), getParameter(), and setParameter().

◆ mySpeedGainParam

double MSLCM_LC2013::mySpeedGainParam
protected

Definition at line 221 of file MSLCM_LC2013.h.

Referenced by getParameter(), initDerivedParameters(), MSLCM_LC2013(), and setParameter().

◆ mySpeedGainProbability

double MSLCM_LC2013::mySpeedGainProbability
protected

a value for tracking the probability that a change to the offset with the same sign is beneficial

Definition at line 202 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), changed(), getParameter(), prepareStep(), resetState(), and setParameter().

◆ mySpeedGainRight

double MSLCM_LC2013::mySpeedGainRight
protected

Definition at line 228 of file MSLCM_LC2013.h.

Referenced by getParameter(), initDerivedParameters(), and setParameter().

◆ mySpeedLat

◆ myStrategicParam

double MSLCM_LC2013::myStrategicParam
protected

Definition at line 219 of file MSLCM_LC2013.h.

Referenced by _wantsChange(), getParameter(), MSLCM_LC2013(), and setParameter().

◆ myTargetLane

MSLane* MSAbstractLaneChangeModel::myTargetLane
protectedinherited

The target lane for the vehicle's current maneuver.

Note
This is used by the sublane model to register the vehicle at lanes, it will reach within the current action step, so vehicles on that lane may react to the started lc-maneuver during the car-following process. If the shadow lane is the same as the lc maneuver target, myTargetLane is set to nullptr. The current shadow lanes and further lanes should always be updated before updating the target lane.

Definition at line 732 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel::cleanupTargetLane(), MSAbstractLaneChangeModel::getTargetLane(), and MSAbstractLaneChangeModel::updateTargetLane().

◆ myVehicle

MSVehicle& MSAbstractLaneChangeModel::myVehicle
protectedinherited

The vehicle this lane-changer belongs to.

Definition at line 669 of file MSAbstractLaneChangeModel.h.

Referenced by _patchSpeed(), MSLCM_SL2015::_patchSpeed(), _wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), adaptSpeedToPedestrians(), MSAbstractLaneChangeModel::addLCSpeedAdvice(), anticipateFollowSpeed(), MSAbstractLaneChangeModel::avoidOvertakeRight(), MSAbstractLaneChangeModel::calcAngleOffset(), MSAbstractLaneChangeModel::cancelRequest(), changed(), MSLCM_SL2015::changed(), MSLCM_SL2015::checkBlocking(), MSLCM_SL2015::checkStrategicChange(), MSAbstractLaneChangeModel::checkTraCICommands(), MSAbstractLaneChangeModel::cleanupShadowLane(), MSAbstractLaneChangeModel::cleanupTargetLane(), MSLCM_SL2015::commitFollowSpeed(), MSLCM_SL2015::commitManoeuvre(), MSLCM_SL2015::computeSpeedGain(), MSAbstractLaneChangeModel::computeSpeedLat(), computeSpeedLat(), MSLCM_SL2015::computeSpeedLat(), MSAbstractLaneChangeModel::congested(), MSLCM_SL2015::decideDirection(), MSAbstractLaneChangeModel::determineTargetLane(), MSAbstractLaneChangeModel::endLaneChangeManeuver(), MSAbstractLaneChangeModel::estimateLCDuration(), MSAbstractLaneChangeModel::getAssumedDecelForLaneChangeDuration(), MSAbstractLaneChangeModel::getCarFollowModel(), MSAbstractLaneChangeModel::getDesiredAlignment(), MSLCM_SL2015::getDesiredAlignment(), MSAbstractLaneChangeModel::getForwardPos(), MSLCM_SL2015::getLateralDrift(), MSLCM_SL2015::getLeftBorder(), MSAbstractLaneChangeModel::getMaxSpeedLat2(), MSLCM_SL2015::getNeighRight(), MSAbstractLaneChangeModel::getNormalizedLaneIndex(), MSLCM_SL2015::getPosLat(), MSAbstractLaneChangeModel::getShadowDirection(), MSAbstractLaneChangeModel::getShadowLane(), MSAbstractLaneChangeModel::getShadowLane(), MSLCM_SL2015::getSublaneWidth(), MSLCM_SL2015::getVehicleCenter(), MSLCM_SL2015::getWidth(), inform(), MSLCM_SL2015::inform(), MSLCM_DK2008::informBlocker(), MSLCM_SL2015::informFollower(), informFollower(), MSLCM_SL2015::informLeader(), informLeader(), MSLCM_SL2015::informLeaders(), MSLCM_SL2015::isBidi(), MSLCM_SL2015::keepLatGap(), MSAbstractLaneChangeModel::laneChangeOutput(), MSLCM_SL2015::msg(), MSLCM_LC2013(), MSLCM_SL2015::mustOvertakeStopped(), MSLCM_SL2015::outsideEdge(), MSLCM_DK2008::patchSpeed(), patchSpeed(), MSLCM_SL2015::patchSpeed(), MSAbstractLaneChangeModel::predInteraction(), prepareStep(), MSLCM_SL2015::prepareStep(), MSLCM_SL2015::preventSliding(), MSAbstractLaneChangeModel::primaryLaneChanged(), MSAbstractLaneChangeModel::remainingTime(), MSAbstractLaneChangeModel::removeShadowApproachingInformation(), saveBlockerLength(), MSLCM_SL2015::saveBlockerLength(), MSAbstractLaneChangeModel::saveNeighbors(), MSAbstractLaneChangeModel::setFollowerGaps(), MSAbstractLaneChangeModel::setLeaderGaps(), MSAbstractLaneChangeModel::setLeaderGaps(), MSAbstractLaneChangeModel::setManeuverDist(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), MSLCM_SL2015::setOwnState(), slowDownForBlocked(), MSLCM_SL2015::slowDownForBlocked(), MSAbstractLaneChangeModel::startLaneChangeManeuver(), MSLCM_SL2015::tieBrakeLeader(), MSLCM_SL2015::updateCFRelated(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), MSLCM_SL2015::updateGaps(), MSAbstractLaneChangeModel::updateShadowLane(), MSAbstractLaneChangeModel::updateTargetLane(), wantsChange(), MSLCM_SL2015::wantsChange(), MSLCM_SL2015::wantsChangeSublane(), MSLCM_DK2008::wantsChangeToLeft(), and MSLCM_DK2008::wantsChangeToRight().

◆ NO_NEIGHBOR

const double MSAbstractLaneChangeModel::NO_NEIGHBOR
staticinherited

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