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

A lane change model developed by J. Erdmann. More...

#include <MSLCM_SL2015.h>

Inheritance diagram for MSLCM_SL2015:
[legend]
Collaboration diagram for MSLCM_SL2015:
[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 depending on the remaining lane change distance to be covered and updates maneuverDist according to lateral safety constraints.
bool debugVehicle () const override
 whether the current vehicles shall be debugged
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
double getCooperativeHelpSpeed (const MSLane *lane, double distToLaneEnd) const
 return speed for helping a vehicle that is blocked from changing
LatAlignmentDefinition getDesiredAlignment () const override
virtual double getExtraReservation (int bestLaneOffset, double neighExtraDist=0) const
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
double getStrategicLookahead () const
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_SL2015 (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)
void setOwnState (const int state) override
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 updateSafeLatDist (const double travelledLatDist) override
 Updates the value of safe lateral distances (mySafeLatDistLeft and mySafeLatDistRight) 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 is a wrapper around wantsChangeSublane). XXX: no, it wraps _wantsChangeSublane This method gets the information about the surrounding vehicles and whether another lane may be more preferable.
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 &maneuverDist, int &blocked) override
 Called to examine whether the vehicle wants to change with the given laneOffset (using the sublane model) This method gets the information about the surrounding vehicles and whether another lane may be more preferable.
virtual ~MSLCM_SL2015 ()

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
static const double UNDEFINED_LOOKAHEAD

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 _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 &maneuverDist, int &blocked)
 helper function for doing the actual work
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 ()
virtual bool avoidOvertakeRight () const
bool cancelRequest (int state, int laneOffset)
 whether the influencer cancels the given request
int checkBlocking (const MSLane &neighLane, double &latDist, double maneuverDist, int laneOffset, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &followers, const MSLeaderDistanceInfo &blockers, const MSLeaderDistanceInfo &neighLeaders, const MSLeaderDistanceInfo &neighFollowers, const MSLeaderDistanceInfo &neighBlockers, std::vector< CLeaderDist > *collectLeadBlockers=0, std::vector< CLeaderDist > *collectFollowBlockers=0, bool keepLatGapManeuver=false, double gapFactor=0, int *retBlockedFully=0)
 restrict latDist to permissible speed and determine blocking state depending on that distance
int checkBlockingVehicles (const MSVehicle *ego, const MSLeaderDistanceInfo &vehicles, int laneOffset, double latDist, double foeOffset, bool leaders, double &safeLatGapRight, double &safeLatGapLeft, std::vector< CLeaderDist > *collectBlockers=0) const
 check whether any of the vehicles overlaps with ego
int checkStrategicChange (int ret, const MSLane &neighLane, int laneOffset, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &neighLeaders, const MSVehicle::LaneQ &curr, const MSVehicle::LaneQ &neigh, const MSVehicle::LaneQ &best, int bestLaneOffset, bool changeToBest, double &currentDist, double neighDist, double laDist, double roundaboutBonus, double latLaneDist, bool checkOpposite, double &latDist)
 compute strategic lane change actions TODO: Better documentation, refs #2
double commitFollowSpeed (double speed, double latDist, double secondsToLeaveLane, const MSLeaderDistanceInfo &leaders, double foeOffset) const
 compute speed when committing to an urgent change that is safe in regard to leading vehicles
void commitManoeuvre (int blocked, int blockedFully, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &neighLeaders, const MSLane &neighLane, double maneuverDist)
 commit to lane change maneuver potentially overriding safe speed
double computeGapFactor (int state) const
 compute the gap factor for the given state
double computeSpeedGain (double latDistSublane, double defaultNextSpeed) const
 compute speedGain when moving by the given amount
int computeSublaneShift (const MSEdge *prevEdge, const MSEdge *curEdge)
 compute shift so that prevSublane + shift = newSublane
virtual bool congested (const MSVehicle *const neighLeader)
bool currentDistAllows (double dist, int laneOffset, double lookForwardDist)
bool currentDistDisallows (double dist, int laneOffset, double lookForwardDist)
StateAndDist decideDirection (StateAndDist sd1, StateAndDist sd2) const override
 decide in which direction to move in case both directions are desirable
double emergencySpeedLat (double speedLat) const
 avoid unsafe lateral speed (overruling lcAccelLat)
double forecastAverageSpeed (double vSafe, double vMax, double gap, double vLeader) const
 estimate average speed over mySpeedGainLookahead time
const MSCFModelgetCarFollowModel () const
 The vehicle's car following model.
double getLateralDrift ()
 get lateral drift for the current step
double getLeftBorder (bool checkOpposite=true) const
 return current edge width optionally extended by opposite direction lane width
CLeaderDist getLongest (const MSLeaderDistanceInfo &ldi) const
 get the longest vehicle in the given info
double getMaxSpeedLat2 () const
 return the max of maxSpeedLat and lcMaxSpeedLatStanding
double getNeighRight (const MSLane &neighLane) const
 return the right offset of the neighboring lane relative to the current edge
double getPosLat ()
 get lateral position of this vehicle
double getSublaneWidth ()
 return the current sublane width (and return a sensible value when running without sublanes)
double getVehicleCenter () const
 return vehicle position relative to the current edge (extend by another virtual lane for opposite-direction driving)
double getWidth () const
 return the width of this vehicle (padded for numerical stability)
void informFollower (int blocked, int dir, const CLeaderDist &neighFollow, double remainingSeconds, double plannedSpeed)
 decide whether we will try cut in before the follower or allow to be overtaken
void informFollowers (int blocked, int dir, const std::vector< CLeaderDist > &blockers, double remainingSeconds, double plannedSpeed)
 call informFollower for multiple followers
double informLeader (int blocked, int dir, const CLeaderDist &neighLead, double remainingSeconds)
double informLeaders (int blocked, int dir, const std::vector< CLeaderDist > &blockers, double remainingSeconds)
void initLastLaneChangeOffset (int dir)
bool isBidi (const MSLane *lane) const
 check whether lane is an upcoming bidi lane
int keepLatGap (int state, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &followers, const MSLeaderDistanceInfo &blockers, const MSLeaderDistanceInfo &neighLeaders, const MSLeaderDistanceInfo &neighFollowers, const MSLeaderDistanceInfo &neighBlockers, const MSLane &neighLane, int laneOffset, double &latDist, double &maneuverDist, int &blocked)
 check whether lateral gap requirements are met override the current maneuver if necessary
void msg (const CLeaderDist &cld, double speed, int state)
 send a speed recommendation to the given vehicle
bool mustOvertakeStopped (bool checkCurrent, const MSLane &neighLane, const MSLeaderDistanceInfo &leaders, const MSLeaderDistanceInfo &neighLead, double posOnLane, double neighDist, bool right, double latLaneDist, double &currentDist, double &latDist)
bool outsideEdge () const
 whether the ego vehicle is driving outside edgebounds
virtual bool predInteraction (const std::pair< MSVehicle *, double > &leader)
bool preventSliding (double maneuverDist) const
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
bool tieBrakeLeader (const MSVehicle *veh) const
void updateCFRelated (const MSLeaderDistanceInfo &vehicles, double foeOffset, bool leaders)
 find leaders/followers that are already in a car-following relationship with ego
void updateExpectedSublaneSpeeds (const MSLeaderDistanceInfo &ahead, int sublaneOffset, int laneIndex) override
 update expected speeds for each sublane of the current edge
void updateGaps (const MSLeaderDistanceInfo &others, double foeOffset, double oldCenter, double gapFactor, double &surplusGapRight, double &surplusGapLeft, bool saveMinGap=false, double netOverlap=0, double latDist=0, std::vector< CLeaderDist > *collectBlockers=0)
 check remaining lateral gaps for the given foe vehicles and optionally update minimum lateral gaps
bool wantsKeepRight (double keepRightProb) const
 check against thresholds

Static Protected Member Functions

static LaneChangeAction getLCA (int state, double latDist)
 compute lane change action from desired lateral distance
static CLeaderDist getSlowest (const MSLeaderDistanceInfo &ldi)
 get the slowest vehicle in the given info
static int lowest_bit (int changeReason)
 return the most important change reason
static bool overlap (double right, double left, double right2, double left2)
 return whether the given intervals overlap

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
double myAssertive
int myCanceledStateCenter
int myCanceledStateLeft
int myCanceledStateRight
bool myCanChangeFully
 whether the current lane changing maneuver can be finished in a single step
std::set< const MSVehicle * > myCFRelated
 set of vehicles that are in a car-following relationship with ego (leader of followers)
bool myCFRelatedReady
double myCommittedSpeed
 the speed when committing to a change maneuver
SUMOTime myCooperativeHelpTime
bool myDontBrake
 flag to prevent speed adaptation by slowing down
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< double > myExpectedSublaneSpeeds
 expected travel speeds on all sublanes on the current edge(!)
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
const MSEdgemyLastEdge
 expected travel speeds on all sublanes on the current edge(!)
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
double mySafeLatDistLeft
double mySafeLatDistRight
 the lateral distance the vehicle can safely move in the currently considered direction
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 mySpeedGainProbabilityLeft
 a value for tracking the probability that a change to the left is beneficial
double mySpeedGainProbabilityRight
 a value for tracking the probability that a change to the right is beneficial
double mySpeedLat
 the current lateral speed
double myStrategicLookahead
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 mySublaneParam
double myMinGapLat
double myPushy
double myImpatience
double myMinImpatience
double myTimeToImpatience
double myAccelLat
double myTurnAlignmentDist
double myLookaheadLeft
double mySpeedGainRight
double myLaneDiscipline
double mySpeedGainLookahead
double mySpeedGainRemainTime
double myRoundaboutBonus
double myCooperativeSpeed
double myKeepRightAcceptanceTime
double myOvertakeDeltaSpeedFactor
derived parameters
double myChangeProbThresholdRight
double myChangeProbThresholdLeft
double mySpeedLossProbThreshold
double mySigmaState
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 J. Erdmann.

Definition at line 35 of file MSLCM_SL2015.h.

Member Typedef Documentation

◆ Info

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

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

Definition at line 218 of file MSLCM_SL2015.h.

Constructor & Destructor Documentation

◆ MSLCM_SL2015()

MSLCM_SL2015::MSLCM_SL2015 ( MSVehicle & v)

◆ ~MSLCM_SL2015()

MSLCM_SL2015::~MSLCM_SL2015 ( )
virtual

Definition at line 157 of file MSLCM_SL2015.cpp.

References changed().

Member Function Documentation

◆ _patchSpeed()

double MSLCM_SL2015::_patchSpeed ( double min,
const double wanted,
double max,
const MSCFModel & cfModel )
protected

◆ _wantsChangeSublane()

int MSLCM_SL2015::_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 & maneuverDist,
int & blocked )
protected

helper function for doing the actual work

determine the leftmost and rightmost sublanes currently occupied

Definition at line 1055 of file MSLCM_SL2015.cpp.

References amBlockingFollowerPlusNB(), ARBITRARY, ARRIVALPOS_LAT_THRESHOLD, MSVehicle::LaneQ::bestContinuations, MSVehicle::LaneQ::bestLaneOffset, MSAbstractLaneChangeModel::cancelRequest(), CENTER, checkBlocking(), checkStrategicChange(), commitManoeuvre(), COMPACT, computeGapFactor(), computeSpeedGain(), currentDistAllows(), DEBUG_COND, DEFAULT, GAIN_PERCEPTION_THRESHOLD, gDebugFlag2, MSAbstractLaneChangeModel::getCanceledState(), MSNet::getCurrentTimeStep(), getDesiredAlignment(), MSLane::getEdge(), MSAbstractLaneChangeModel::getExtraReservation(), MSAbstractLaneChangeModel::getForwardPos(), Named::getIDSecure(), MSLane::getIndex(), MSNet::getInstance(), getLCA(), getLeftBorder(), MSLane::getLinkCont(), getLongest(), MSAbstractLaneChangeModel::getManeuverDist(), getNeighRight(), MSLane::getNormalPredecessorLane(), getPosLat(), MSAbstractLaneChangeModel::getPreviousManeuverDist(), MSLane::getRightmostSublane(), MSLane::getRightSideOnEdge(), MSLCHelper::getRoundaboutDistBonus(), getSlowest(), MSEdge::getSubLaneSides(), getVehicleCenter(), MSEdge::getWidth(), MSLane::getWidth(), getWidth(), GIVEN, gPrecision, MSLeaderInfo::hasStoppedVehicle(), MSLeaderInfo::hasVehicles(), informFollowers(), informLeaders(), MSEdge::isInternal(), MSAbstractLaneChangeModel::isOpposite(), KEEP_RIGHT_TIME, MSVehicle::LaneQ::lane, LCA_CHANGE_REASONS, LCA_COOPERATIVE, LCA_KEEPRIGHT, LCA_LEFT, LCA_MLEFT, LCA_MRIGHT, LCA_NONE, LCA_RIGHT, LCA_SPEEDGAIN, LCA_STAY, LCA_STRATEGIC, LCA_SUBLANE, LCA_TRACI, LCA_URGENT, LEFT, MSVehicle::LaneQ::length, LOOK_AHEAD_MIN_SPEED, LOOK_AHEAD_SPEED_MEMORY, LOOK_FORWARD, MAGIC_OFFSET, MAX2(), MIN2(), myCanChangeFully, myChangeProbThresholdLeft, myChangeProbThresholdRight, myCooperativeParam, myDontBrake, myExpectedSublaneSpeeds, myKeepRightAcceptanceTime, myKeepRightParam, myKeepRightProbability, myLaneDiscipline, myLeadingBlockerLength, myLeftSpace, myLookaheadLeft, myLookAheadSpeed, MSAbstractLaneChangeModel::myOwnState, MSAbstractLaneChangeModel::myPreviousState, myRoundaboutBonus, mySafeLatDistLeft, mySafeLatDistRight, mySpeedGainProbabilityLeft, mySpeedGainProbabilityRight, mySpeedGainRemainTime, mySpeedLossProbThreshold, myStrategicParam, mySublaneParam, myTurnAlignmentDist, MSAbstractLaneChangeModel::myVehicle, NICE, MSLeaderInfo::numSublanes(), overlap(), preventSliding(), RELGAIN_NORMALIZATION_MIN_SPEED, RIGHT, SIMTIME, slowDownForBlocked(), SPEEDGAIN_DECAY_FACTOR, STEPS2TIME, SUMO_const_laneWidth, tieBrakeLeader(), MSLeaderDistanceInfo::toString(), toString(), TS, UNUSED_PARAMETER, MSLCHelper::updateBlockerLength(), updateGaps(), URGENCY, and wantsKeepRight().

Referenced by wantsChange(), and wantsChangeSublane().

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 1105 of file MSAbstractLaneChangeModel.cpp.

References myLCAccelerationAdvices, myVehicle, and SPEED2ACCEL.

Referenced by MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::checkStrategicChange(), MSLCM_LC2013::inform(), MSLCM_SL2015::inform(), MSLCM_LC2013::informFollower(), MSLCM_SL2015::informFollower(), MSLCM_LC2013::informLeader(), MSLCM_SL2015::informLeader(), MSLCM_LC2013::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 myAlreadyChanged.

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

Here is the caller graph for this function:

◆ amBlockingFollower()

bool MSLCM_SL2015::amBlockingFollower ( )
inlineprotected

◆ amBlockingFollowerNB()

bool MSLCM_SL2015::amBlockingFollowerNB ( )
inlineprotected

◆ amBlockingFollowerPlusNB()

bool MSLCM_SL2015::amBlockingFollowerPlusNB ( )
inlineprotected

Definition at line 206 of file MSLCM_SL2015.h.

References LCA_AMBLOCKINGFOLLOWER, LCA_AMBLOCKINGFOLLOWER_DONTBRAKE, and MSAbstractLaneChangeModel::myOwnState.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ amBlockingLeader()

bool MSLCM_SL2015::amBlockingLeader ( )
inlineprotected

Definition at line 197 of file MSLCM_SL2015.h.

References LCA_AMBLOCKINGLEADER, and MSAbstractLaneChangeModel::myOwnState.

◆ avoidOvertakeRight()

bool MSAbstractLaneChangeModel::avoidOvertakeRight ( ) const
protectedvirtualinherited

Definition at line 287 of file MSAbstractLaneChangeModel.cpp.

References myAllowOvertakingRight, myOvertakeRightParam, myVehicle, RandHelper::rand(), and SVC_EMERGENCY.

Referenced by MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::checkStrategicChange(), and MSLCM_SL2015::mustOvertakeStopped().

Here is the caller graph for this function:

◆ 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 82 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 747 of file MSAbstractLaneChangeModel.cpp.

References M_PI, myAngleOffset, myPreviousAngleOffset, mySpeedLat, myVehicle, and SPEED2DIST.

◆ cancelRequest()

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

whether the influencer cancels the given request

Definition at line 562 of file MSAbstractLaneChangeModel.cpp.

References getCanceledState(), and myVehicle.

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

Here is the caller graph for this function:

◆ changed()

void MSLCM_SL2015::changed ( )
overridevirtual

◆ changedToOpposite()

void MSAbstractLaneChangeModel::changedToOpposite ( )
inherited

called when a vehicle changes between lanes in opposite directions

Definition at line 952 of file MSAbstractLaneChangeModel.cpp.

References myAlreadyChanged, and myAmOpposite.

Referenced by endLaneChangeManeuver(), and primaryLaneChanged().

Here is the caller graph for this function:

◆ checkBlocking()

int MSLCM_SL2015::checkBlocking ( const MSLane & neighLane,
double & latDist,
double maneuverDist,
int laneOffset,
const MSLeaderDistanceInfo & leaders,
const MSLeaderDistanceInfo & followers,
const MSLeaderDistanceInfo & blockers,
const MSLeaderDistanceInfo & neighLeaders,
const MSLeaderDistanceInfo & neighFollowers,
const MSLeaderDistanceInfo & neighBlockers,
std::vector< CLeaderDist > * collectLeadBlockers = 0,
std::vector< CLeaderDist > * collectFollowBlockers = 0,
bool keepLatGapManeuver = false,
double gapFactor = 0,
int * retBlockedFully = 0 )
protected

restrict latDist to permissible speed and determine blocking state depending on that distance

Definition at line 2314 of file MSLCM_SL2015.cpp.

References checkBlockingVehicles(), gDebugFlag2, MSAbstractLaneChangeModel::getMaxSpeedLat2(), getNeighRight(), LCA_BLOCKED_LEFT, LCA_BLOCKED_RIGHT, LCA_OVERLAPPING, MAX2(), MIN2(), myCanChangeFully, myCFRelatedReady, myPushy, mySafeLatDistLeft, mySafeLatDistRight, MSAbstractLaneChangeModel::myVehicle, SPEED2DIST, updateCFRelated(), and updateGaps().

Referenced by _wantsChangeSublane(), and keepLatGap().

Here is the caller graph for this function:

◆ checkBlockingVehicles()

int MSLCM_SL2015::checkBlockingVehicles ( const MSVehicle * ego,
const MSLeaderDistanceInfo & vehicles,
int laneOffset,
double latDist,
double foeOffset,
bool leaders,
double & safeLatGapRight,
double & safeLatGapLeft,
std::vector< CLeaderDist > * collectBlockers = 0 ) const
protected

◆ 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:

◆ checkStrategicChange()

int MSLCM_SL2015::checkStrategicChange ( int ret,
const MSLane & neighLane,
int laneOffset,
const MSLeaderDistanceInfo & leaders,
const MSLeaderDistanceInfo & neighLeaders,
const MSVehicle::LaneQ & curr,
const MSVehicle::LaneQ & neigh,
const MSVehicle::LaneQ & best,
int bestLaneOffset,
bool changeToBest,
double & currentDist,
double neighDist,
double laDist,
double roundaboutBonus,
double latLaneDist,
bool checkOpposite,
double & latDist )
protected

compute strategic lane change actions TODO: Better documentation, refs #2

we urgently need to change lanes to follow our route

Definition at line 2806 of file MSLCM_SL2015.cpp.

References ACCEL2SPEED, MSAbstractLaneChangeModel::addLCSpeedAdvice(), MSAbstractLaneChangeModel::avoidOvertakeRight(), MSVehicle::LaneQ::bestContinuations, MSVehicle::LaneQ::bestLaneOffset, currentDistDisallows(), MSCFModel::followSpeed(), gDebugFlag2, MSAbstractLaneChangeModel::getCanceledState(), MSAbstractLaneChangeModel::getCarFollowModel(), MSVehicle::getCarFollowModel(), MSLane::getEdge(), MSAbstractLaneChangeModel::getForwardPos(), Named::getID(), MSEdge::getInternalFollowingLengthTo(), MSLane::getLength(), MSCFModel::getMaxDecel(), MSAbstractLaneChangeModel::getShadowLane(), getSlowest(), MSVehicle::getSpeed(), MSLeaderInfo::hasStoppedVehicle(), MSLeaderInfo::hasVehicles(), JAM_FACTOR, LCA_LEFT, LCA_RIGHT, LCA_STAY, LCA_STRATEGIC, LCA_TRACI, LCA_URGENT, MSVehicle::LaneQ::length, MAX2(), mustOvertakeStopped(), myChangeProbThresholdLeft, MSAbstractLaneChangeModel::myLCAccelerationAdvices, myLeftSpace, myLookAheadSpeed, mySpeedGainProbabilityRight, myStrategicParam, MSAbstractLaneChangeModel::myVehicle, MSVehicle::LaneQ::occupation, SIMTIME, SUMO_const_haltingSpeed, SUMO_const_laneWidth, toString(), and TURN_LANE_DIST.

Referenced by _wantsChangeSublane().

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 906 of file MSAbstractLaneChangeModel.cpp.

References gDebugFlag2, MSGlobals::gLateralResolution, LCA_LEFT, LCA_RIGHT, LCA_STAY, LCA_TRACI, myOwnState, myVehicle, setManeuverDist(), setOwnState(), SIMTIME, and toString().

Referenced by MSLaneChanger::checkTraCICommands().

Here is the caller graph for this function:

◆ cleanupShadowLane()

void MSAbstractLaneChangeModel::cleanupShadowLane ( )
inherited

Definition at line 521 of file MSAbstractLaneChangeModel.cpp.

References debugVehicle(), myNoPartiallyOccupatedByShadow, myShadowFurtherLanes, myShadowLane, myVehicle, and SIMTIME.

Referenced by endLaneChangeManeuver().

Here is the caller graph for this function:

◆ cleanupTargetLane()

void MSAbstractLaneChangeModel::cleanupTargetLane ( )
inherited

Definition at line 540 of file MSAbstractLaneChangeModel.cpp.

References debugVehicle(), myFurtherTargetLanes, myTargetLane, myVehicle, and SIMTIME.

Referenced by endLaneChangeManeuver().

Here is the caller graph for this function:

◆ clearGapsAtLCInit()

void MSAbstractLaneChangeModel::clearGapsAtLCInit ( )
inherited

Definition at line 331 of file MSAbstractLaneChangeModel.cpp.

References myDontResetLCGaps.

Referenced by 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 232 of file MSAbstractLaneChangeModel.cpp.

References myLeftFollowers, myLeftLeaders, myRightFollowers, and myRightLeaders.

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

Here is the caller graph for this function:

◆ commitFollowSpeed()

double MSLCM_SL2015::commitFollowSpeed ( double speed,
double latDist,
double secondsToLeaveLane,
const MSLeaderDistanceInfo & leaders,
double foeOffset ) const
protected

compute speed when committing to an urgent change that is safe in regard to leading vehicles

Definition at line 3729 of file MSLCM_SL2015.cpp.

References gDebugFlag2, MSVehicle::getCarFollowModel(), MSCFModel::getMaxDecel(), getSafetyFactor(), MSVehicle::getSpeed(), MSLeaderInfo::getSublaneBorders(), getWidth(), MSLeaderInfo::hasVehicles(), MIN2(), MSAbstractLaneChangeModel::myVehicle, MSLeaderInfo::numSublanes(), overlap(), and MSCFModel::setMaxDecel().

Referenced by commitManoeuvre().

Here is the caller graph for this function:

◆ commitManoeuvre()

void MSLCM_SL2015::commitManoeuvre ( int blocked,
int blockedFully,
const MSLeaderDistanceInfo & leaders,
const MSLeaderDistanceInfo & neighLeaders,
const MSLane & neighLane,
double maneuverDist )
protected

commit to lane change maneuver potentially overriding safe speed

Definition at line 3647 of file MSLCM_SL2015.cpp.

References ACCEL2SPEED, MSCFModel::avoidArrivalAccel(), commitFollowSpeed(), debugVehicle(), MSCFModel::estimateArrivalTime(), gDebugFlag2, MSLane::getRightSideOnEdge(), MSGlobals::gSemiImplicitEulerUpdate, MAX2(), MIN3(), myAccelLat, myCanChangeFully, MSAbstractLaneChangeModel::myCommittedSpeed, myLeftSpace, MSAbstractLaneChangeModel::myVehicle, SIMTIME, and TS.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ computeGapFactor()

double MSLCM_SL2015::computeGapFactor ( int state) const
protected

compute the gap factor for the given state

Definition at line 3107 of file MSLCM_SL2015.cpp.

References LCA_STRATEGIC, MAX2(), myImpatience, and myPushy.

Referenced by _wantsChangeSublane(), and keepLatGap().

Here is the caller graph for this function:

◆ computeSpeedGain()

double MSLCM_SL2015::computeSpeedGain ( double latDistSublane,
double defaultNextSpeed ) const
protected

compute speedGain when moving by the given amount

Definition at line 2251 of file MSLCM_SL2015.cpp.

References getWidth(), MAX2(), MIN2(), myExpectedSublaneSpeeds, MSAbstractLaneChangeModel::myVehicle, and overlap().

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ computeSpeedLat()

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

decides the next lateral speed depending on the remaining lane change distance to be covered and updates maneuverDist according to lateral safety constraints.

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 3459 of file MSLCM_SL2015.cpp.

References ACCEL2SPEED, MSCFModel::brakeGapEuler(), debugVehicle(), DIST2SPEED, emergencySpeedLat(), getWidth(), MSAbstractLaneChangeModel::isOpposite(), MAX2(), MIN2(), myAccelLat, myLeftSpace, MSAbstractLaneChangeModel::myMaxSpeedLatFactor, MSAbstractLaneChangeModel::myMaxSpeedLatStanding, mySafeLatDistLeft, mySafeLatDistRight, MSAbstractLaneChangeModel::mySpeedLat, MSAbstractLaneChangeModel::myVehicle, SIMTIME, and SPEED2DIST.

Referenced by wantsChangeSublane().

Here is the caller graph for this function:

◆ computeSublaneShift()

int MSLCM_SL2015::computeSublaneShift ( const MSEdge * prevEdge,
const MSEdge * curEdge )
protected

compute shift so that prevSublane + shift = newSublane

Definition at line 975 of file MSLCM_SL2015.cpp.

References MSEdge::getLanes(), MSLane::getWidth(), and MSLeaderInfo::numSublanes().

Referenced by prepareStep().

Here is the caller graph for this function:

◆ congested()

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

Definition at line 268 of file MSAbstractLaneChangeModel.cpp.

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

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

Here is the caller graph for this function:

◆ currentDistAllows()

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

Definition at line 212 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ currentDistDisallows()

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

Definition at line 209 of file MSLCM_SL2015.h.

Referenced by checkStrategicChange().

Here is the caller graph for this function:

◆ debugVehicle()

bool MSLCM_SL2015::debugVehicle ( ) const
overridevirtual

whether the current vehicles shall be debugged

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 176 of file MSLCM_SL2015.cpp.

References DEBUG_COND.

Referenced by commitManoeuvre(), computeSpeedLat(), emergencySpeedLat(), prepareStep(), and updateGaps().

Here is the caller graph for this function:

◆ decideDirection()

◆ determineTargetLane()

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

Definition at line 715 of file MSAbstractLaneChangeModel.cpp.

References myManeuverDist, myShadowLane, and myVehicle.

Referenced by updateTargetLane().

Here is the caller graph for this function:

◆ emergencySpeedLat()

double MSLCM_SL2015::emergencySpeedLat ( double speedLat) const
protected

avoid unsafe lateral speed (overruling lcAccelLat)

Definition at line 3590 of file MSLCM_SL2015.cpp.

References debugVehicle(), DIST2SPEED, mySafeLatDistLeft, mySafeLatDistRight, and SPEED2DIST.

Referenced by computeSpeedLat().

Here is the caller graph for this function:

◆ endLaneChangeManeuver()

void MSAbstractLaneChangeModel::endLaneChangeManeuver ( const MSMoveReminder::Notification reason = MSMoveReminder::NOTIFICATION_LANE_CHANGE)
inherited

◆ 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 763 of file MSAbstractLaneChangeModel.cpp.

References computeSpeedLat(), MSGlobals::gLaneChangeDuration, myMaxSpeedLatFactor, myMaxSpeedLatStanding, myVehicle, STEPS2TIME, SUMO_ATTR_LCA_MAXSPEEDLATFACTOR, SUMO_ATTR_LCA_MAXSPEEDLATSTANDING, SUMO_const_haltingSpeed, and VTYPEPARS_MAXSPEED_LAT_SET.

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

Here is the caller graph for this function:

◆ forecastAverageSpeed()

double MSLCM_SL2015::forecastAverageSpeed ( double vSafe,
double vMax,
double gap,
double vLeader ) const
protected

estimate average speed over mySpeedGainLookahead time

Definition at line 2231 of file MSLCM_SL2015.cpp.

References DEBUG_COND, MAX2(), and mySpeedGainLookahead.

Referenced by updateExpectedSublaneSpeeds().

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 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 myAngleOffset.

◆ 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 431 of file MSAbstractLaneChangeModel.cpp.

References LC_ASSUMED_DECEL, MAX2(), and myVehicle.

Referenced by MSLaneChanger::checkChange().

Here is the caller graph for this function:

◆ getCanceledState()

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

Definition at line 258 of file MSAbstractLaneChangeModel.h.

References myCanceledStateCenter, myCanceledStateLeft, and myCanceledStateRight.

Referenced by MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), cancelRequest(), MSLaneChangerSublane::checkChangeSublane(), MSLCM_SL2015::checkStrategicChange(), prepareStep(), and saveLCState().

Here is the caller graph for this function:

◆ getCarFollowModel()

const MSCFModel & MSAbstractLaneChangeModel::getCarFollowModel ( ) const
inlineprotectedinherited

◆ getCommittedSpeed()

double MSAbstractLaneChangeModel::getCommittedSpeed ( ) const
inlineinherited

Definition at line 583 of file MSAbstractLaneChangeModel.h.

References myCommittedSpeed.

Referenced by MSLaneChangerSublane::startChangeSublane().

Here is the caller graph for this function:

◆ getCooperativeHelpSpeed()

double MSAbstractLaneChangeModel::getCooperativeHelpSpeed ( const MSLane * lane,
double distToLaneEnd ) const
inherited

return speed for helping a vehicle that is blocked from changing

Definition at line 1150 of file MSAbstractLaneChangeModel.cpp.

References MSLane::getEdge(), MSLane::getIndex(), MSEdge::getLastBlocked(), MSLane::getLength(), myCooperativeHelpTime, and myVehicle.

◆ getDesiredAlignment()

LatAlignmentDefinition MSLCM_SL2015::getDesiredAlignment ( ) const
overridevirtual

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 3612 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::getDesiredAlignment(), MSGlobals::gLefthand, LEFT, myTurnAlignmentDist, MSAbstractLaneChangeModel::myVehicle, NODIR, PARTLEFT, PARTRIGHT, RIGHT, STRAIGHT, TURN, and TURN_LEFTHAND.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ getExtraReservation()

double MSAbstractLaneChangeModel::getExtraReservation ( int bestLaneOffset,
double neighExtraDist = 0 ) const
virtualinherited

Definition at line 1136 of file MSAbstractLaneChangeModel.cpp.

References myVehicle.

Referenced by MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), and MSLane::isInsertionSuccess().

Here is the caller graph for this function:

◆ 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 241 of file MSAbstractLaneChangeModel.cpp.

References myLeftFollowers, and myRightFollowers.

◆ getForwardPos()

double MSAbstractLaneChangeModel::getForwardPos ( ) const
inherited

get vehicle position relative to the forward direction lane

Definition at line 1089 of file MSAbstractLaneChangeModel.cpp.

References myAmOpposite, and myVehicle.

Referenced by MSLCM_LC2013::_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 myFurtherTargetLanes.

◆ getLaneChangeCompletion()

double MSAbstractLaneChangeModel::getLaneChangeCompletion ( ) const
inlineinherited

Get the current lane change completion ratio.

Definition at line 472 of file MSAbstractLaneChangeModel.h.

References myLaneChangeCompletion.

Referenced by MSLaneChanger::continueChange().

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 myLaneChangeDirection.

Referenced by MSLaneChanger::continueChange().

Here is the caller graph for this function:

◆ getLastLaneChangeOffset()

SUMOTime MSAbstractLaneChangeModel::getLastLaneChangeOffset ( ) const
inlineinherited

Definition at line 440 of file MSAbstractLaneChangeModel.h.

References myLastLaneChangeOffset.

◆ getLateralDrift()

double MSLCM_SL2015::getLateralDrift ( )
protected

get lateral drift for the current step

Definition at line 960 of file MSLCM_SL2015.cpp.

References MAX2(), MSAbstractLaneChangeModel::mySigma, mySigmaState, MSAbstractLaneChangeModel::myVehicle, and OUProcess::step().

Referenced by prepareStep().

Here is the caller graph for this function:

◆ getLCA()

LaneChangeAction MSLCM_SL2015::getLCA ( int state,
double latDist )
staticprotected

compute lane change action from desired lateral distance

Definition at line 2799 of file MSLCM_SL2015.cpp.

References LCA_CHANGE_REASONS, LCA_LEFT, LCA_NONE, and LCA_RIGHT.

Referenced by _wantsChangeSublane(), wantsChange(), and wantsChangeSublane().

Here is the caller graph for this function:

◆ 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 254 of file MSAbstractLaneChangeModel.cpp.

References myLeftLeaders, and myRightLeaders.

◆ getLeftBorder()

double MSLCM_SL2015::getLeftBorder ( bool checkOpposite = true) const
protected

return current edge width optionally extended by opposite direction lane width

Definition at line 4054 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane(), and keepLatGap().

Here is the caller graph for this function:

◆ getLongest()

CLeaderDist MSLCM_SL2015::getLongest ( const MSLeaderDistanceInfo & ldi) const
protected

get the longest vehicle in the given info

Definition at line 2269 of file MSLCM_SL2015.cpp.

References MSVehicleType::getLength(), MSBaseVehicle::getVehicleType(), MSLeaderInfo::numSublanes(), and tieBrakeLeader().

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ getManeuverDist()

double MSAbstractLaneChangeModel::getManeuverDist ( ) const
inherited

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

Definition at line 192 of file MSAbstractLaneChangeModel.cpp.

References myManeuverDist.

Referenced by MSLCM_SL2015::_wantsChangeSublane(), MSLaneChangerSublane::change(), MSLCM_SL2015::changed(), MSLaneChangerSublane::continueChangeSublane(), MSLink::getLeaderInfo(), GUIVehicle::getManeuverDist(), MSLeaderInfo::getSubLanes(), MSLaneChangerSublane::startChangeSublane(), 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 570 of file MSAbstractLaneChangeModel.cpp.

References MAX2(), myMaxSpeedLatStanding, and myVehicle.

Referenced by MSLCM_SL2015::checkBlocking().

Here is the caller graph for this function:

◆ getModelID()

LaneChangeModel MSLCM_SL2015::getModelID ( ) const
inlineoverridevirtual

Returns the model's id.

Implements MSAbstractLaneChangeModel.

Definition at line 43 of file MSLCM_SL2015.h.

References SL2015.

◆ getNeighRight()

double MSLCM_SL2015::getNeighRight ( const MSLane & neighLane) const
protected

return the right offset of the neighboring lane relative to the current edge

Definition at line 4069 of file MSLCM_SL2015.cpp.

References MSLane::getEdge(), MSLane::getRightSideOnEdge(), MSLane::getWidth(), MSAbstractLaneChangeModel::isOpposite(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane(), checkBlocking(), and keepLatGap().

Here is the caller graph for this function:

◆ 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 1095 of file MSAbstractLaneChangeModel.cpp.

References myAmOpposite, and myVehicle.

Referenced by MSLaneChanger::checkOppositeStop().

Here is the caller graph for this function:

◆ getOppositeSafetyFactor()

double MSLCM_SL2015::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 3814 of file MSLCM_SL2015.cpp.

References myOppositeParam.

◆ getOwnState()

int MSAbstractLaneChangeModel::getOwnState ( ) const
inlineinherited

Definition at line 195 of file MSAbstractLaneChangeModel.h.

References myOwnState.

Referenced by MSLaneChangerSublane::abortLCManeuver(), MSLaneChanger::applyTraCICommands(), MSLaneChanger::change(), MSLaneChanger::checkTraCICommands(), MSLaneChangerSublane::outputLCEnded(), MSLaneChangerSublane::outputLCStarted(), MSLaneChangerSublane::startChangeSublane(), and MSLCHelper::updateBlockerLength().

Here is the caller graph for this function:

◆ getParameter()

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

try to retrieve the given parameter from this device. Throw exception for unsupported key

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 3820 of file MSLCM_SL2015.cpp.

References myAccelLat, MSAbstractLaneChangeModel::myAssertive, myChangeProbThresholdLeft, myChangeProbThresholdRight, myCooperativeParam, myCooperativeSpeed, myImpatience, myKeepRightAcceptanceTime, myKeepRightParam, myKeepRightProbability, myLaneDiscipline, myLookaheadLeft, myLookAheadSpeed, MSAbstractLaneChangeModel::myMaxDistLatStanding, MSAbstractLaneChangeModel::myMaxSpeedLatFactor, MSAbstractLaneChangeModel::myMaxSpeedLatStanding, myMinGapLat, MSAbstractLaneChangeModel::myModel, myOppositeParam, myOvertakeDeltaSpeedFactor, myPushy, myRoundaboutBonus, MSAbstractLaneChangeModel::mySigma, mySigmaState, mySpeedGainLookahead, mySpeedGainParam, mySpeedGainProbabilityLeft, mySpeedGainProbabilityRight, mySpeedGainRemainTime, mySpeedGainRight, myStrategicParam, mySublaneParam, myTimeToImpatience, SUMO_ATTR_LCA_ACCEL_LAT, SUMO_ATTR_LCA_ASSERTIVE, SUMO_ATTR_LCA_COOPERATIVE_PARAM, SUMO_ATTR_LCA_COOPERATIVE_ROUNDABOUT, SUMO_ATTR_LCA_COOPERATIVE_SPEED, SUMO_ATTR_LCA_IMPATIENCE, SUMO_ATTR_LCA_KEEPRIGHT_ACCEPTANCE_TIME, SUMO_ATTR_LCA_KEEPRIGHT_PARAM, SUMO_ATTR_LCA_LANE_DISCIPLINE, SUMO_ATTR_LCA_LOOKAHEADLEFT, SUMO_ATTR_LCA_MAXDISTLATSTANDING, SUMO_ATTR_LCA_MAXSPEEDLATFACTOR, SUMO_ATTR_LCA_MAXSPEEDLATSTANDING, SUMO_ATTR_LCA_OPPOSITE_PARAM, SUMO_ATTR_LCA_OVERTAKE_DELTASPEED_FACTOR, SUMO_ATTR_LCA_PUSHY, SUMO_ATTR_LCA_PUSHYGAP, SUMO_ATTR_LCA_SIGMA, SUMO_ATTR_LCA_SPEEDGAIN_LOOKAHEAD, SUMO_ATTR_LCA_SPEEDGAIN_PARAM, SUMO_ATTR_LCA_SPEEDGAIN_REMAIN_TIME, SUMO_ATTR_LCA_SPEEDGAINRIGHT, SUMO_ATTR_LCA_STRATEGIC_PARAM, SUMO_ATTR_LCA_SUBLANE_PARAM, SUMO_ATTR_LCA_TIME_TO_IMPATIENCE, SUMO_ATTR_MINGAP_LAT, and toString().

Referenced by MSLCM_SL2015().

Here is the caller graph for this function:

◆ getPosLat()

double MSLCM_SL2015::getPosLat ( )
protected

get lateral position of this vehicle

Definition at line 970 of file MSLCM_SL2015.cpp.

References mySigmaState, and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ getPreviousManeuverDist()

double MSAbstractLaneChangeModel::getPreviousManeuverDist ( ) const
inherited

Definition at line 197 of file MSAbstractLaneChangeModel.cpp.

References 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 myPreviousState2.

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

Here is the caller graph for this function:

◆ getSafetyFactor()

double MSLCM_SL2015::getSafetyFactor ( ) const
overridevirtual

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

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 3809 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::myAssertive, and myImpatience.

Referenced by checkBlockingVehicles(), and commitFollowSpeed().

Here is the caller graph for this function:

◆ getSavedState()

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

◆ getShadowDirection()

int MSAbstractLaneChangeModel::getShadowDirection ( ) const
inherited

return the direction in which the current shadow lane lies

Definition at line 645 of file MSAbstractLaneChangeModel.cpp.

References isChangingLanes(), myAmOpposite, myLaneChangeDirection, myShadowLane, myVehicle, and pastMidpoint().

Referenced by GUIVehicle::selectBlockingFoes().

Here is the caller graph for this function:

◆ getShadowFurtherLanes()

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

Definition at line 421 of file MSAbstractLaneChangeModel.h.

References myShadowFurtherLanes.

◆ getShadowFurtherLanesPosLat()

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

Definition at line 425 of file MSAbstractLaneChangeModel.h.

References myShadowFurtherLanesPosLat.

◆ getShadowLane() [1/3]

MSLane * MSAbstractLaneChangeModel::getShadowLane ( ) const
inlineinherited

Returns the lane the vehicle's shadow is on during continuous/sublane lane change.

Returns
The vehicle's shadow lane

Definition at line 411 of file MSAbstractLaneChangeModel.h.

References myShadowLane.

Referenced by MSVehicle::adaptToLeaders(), MSLaneChangerSublane::addOutsideLeaders(), MSLCM_SL2015::checkStrategicChange(), MSLaneChanger::computeSafeOppositeLength(), MSLaneChanger::computeSurplusGap(), MSLaneChanger::continueChange(), MSLane::detectCollisionBetween(), MSLane::executeMovements(), MSLane::getLeader(), MSLink::getLeaderInfo(), getShadowLane(), MSLane::isInsertionSuccess(), MSLaneChangerSublane::startChangeSublane(), MSLaneChangerSublane::updateChanger(), and updateShadowLane().

Here is the caller graph for this function:

◆ getShadowLane() [2/3]

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

return the shadow lane for the given lane

Definition at line 515 of file MSAbstractLaneChangeModel.cpp.

References getShadowLane(), and myVehicle.

◆ getShadowLane() [3/3]

MSLane * MSAbstractLaneChangeModel::getShadowLane ( const MSLane * lane,
double posLat ) const
inherited

◆ getSlowest()

CLeaderDist MSLCM_SL2015::getSlowest ( const MSLeaderDistanceInfo & ldi)
staticprotected

get the slowest vehicle in the given info

Definition at line 2297 of file MSLCM_SL2015.cpp.

References MSLeaderInfo::numSublanes().

Referenced by _wantsChangeSublane(), and checkStrategicChange().

Here is the caller graph for this function:

◆ 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 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:

◆ getStrategicLookahead()

double MSAbstractLaneChangeModel::getStrategicLookahead ( ) const
inlineinherited

Definition at line 601 of file MSAbstractLaneChangeModel.h.

References myStrategicLookahead.

Referenced by MSVehicle::updateBestLanes().

Here is the caller graph for this function:

◆ getSublaneWidth()

double MSLCM_SL2015::getSublaneWidth ( )
inlineprotected

return the current sublane width (and return a sensible value when running without sublanes)

Definition at line 327 of file MSLCM_SL2015.h.

References MSGlobals::gLateralResolution, and MSAbstractLaneChangeModel::myVehicle.

◆ 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 myTargetLane.

◆ getVehicleCenter()

double MSLCM_SL2015::getVehicleCenter ( ) const
protected

return vehicle position relative to the current edge (extend by another virtual lane for opposite-direction driving)

Definition at line 4060 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::isOpposite(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ getWidth()

double MSLCM_SL2015::getWidth ( ) const
protected

return the width of this vehicle (padded for numerical stability)

Definition at line 3453 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane(), checkBlockingVehicles(), commitFollowSpeed(), computeSpeedGain(), computeSpeedLat(), keepLatGap(), prepareStep(), and updateGaps().

Here is the caller graph for this function:

◆ hasBlueLight()

bool MSAbstractLaneChangeModel::hasBlueLight ( ) const
inlineinherited

Definition at line 640 of file MSAbstractLaneChangeModel.h.

References myHaveBlueLight.

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

Here is the caller graph for this function:

◆ haveLCOutput()

bool MSAbstractLaneChangeModel::haveLCOutput ( )
inlinestaticinherited

whether lanechange-output is active

Definition at line 172 of file MSAbstractLaneChangeModel.h.

References myLCOutput.

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

Here is the caller graph for this function:

◆ inform()

◆ informFollower()

◆ informFollowers()

void MSLCM_SL2015::informFollowers ( int blocked,
int dir,
const std::vector< CLeaderDist > & blockers,
double remainingSeconds,
double plannedSpeed )
protected

call informFollower for multiple followers

Definition at line 868 of file MSLCM_SL2015.cpp.

References informFollower().

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ informLeader()

◆ informLeaders()

double MSLCM_SL2015::informLeaders ( int blocked,
int dir,
const std::vector< CLeaderDist > & blockers,
double remainingSeconds )
protected

Definition at line 844 of file MSLCM_SL2015.cpp.

References informLeader(), MAGIC_OFFSET, MIN2(), myLeadingBlockerLength, myLeftSpace, and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ initDerivedParameters()

void MSLCM_SL2015::initDerivedParameters ( )

init cached parameters derived directly from model parameters

Definition at line 163 of file MSLCM_SL2015.cpp.

References myChangeProbThresholdLeft, myChangeProbThresholdRight, mySpeedGainParam, mySpeedGainRight, mySpeedLossProbThreshold, and mySublaneParam.

Referenced by MSLCM_SL2015(), 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 72 of file MSAbstractLaneChangeModel.cpp.

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

Referenced by MSFrame::setMSGlobals().

Here is the caller graph for this function:

◆ initLastLaneChangeOffset()

void MSAbstractLaneChangeModel::initLastLaneChangeOffset ( int dir)
protectedinherited

Definition at line 575 of file MSAbstractLaneChangeModel.cpp.

References myLastLaneChangeOffset.

Referenced by primaryLaneChanged().

Here is the caller graph for this function:

◆ isBidi()

bool MSLCM_SL2015::isBidi ( const MSLane * lane) const
protected

check whether lane is an upcoming bidi lane

Definition at line 2097 of file MSLCM_SL2015.cpp.

References MSNet::getInstance(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by updateExpectedSublaneSpeeds().

Here is the caller graph for this function:

◆ isChangingLanes()

bool MSAbstractLaneChangeModel::isChangingLanes ( ) const
inlineinherited

return true if the vehicle currently performs a lane change maneuver

Definition at line 467 of file MSAbstractLaneChangeModel.h.

References myLaneChangeCompletion.

Referenced by MSLaneChanger::change(), MSLaneChangerSublane::change(), MSLCM_LC2013::computeSpeedLat(), MSLaneChanger::continueChange(), MSLane::detectCollisionBetween(), MSLane::getLeader(), getShadowDirection(), getShadowLane(), MSLCM_LC2013::prepareStep(), remainingTime(), resetSpeedLat(), and updateShadowLane().

Here is the caller graph for this function:

◆ isOpposite()

bool MSAbstractLaneChangeModel::isOpposite ( ) const
inlineinherited

Definition at line 576 of file MSAbstractLaneChangeModel.h.

References myAmOpposite.

Referenced by MSLCM_LC2013::_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(), MSDevice_SSM::classifyEncounter(), MSLaneChanger::computeSafeOppositeLength(), MSLCM_SL2015::computeSpeedLat(), MSLaneChanger::computeSurplusGap(), MSLaneChanger::continueChange(), MSLane::detectCollisionBetween(), MSDevice_SSM::findFoeConflictLane(), MSDevice_SSM::findSurroundingVehicles(), MSLaneChanger::getBestLanesOpposite(), GUIVehicle::getColorValue(), MSLane::getFollowersOnConsecutive(), MSLane::getLeader(), MSLink::getLeaderInfo(), LIBSUMO_NAMESPACE::Vehicle::getNeighbors(), MSLCM_SL2015::getNeighRight(), MSLane::getOppositeFollower(), MSLane::getOppositeLeader(), MSLCHelper::getRoundaboutDistBonus(), GUIBaseVehicle::getScaleValue(), MSLCM_SL2015::getVehicleCenter(), MSLane::handleCollisionBetween(), MSLCM_LC2013::informLeader(), MSLCM_SL2015::informLeader(), MSLane::isFrontalCollision(), MSLCM_SL2015::keepLatGap(), MSVehicle::lateralDistanceToLane(), MSLCM_SL2015::prepareStep(), MSLeaderInfo::removeOpposite(), MSLCM_LC2013::saveBlockerLength(), MSLCM_SL2015::saveBlockerLength(), MSLaneChangerSublane::startChangeSublane(), and MSLCM_SL2015::updateExpectedSublaneSpeeds().

Here is the caller graph for this function:

◆ isStrategicBlocked()

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

Definition at line 1070 of file MSAbstractLaneChangeModel.cpp.

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

Referenced by MSLink::getLeaderInfo().

Here is the caller graph for this function:

◆ keepLatGap()

int MSLCM_SL2015::keepLatGap ( int state,
const MSLeaderDistanceInfo & leaders,
const MSLeaderDistanceInfo & followers,
const MSLeaderDistanceInfo & blockers,
const MSLeaderDistanceInfo & neighLeaders,
const MSLeaderDistanceInfo & neighFollowers,
const MSLeaderDistanceInfo & neighBlockers,
const MSLane & neighLane,
int laneOffset,
double & latDist,
double & maneuverDist,
int & blocked )
protected

check whether lateral gap requirements are met override the current maneuver if necessary

XXX to be made configurable

passed state is without traci-influence but we need it here

Definition at line 3113 of file MSLCM_SL2015.cpp.

References checkBlocking(), computeGapFactor(), gDebugFlag2, getLeftBorder(), getNeighRight(), getWidth(), MSAbstractLaneChangeModel::isOpposite(), LCA_BLOCKED_LEFT, LCA_BLOCKED_RIGHT, LCA_CHANGE_REASONS, LCA_COOPERATIVE, LCA_KEEPRIGHT, LCA_OVERLAPPING, LCA_SPEEDGAIN, LCA_STAY, LCA_STRATEGIC, LCA_SUBLANE, LCA_TRACI, MAX2(), MIN2(), MSAbstractLaneChangeModel::myLastLateralGapLeft, MSAbstractLaneChangeModel::myLastLateralGapRight, mySafeLatDistLeft, mySafeLatDistRight, MSAbstractLaneChangeModel::myVehicle, MSAbstractLaneChangeModel::NO_NEIGHBOR, SIMTIME, toString(), and updateGaps().

Referenced by wantsChangeSublane().

Here is the caller graph for this function:

◆ laneChangeOutput()

◆ 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 1125 of file MSAbstractLaneChangeModel.cpp.

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

◆ lowest_bit()

int MSLCM_SL2015::lowest_bit ( int changeReason)
staticprotected

return the most important change reason

Definition at line 2676 of file MSLCM_SL2015.cpp.

References LCA_COOPERATIVE, LCA_KEEPRIGHT, LCA_SPEEDGAIN, LCA_STRATEGIC, and LCA_TRACI.

Referenced by decideDirection().

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 326 of file MSAbstractLaneChangeModel.cpp.

References myDontResetLCGaps.

Referenced by startLaneChangeManeuver().

Here is the caller graph for this function:

◆ msg()

void MSLCM_SL2015::msg ( const CLeaderDist & cld,
double speed,
int state )
protected

send a speed recommendation to the given vehicle

Definition at line 533 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::myVehicle.

Referenced by informFollower(), and informLeader().

Here is the caller graph for this function:

◆ mustOvertakeStopped()

bool MSLCM_SL2015::mustOvertakeStopped ( bool checkCurrent,
const MSLane & neighLane,
const MSLeaderDistanceInfo & leaders,
const MSLeaderDistanceInfo & neighLead,
double posOnLane,
double neighDist,
bool right,
double latLaneDist,
double & currentDist,
double & latDist )
protected

◆ outputLCEnded()

bool MSAbstractLaneChangeModel::outputLCEnded ( )
inlinestaticinherited

whether start of maneuvers shall be recorede

Definition at line 182 of file MSAbstractLaneChangeModel.h.

References myLCEndedOutput.

Referenced by MSLaneChangerSublane::outputLCEnded().

Here is the caller graph for this function:

◆ outputLCStarted()

bool MSAbstractLaneChangeModel::outputLCStarted ( )
inlinestaticinherited

whether start of maneuvers shall be recorede

Definition at line 177 of file MSAbstractLaneChangeModel.h.

References myLCStartedOutput.

Referenced by MSLaneChangerSublane::outputLCStarted().

Here is the caller graph for this function:

◆ outsideEdge()

bool MSLCM_SL2015::outsideEdge ( ) const
protected

whether the ego vehicle is driving outside edgebounds

Definition at line 4125 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::myVehicle.

Referenced by checkBlockingVehicles(), and updateCFRelated().

Here is the caller graph for this function:

◆ overlap()

bool MSLCM_SL2015::overlap ( double right,
double left,
double right2,
double left2 )
staticprotected

return whether the given intervals overlap

Definition at line 2668 of file MSLCM_SL2015.cpp.

Referenced by _wantsChangeSublane(), checkBlockingVehicles(), commitFollowSpeed(), computeSpeedGain(), and updateCFRelated().

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 myLaneChangeCompletion.

Referenced by getShadowDirection(), and updateCompletion().

Here is the caller graph for this function:

◆ patchSpeed()

double MSLCM_SL2015::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 306 of file MSLCM_SL2015.cpp.

References _patchSpeed(), DEBUG_COND, gDebugFlag2, MAX2(), MSAbstractLaneChangeModel::myVehicle, SIMTIME, and toString().

◆ predInteraction()

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

Definition at line 295 of file MSAbstractLaneChangeModel.cpp.

References getCarFollowModel(), MSCFModel::interactionGap(), and myVehicle.

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

Here is the caller graph for this function:

◆ prepareStep()

◆ preventSliding()

bool MSLCM_SL2015::preventSliding ( double maneuverDist) const
protected

Definition at line 4082 of file MSLCM_SL2015.cpp.

References gDebugFlag2, MSAbstractLaneChangeModel::myMaxDistLatStanding, MSAbstractLaneChangeModel::myMaxSpeedLatFactor, MSAbstractLaneChangeModel::myVehicle, SIMTIME, and SVC_EMERGENCY.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ primaryLaneChanged()

void MSAbstractLaneChangeModel::primaryLaneChanged ( MSLane * source,
MSLane * target,
int direction )
inherited

called once when the vehicles primary lane changes

Definition at line 336 of file MSAbstractLaneChangeModel.cpp.

References changed(), changedToOpposite(), debugVehicle(), MSLane::enteredByLaneChange(), MSLane::forceVehicleInsertion(), MSLane::getEdge(), Named::getID(), MSLane::getOppositePos(), MSGlobals::gSublane, initLastLaneChangeOffset(), laneChangeOutput(), MSLane::leftByLaneChange(), myAlreadyChanged, myAmOpposite, myVehicle, MSMoveReminder::NOTIFICATION_LANE_CHANGE, and SIMTIME.

Referenced by MSLaneChanger::continueChange(), and startLaneChangeManeuver().

Here is the caller graph for this function:

◆ remainingTime()

◆ removeShadowApproachingInformation()

void MSAbstractLaneChangeModel::removeShadowApproachingInformation ( ) const
inherited

Definition at line 895 of file MSAbstractLaneChangeModel.cpp.

References myApproachedByShadow, and myVehicle.

◆ resetChanged()

void MSAbstractLaneChangeModel::resetChanged ( )
inlineinherited

reset the flag whether a vehicle already moved to false

Definition at line 508 of file MSAbstractLaneChangeModel.h.

References myAlreadyChanged.

◆ resetSpeedLat()

void MSAbstractLaneChangeModel::resetSpeedLat ( )
virtualinherited

Definition at line 443 of file MSAbstractLaneChangeModel.cpp.

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

Referenced by MSLCM_DK2008::prepareStep(), and MSLCM_LC2013::prepareStep().

Here is the caller graph for this function:

◆ resetState()

◆ saveBlockerLength()

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

reserve space at the end of the lane to avoid dead locks

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 4109 of file MSLCM_SL2015.cpp.

References MSLCHelper::canSaveBlockerLength(), MSAbstractLaneChangeModel::isOpposite(), MAX2(), myLeadingBlockerLength, myLeftSpace, and MSAbstractLaneChangeModel::myVehicle.

◆ saveLCState()

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

Definition at line 225 of file MSAbstractLaneChangeModel.h.

References getCanceledState(), LCA_WANTS_LANECHANGE_OR_STAY, mySavedStateCenter, mySavedStateLeft, and mySavedStateRight.

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

Here is the caller graph for this function:

◆ 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 202 of file MSAbstractLaneChangeModel.cpp.

References myLeftFollowers, myLeftLeaders, myRightFollowers, and 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 217 of file MSAbstractLaneChangeModel.cpp.

References myLeftFollowers, myLeftLeaders, myRightFollowers, myRightLeaders, and 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 1112 of file MSAbstractLaneChangeModel.cpp.

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

◆ 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 myAngleOffset.

◆ setFollowerGaps() [1/2]

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

Definition at line 958 of file MSAbstractLaneChangeModel.cpp.

References myLastFollowerGap, myLastFollowerSecureGap, and 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

Definition at line 967 of file MSAbstractLaneChangeModel.cpp.

References myLastLeaderGap, myLastLeaderSecureGap, myLastLeaderSpeed, and myVehicle.

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

Here is the caller graph for this function:

◆ 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 176 of file MSAbstractLaneChangeModel.cpp.

References DEBUG_COND, myManeuverDist, myPreviousManeuverDist, myVehicle, and SIMTIME.

Referenced by MSLaneChangerSublane::abortLCManeuver(), checkTraCICommands(), MSLaneChangerSublane::startChangeSublane(), and 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 myNoPartiallyOccupatedByShadow.

◆ setOrigLeaderGaps() [1/2]

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

Definition at line 976 of file MSAbstractLaneChangeModel.cpp.

References myLastOrigLeaderGap, myLastOrigLeaderSecureGap, myLastOrigLeaderSpeed, and myVehicle.

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

Here is the caller graph for this function:

◆ setOrigLeaderGaps() [2/2]

◆ setOwnState()

◆ setParameter()

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

try to set the given parameter for this laneChangeModel. Throw exception for unsupported key

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 3896 of file MSLCM_SL2015.cpp.

References initDerivedParameters(), invalid_return< std::string >::value, myAccelLat, MSAbstractLaneChangeModel::myAssertive, myCooperativeParam, myCooperativeSpeed, myImpatience, myKeepRightAcceptanceTime, myKeepRightParam, myKeepRightProbability, myLaneDiscipline, myLookaheadLeft, myLookAheadSpeed, MSAbstractLaneChangeModel::myMaxDistLatStanding, MSAbstractLaneChangeModel::myMaxSpeedLatFactor, MSAbstractLaneChangeModel::myMaxSpeedLatStanding, myMinGapLat, myMinImpatience, MSAbstractLaneChangeModel::myModel, myOppositeParam, myOvertakeDeltaSpeedFactor, myPushy, myRoundaboutBonus, MSAbstractLaneChangeModel::mySigma, mySigmaState, mySpeedGainLookahead, mySpeedGainParam, mySpeedGainProbabilityLeft, mySpeedGainProbabilityRight, mySpeedGainRemainTime, mySpeedGainRight, myStrategicParam, mySublaneParam, myTimeToImpatience, myTurnAlignmentDist, SUMO_ATTR_LCA_ACCEL_LAT, SUMO_ATTR_LCA_ASSERTIVE, SUMO_ATTR_LCA_COOPERATIVE_PARAM, SUMO_ATTR_LCA_COOPERATIVE_ROUNDABOUT, SUMO_ATTR_LCA_COOPERATIVE_SPEED, SUMO_ATTR_LCA_IMPATIENCE, SUMO_ATTR_LCA_KEEPRIGHT_ACCEPTANCE_TIME, SUMO_ATTR_LCA_KEEPRIGHT_PARAM, SUMO_ATTR_LCA_LANE_DISCIPLINE, SUMO_ATTR_LCA_LOOKAHEADLEFT, SUMO_ATTR_LCA_MAXDISTLATSTANDING, SUMO_ATTR_LCA_MAXSPEEDLATFACTOR, SUMO_ATTR_LCA_MAXSPEEDLATSTANDING, SUMO_ATTR_LCA_OPPOSITE_PARAM, SUMO_ATTR_LCA_OVERTAKE_DELTASPEED_FACTOR, SUMO_ATTR_LCA_PUSHY, SUMO_ATTR_LCA_PUSHYGAP, SUMO_ATTR_LCA_SIGMA, SUMO_ATTR_LCA_SPEEDGAIN_LOOKAHEAD, SUMO_ATTR_LCA_SPEEDGAIN_PARAM, SUMO_ATTR_LCA_SPEEDGAIN_REMAIN_TIME, SUMO_ATTR_LCA_SPEEDGAINRIGHT, SUMO_ATTR_LCA_STRATEGIC_PARAM, SUMO_ATTR_LCA_SUBLANE_PARAM, SUMO_ATTR_LCA_TIME_TO_IMPATIENCE, SUMO_ATTR_LCA_TURN_ALIGNMENT_DISTANCE, SUMO_ATTR_MINGAP_LAT, StringUtils::toDouble(), and toString().

◆ 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 myPreviousAngleOffset.

◆ setShadowApproachingInformation()

void MSAbstractLaneChangeModel::setShadowApproachingInformation ( MSLink * link) const
inherited

set approach information for the shadow vehicle

Definition at line 889 of file MSAbstractLaneChangeModel.cpp.

References myApproachedByShadow.

◆ setShadowPartialOccupator()

void MSAbstractLaneChangeModel::setShadowPartialOccupator ( MSLane * lane)
inlineinherited

Definition at line 552 of file MSAbstractLaneChangeModel.h.

References myPartiallyOccupatedByShadow.

◆ setSpeedLat()

void MSAbstractLaneChangeModel::setSpeedLat ( double speedLat)
inherited

set the lateral speed and update lateral acceleraton

Definition at line 436 of file MSAbstractLaneChangeModel.cpp.

References myAccelerationLat, mySpeedLat, and SPEED2ACCEL.

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

Here is the caller graph for this function:

◆ slowDownForBlocked()

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

compute useful slowdowns for blocked vehicles

Definition at line 2059 of file MSLCM_SL2015.cpp.

References MSAbstractLaneChangeModel::addLCSpeedAdvice(), gDebugFlag2, MSAbstractLaneChangeModel::getCarFollowModel(), Named::getIDSecure(), LCA_AMBACKBLOCKER, LCA_AMBACKBLOCKER_STANDING, MSAbstractLaneChangeModel::myVehicle, SIMTIME, and SUMO_const_haltingSpeed.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

◆ startLaneChangeManeuver()

bool MSAbstractLaneChangeModel::startLaneChangeManeuver ( MSLane * source,
MSLane * target,
int direction )
inherited

start the lane change maneuver and return whether it continues

Definition at line 308 of file MSAbstractLaneChangeModel.cpp.

References DELTA_T, MSLane::getWidth(), MSGlobals::gLaneChangeDuration, MSGlobals::gLefthand, memorizeGapsAtLCInit(), myLaneChangeCompletion, myLaneChangeDirection, myLCOutput, myVehicle, primaryLaneChanged(), setManeuverDist(), MSVehicle::VEH_SIGNAL_BLINKER_LEFT, and MSVehicle::VEH_SIGNAL_BLINKER_RIGHT.

Referenced by MSLaneChanger::applyTraCICommands(), MSLaneChanger::checkChangeOpposite(), MSLaneChangerSublane::checkChangeToNewLane(), and MSLaneChanger::startChange().

Here is the caller graph for this function:

◆ 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 myModel, toString(), and UNUSED_PARAMETER.

◆ tieBrakeLeader()

bool MSLCM_SL2015::tieBrakeLeader ( const MSVehicle * veh) const
protected

Definition at line 2287 of file MSLCM_SL2015.cpp.

References MSLane::getEdge(), MSLane::getIndex(), MSVehicle::getLane(), MSVehicle::getPositionOnLane(), MSVehicle::getSpeed(), and MSAbstractLaneChangeModel::myVehicle.

Referenced by _wantsChangeSublane(), and getLongest().

Here is the caller graph for this function:

◆ unchanged()

void MSAbstractLaneChangeModel::unchanged ( )
inlineinherited

Definition at line 400 of file MSAbstractLaneChangeModel.h.

References DELTA_T, and myLastLaneChangeOffset.

Referenced by MSLaneChanger::registerUnchanged().

Here is the caller graph for this function:

◆ updateCFRelated()

void MSLCM_SL2015::updateCFRelated ( const MSLeaderDistanceInfo & vehicles,
double foeOffset,
bool leaders )
protected

find leaders/followers that are already in a car-following relationship with ego

Definition at line 2609 of file MSLCM_SL2015.cpp.

References gDebugFlag2, MSLeaderInfo::getSublaneBorders(), myCFRelated, MSAbstractLaneChangeModel::myVehicle, MSLeaderInfo::numSublanes(), outsideEdge(), overlap(), SUMO_const_haltingSpeed, MSLeaderDistanceInfo::toString(), and UNUSED_PARAMETER.

Referenced by checkBlocking().

Here is the caller graph for this function:

◆ updateCompletion()

bool MSAbstractLaneChangeModel::updateCompletion ( )
inherited

Definition at line 451 of file MSAbstractLaneChangeModel.cpp.

References computeSpeedLat(), getManeuverDist(), LCA_URGENT, myLaneChangeCompletion, myManeuverDist, myOwnState, mySpeedLat, pastMidpoint(), setSpeedLat(), and SPEED2DIST.

Referenced by MSLaneChanger::continueChange().

Here is the caller graph for this function:

◆ updateExpectedSublaneSpeeds()

◆ updateGaps()

void MSLCM_SL2015::updateGaps ( const MSLeaderDistanceInfo & others,
double foeOffset,
double oldCenter,
double gapFactor,
double & surplusGapRight,
double & surplusGapLeft,
bool saveMinGap = false,
double netOverlap = 0,
double latDist = 0,
std::vector< CLeaderDist > * collectBlockers = 0 )
protected

check remaining lateral gaps for the given foe vehicles and optionally update minimum lateral gaps

foe vehicle occupies full sublanes

Definition at line 3363 of file MSLCM_SL2015.cpp.

References debugVehicle(), gDebugFlag2, Named::getID(), MSVehicle::getLaneChangeModel(), MSAbstractLaneChangeModel::getManeuverDist(), MSVehicle::getSpeed(), MSLeaderInfo::getSublaneBorders(), getWidth(), MSGlobals::gLateralResolution, MSLeaderInfo::hasVehicles(), LATGAP_SPEED_THRESHOLD, LATGAP_SPEED_THRESHOLD2, MAX2(), MAX3(), MIN2(), MIN3(), myCFRelated, MSAbstractLaneChangeModel::myLastLateralGapLeft, MSAbstractLaneChangeModel::myLastLateralGapRight, myMinGapLat, MSAbstractLaneChangeModel::myVehicle, and MSLeaderInfo::numSublanes().

Referenced by _wantsChangeSublane(), checkBlocking(), and keepLatGap().

Here is the caller graph for this function:

◆ updateSafeLatDist()

void MSLCM_SL2015::updateSafeLatDist ( const double travelledLatDist)
overridevirtual

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

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 292 of file MSLCM_SL2015.cpp.

References mySafeLatDistLeft, and mySafeLatDistRight.

◆ updateShadowLane()

void MSAbstractLaneChangeModel::updateShadowLane ( )
inherited

◆ updateTargetLane()

MSLane * MSAbstractLaneChangeModel::updateTargetLane ( )
inherited

Definition at line 667 of file MSAbstractLaneChangeModel.cpp.

References debugVehicle(), determineTargetLane(), Named::getID(), MSLane::getParallelLane(), myFurtherTargetLanes, myManeuverDist, myTargetLane, myVehicle, MSLane::setManeuverReservation(), SIMTIME, and toString().

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

Here is the caller graph for this function:

◆ wantsChange()

int MSLCM_SL2015::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 is a wrapper around wantsChangeSublane). XXX: no, it wraps _wantsChangeSublane 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 3977 of file MSLCM_SL2015.cpp.

References _wantsChangeSublane(), DEBUG_COND, Named::getID(), getLCA(), LCA_BLOCKED, LCA_CHANGE_TO_HELP, LCA_COOPERATIVE, LCA_KEEPRIGHT, LCA_NONE, LCA_OVERLAPPING, LCA_SPEEDGAIN, LCA_STRATEGIC, LCA_SUBLANE, LCA_TRACI, LCA_URGENT, LCA_WANTS_LANECHANGE, myCanChangeFully, MSAbstractLaneChangeModel::myVehicle, and SIMTIME.

◆ wantsChangeSublane()

int MSLCM_SL2015::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 & maneuverDist,
int & blocked )
overridevirtual

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

TODO better documentation. Refs #2 A.o.: When is this called (as a wantsChange() exists as well!? What's the difference?)

Reimplemented from MSAbstractLaneChangeModel.

Definition at line 182 of file MSLCM_SL2015.cpp.

References _wantsChangeSublane(), computeSpeedLat(), DEBUG_COND, DIST2SPEED, gDebugFlag2, Named::getID(), getLCA(), gPrecision, keepLatGap(), LCA_BLOCKED, LCA_OVERLAPPING, LCA_URGENT, LCA_WANTS_LANECHANGE, mySigmaState, MSAbstractLaneChangeModel::mySpeedLat, MSAbstractLaneChangeModel::myVehicle, SIMTIME, SPEED2DIST, and toString().

◆ wantsKeepRight()

bool MSLCM_SL2015::wantsKeepRight ( double keepRightProb) const
inlineprotected

check against thresholds

Definition at line 4103 of file MSLCM_SL2015.cpp.

References MAX2(), myChangeProbThresholdRight, myKeepRightParam, and mySpeedGainProbabilityLeft.

Referenced by _wantsChangeSublane().

Here is the caller graph for this function:

Field Documentation

◆ myAccelerationLat

double MSAbstractLaneChangeModel::myAccelerationLat
protectedinherited

the current lateral acceleration

Definition at line 706 of file MSAbstractLaneChangeModel.h.

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

◆ myAccelLat

double MSLCM_SL2015::myAccelLat
protected

◆ myAllowOvertakingRight

bool MSAbstractLaneChangeModel::myAllowOvertakingRight
staticprotectedinherited

◆ myAlreadyChanged

bool MSAbstractLaneChangeModel::myAlreadyChanged
protectedinherited

whether the vehicle has already moved this step

Definition at line 724 of file MSAbstractLaneChangeModel.h.

Referenced by alreadyChanged(), changedToOpposite(), MSAbstractLaneChangeModel(), primaryLaneChanged(), and resetChanged().

◆ myAmOpposite

bool MSAbstractLaneChangeModel::myAmOpposite
privateinherited

◆ myAngleOffset

double MSAbstractLaneChangeModel::myAngleOffset
protectedinherited

the current angle offset resulting from lane change and sigma

Definition at line 709 of file MSAbstractLaneChangeModel.h.

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

◆ myApproachedByShadow

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

links which are approached by the shadow vehicle

Definition at line 833 of file MSAbstractLaneChangeModel.h.

Referenced by removeShadowApproachingInformation(), and setShadowApproachingInformation().

◆ myAssertive

◆ myCanceledStateCenter

int MSAbstractLaneChangeModel::myCanceledStateCenter
protectedinherited

Definition at line 691 of file MSAbstractLaneChangeModel.h.

Referenced by getCanceledState(), and MSAbstractLaneChangeModel().

◆ myCanceledStateLeft

int MSAbstractLaneChangeModel::myCanceledStateLeft
protectedinherited

Definition at line 692 of file MSAbstractLaneChangeModel.h.

Referenced by getCanceledState(), and MSAbstractLaneChangeModel().

◆ myCanceledStateRight

int MSAbstractLaneChangeModel::myCanceledStateRight
protectedinherited

Definition at line 690 of file MSAbstractLaneChangeModel.h.

Referenced by getCanceledState(), and MSAbstractLaneChangeModel().

◆ myCanChangeFully

bool MSLCM_SL2015::myCanChangeFully
protected

whether the current lane changing maneuver can be finished in a single step

Definition at line 403 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), changed(), checkBlocking(), checkBlockingVehicles(), commitManoeuvre(), MSLCM_SL2015(), prepareStep(), setOwnState(), and wantsChange().

◆ myCFRelated

std::set<const MSVehicle*> MSLCM_SL2015::myCFRelated
protected

set of vehicles that are in a car-following relationship with ego (leader of followers)

Definition at line 410 of file MSLCM_SL2015.h.

Referenced by checkBlockingVehicles(), prepareStep(), updateCFRelated(), and updateGaps().

◆ myCFRelatedReady

bool MSLCM_SL2015::myCFRelatedReady
protected

Definition at line 411 of file MSLCM_SL2015.h.

Referenced by checkBlocking(), and prepareStep().

◆ myChangeProbThresholdLeft

double MSLCM_SL2015::myChangeProbThresholdLeft
protected

◆ myChangeProbThresholdRight

double MSLCM_SL2015::myChangeProbThresholdRight
protected

◆ myCommittedSpeed

double MSAbstractLaneChangeModel::myCommittedSpeed
protectedinherited

the speed when committing to a change maneuver

Definition at line 715 of file MSAbstractLaneChangeModel.h.

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

◆ myCooperativeHelpTime

SUMOTime MSAbstractLaneChangeModel::myCooperativeHelpTime
protectedinherited

◆ myCooperativeParam

double MSLCM_SL2015::myCooperativeParam
protected

Definition at line 416 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ myCooperativeSpeed

double MSLCM_SL2015::myCooperativeSpeed
protected

Definition at line 447 of file MSLCM_SL2015.h.

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

◆ myDontBrake

bool MSLCM_SL2015::myDontBrake
protected

flag to prevent speed adaptation by slowing down

Definition at line 400 of file MSLCM_SL2015.h.

Referenced by _patchSpeed(), _wantsChangeSublane(), 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 786 of file MSAbstractLaneChangeModel.h.

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

◆ myExpectedSublaneSpeeds

std::vector<double> MSLCM_SL2015::myExpectedSublaneSpeeds
protected

expected travel speeds on all sublanes on the current edge(!)

Definition at line 394 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), computeSpeedGain(), prepareStep(), and updateExpectedSublaneSpeeds().

◆ 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 805 of file MSAbstractLaneChangeModel.h.

Referenced by hasBlueLight(), and MSAbstractLaneChangeModel().

◆ myImpatience

double MSLCM_SL2015::myImpatience
protected

◆ myKeepRightAcceptanceTime

double MSLCM_SL2015::myKeepRightAcceptanceTime
protected

Definition at line 449 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ myKeepRightParam

double MSLCM_SL2015::myKeepRightParam
protected

◆ myKeepRightProbability

double MSLCM_SL2015::myKeepRightProbability
protected

◆ myLaneChangeCompletion

double MSAbstractLaneChangeModel::myLaneChangeCompletion
protectedinherited

◆ myLaneChangeDirection

int MSAbstractLaneChangeModel::myLaneChangeDirection
protectedinherited

direction of the lane change maneuver -1 means right, 1 means left

Definition at line 721 of file MSAbstractLaneChangeModel.h.

Referenced by getLaneChangeDirection(), getShadowDirection(), getShadowLane(), loadState(), MSAbstractLaneChangeModel(), saveState(), and startLaneChangeManeuver().

◆ myLaneDiscipline

double MSLCM_SL2015::myLaneDiscipline
protected

Definition at line 439 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ myLastEdge

const MSEdge* MSLCM_SL2015::myLastEdge
protected

expected travel speeds on all sublanes on the current edge(!)

Definition at line 397 of file MSLCM_SL2015.h.

Referenced by MSLCM_SL2015(), and prepareStep().

◆ myLastFollowerGap

double MSAbstractLaneChangeModel::myLastFollowerGap
protectedinherited

◆ myLastFollowerSecureGap

double MSAbstractLaneChangeModel::myLastFollowerSecureGap
protectedinherited

◆ myLastFollowerSpeed

double MSAbstractLaneChangeModel::myLastFollowerSpeed
protectedinherited

◆ 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 767 of file MSAbstractLaneChangeModel.h.

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

◆ myLastLateralGapRight

double MSAbstractLaneChangeModel::myLastLateralGapRight
protectedinherited

◆ myLastLeaderGap

double MSAbstractLaneChangeModel::myLastLeaderGap
protectedinherited

the actual minimum longitudinal distances to vehicles on the target lane

Definition at line 771 of file MSAbstractLaneChangeModel.h.

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

◆ 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 774 of file MSAbstractLaneChangeModel.h.

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

◆ myLastLeaderSpeed

double MSAbstractLaneChangeModel::myLastLeaderSpeed
protectedinherited

speeds of surrounding vehicles at the time of lane change

Definition at line 780 of file MSAbstractLaneChangeModel.h.

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

◆ myLastOrigLeaderGap

double MSAbstractLaneChangeModel::myLastOrigLeaderGap
protectedinherited

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

Definition at line 777 of file MSAbstractLaneChangeModel.h.

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

◆ myLastOrigLeaderSecureGap

double MSAbstractLaneChangeModel::myLastOrigLeaderSecureGap
protectedinherited

◆ myLastOrigLeaderSpeed

double MSAbstractLaneChangeModel::myLastOrigLeaderSpeed
protectedinherited

◆ myLCAccelerationAdvices

◆ myLCEndedOutput

bool MSAbstractLaneChangeModel::myLCEndedOutput
staticprotectedinherited

Definition at line 822 of file MSAbstractLaneChangeModel.h.

Referenced by initGlobalOptions(), and outputLCEnded().

◆ myLCOutput

bool MSAbstractLaneChangeModel::myLCOutput
staticprotectedinherited

whether to record lane-changing

Definition at line 820 of file MSAbstractLaneChangeModel.h.

Referenced by haveLCOutput(), initGlobalOptions(), laneChangeOutput(), and startLaneChangeManeuver().

◆ myLCStartedOutput

bool MSAbstractLaneChangeModel::myLCStartedOutput
staticprotectedinherited

Definition at line 821 of file MSAbstractLaneChangeModel.h.

Referenced by initGlobalOptions(), and outputLCStarted().

◆ myLCXYOutput

bool MSAbstractLaneChangeModel::myLCXYOutput
staticprotectedinherited

Definition at line 823 of file MSAbstractLaneChangeModel.h.

Referenced by initGlobalOptions(), and laneChangeOutput().

◆ myLeadingBlockerLength

double MSLCM_SL2015::myLeadingBlockerLength
protected

◆ myLeftFollowers

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

Cached info on lc-relevant neighboring vehicles.

Definition at line 696 of file MSAbstractLaneChangeModel.h.

Referenced by clearNeighbors(), getFollowers(), saveNeighbors(), and saveNeighbors().

◆ myLeftLeaders

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

◆ myLeftSpace

◆ myLookaheadLeft

double MSLCM_SL2015::myLookaheadLeft
protected

Definition at line 435 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ myLookAheadSpeed

double MSLCM_SL2015::myLookAheadSpeed
protected

◆ myManeuverDist

double MSAbstractLaneChangeModel::myManeuverDist
privateinherited

The complete lateral distance the vehicle wants to travel to finish its maneuver Only used by sublane model, currently.

Definition at line 840 of file MSAbstractLaneChangeModel.h.

Referenced by determineTargetLane(), getManeuverDist(), MSAbstractLaneChangeModel(), remainingTime(), setManeuverDist(), updateCompletion(), and updateTargetLane().

◆ myMaxDistLatStanding

double MSAbstractLaneChangeModel::myMaxDistLatStanding
protectedinherited

◆ myMaxSpeedLatFactor

◆ myMaxSpeedLatStanding

◆ myMinGapLat

double MSLCM_SL2015::myMinGapLat
protected

Definition at line 422 of file MSLCM_SL2015.h.

Referenced by getParameter(), MSLCM_SL2015(), setParameter(), and updateGaps().

◆ myMinImpatience

double MSLCM_SL2015::myMinImpatience
protected

Definition at line 427 of file MSLCM_SL2015.h.

Referenced by MSLCM_SL2015(), setOwnState(), and setParameter().

◆ myModel

◆ myNoPartiallyOccupatedByShadow

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

◆ myOppositeParam

double MSLCM_SL2015::myOppositeParam
protected

Definition at line 419 of file MSLCM_SL2015.h.

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

◆ myOvertakeDeltaSpeedFactor

double MSLCM_SL2015::myOvertakeDeltaSpeedFactor
protected

Definition at line 451 of file MSLCM_SL2015.h.

Referenced by getParameter(), informLeader(), MSLCM_SL2015(), 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 760 of file MSAbstractLaneChangeModel.h.

Referenced by setShadowPartialOccupator().

◆ myPreviousAngleOffset

double MSAbstractLaneChangeModel::myPreviousAngleOffset
protectedinherited

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

Definition at line 712 of file MSAbstractLaneChangeModel.h.

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

◆ myPreviousManeuverDist

double MSAbstractLaneChangeModel::myPreviousManeuverDist
privateinherited

Maneuver distance from the previous simulation step.

Definition at line 843 of file MSAbstractLaneChangeModel.h.

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

◆ myPreviousState

int MSAbstractLaneChangeModel::myPreviousState
protectedinherited

lane changing state from the previous simulation step

Definition at line 683 of file MSAbstractLaneChangeModel.h.

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

◆ myPreviousState2

int MSAbstractLaneChangeModel::myPreviousState2
protectedinherited

lane changing state from step before the previous simulation step

Definition at line 685 of file MSAbstractLaneChangeModel.h.

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

◆ myPushy

double MSLCM_SL2015::myPushy
protected

◆ myRightFollowers

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

◆ myRightLeaders

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

◆ myRoundaboutBonus

double MSLCM_SL2015::myRoundaboutBonus
protected

Definition at line 445 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ mySafeLatDistLeft

double MSLCM_SL2015::mySafeLatDistLeft
protected

◆ mySafeLatDistRight

double MSLCM_SL2015::mySafeLatDistRight
protected

the lateral distance the vehicle can safely move in the currently considered direction

Definition at line 406 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), checkBlocking(), computeSpeedLat(), emergencySpeedLat(), keepLatGap(), MSLCM_SL2015(), prepareStep(), and updateSafeLatDist().

◆ mySavedStateCenter

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

Definition at line 688 of file MSAbstractLaneChangeModel.h.

Referenced by getSavedState(), and saveLCState().

◆ mySavedStateLeft

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

Definition at line 689 of file MSAbstractLaneChangeModel.h.

Referenced by getSavedState(), isStrategicBlocked(), and saveLCState().

◆ mySavedStateRight

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

Definition at line 687 of file MSAbstractLaneChangeModel.h.

Referenced by getSavedState(), isStrategicBlocked(), and saveLCState().

◆ myShadowFurtherLanes

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

◆ myShadowFurtherLanesPosLat

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

Definition at line 731 of file MSAbstractLaneChangeModel.h.

Referenced by getShadowFurtherLanesPosLat(), and updateShadowLane().

◆ myShadowLane

MSLane* MSAbstractLaneChangeModel::myShadowLane
protectedinherited

A lane that is partially occupied by the front of the vehicle but that is not the primary lane.

Definition at line 727 of file MSAbstractLaneChangeModel.h.

Referenced by cleanupShadowLane(), determineTargetLane(), getShadowDirection(), getShadowLane(), MSAbstractLaneChangeModel(), and updateShadowLane().

◆ mySigma

◆ mySigmaState

double MSLCM_SL2015::mySigmaState
protected

◆ mySpeedGainLookahead

double MSLCM_SL2015::mySpeedGainLookahead
protected

◆ mySpeedGainParam

double MSLCM_SL2015::mySpeedGainParam
protected

Definition at line 417 of file MSLCM_SL2015.h.

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

◆ mySpeedGainProbabilityLeft

double MSLCM_SL2015::mySpeedGainProbabilityLeft
protected

a value for tracking the probability that a change to the left is beneficial

Definition at line 379 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), changed(), decideDirection(), getParameter(), MSLCM_SL2015(), prepareStep(), resetState(), setParameter(), and wantsKeepRight().

◆ mySpeedGainProbabilityRight

double MSLCM_SL2015::mySpeedGainProbabilityRight
protected

a value for tracking the probability that a change to the right is beneficial

Definition at line 377 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), changed(), checkStrategicChange(), decideDirection(), getParameter(), MSLCM_SL2015(), prepareStep(), resetState(), and setParameter().

◆ mySpeedGainRemainTime

double MSLCM_SL2015::mySpeedGainRemainTime
protected

Definition at line 443 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), getParameter(), MSLCM_SL2015(), and setParameter().

◆ mySpeedGainRight

double MSLCM_SL2015::mySpeedGainRight
protected

Definition at line 437 of file MSLCM_SL2015.h.

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

◆ mySpeedLat

double MSAbstractLaneChangeModel::mySpeedLat
protectedinherited

◆ mySpeedLossProbThreshold

double MSLCM_SL2015::mySpeedLossProbThreshold
protected

Definition at line 461 of file MSLCM_SL2015.h.

Referenced by _wantsChangeSublane(), and initDerivedParameters().

◆ myStrategicLookahead

double MSAbstractLaneChangeModel::myStrategicLookahead
protectedinherited

◆ myStrategicParam

double MSLCM_SL2015::myStrategicParam
protected

◆ mySublaneParam

double MSLCM_SL2015::mySublaneParam
protected

◆ 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 741 of file MSAbstractLaneChangeModel.h.

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

◆ myTimeToImpatience

double MSLCM_SL2015::myTimeToImpatience
protected

Definition at line 429 of file MSLCM_SL2015.h.

Referenced by getParameter(), MSLCM_SL2015(), setOwnState(), and setParameter().

◆ myTurnAlignmentDist

double MSLCM_SL2015::myTurnAlignmentDist
protected

◆ myVehicle

MSVehicle& MSAbstractLaneChangeModel::myVehicle
protectedinherited

The vehicle this lane-changer belongs to.

Definition at line 678 of file MSAbstractLaneChangeModel.h.

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

◆ NO_NEIGHBOR

const double MSAbstractLaneChangeModel::NO_NEIGHBOR
staticinherited

◆ UNDEFINED_LOOKAHEAD

const double MSAbstractLaneChangeModel::UNDEFINED_LOOKAHEAD
staticinherited

Definition at line 652 of file MSAbstractLaneChangeModel.h.

Referenced by MSAbstractLaneChangeModel().


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