SUMO - Simulation of Urban MObility
MEVehicle Class Reference

A vehicle from the mesoscopic point of view. More...

#include <MEVehicle.h>

Inheritance diagram for MEVehicle:
Inheritance graph
Collaboration diagram for MEVehicle:
Collaboration graph

Public Member Functions

virtual void activateReminders (const MSMoveReminder::Notification reason, const MSLane *enteredLane=0)
 "Activates" all current move reminder More...
 
virtual void addContainer (MSTransportable *container)
 Adds a container to this vehicle. More...
 
virtual void addPerson (MSTransportable *person)
 Adds a person to this vehicle. More...
 
void addReminder (MSMoveReminder *rem)
 Adds a MoveReminder dynamically. More...
 
bool addStop (const SUMOVehicleParameter::Stop &stopPar, std::string &errorMsg, SUMOTime untilOffset=0, bool collision=false, MSRouteIterator *searchStart=0)
 Adds a stop. More...
 
void addStops (const bool ignoreStopErrors)
 Adds stops to the built vehicle. More...
 
void createDevice (const std::string &deviceName)
 create device of the given type More...
 
double estimateLeaveSpeed (const MSLink *link) const
 Returns the vehicle's estimated speed after driving accross the link. More...
 
virtual double getAcceleration () const
 Returns the vehicle's acceleration. More...
 
SUMOTime getAccumulatedWaitingTime () const
 Returns the duration for which the vehicle was blocked. More...
 
double getAngle () const
 Returns the vehicle's direction in degrees. More...
 
virtual double getArrivalPos () const
 Returns this vehicle's desired arrivalPos for its current route (may change on reroute) More...
 
double getAverageSpeed () const
 Returns the vehicle's estimated average speed on the segment assuming no further delays. More...
 
double getBackPositionOnLane (const MSLane *lane) const
 Get the vehicle's position relative to the given lane. More...
 
SUMOTime getBlockTime () const
 Returns the time at which the vehicle was blocked. More...
 
double getBlockTimeSeconds () const
 Returns the time at which the vehicle was blocked on the current segment. More...
 
double getChosenSpeedFactor () const
 Returns the precomputed factor by which the driver wants to be faster than the speed limit. More...
 
double getConservativeSpeed (SUMOTime &earliestArrival) const
 Returns the vehicle's estimated speed taking into account delays. More...
 
double getCurrentLinkPenaltySeconds () const
 Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty. More...
 
const MSRouteIteratorgetCurrentRouteEdge () const
 Returns an iterator pointing to the current edge in this vehicles route. More...
 
SUMOTime getDepartDelay () const
 Returns the depart delay. More...
 
double getDepartPos () const
 Returns this vehicle's real departure position. More...
 
SUMOTime getDeparture () const
 Returns this vehicle's real departure time. More...
 
MSDevicegetDevice (const std::type_info &type) const
 Returns a device of the given type if it exists or 0. More...
 
std::string getDeviceParameter (const std::string &deviceName, const std::string &key) const
 try to retrieve the given parameter from any of the vehicles devices, raise InvalidArgument if no device parameter by that name exists More...
 
const std::vector< MSDevice * > & getDevices () const
 Returns this vehicle's devices. More...
 
const MSEdgegetEdge () const
 Returns the edge the vehicle is currently at. More...
 
SUMOTime getEventTime () const
 Returns the (planned) time at which the vehicle leaves his current cell. More...
 
double getEventTimeSeconds () const
 Returns the earliest leave time for the current segment. More...
 
const std::string & getID () const
 Returns the name of the vehicle. More...
 
double getImpatience () const
 Returns this vehicles impatience. More...
 
MSLanegetLane () const
 Returns the lane the vehicle is on. More...
 
SUMOTime getLastEntryTime () const
 Returns the time the vehicle entered the current segment. More...
 
double getLastEntryTimeSeconds () const
 Returns the entry time for the current segment. More...
 
virtual double getLateralPositionOnLane () const
 Get the vehicle's lateral position on the lane. More...
 
double getLength () const
 Returns the vehicle's length. More...
 
double getMaxSpeed () const
 Returns the maximum speed. More...
 
MSParkingAreagetNextParkingArea ()
 get the current parking area stop More...
 
int getNumberReroutes () const
 Returns the number of new routes this vehicle got. More...
 
const SUMOVehicleParametergetParameter () const
 Returns the vehicle's parameter (including departure definition) More...
 
Position getPosition (const double offset=0) const
 Return current position (x/y, cartesian) More...
 
double getPositionOnLane () const
 Get the vehicle's position along the lane. More...
 
double getPreviousSpeed () const
 Returns the vehicle's previous speed. More...
 
int getQueIndex () const
 Returns the index of the que the vehicle is in. More...
 
virtual const MSEdgegetRerouteOrigin () const
 Returns the starting point for reroutes (usually the current edge) More...
 
const MSRoutegetRoute () const
 Returns the current route. More...
 
MESegmentgetSegment () const
 Returns the current segment the vehicle is on. More...
 
MSVehicleTypegetSingularType ()
 Replaces the current vehicle type with a new one used by this vehicle only. More...
 
double getSlope () const
 Returns the slope of the road at vehicle's position. More...
 
double getSpeed () const
 Returns the vehicle's estimated speed assuming no delays. More...
 
const ConstMSEdgeVector getStopEdges () const
 Returns the list of still pending stop edges. More...
 
SUMOTime getStoptime (const MESegment *const seg) const
 Returns how long to stop at the given segment. More...
 
SUMOVehicleClass getVClass () const
 Returns the vehicle's access class. More...
 
const MSVehicleTypegetVehicleType () const
 Returns the vehicle's type definition. More...
 
double getWaitingSeconds () const
 Returns the number of seconds waited (speed was lesser than 0.1m/s) More...
 
SUMOTime getWaitingTime () const
 Returns the duration for which the vehicle was blocked. More...
 
double getWidth () const
 Returns the vehicle's width. More...
 
bool hasArrived () const
 Returns whether this vehicle has already arived (reached the arrivalPosition on its final edge) More...
 
bool hasDeparted () const
 Returns whether this vehicle has already departed. More...
 
bool hasDevice (const std::string &deviceName) const
 check whether the vehicle is equiped with a device of the given type More...
 
bool hasValidRoute (std::string &msg, const MSRoute *route=0) const
 Validates the current or given route. More...
 
virtual bool isFrontOnLane (const MSLane *) const
 Returns the information whether the front of the vehhicle is on the given lane. More...
 
bool isOnRoad () const
 Returns the information whether the vehicle is on a road (is simulated) More...
 
bool isParking () const
 Returns whether the vehicle is parking. More...
 
virtual bool isRemoteControlled () const
 Returns the information whether the vehicle is fully controlled via TraCI. More...
 
virtual bool isSelected () const
 whether this vehicle is selected in the GUI More...
 
bool isStopped () const
 Returns whether the vehicle is at a stop. More...
 
bool isStoppedInRange (double pos) const
 return whether the given position is within range of the current stop More...
 
bool isStoppedTriggered () const
 Returns whether the vehicle is on a triggered stop. More...
 
bool mayProceed () const
 Returns whether the vehicle is allowed to pass the next junction. More...
 
 MEVehicle (SUMOVehicleParameter *pars, const MSRoute *route, MSVehicleType *type, const double speedFactor)
 Constructor. More...
 
bool moveRoutePointer ()
 Update when the vehicle enters a new edge in the move step. More...
 
void onDepart ()
 Called when the vehicle is inserted into the network. More...
 
void removeReminder (MSMoveReminder *rem)
 Removes a MoveReminder dynamically. More...
 
bool replaceParkingArea (MSParkingArea *, std::string &)
 replace the current parking area stop with a new stop with merge duration More...
 
bool replaceRoute (const MSRoute *route, bool onInit=false, int offset=0, bool addStops=true, bool removeStops=true)
 Replaces the current route by the given one. More...
 
bool replaceRouteEdges (ConstMSEdgeVector &edges, bool onInit=false, bool check=false, bool removeStops=true)
 Replaces the current route by the given edges. More...
 
void replaceVehicleType (MSVehicleType *type)
 Replaces the current vehicle type by the one given. More...
 
void reroute (SUMOTime t, SUMOAbstractRouter< MSEdge, SUMOVehicle > &router, const bool onInit=false, const bool withTaz=false)
 Performs a rerouting using the given router. More...
 
virtual void setArrivalPos (double arrivalPos)
 Sets this vehicle's desired arrivalPos for its current route. More...
 
void setBlockTime (const SUMOTime t)
 Sets the time at which the vehicle was blocked. More...
 
void setChosenSpeedFactor (const double factor)
 Returns the precomputed factor by which the driver wants to be faster than the speed limit. More...
 
void setDeviceParameter (const std::string &deviceName, const std::string &key, const std::string &value)
 try to set the given parameter from any of the vehicles devices, raise InvalidArgument if no device parameter by that name exists More...
 
void setEventTime (SUMOTime t, bool hasDelay=true)
 Sets the (planned) time at which the vehicle leaves his current cell. More...
 
void setLastEntryTime (SUMOTime t)
 Sets the entry time for the current segment. More...
 
virtual void setSegment (MESegment *s, int idx=0)
 Sets the current segment the vehicle is at together with its que. More...
 
const MSEdgesuccEdge (int nSuccs) const
 Returns the nSuccs'th successor of edge the vehicle is currently at. More...
 
void updateDetectorForWriting (MSMoveReminder *rem, SUMOTime currentTime, SUMOTime exitTime)
 Updates a single vehicle detector if present. More...
 
void updateDetectors (SUMOTime currentTime, const bool isLeave, const MSMoveReminder::Notification reason=MSMoveReminder::NOTIFICATION_JUNCTION)
 Updates all vehicle detectors. More...
 
state io
void saveState (OutputDevice &out)
 Saves the states of a vehicle. More...
 
void loadState (const SUMOSAXAttributes &attrs, const SUMOTime offset)
 Loads the state of this vehicle from the given description. More...
 

Protected Member Functions

void calculateArrivalParams ()
 (Re-)Calculates the arrival position and lane from the vehicle parameters More...
 

Protected Attributes

int myArrivalLane
 The destination lane where the vehicle stops. More...
 
double myArrivalPos
 The position on the destination lane where the vehicle stops. More...
 
SUMOTime myBlockTime
 The time at which the vehicle was blocked on its current segment. More...
 
double myChosenSpeedFactor
 A precomputed factor by which the driver wants to be faster than the speed limit. More...
 
MSRouteIterator myCurrEdge
 Iterator to current route-edge. More...
 
double myDepartPos
 The real depart position. More...
 
SUMOTime myDeparture
 The real departure time. More...
 
std::vector< MSDevice * > myDevices
 The devices this vehicle has. More...
 
SUMOTime myEventTime
 The (planned) time of leaving the segment (cell) More...
 
SUMOTime myLastEntryTime
 The time the vehicle entered its current segment. More...
 
int myNumberReroutes
 The number of reroutings. More...
 
const SUMOVehicleParametermyParameter
 This vehicle's parameter. More...
 
int myQueIndex
 Index of the que the vehicle is in (important for multiqueue extension) More...
 
const MSRoutemyRoute
 This vehicle's route. More...
 
MESegmentmySegment
 The segment the vehicle is at. More...
 
std::map< const MESegment *const, SUMOTimemyStops
 where to stop More...
 
MSVehicleTypemyType
 This vehicle's type. More...
 

Static Protected Attributes

static const SUMOTime NOT_YET_DEPARTED = SUMOTime_MAX
 

Move reminder structures

MoveReminderCont myMoveReminders
 Currently relevant move reminders. More...
 
typedef std::vector< std::pair< MSMoveReminder *, double > > MoveReminderCont
 Definition of a move reminder container. More...
 

Detailed Description

A vehicle from the mesoscopic point of view.

Definition at line 51 of file MEVehicle.h.

Member Typedef Documentation

◆ MoveReminderCont

typedef std::vector< std::pair<MSMoveReminder*, double> > MSBaseVehicle::MoveReminderCont
protectedinherited

Definition of a move reminder container.

Definition at line 468 of file MSBaseVehicle.h.

Constructor & Destructor Documentation

◆ MEVehicle()

MEVehicle::MEVehicle ( SUMOVehicleParameter pars,
const MSRoute route,
MSVehicleType type,
const double  speedFactor 
)

Constructor.

Parameters
[in]parsThe vehicle description
[in]routeThe vehicle's route
[in]typeThe vehicle's type
[in]speedFactorThe factor for driven lane's speed limits
Exceptions
ProcessErrorIf a value is wrong

Definition at line 53 of file MEVehicle.cpp.

References DEPART_SPEED_GIVEN, SUMOVehicleParameter::departSpeed, SUMOVehicleParameter::departSpeedProcedure, MSVehicleType::getID(), MSVehicleType::getMaxSpeed(), MSVehicleType::getVehicleClass(), and SUMOVehicleParameter::id.

Member Function Documentation

◆ activateReminders()

void MSBaseVehicle::activateReminders ( const MSMoveReminder::Notification  reason,
const MSLane enteredLane = 0 
)
virtualinherited

"Activates" all current move reminder

For all move reminder stored in "myMoveReminders", their method "MSMoveReminder::notifyEnter" is called.

Parameters
[in]reasonThe reason for changing the reminders' states
[in]enteredLaneThe lane, which is entered (if applicable)
See also
MSMoveReminder
MSMoveReminder::notifyEnter
MSMoveReminder::Notification

Reimplemented in MSVehicle.

Definition at line 376 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myMoveReminders.

Referenced by MSBaseVehicle::getDevices(), MESegment::receive(), and MELoop::teleportVehicle().

◆ addContainer()

void MSBaseVehicle::addContainer ( MSTransportable container)
virtualinherited

Adds a container to this vehicle.

The default implementation does nothing since containers are not supported by default

Parameters
[in]containerThe container to add

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 316 of file MSBaseVehicle.cpp.

References MSBaseVehicle::getID(), and MSTransportable::getID().

Referenced by MSBaseVehicle::getDevices().

◆ addPerson()

void MSBaseVehicle::addPerson ( MSTransportable person)
virtualinherited

Adds a person to this vehicle.

The default implementation does nothing since persons are not supported by default

Parameters
[in]personThe person to add

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 311 of file MSBaseVehicle.cpp.

References MSBaseVehicle::getID(), and MSTransportable::getID().

Referenced by MSBaseVehicle::getDevices().

◆ addReminder()

void MSBaseVehicle::addReminder ( MSMoveReminder rem)
inherited

◆ addStop()

bool MEVehicle::addStop ( const SUMOVehicleParameter::Stop stopPar,
std::string &  errorMsg,
SUMOTime  untilOffset = 0,
bool  collision = false,
MSRouteIterator searchStart = 0 
)
virtual

Adds a stop.

The stop is put into the sorted list.

Parameters
[in]stopThe stop to add
Returns
Whether the stop could be added

Implements SUMOVehicle.

Definition at line 223 of file MEVehicle.cpp.

References MSEdge::dictionary(), SUMOVehicleParameter::Stop::duration, SUMOVehicleParameter::Stop::endPos, MELoop::getSegmentForEdge(), MSGlobals::gMesoNet, SUMOVehicleParameter::Stop::lane, and myStops.

Referenced by getLane().

◆ addStops()

void MSBaseVehicle::addStops ( const bool  ignoreStopErrors)
inherited

Adds stops to the built vehicle.

This code needs to be separated from the MSBaseVehicle constructor since it is not allowed to call virtual functions from a constructor

Parameters
[in]ignoreStopErrorswhether invalid stops trigger a warning only

Definition at line 473 of file MSBaseVehicle.cpp.

References SUMOVehicle::addStop(), SUMOVehicleParameter::depart, MSRoute::getStops(), MSBaseVehicle::myParameter, MSBaseVehicle::myRoute, SUMOVehicleParameter::repetitionOffset, SUMOVehicleParameter::repetitionsDone, SUMOVehicleParameter::stops, and WRITE_WARNING.

Referenced by MEVehicleControl::buildVehicle(), GUIMEVehicleControl::buildVehicle(), GUIVehicleControl::buildVehicle(), MSVehicleControl::buildVehicle(), getBlockTimeSeconds(), MSVehicle::replaceRoute(), and MSBaseVehicle::setChosenSpeedFactor().

◆ calculateArrivalParams()

◆ createDevice()

◆ estimateLeaveSpeed()

double MEVehicle::estimateLeaveSpeed ( const MSLink link) const

Returns the vehicle's estimated speed after driving accross the link.

See also
MSVehicle.cpp::estimateLeaveSpeed

Definition at line 125 of file MEVehicle.cpp.

References MSVehicleType::getCarFollowModel(), MSLink::getLength(), MSCFModel::getMaxAccel(), getSpeed(), MSLane::getVehicleMaxSpeed(), MSBaseVehicle::getVehicleType(), MSLink::getViaLaneOrLane(), and MIN2().

Referenced by getLane(), and MESegment::isOpen().

◆ getAcceleration()

double MSBaseVehicle::getAcceleration ( ) const
virtualinherited

Returns the vehicle's acceleration.

This default implementation returns always 0.

Returns
The acceleration

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 280 of file MSBaseVehicle.cpp.

Referenced by MSBaseVehicle::getCurrentRouteEdge().

◆ getAccumulatedWaitingTime()

SUMOTime MEVehicle::getAccumulatedWaitingTime ( ) const
inlinevirtual

Returns the duration for which the vehicle was blocked.

Implements SUMOVehicle.

Definition at line 281 of file MEVehicle.h.

References getWaitingTime().

◆ getAngle()

double MEVehicle::getAngle ( ) const
virtual

Returns the vehicle's direction in degrees.

Returns
The vehicle's current angle

Implements SUMOVehicle.

Definition at line 88 of file MEVehicle.cpp.

References MSBaseVehicle::getEdge(), MSEdge::getLanes(), getPositionOnLane(), MSLane::getShape(), MSLane::interpolateLanePosToGeometryPos(), and PositionVector::rotationAtOffset().

Referenced by GUIMEVehicle::getAngle().

◆ getArrivalPos()

virtual double MSBaseVehicle::getArrivalPos ( ) const
inlinevirtualinherited

Returns this vehicle's desired arrivalPos for its current route (may change on reroute)

Returns
This vehicle's real arrivalPos

Implements SUMOVehicle.

Definition at line 269 of file MSBaseVehicle.h.

References MSBaseVehicle::myArrivalPos.

Referenced by MSLCM_SL2015::_wantsChangeSublane().

◆ getAverageSpeed()

double MEVehicle::getAverageSpeed ( ) const

Returns the vehicle's estimated average speed on the segment assuming no further delays.

Returns
The vehicle's estimated average speed
Note
This is only an upper bound. The speed will be lower if the preceeding vehicle is delayed

Definition at line 119 of file MEVehicle.cpp.

References MESegment::getLength(), myEventTime, myLastEntryTime, mySegment, and STEPS2TIME.

Referenced by getLane(), and getSpeed().

◆ getBackPositionOnLane()

double MEVehicle::getBackPositionOnLane ( const MSLane lane) const
virtual

Get the vehicle's position relative to the given lane.

Returns
The back position of the vehicle (in m from the given lane's begin)

Implements SUMOVehicle.

Definition at line 74 of file MEVehicle.cpp.

References MSVehicleType::getLength(), getPositionOnLane(), and MSBaseVehicle::getVehicleType().

◆ getBlockTime()

SUMOTime MEVehicle::getBlockTime ( ) const
inline

Returns the time at which the vehicle was blocked.

Returns
The blocking time

Definition at line 270 of file MEVehicle.h.

References myBlockTime.

Referenced by MELoop::checkCar(), and getBlockTimeSeconds().

◆ getBlockTimeSeconds()

double MEVehicle::getBlockTimeSeconds ( ) const
inline

◆ getChosenSpeedFactor()

double MSBaseVehicle::getChosenSpeedFactor ( ) const
inlinevirtualinherited

Returns the precomputed factor by which the driver wants to be faster than the speed limit.

Returns
Speed limit factor

Implements SUMOVehicle.

Definition at line 377 of file MSBaseVehicle.h.

References MSBaseVehicle::myChosenSpeedFactor.

Referenced by GUIMEVehicle::getParameterWindow(), GUIVehicle::getParameterWindow(), and libsumo::Vehicle::getSpeedFactor().

◆ getConservativeSpeed()

double MEVehicle::getConservativeSpeed ( SUMOTime earliestArrival) const

Returns the vehicle's estimated speed taking into account delays.

Returns
The vehicle's estimated speed
Parameters
[in,out]earliestArrivalA lower bound on leaveTime, modified to contain new lower bound on leave Time
Note
This is only an upper bound. The speed may be even lower if there are further delays downstream

Definition at line 134 of file MEVehicle.cpp.

References DELTA_T, MESegment::getLength(), MAX2(), myEventTime, myLastEntryTime, mySegment, and STEPS2TIME.

Referenced by getLane().

◆ getCurrentLinkPenaltySeconds()

double MEVehicle::getCurrentLinkPenaltySeconds ( ) const

Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty.

Definition at line 278 of file MEVehicle.cpp.

References MESegment::getLinkPenalty(), mySegment, and STEPS2TIME.

Referenced by getBlockTimeSeconds(), and GUIMEVehicle::getParameterWindow().

◆ getCurrentRouteEdge()

const MSRouteIterator& MSBaseVehicle::getCurrentRouteEdge ( ) const
inlinevirtualinherited

Returns an iterator pointing to the current edge in this vehicles route.

Returns
The current route pointer

Implements SUMOVehicle.

Definition at line 192 of file MSBaseVehicle.h.

References MSBaseVehicle::getAcceleration(), MSBaseVehicle::getSlope(), MSBaseVehicle::myCurrEdge, MSBaseVehicle::onDepart(), MSBaseVehicle::replaceRouteEdges(), and MSBaseVehicle::reroute().

Referenced by MSDevice_SSM::findSurroundingVehicles(), libsumo::Vehicle::getDistance(), and libsumo::Vehicle::moveToXY().

◆ getDepartDelay()

SUMOTime MSBaseVehicle::getDepartDelay ( ) const
inlinevirtualinherited

◆ getDepartPos()

double MSBaseVehicle::getDepartPos ( ) const
inlinevirtualinherited

Returns this vehicle's real departure position.

Returns
This vehicle's real departure position

Implements SUMOVehicle.

Definition at line 261 of file MSBaseVehicle.h.

References MSBaseVehicle::myDepartPos.

Referenced by libsumo::Vehicle::getDistance().

◆ getDeparture()

SUMOTime MSBaseVehicle::getDeparture ( ) const
inlinevirtualinherited

Returns this vehicle's real departure time.

Returns
This vehicle's real departure time

Implements SUMOVehicle.

Definition at line 248 of file MSBaseVehicle.h.

References MSBaseVehicle::myDeparture.

Referenced by MSBaseVehicle::getDepartDelay(), and MSVehicle::Influencer::postProcessRemoteControl().

◆ getDevice()

MSDevice * MSBaseVehicle::getDevice ( const std::type_info &  type) const
virtualinherited

Returns a device of the given type if it exists or 0.

Implements SUMOVehicle.

Definition at line 447 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myDevices.

Referenced by MSBaseVehicle::createDevice(), GUIBaseVehicle::drawOnPos(), MSVehicle::resumeFromStopping(), MSBaseVehicle::setChosenSpeedFactor(), and MSBatteryExport::write().

◆ getDeviceParameter()

std::string MSBaseVehicle::getDeviceParameter ( const std::string &  deviceName,
const std::string &  key 
) const
inherited

try to retrieve the given parameter from any of the vehicles devices, raise InvalidArgument if no device parameter by that name exists

Definition at line 527 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myDevices.

Referenced by libsumo::Vehicle::getParameter().

◆ getDevices()

const std::vector<MSDevice*>& MSBaseVehicle::getDevices ( ) const
inlinevirtualinherited

◆ getEdge()

◆ getEventTime()

SUMOTime MEVehicle::getEventTime ( ) const
inline

Returns the (planned) time at which the vehicle leaves his current cell.

Returns
The time the vehicle thinks he leaves his cell at

Definition at line 211 of file MEVehicle.h.

References myEventTime.

Referenced by MELoop::addLeaderCar(), MELoop::checkCar(), getEventTimeSeconds(), MESegment::isOpen(), MESegment::receive(), MELoop::removeLeaderCar(), MESegment::send(), MELoop::setApproaching(), MESegment::setSpeedForQueue(), MELoop::teleportVehicle(), and updateDetectors().

◆ getEventTimeSeconds()

double MEVehicle::getEventTimeSeconds ( ) const
inline

Returns the earliest leave time for the current segment.

Definition at line 298 of file MEVehicle.h.

References getEventTime(), and STEPS2TIME.

Referenced by GUIMEVehicle::getParameterWindow().

◆ getID()

const std::string & MSBaseVehicle::getID ( ) const
virtualinherited

Returns the name of the vehicle.

Implements SUMOVehicle.

Definition at line 121 of file MSBaseVehicle.cpp.

References SUMOVehicleParameter::id, and MSBaseVehicle::myParameter.

Referenced by MSLCM_LC2013::_patchSpeed(), MSLCM_SL2015::_patchSpeed(), MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), MSLaneChangerSublane::abortLCManeuver(), MSVehicle::adaptToLeader(), MSVehicle::adaptToLeaders(), MSVehicleTransfer::add(), MSBaseVehicle::addContainer(), MSPModel_Striping::addCrossingVehs(), MSLCM_SL2015::addLCSpeedAdvice(), MSBaseVehicle::addPerson(), MSVehicle::addTraciStopAtStoppingPlace(), MSBaseVehicle::calculateArrivalParams(), MSLaneChangerSublane::change(), MSLaneChanger::change(), MSLCM_SL2015::changed(), MSLaneChanger::changeOpposite(), MELoop::changeSegment(), libsumo::Vehicle::changeTarget(), MSLaneChanger::checkChange(), MSLaneChangerSublane::checkChangeSublane(), MSLane::checkFailure(), MSLane::checkForPedestrians(), MSVehicleTransfer::checkInsertions(), MSVehicle::checkLinkLeader(), MSVehicle::checkRewindLinkLanes(), MSLCM_SL2015::checkStrategicChange(), MSLaneChanger::checkTraCICommands(), MSAbstractLaneChangeModel::checkTraCICommands(), MSDevice_SSM::classifyEncounter(), MSLCM_SL2015::commitManoeuvre(), MSVehicle::computeAngle(), MSLCM_SL2015::computeSpeedLat(), MSDevice_SSM::computeSSMs(), MSLaneChanger::continueChange(), MSLaneChangerSublane::continueChangeSublane(), MSLCM_SL2015::decideDirection(), MSLane::detectCollisionBetween(), MSLane::detectCollisions(), MSLane::detectPedestrianJunctionCollision(), MSDevice_SSM::Encounter::Encounter(), MSCalibrator::execute(), MSVehicle::executeMove(), MSLane::executeMovements(), MSLaneChanger::findCandidate(), MSDevice_SSM::findFoeConflictLane(), MSDevice_SSM::findSurroundingVehicles(), MSVehicle::getBackPosition(), MSVehicle::getBackPositionOnLane(), MSVehicle::getCenterOnEdge(), MSLane::getFirstVehicleInformation(), MSLane::getFollower(), MSLane::getFollowersOnConsecutive(), MSLane::getLastVehicleInformation(), MSVehicle::getLatOffset(), MSLane::getLeader(), MSLink::getLeaderInfo(), MSLane::getLeaderOnConsecutive(), MSLaneChangerSublane::getLeaders(), MSLane::getLeadersOnConsecutive(), MSLane::getOppositeFollower(), MSLane::getOppositeLeader(), GUIMEVehicle::getParameterWindow(), GUIVehicle::getParameterWindow(), MSLane::getPartialBehind(), MSLaneChanger::getRealFollower(), MSLaneChanger::getRealLeader(), MSAbstractLaneChangeModel::getShadowLane(), MSBaseVehicle::getSingularType(), MSDevice_SSM::getUpstreamVehicles(), MSLane::handleCollisionBetween(), MSVehicle::ignoreRed(), MSLCM_LC2013::inform(), MSLCM_SL2015::inform(), MSLCM_LC2013::informFollower(), MSLCM_SL2015::informFollower(), MSLCM_LC2013::informLeader(), MSLCM_SL2015::informLeader(), MESegment::initialise(), MSPedestrianPushButton::isActiveForEdge(), MSLane::isInsertionSuccess(), MSAbstractLaneChangeModel::laneChangeOutput(), MSVehicle::lateralDistanceToLane(), MSVehicle::leaveLane(), MSCFModel_Daniel1::moveHelper(), MSCFModel_KraussOrig1::moveHelper(), MSCFModel_Krauss::moveHelper(), MSCFModel_SmartSK::moveHelper(), MSPModel_Striping::moveInDirectionOnLane(), libsumo::Vehicle::moveToXY(), MSLCM_LC2013::MSLCM_LC2013(), MSCalibrator::VehicleRemover::notifyEnter(), MSVehicle::onRemovalFromNet(), MSLaneChangerSublane::outputLCStarted(), MSLCM_LC2013::patchSpeed(), MSLCM_SL2015::patchSpeed(), MSVehicle::planMove(), MSVehicle::planMoveInternal(), MSLCM_SL2015::prepareStep(), MSVehicle::processLaneAdvances(), MSVehicle::processLinkAproaches(), MSVehicle::processNextStop(), MSVehicle::removePassedDriveItems(), MSBaseVehicle::replaceRouteEdges(), MSBaseVehicle::reroute(), MSLane::resetManeuverReservation(), MSLane::resetPartialOccupation(), libsumo::Vehicle::resume(), MSLCM_SL2015::saveBlockerLength(), MSLCM_LC2013::saveBlockerLength(), MSBaseVehicle::saveState(), MSCalibrator::scheduleRemoval(), GUIVehicle::selectBlockingFoes(), MSVehicle::setAngle(), MSAbstractLaneChangeModel::setManeuverDist(), MSLane::setManeuverReservation(), MSLCM_SL2015::setOwnState(), MSLane::setPartialOccupation(), libsumo::Helper::setRemoteControlled(), libsumo::Vehicle::setRoute(), libsumo::Vehicle::setRouteID(), MSLCM_LC2013::slowDownForBlocked(), MSLCM_SL2015::slowDownForBlocked(), MSLaneChangerSublane::startChangeSublane(), MELoop::teleportVehicle(), METriggeredCalibrator::tryEmit(), MSVehicle::updateBestLanes(), MSVehicle::updateDriveItems(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), MSLCM_SL2015::updateGaps(), MSAbstractLaneChangeModel::updateShadowLane(), MSVehicle::updateState(), MSAbstractLaneChangeModel::updateTargetLane(), MSLCM_LC2013::wantsChange(), MSLCM_SL2015::wantsChange(), MSLCM_SL2015::wantsChangeSublane(), MSBatteryExport::write(), and MSXMLRawOut::writeVehicle().

◆ getImpatience()

◆ getLane()

MSLane* MEVehicle::getLane ( ) const
inlinevirtual

◆ getLastEntryTime()

SUMOTime MEVehicle::getLastEntryTime ( ) const
inline

Returns the time the vehicle entered the current segment.

Returns
The entry time

Definition at line 253 of file MEVehicle.h.

References myLastEntryTime.

Referenced by getLastEntryTimeSeconds(), MESegment::newArrival(), updateDetectorForWriting(), and updateDetectors().

◆ getLastEntryTimeSeconds()

double MEVehicle::getLastEntryTimeSeconds ( ) const
inline

Returns the entry time for the current segment.

Definition at line 303 of file MEVehicle.h.

References getLastEntryTime(), and STEPS2TIME.

Referenced by GUIMEVehicle::getParameterWindow().

◆ getLateralPositionOnLane()

virtual double MSBaseVehicle::getLateralPositionOnLane ( ) const
inlinevirtualinherited

Get the vehicle's lateral position on the lane.

Returns
The lateral position of the vehicle (in m relative to the centerline of the lane)

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 175 of file MSBaseVehicle.h.

◆ getLength()

◆ getMaxSpeed()

◆ getNextParkingArea()

MSParkingArea* MEVehicle::getNextParkingArea ( )
inlinevirtual

get the current parking area stop

Implements SUMOVehicle.

Definition at line 192 of file MEVehicle.h.

◆ getNumberReroutes()

int MSBaseVehicle::getNumberReroutes ( ) const
inlinevirtualinherited

Returns the number of new routes this vehicle got.

Returns
the number of new routes this vehicle got

Implements SUMOVehicle.

Definition at line 291 of file MSBaseVehicle.h.

References MSBaseVehicle::getImpatience(), and MSBaseVehicle::myNumberReroutes.

Referenced by GUIBaseVehicle::drawGLAdditional(), GUIMEVehicle::getColorValue(), GUIVehicle::getColorValue(), and MSBaseVehicle::replaceRouteEdges().

◆ getParameter()

◆ getPosition()

Position MEVehicle::getPosition ( const double  offset = 0) const
virtual

Return current position (x/y, cartesian)

If the vehicle's myLane is 0, Position::INVALID.

Parameters
[in]offsetoptional offset in longitudinal direction
Returns
The current position (in cartesian coordinates)
See also
myLane

Implements SUMOVehicle.

Definition at line 102 of file MEVehicle.cpp.

References MSLane::geometryPositionAtOffset(), MSBaseVehicle::getEdge(), MSEdge::getLanes(), and getPositionOnLane().

Referenced by getLane(), and GUIMEVehicle::getPosition().

◆ getPositionOnLane()

double MEVehicle::getPositionOnLane ( ) const
virtual

Get the vehicle's position along the lane.

Returns
The position of the vehicle (in m from the lane's begin)

Implements SUMOVehicle.

Definition at line 80 of file MEVehicle.cpp.

References MESegment::getIndex(), MESegment::getLength(), and mySegment.

Referenced by getAngle(), getBackPositionOnLane(), GUIMEVehicle::getParameterWindow(), getPosition(), getSlope(), and hasArrived().

◆ getPreviousSpeed()

double MSBaseVehicle::getPreviousSpeed ( ) const
virtualinherited

Returns the vehicle's previous speed.

Returns
The vehicle's speed

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 64 of file MSBaseVehicle.cpp.

◆ getQueIndex()

int MEVehicle::getQueIndex ( ) const
inline

Returns the index of the que the vehicle is in.

Returns
The que index

Definition at line 237 of file MEVehicle.h.

References myQueIndex.

Referenced by MESegment::getLink(), MESegment::removeCar(), saveState(), and MESegment::send().

◆ getRerouteOrigin()

virtual const MSEdge* MSBaseVehicle::getRerouteOrigin ( ) const
inlinevirtualinherited

Returns the starting point for reroutes (usually the current edge)

This differs from *myCurrEdge only if the vehicle is on an internal edge

Returns
The rerouting start point

Reimplemented in MSVehicle.

Definition at line 184 of file MSBaseVehicle.h.

References MSBaseVehicle::myCurrEdge.

Referenced by MSBaseVehicle::replaceRouteEdges(), and MSBaseVehicle::reroute().

◆ getRoute()

◆ getSegment()

MESegment* MEVehicle::getSegment ( ) const
inline

Returns the current segment the vehicle is on.

Returns
The segment the vehicle is on

Definition at line 229 of file MEVehicle.h.

References mySegment.

Referenced by MELoop::changeSegment(), MELoop::checkCar(), GUIMEVehicle::getColorValue(), GUIMEVehicle::getParameterWindow(), isOnRoad(), MESegment::loadState(), MELoop::setApproaching(), and MELoop::teleportVehicle().

◆ getSingularType()

◆ getSlope()

double MEVehicle::getSlope ( ) const
virtual

Returns the slope of the road at vehicle's position.

Returns
The slope

Reimplemented from MSBaseVehicle.

Definition at line 95 of file MEVehicle.cpp.

References MSBaseVehicle::getEdge(), MSEdge::getLanes(), getPositionOnLane(), MSLane::getShape(), MSLane::interpolateLanePosToGeometryPos(), and PositionVector::slopeDegreeAtOffset().

◆ getSpeed()

double MEVehicle::getSpeed ( ) const
virtual

Returns the vehicle's estimated speed assuming no delays.

Returns
The vehicle's estimated speed
Note
This is only an upper bound. The speed will be lower if the preceeding vehicle is delayed

Implements SUMOVehicle.

Definition at line 109 of file MEVehicle.cpp.

References getAverageSpeed(), and getWaitingTime().

Referenced by estimateLeaveSpeed(), GUIMEVehicle::getColorValue(), getLane(), GUIMEVehicle::getParameterWindow(), MESegment::isOpen(), MESegment::newArrival(), MESegment::receive(), and MELoop::setApproaching().

◆ getStopEdges()

const ConstMSEdgeVector MEVehicle::getStopEdges ( ) const
virtual

Returns the list of still pending stop edges.

Implements MSBaseVehicle.

Definition at line 262 of file MEVehicle.cpp.

References myStops.

Referenced by getLane().

◆ getStoptime()

SUMOTime MEVehicle::getStoptime ( const MESegment *const  seg) const

Returns how long to stop at the given segment.

Parameters
[in]segThe segment in question
Returns
stop time for the segment

Definition at line 253 of file MEVehicle.cpp.

References myStops.

Referenced by getLane(), and MESegment::receive().

◆ getVClass()

SUMOVehicleClass MSBaseVehicle::getVClass ( ) const
inlinevirtualinherited

◆ getVehicleType()

const MSVehicleType& MSBaseVehicle::getVehicleType ( ) const
inlinevirtualinherited

Returns the vehicle's type definition.

Returns
The vehicle's type definition

Implements SUMOVehicle.

Definition at line 115 of file MSBaseVehicle.h.

References MSBaseVehicle::myType.

Referenced by MSLCM_LC2013::_patchSpeed(), MSLCM_SL2015::_patchSpeed(), MSLCM_LC2013::_wantsChange(), MSLCM_SL2015::_wantsChangeSublane(), MSLCM_LC2013::adaptSpeedToPedestrians(), MSVehicle::adaptToLeaders(), MSPModel_Striping::addCrossingVehs(), MSVehicle::addStop(), MSLane::basePos(), MSTransportableControl::boardAnyWaiting(), MSLaneChanger::change(), MSLaneChanger::changeOpposite(), MSLCM_SL2015::checkBlocking(), MSLaneChanger::checkChange(), MSLaneChangerSublane::checkChangeToNewLane(), MSLane::checkFailure(), MSLane::checkForPedestrians(), GUIApplicationWindow::checkGamingEvents(), MSVehicleTransfer::checkInsertions(), MSVehicle::checkRewindLinkLanes(), MSLCM_SL2015::checkStrategicChange(), MSDevice_SSM::classifyEncounter(), MSLCM_SL2015::commitManoeuvre(), MSLaneChanger::computeOvertakingTime(), MSLCM_SL2015::computeSpeedLat(), MSLane::detectCollisionBetween(), MSLane::detectCollisions(), GUIVehicle::drawAction_drawLinkItems(), GUIVehicle::drawAction_drawRailCarriages(), GUIVehicle::drawAction_drawVehicleBlinker(), GUIVehicle::drawAction_drawVehicleBrakeLight(), GUIEdge::drawMesoVehicles(), MSLane::enteredByLaneChange(), MSVehicle::enterLaneAtInsertion(), MSVehicle::enterLaneAtLaneChange(), MSDevice_SSM::estimateConflictTimes(), estimateLeaveSpeed(), MSVehicle::estimateLeaveSpeed(), MSLane::executeMovements(), MSLane::freeInsertion(), getBackPositionOnLane(), MSLane::getBruttoOccupancy(), GUIBaseVehicle::getCenteringBoundary(), MSLane::getCriticalLeader(), MSEdge::getDepartLane(), MSEdge::getDepartPosBound(), MSLane::getDepartPosLat(), MSLane::getFollower(), MSLane::getFollowersOnConsecutive(), MSBaseVehicle::getImpatience(), MSVehicle::getLateralOverlap(), MSLane::getLeader(), MSVehicle::getLeader(), MSLink::getLeaderInfo(), MSLane::getLeaderOnConsecutive(), MSLaneChangerSublane::getLeaders(), MSLane::getLeadersOnConsecutive(), GUIVehicle::getLeftSideOnEdge(), MSLane::getNettoOccupancy(), MSLane::getOppositeFollower(), MSLane::getOppositeLeader(), MSLaneChanger::getRealFollower(), MSLaneChanger::getRealLeader(), MSVehicle::getRightSideOnEdge(), MSVehicle::getRightSideOnLane(), MSLeaderInfo::getSubLanes(), MSVehicle::getTimeGapOnLane(), MESegment::getTimeHeadway(), libsumo::Vehicle::getTypeID(), libsumo::Vehicle::getVehicleType(), GUIBaseVehicle::getVType(), MSLCM_SL2015::getWidth(), MSLink::getZipperSpeed(), MSLane::handleCollisionBetween(), MESegment::hasSpaceFor(), MSVehicle::ignoreRed(), MSLane::incorporateVehicle(), MSLCM_SL2015::informFollower(), MSLCM_SL2015::informLeader(), MSLCM_SL2015::informLeaders(), MSLane::insertVehicle(), MSLane::integrateNewVehicle(), MSLane::isInsertionSuccess(), MESegment::isOpen(), MSVehicle::keepClear(), MSLCM_SL2015::keepLatGap(), MSAbstractLaneChangeModel::laneChangeOutput(), MSLane::lastInsertion(), MSLane::leftByLaneChange(), MSTransportableControl::loadAnyWaiting(), MESegment::loadState(), MSCFModel_Krauss::moveHelper(), MSPModel_Striping::moveInDirectionOnLane(), libsumo::Vehicle::moveToXY(), MSVehicle::overlap(), MSLCM_LC2013::overtakeDistance(), MSLCM_DK2008::patchSpeed(), MSVehicle::planMoveInternal(), MSVehicle::Influencer::postProcessRemoteControl(), MSVehicle::processLinkAproaches(), MSVehicle::processNextStop(), MSVehicle::processTraCISpeedControl(), MESegment::receive(), MSLaneChanger::ChangeElem::registerHop(), MSLaneChanger::registerUnchanged(), MESegment::removeCar(), MSLane::removeVehicle(), MSLane::safeInsertionSpeed(), MSLCM_SL2015::saveBlockerLength(), MSLCM_LC2013::saveBlockerLength(), MSBaseVehicle::saveState(), GUIVehicle::selectBlockingFoes(), MSVehicleType::setActionStepLength(), MSAbstractLaneChangeModel::setFollowerGaps(), GUIBaseVehicle::setFunctionalColor(), MSAbstractLaneChangeModel::setLeaderGaps(), MSAbstractLaneChangeModel::setOrigLeaderGaps(), MSVehicle::setTentativeLaneAndPosition(), MSLCM_LC2013::slowDownForBlocked(), MSLCM_SL2015::slowDownForBlocked(), MSLaneChangerSublane::startChangeSublane(), MSVehicle::unsafeLinkAhead(), MSLCM_SL2015::updateCFRelated(), MSLCM_SL2015::updateExpectedSublaneSpeeds(), MSLCM_SL2015::updateGaps(), MSLCM_DK2008::wantsChangeToLeft(), MSLCM_DK2008::wantsChangeToRight(), MSBatteryExport::write(), and MSQueueExport::writeLane().

◆ getWaitingSeconds()

double MEVehicle::getWaitingSeconds ( ) const
inline

Returns the number of seconds waited (speed was lesser than 0.1m/s)

The value is reset if the vehicle moves faster than 0.1m/s Intentional stopping does not count towards this time.

Returns
The time the vehicle is standing

Definition at line 292 of file MEVehicle.h.

References getWaitingTime(), and STEPS2TIME.

Referenced by GUIMEVehicle::getColorValue(), and GUIMEVehicle::getParameterWindow().

◆ getWaitingTime()

SUMOTime MEVehicle::getWaitingTime ( ) const
inlinevirtual

Returns the duration for which the vehicle was blocked.

Implements SUMOVehicle.

Definition at line 276 of file MEVehicle.h.

References MAX2(), myBlockTime, and myEventTime.

Referenced by MELoop::checkCar(), getAccumulatedWaitingTime(), getSpeed(), getWaitingSeconds(), MESegment::isOpen(), and MELoop::setApproaching().

◆ getWidth()

◆ hasArrived()

bool MEVehicle::hasArrived ( ) const
virtual

Returns whether this vehicle has already arived (reached the arrivalPosition on its final edge)

Reimplemented from MSBaseVehicle.

Definition at line 159 of file MEVehicle.cpp.

References MSRoute::end(), getPositionOnLane(), MSBaseVehicle::myArrivalPos, MSBaseVehicle::myCurrEdge, myEventTime, MSBaseVehicle::myRoute, mySegment, POSITION_EPS, and SUMOTime_MIN.

Referenced by getLane(), moveRoutePointer(), and MESegment::receive().

◆ hasDeparted()

◆ hasDevice()

bool MSBaseVehicle::hasDevice ( const std::string &  deviceName) const
inherited

check whether the vehicle is equiped with a device of the given type

Definition at line 497 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myDevices.

Referenced by MSBaseVehicle::createDevice(), and libsumo::Vehicle::getParameter().

◆ hasValidRoute()

bool MSBaseVehicle::hasValidRoute ( std::string &  msg,
const MSRoute route = 0 
) const
virtualinherited

Validates the current or given route.

Parameters
[out]msgDescription why the route is not valid (if it is the case)
[in]routeThe route to check (or 0 if the current route shall be checked)
Returns
Whether the vehicle's current route is valid

Implements SUMOVehicle.

Definition at line 321 of file MSBaseVehicle.cpp.

References MSRoute::begin(), MSRoute::end(), MSVehicleType::getVehicleClass(), MSBaseVehicle::myCurrEdge, MSBaseVehicle::myRoute, and MSBaseVehicle::myType.

Referenced by MSBaseVehicle::getDevices(), MESegment::initialise(), libsumo::Vehicle::isRouteValid(), MSBaseVehicle::MSBaseVehicle(), MSBaseVehicle::replaceRouteEdges(), and libsumo::Vehicle::setRouteID().

◆ isFrontOnLane()

virtual bool MSBaseVehicle::isFrontOnLane ( const MSLane ) const
inlinevirtualinherited

Returns the information whether the front of the vehhicle is on the given lane.

Returns
Whether the vehicle's front is on that lane

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 167 of file MSBaseVehicle.h.

◆ isOnRoad()

bool MEVehicle::isOnRoad ( ) const
virtual

Returns the information whether the vehicle is on a road (is simulated)

Returns
Whether the vehicle is simulated

Reimplemented from MSBaseVehicle.

Definition at line 168 of file MEVehicle.cpp.

References getSegment().

Referenced by getLane().

◆ isParking()

bool MEVehicle::isParking ( ) const
virtual

Returns whether the vehicle is parking.

Returns
whether the vehicle is parking

Implements SUMOVehicle.

Definition at line 174 of file MEVehicle.cpp.

Referenced by getLane(), and GUIMEVehicle::getStopInfo().

◆ isRemoteControlled()

virtual bool MSBaseVehicle::isRemoteControlled ( ) const
inlinevirtualinherited

Returns the information whether the vehicle is fully controlled via TraCI.

Returns
Whether the vehicle is remote-controlled

Implements SUMOVehicle.

Reimplemented in MSVehicle.

Definition at line 160 of file MSBaseVehicle.h.

◆ isSelected()

virtual bool MSBaseVehicle::isSelected ( ) const
inlinevirtualinherited

whether this vehicle is selected in the GUI

Implements SUMOVehicle.

Reimplemented in GUIVehicle.

Definition at line 430 of file MSBaseVehicle.h.

References MSBaseVehicle::calculateArrivalParams(), and MSBaseVehicle::getStopEdges().

◆ isStopped()

bool MEVehicle::isStopped ( ) const
virtual

Returns whether the vehicle is at a stop.

Returns
Whether it has stopped

Implements SUMOVehicle.

Definition at line 234 of file MEVehicle.cpp.

References mySegment, and myStops.

Referenced by MELoop::checkCar(), getLane(), GUIMEVehicle::getStopInfo(), and isStoppedInRange().

◆ isStoppedInRange()

bool MEVehicle::isStoppedInRange ( double  pos) const
virtual

return whether the given position is within range of the current stop

Implements SUMOVehicle.

Definition at line 246 of file MEVehicle.cpp.

References isStopped(), and UNUSED_PARAMETER.

Referenced by getLane().

◆ isStoppedTriggered()

bool MEVehicle::isStoppedTriggered ( ) const
virtual

Returns whether the vehicle is on a triggered stop.

Returns
whether the vehicle is on a triggered stop

Implements SUMOVehicle.

Definition at line 240 of file MEVehicle.cpp.

Referenced by getLane().

◆ loadState()

◆ mayProceed()

bool MEVehicle::mayProceed ( ) const

Returns whether the vehicle is allowed to pass the next junction.

Returns
true iff the vehicle may drive over the next junction

Definition at line 272 of file MEVehicle.cpp.

References MESegment::isOpen(), and mySegment.

Referenced by MELoop::changeSegment(), MELoop::checkCar(), and getBlockTimeSeconds().

◆ moveRoutePointer()

bool MEVehicle::moveRoutePointer ( )

Update when the vehicle enters a new edge in the move step.

Returns
Whether the vehicle's route has ended (due to vaporization, or because the destination was reached)

Definition at line 141 of file MEVehicle.cpp.

References MSRoute::end(), hasArrived(), MSBaseVehicle::myCurrEdge, MSBaseVehicle::myParameter, MSBaseVehicle::myRoute, and SUMOVehicleParameter::via.

Referenced by METriggeredCalibrator::execute(), getLane(), MESegment::receive(), and MELoop::teleportVehicle().

◆ onDepart()

void MSBaseVehicle::onDepart ( )
virtualinherited

Called when the vehicle is inserted into the network.

Sets optional information about departure time, informs the vehicle control about a further running vehicle.

Implements SUMOVehicle.

Definition at line 292 of file MSBaseVehicle.cpp.

References MSNet::getCurrentTimeStep(), MSNet::getInstance(), SUMOVehicle::getPositionOnLane(), MSNet::getVehicleControl(), MSBaseVehicle::myDepartPos, MSBaseVehicle::myDeparture, and MSVehicleControl::vehicleDeparted().

Referenced by MSVehicle::enterLaneAtInsertion(), MSBaseVehicle::getCurrentRouteEdge(), MSVehicle::Influencer::postProcessRemoteControl(), and MESegment::receive().

◆ removeReminder()

void MSBaseVehicle::removeReminder ( MSMoveReminder rem)
inherited

Removes a MoveReminder dynamically.

Parameters
[in]remthe reminder to remove
See also
MSMoveReminder

Definition at line 360 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myMoveReminders.

Referenced by MSBaseVehicle::getDevices().

◆ replaceParkingArea()

bool MEVehicle::replaceParkingArea ( MSParkingArea ,
std::string &   
)
inlinevirtual

replace the current parking area stop with a new stop with merge duration

Implements SUMOVehicle.

Definition at line 186 of file MEVehicle.h.

◆ replaceRoute()

bool MEVehicle::replaceRoute ( const MSRoute route,
bool  onInit = false,
int  offset = 0,
bool  addStops = true,
bool  removeStops = true 
)
virtual

◆ replaceRouteEdges()

bool MSBaseVehicle::replaceRouteEdges ( ConstMSEdgeVector edges,
bool  onInit = false,
bool  check = false,
bool  removeStops = true 
)
virtualinherited

Replaces the current route by the given edges.

It is possible that the new route is not accepted, if a) it does not contain the vehicle's current edge, or b) something fails on insertion into the routes container (see in-line comments).

Parameters
[in]edgesThe new list of edges to pass
[in]onInitWhether the vehicle starts with this route
[in]checkWhether the route should be checked for validity
[in]removeStopsWhether stops should be removed if they do not fit onto the new route
Returns
Whether the new route was accepted

Implements SUMOVehicle.

Definition at line 227 of file MSBaseVehicle.cpp.

References MSRoute::addReference(), MSRoute::begin(), RGBColor::DEFAULT_COLOR, MSRoute::dictionary(), MSGlobals::gCheckRoutes, MSRoute::getColor(), MSRoute::getEdges(), Named::getID(), MSBaseVehicle::getID(), MSBaseVehicle::getNumberReroutes(), MSBaseVehicle::getRerouteOrigin(), MSBaseVehicle::hasValidRoute(), MSBaseVehicle::myCurrEdge, MSBaseVehicle::myRoute, MSRoute::release(), SUMOVehicle::replaceRoute(), MSRoute::size(), toString(), and WRITE_WARNING.

Referenced by libsumo::Vehicle::changeTarget(), MSBaseVehicle::getCurrentRouteEdge(), MSVehicle::Influencer::postProcessRemoteControl(), MSBaseVehicle::reroute(), and libsumo::Vehicle::setRoute().

◆ replaceVehicleType()

void MSBaseVehicle::replaceVehicleType ( MSVehicleType type)
inherited

Replaces the current vehicle type by the one given.

If the currently used vehicle type is marked as being used by this vehicle only, it is deleted, first. The new, given type is then assigned to "myType".

Parameters
[in]typeThe new vehicle type
See also
MSBaseVehicle::myType

Definition at line 550 of file MSBaseVehicle.cpp.

References MSNet::getInstance(), MSNet::getVehicleControl(), MSVehicleType::isVehicleSpecific(), MSBaseVehicle::myType, and MSVehicleControl::removeVType().

Referenced by MSBaseVehicle::getSingularType(), MSBaseVehicle::setChosenSpeedFactor(), and libsumo::Vehicle::setType().

◆ reroute()

void MSBaseVehicle::reroute ( SUMOTime  t,
SUMOAbstractRouter< MSEdge, SUMOVehicle > &  router,
const bool  onInit = false,
const bool  withTaz = false 
)
virtualinherited

◆ saveState()

◆ setArrivalPos()

virtual void MSBaseVehicle::setArrivalPos ( double  arrivalPos)
inlinevirtualinherited

Sets this vehicle's desired arrivalPos for its current route.

Implements SUMOVehicle.

Definition at line 275 of file MSBaseVehicle.h.

References MSBaseVehicle::hasArrived(), MSBaseVehicle::hasDeparted(), and MSBaseVehicle::myArrivalPos.

◆ setBlockTime()

void MEVehicle::setBlockTime ( const SUMOTime  t)
inline

Sets the time at which the vehicle was blocked.

Parameters
[in]tThe blocking time

Definition at line 261 of file MEVehicle.h.

References myBlockTime, and myLastEntryTime.

Referenced by MELoop::checkCar(), and MESegment::receive().

◆ setChosenSpeedFactor()

void MSBaseVehicle::setChosenSpeedFactor ( const double  factor)
inlinevirtualinherited

Returns the precomputed factor by which the driver wants to be faster than the speed limit.

Returns
Speed limit factor

Implements SUMOVehicle.

Definition at line 384 of file MSBaseVehicle.h.

References MSBaseVehicle::addStops(), MSBaseVehicle::getDevice(), MSBaseVehicle::getSingularType(), MSBaseVehicle::myChosenSpeedFactor, MSBaseVehicle::replaceVehicleType(), and MSBaseVehicle::saveState().

Referenced by TraCIServerAPI_Vehicle::processSet().

◆ setDeviceParameter()

void MSBaseVehicle::setDeviceParameter ( const std::string &  deviceName,
const std::string &  key,
const std::string &  value 
)
inherited

try to set the given parameter from any of the vehicles devices, raise InvalidArgument if no device parameter by that name exists

Definition at line 538 of file MSBaseVehicle.cpp.

References MSBaseVehicle::myDevices.

Referenced by libsumo::Vehicle::setParameter().

◆ setEventTime()

void MEVehicle::setEventTime ( SUMOTime  t,
bool  hasDelay = true 
)
inline

Sets the (planned) time at which the vehicle leaves his current cell.

Parameters
[in]tThe leaving time

Definition at line 199 of file MEVehicle.h.

References MESegment::getEdge(), MSEdge::markDelayed(), myEventTime, myLastEntryTime, and mySegment.

Referenced by MELoop::checkCar(), METriggeredCalibrator::execute(), MESegment::receive(), MESegment::send(), MESegment::setSpeedForQueue(), and MELoop::teleportVehicle().

◆ setLastEntryTime()

void MEVehicle::setLastEntryTime ( SUMOTime  t)
inline

Sets the entry time for the current segment.

Parameters
[in]tThe entry time

Definition at line 245 of file MEVehicle.h.

References myLastEntryTime.

Referenced by MESegment::receive().

◆ setSegment()

virtual void MEVehicle::setSegment ( MESegment s,
int  idx = 0 
)
inlinevirtual

Sets the current segment the vehicle is at together with its que.

Parameters
[in]sThe current segment
[in]qThe current que

Definition at line 220 of file MEVehicle.h.

References myQueIndex, and mySegment.

Referenced by MELoop::changeSegment(), METriggeredCalibrator::execute(), loadState(), MESegment::receive(), and MELoop::teleportVehicle().

◆ succEdge()

const MSEdge * MSBaseVehicle::succEdge ( int  nSuccs) const
virtualinherited

Returns the nSuccs'th successor of edge the vehicle is currently at.

If the rest of the route (counted from the current edge) has less than nSuccs edges, 0 is returned.

Parameters
[in]nSuccsThe number of edge to look forward
Returns
The nSuccs'th following edge in the vehicle's route

Implements SUMOVehicle.

Definition at line 139 of file MSBaseVehicle.cpp.

References MSRoute::begin(), MSBaseVehicle::myCurrEdge, and MSBaseVehicle::myRoute.

Referenced by MSVehicleTransfer::add(), MSLane::appropriate(), MSVehicleTransfer::checkInsertions(), MESegment::getLink(), MSBaseVehicle::getVClass(), MSBaseVehicle::hasArrived(), MSPedestrianPushButton::isActiveForEdge(), libsumo::Vehicle::moveTo(), MELoop::nextSegment(), and MESegment::receive().

◆ updateDetectorForWriting()

void MEVehicle::updateDetectorForWriting ( MSMoveReminder rem,
SUMOTime  currentTime,
SUMOTime  exitTime 
)

Updates a single vehicle detector if present.

Definition at line 288 of file MEVehicle.cpp.

References MESegment::getIndex(), getLastEntryTime(), MESegment::getLength(), MSBaseVehicle::myMoveReminders, mySegment, and MSMoveReminder::updateDetector().

Referenced by getBlockTimeSeconds().

◆ updateDetectors()

Field Documentation

◆ myArrivalLane

int MSBaseVehicle::myArrivalLane
protectedinherited

The destination lane where the vehicle stops.

Definition at line 487 of file MSBaseVehicle.h.

Referenced by MSBaseVehicle::calculateArrivalParams(), and MSVehicle::updateBestLanes().

◆ myArrivalPos

double MSBaseVehicle::myArrivalPos
protectedinherited

◆ myBlockTime

SUMOTime MEVehicle::myBlockTime
protected

The time at which the vehicle was blocked on its current segment.

Definition at line 359 of file MEVehicle.h.

Referenced by getBlockTime(), getWaitingTime(), loadState(), saveState(), and setBlockTime().

◆ myChosenSpeedFactor

double MSBaseVehicle::myChosenSpeedFactor
protectedinherited

A precomputed factor by which the driver wants to be faster than the speed limit.

Definition at line 457 of file MSBaseVehicle.h.

Referenced by MSBaseVehicle::getChosenSpeedFactor(), and MSBaseVehicle::setChosenSpeedFactor().

◆ myCurrEdge

◆ myDepartPos

double MSBaseVehicle::myDepartPos
protectedinherited

The real depart position.

Definition at line 481 of file MSBaseVehicle.h.

Referenced by MSBaseVehicle::getDepartPos(), MSVehicle::loadState(), MSBaseVehicle::onDepart(), and MSVehicle::saveState().

◆ myDeparture

◆ myDevices

◆ myEventTime

SUMOTime MEVehicle::myEventTime
protected

The (planned) time of leaving the segment (cell)

Definition at line 353 of file MEVehicle.h.

Referenced by getAverageSpeed(), getConservativeSpeed(), getEventTime(), getWaitingTime(), hasArrived(), loadState(), saveState(), and setEventTime().

◆ myLastEntryTime

SUMOTime MEVehicle::myLastEntryTime
protected

The time the vehicle entered its current segment.

Definition at line 356 of file MEVehicle.h.

Referenced by getAverageSpeed(), getConservativeSpeed(), getLastEntryTime(), loadState(), saveState(), setBlockTime(), setEventTime(), and setLastEntryTime().

◆ myMoveReminders

◆ myNumberReroutes

int MSBaseVehicle::myNumberReroutes
protectedinherited

The number of reroutings.

Definition at line 490 of file MSBaseVehicle.h.

Referenced by MSBaseVehicle::getNumberReroutes(), MSVehicle::replaceRoute(), and replaceRoute().

◆ myParameter

◆ myQueIndex

int MEVehicle::myQueIndex
protected

Index of the que the vehicle is in (important for multiqueue extension)

Definition at line 350 of file MEVehicle.h.

Referenced by getQueIndex(), and setSegment().

◆ myRoute

◆ mySegment

◆ myStops

std::map<const MESegment* const, SUMOTime> MEVehicle::myStops
protected

where to stop

Definition at line 362 of file MEVehicle.h.

Referenced by addStop(), getStopEdges(), getStoptime(), isStopped(), and saveState().

◆ myType

◆ NOT_YET_DEPARTED

const SUMOTime MSBaseVehicle::NOT_YET_DEPARTED = SUMOTime_MAX
staticprotectedinherited

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