Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
MEVehicle.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2026 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
19// A vehicle from the mesoscopic point of view
20/****************************************************************************/
21#include <config.h>
22
23#include <iostream>
24#include <cassert>
35#include <microsim/MSGlobals.h>
36#include <microsim/MSEdge.h>
37#include <microsim/MSLane.h>
38#include <microsim/MSNet.h>
40#include <microsim/MSLink.h>
41#include <microsim/MSStop.h>
45#include "MELoop.h"
46#include "MEVehicle.h"
47#include "MESegment.h"
48
49
50// ===========================================================================
51// method definitions
52// ===========================================================================
54 MSVehicleType* type, const double speedFactor) :
55 MSBaseVehicle(pars, route, type, speedFactor),
56 mySegment(nullptr),
57 myQueIndex(0),
58 myEventTime(SUMOTime_MIN),
59 myLastEntryTime(SUMOTime_MIN),
60 myBlockTime(SUMOTime_MAX),
61 myInfluencer(nullptr) {
62}
63
64
65double
66MEVehicle::getBackPositionOnLane(const MSLane* /* lane */) const {
68}
69
70
71double
73// the following interpolation causes problems with arrivals and calibrators
74// const double fracOnSegment = MIN2(double(1), STEPS2TIME(MSNet::getInstance()->getCurrentTimeStep() - myLastEntryTime) / STEPS2TIME(myEventTime - myLastEntryTime));
75 return mySegment == nullptr ? 0 : (double(mySegment->getIndex()) /* + fracOnSegment */) * mySegment->getLength();
76}
77
78
79double
81 const MSLane* const lane = getEdge()->getLanes()[0];
83}
84
85
86double
88 const MSLane* const lane = getEdge()->getLanes()[0];
90}
91
92
93const MSEdge*
95 return mySegment != nullptr ? &mySegment->getEdge() : getEdge();
96}
97
98
100MEVehicle::getPosition(const double offset) const {
101 const MSLane* const lane = getEdge()->getLanes()[0];
102 return lane->geometryPositionAtOffset(getPositionOnLane() + offset);
103}
104
106MEVehicle::getBoundingBox(double offset) const {
107 double a = getAngle() + M_PI; // angle pointing backwards
108 double l = getLength();
109 Position pos = getPosition();
110 Position backPos = pos + Position(l * cos(a), l * sin(a));
111 PositionVector centerLine;
112 centerLine.push_back(pos);
113 centerLine.push_back(backPos);
114 if (offset != 0) {
115 centerLine.extrapolate2D(offset);
116 }
117 PositionVector result = centerLine;
118 result.move2side(MAX2(0.0, 0.5 * myType->getWidth() + offset));
119 centerLine.move2side(MIN2(0.0, -0.5 * myType->getWidth() - offset));
120 result.append(centerLine.reverse(), POSITION_EPS);
121 return result;
122}
123
124double
126 if (getWaitingTime() > 0 || isStopped()) {
127 return 0;
128 } else {
129 return getAverageSpeed();
130 }
131}
132
133
134double
136 // cache for thread safety
137 MESegment* s = mySegment;
138 if (s == nullptr || myQueIndex == MESegment::PARKING_QUEUE) {
139 return 0;
140 } else {
142 getEdge()->getLanes()[myQueIndex]->getVehicleMaxSpeed(this));
143 }
144}
145
146
147double
150 const double v = getSpeed();
151 return MIN2(link->getViaLaneOrLane()->getVehicleMaxSpeed(this),
152 (double)sqrt(2 * link->getLength() * getVehicleType().getCarFollowModel().getMaxAccel() + v * v));
153}
154
155
156double
158 earliestArrival = MAX2(myEventTime, earliestArrival - DELTA_T); // event times have subsecond resolution
159 return mySegment->getLength() / STEPS2TIME(earliestArrival - myLastEntryTime);
160}
161
162
163bool
165 // vehicle has just entered a new edge. Position is 0
166 if (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) { // may happen during teleport
167 return true;
168 }
169 ++myCurrEdge;
170 if ((*myCurrEdge)->isVaporizing()) {
171 return true;
172 }
173 // update via
174 if (myParameter->via.size() > 0 && (*myCurrEdge)->getID() == myParameter->via.front()) {
175 myParameter->via.erase(myParameter->via.begin());
176 }
177 return hasArrived();
178}
179
180
181bool
183 // mySegment may be 0 due to teleporting or arrival
184 return (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) && (
185 (mySegment == nullptr)
187 || getPositionOnLane() > myArrivalPos - POSITION_EPS);
188}
189
190
191bool
193 return getSegment() != nullptr;
194}
195
196
197bool
199 return false;
200}
201
202
203void
205 if (link != nullptr) {
206 const double speed = getSpeed();
207 link->setApproaching(this, getEventTime() + (link->getState() == LINKSTATE_ALLWAY_STOP ?
208 (SUMOTime)RandHelper::rand((int)2) : 0), // tie braker
209 speed, link->getViaLaneOrLane()->getVehicleMaxSpeed(this), true,
210 speed, getWaitingTime(),
211 // @note: dist is not used by meso (getZipperSpeed is never called)
212 getSegment()->getLength(), 0);
213 }
214}
215
216
217bool
218MEVehicle::replaceRoute(ConstMSRoutePtr newRoute, const std::string& info, bool onInit, int offset, bool addRouteStops, bool removeStops, std::string* msgReturn) {
219 MSLink* const oldLink = mySegment != nullptr ? mySegment->getLink(this) : nullptr;
220 if (MSBaseVehicle::replaceRoute(newRoute, info, onInit, offset, addRouteStops, removeStops, msgReturn)) {
221 if (mySegment != nullptr) {
222 MSLink* const newLink = mySegment->getLink(this);
223 // update approaching vehicle information
224 if (oldLink != newLink) {
225 if (oldLink != nullptr) {
226 oldLink->removeApproaching(this);
227 }
228 setApproaching(newLink);
229 }
230 }
231 return true;
232 }
233 return false;
234}
235
236
239 const SUMOTime initialTime = time;
240 bool hadStop = false;
241 for (MSStop& stop : myStops) {
242 if (stop.joinTriggered) {
243 WRITE_WARNINGF(TL("Join stops are not available in meso yet (vehicle '%', segment '%')."),
244 getID(), mySegment->getID());
245 continue;
246 }
247 if (stop.edge != myCurrEdge || stop.segment != mySegment) {
248 break;
249 }
250 const SUMOTime cur = time;
251 if (stop.duration > 0) { // it might be a triggered stop with duration -1
252 time += stop.duration;
253 }
254 if (stop.pars.until > time) {
255 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
256 // travel time is overestimated of the stop is not at the start of the segment
257 time = stop.pars.until;
258 }
259 if (MSGlobals::gUseStopEnded && stop.pars.ended >= 0) {
260 time = MAX2(cur, stop.pars.ended);
261 }
262 if (!stop.reached) {
263 stop.reached = true;
264 stop.pars.started = myLastEntryTime;
265 stop.endBoarding = stop.pars.extension >= 0 ? time + stop.pars.extension : SUMOTime_MAX;
266 if (MSStopOut::active()) {
267 if (!hadStop) {
269 } else {
270 WRITE_WARNINGF(TL("Vehicle '%' has multiple stops on segment '%', time=% (stop-output will be merged)."),
271 getID(), mySegment->getID(), time2string(time));
272 }
273 }
274 MSDevice_Taxi* taxi = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
275 if (taxi != nullptr) {
276 taxi->notifyMove(*this, 0, 0, 0);
277 }
278 }
279 if (stop.triggered || stop.containerTriggered || stop.joinTriggered) {
280 time = MAX2(time, cur + DELTA_T);
281 }
282 hadStop = true;
283 }
284 MSDevice_Tripinfo* tripinfo = static_cast<MSDevice_Tripinfo*>(getDevice(typeid(MSDevice_Tripinfo)));
285 if (tripinfo != nullptr) {
286 tripinfo->updateStopTime(time - initialTime);
287 }
288 return time;
289}
290
291
292bool
294 if (isStopped()) {
295 const SUMOTime now = SIMSTEP;
296 MSStop& stop = myStops.front();
297 stop.pars.ended = now;
298 for (const auto& rem : myMoveReminders) {
299 rem.first->notifyStopEnded();
300 }
301 if (MSStopOut::active()) {
302 MSStopOut::getInstance()->stopEnded(this, stop);
303 }
304 myPastStops.push_back(stop.pars);
305 myPastStops.back().routeIndex = (int)(stop.edge - myRoute->begin());
309 }
310 myStops.pop_front();
311 if (myEventTime > now) {
312 // if this is an aborted stop we need to change the event time of the vehicle
313 if (MSGlobals::gMesoNet->removeLeaderCar(this)) {
314 myEventTime = now + 1;
315 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
316 }
317 }
318 return true;
319 }
320 return false;
321}
322
323
324double
327 for (const MSStop& stop : myStops) {
328 if (stop.reached) {
329 time += stop.duration;
330 if (stop.pars.until > time) {
331 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
332 // travel time is overestimated of the stop is not at the start of the segment
333 time = stop.pars.until;
334 }
335 } else {
336 break;
337 }
338 }
339 return STEPS2TIME(time - myLastEntryTime);
340}
341
342
343void
345 assert(isStopped());
346 double lastPos = -1;
347 bool hadStop = false;
348 while (!myStops.empty()) {
349 MSStop& stop = myStops.front();
350 if (stop.edge != myCurrEdge || stop.segment != mySegment || stop.pars.endPos <= lastPos) {
351 break;
352 }
353 lastPos = stop.pars.endPos;
354 MSNet* const net = MSNet::getInstance();
355 SUMOTime dummy = -1; // boarding- and loading-time are not considered
356 if (hadStop && MSStopOut::active()) {
357 stop.reached = true;
359 }
360 if (net->hasPersons()) {
361 net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
362 }
363 if (net->hasContainers()) {
364 net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
365 }
367 hadStop = true;
368 }
369 if (getWaitingTime() > 0) {
370 // entry back onto the road was blocked for some time
371 MSDevice_Tripinfo* tripinfoDevice = static_cast<MSDevice_Tripinfo*>(getDevice(typeid(MSDevice_Tripinfo)));
372 if (tripinfoDevice != nullptr) {
373 tripinfoDevice->recordMesoParkingTimeLoss(getWaitingTime());
374 }
375 }
377}
378
379
380bool
382 if (mySegment == nullptr) {
383 return true;
384 }
385 MSNet* const net = MSNet::getInstance();
386 SUMOTime dummy = -1; // boarding- and loading-time are not considered
387 for (MSStop& stop : myStops) {
388 if (!stop.reached) {
389 break;
390 }
391 if (net->getCurrentTimeStep() > stop.endBoarding) {
392 if (stop.triggered || stop.containerTriggered) {
393 MSDevice_Taxi* taxiDevice = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
394 if (taxiDevice != nullptr) {
395 taxiDevice->cancelCurrentCustomers();
396 }
397 stop.triggered = false;
398 stop.containerTriggered = false;
399 }
403 }
404 }
405 if (stop.triggered) {
407 // we could not check this on entering the segment because there may be persons who still want to leave
408 WRITE_WARNINGF(TL("Vehicle '%' ignores triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
409 stop.triggered = false;
413 }
414 } else if (!net->hasPersons() || !net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
418 }
419 return false;
420 }
421 }
422 if (stop.containerTriggered) {
423 if (getVehicleType().getContainerCapacity() == getContainerNumber()) {
424 // we could not check this on entering the segment because there may be containers who still want to leave
425 WRITE_WARNINGF(TL("Vehicle '%' ignores container triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
426 stop.containerTriggered = false;
430 }
431 } else if (!net->hasContainers() || !net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
435 }
436 return false;
437 }
438 }
439 if (stop.joinTriggered) {
440 // TODO do something useful here
441 return false;
442 }
443 }
444 return mySegment->isOpen(this);
445}
446
447
448double
450 if (mySegment == nullptr) {
451 return 0;
452 } else {
453 return STEPS2TIME(mySegment->getLinkPenalty(this));
454 }
455}
456
457
458void
460 for (MoveReminderCont::iterator i = myMoveReminders.begin(); i != myMoveReminders.end(); ++i) {
461 if (i->first == rem) {
464 getLastEntryTime(), currentTime, exitTime, false);
465#ifdef _DEBUG
466 if (myTraceMoveReminders) {
467 traceMoveReminder("notifyMove", i->first, i->second, true);
468 }
469#endif
470 return;
471 }
472 }
473}
474
475
476void
477MEVehicle::updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave, const MSMoveReminder::Notification reason) {
478 // segments of the same edge have the same reminder so no cleaning up must take place
479 const bool cleanUp = isLeave && (reason != MSMoveReminder::NOTIFICATION_SEGMENT);
480 for (MoveReminderCont::iterator rem = myMoveReminders.begin(); rem != myMoveReminders.end();) {
482 rem->first->updateDetector(*this, mySegment->getIndex() * mySegment->getLength(),
484 getLastEntryTime(), currentTime, exitTime, cleanUp);
485#ifdef _DEBUG
486 if (myTraceMoveReminders) {
487 traceMoveReminder("notifyMove", rem->first, rem->second, true);
488 }
489#endif
490 }
491 if (!isLeave || rem->first->notifyLeave(*this, mySegment == nullptr ? 0 : mySegment->getLength(), reason)) {
492#ifdef _DEBUG
493 if (isLeave && myTraceMoveReminders) {
494 traceMoveReminder("notifyLeave", rem->first, rem->second, true);
495 }
496#endif
497
498 if (isLeave) {
499 rem->second += getEdge()->getLength();
500#ifdef _DEBUG
501 if (myTraceMoveReminders) {
502 traceMoveReminder("adaptedPos", rem->first, rem->second, true);
503 }
504#endif
505 }
506 ++rem;
507 } else {
508#ifdef _DEBUG
509 if (myTraceMoveReminders) {
510 traceMoveReminder("remove", rem->first, rem->second, false);
511 }
512#endif
513 rem = myMoveReminders.erase(rem);
514 }
515 }
518 }
519}
520
521
524 if (myInfluencer == nullptr) {
526 }
527 return *myInfluencer;
528}
529
530
535
536
537void
542
543
544int
546 return getSegment() != nullptr ? getSegment()->getIndex() : -1;
547}
548
549
550double
551MEVehicle::getRightSideOnEdge(const MSLane* /*lane*/) const {
552 if (mySegment == nullptr || mySegment->getIndex() >= getEdge()->getNumLanes()) {
553 return 0;
554 }
555 const MSLane* lane = getEdge()->getLanes()[mySegment->getIndex()];
556 return lane->getRightSideOnEdge() + lane->getWidth() * 0.5 - 0.5 * getVehicleType().getWidth();
557
558}
559
560
561void
563 if (mySegment != nullptr && MESegment::isInvalid(mySegment)) {
564 // segment is vaporization target, do not write this vehicle
565 return;
566 }
568 assert(mySegment == nullptr || *myCurrEdge == &mySegment->getEdge());
569 std::vector<SUMOTime> internals;
570 internals.push_back(myParameter->parametersSet);
571 internals.push_back(myDeparture);
572 internals.push_back((SUMOTime)distance(myRoute->begin(), myCurrEdge));
573 internals.push_back((SUMOTime)myDepartPos * 1000); // store as mm
574 internals.push_back(mySegment == nullptr ? (SUMOTime) - 1 : (SUMOTime)mySegment->getIndex());
575 internals.push_back((SUMOTime)getQueIndex());
576 internals.push_back(myEventTime);
577 internals.push_back(myLastEntryTime);
578 internals.push_back(myBlockTime);
579 internals.push_back(isStopped());
580 internals.push_back(myPastStops.size());
581 out.writeAttr(SUMO_ATTR_STATE, toString(internals));
582 // save past stops
584 stop.write(out, false);
585 // do not write started and ended twice
586 if ((stop.parametersSet & STOP_STARTED_SET) == 0) {
587 out.writeAttr(SUMO_ATTR_STARTED, time2string(stop.started));
588 }
589 if ((stop.parametersSet & STOP_ENDED_SET) == 0) {
590 out.writeAttr(SUMO_ATTR_ENDED, time2string(stop.ended));
591 }
592 out.closeTag();
593 }
594 // save upcoming stops
595 for (const MSStop& stop : myStops) {
596 stop.write(out);
597 }
598 // save parameters
600 for (MSDevice* dev : myDevices) {
601 dev->saveState(out);
602 }
603 for (const auto& item : myMoveReminders) {
604 item.first->saveReminderState(out, *this);
605 }
606 out.closeTag();
607}
608
609
610void
612 if (attrs.hasAttribute(SUMO_ATTR_POSITION)) {
613 throw ProcessError(TL("Error: Invalid vehicles in state (may be a micro state)!"));
614 }
615 int routeOffset;
616 bool stopped;
617 int pastStops;
618 int segIndex;
619 int queIndex;
620 std::istringstream bis(attrs.getString(SUMO_ATTR_STATE));
622 bis >> myDeparture;
623 bis >> routeOffset;
624 bis >> myDepartPos;
625 bis >> segIndex;
626 bis >> queIndex;
627 bis >> myEventTime;
628 bis >> myLastEntryTime;
629 bis >> myBlockTime;
630 bis >> stopped;
631 bis >> pastStops;
632 myDepartPos /= 1000.; // was stored as mm
633
635 bool ok;
636 myArrivalPos = attrs.get<double>(SUMO_ATTR_ARRIVALPOS_RANDOMIZED, getID().c_str(), ok);
637 }
638
639 // load stops
640 myStops.clear();
642
643 if (hasDeparted()) {
644 myDeparture -= offset;
645 myEventTime -= offset;
646 myLastEntryTime -= offset;
647 myCurrEdge = myRoute->begin() + routeOffset;
648 // fix stops
649 while (pastStops > 0) {
650 myPastStops.push_back(myStops.front().pars);
651 myPastStops.back().routeIndex = (int)(myStops.front().edge - myRoute->begin());
652 myStops.pop_front();
653 pastStops--;
654 }
655 if (segIndex >= 0) {
657 while (seg->getIndex() != (int)segIndex) {
658 seg = seg->getNextSegment();
659 if (seg == nullptr) {
660 throw ProcessError(TLF("Unknown segment '%:%' for vehicle '%' in loaded state.", (*myCurrEdge)->getID(), segIndex, getID()));
661 }
662 }
663 setSegment(seg, queIndex);
664 if (queIndex == MESegment::PARKING_QUEUE) {
665 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
666 getCurrentEdge()->getLanes()[0]->addParking(this);
667 }
668 } else {
669 // on teleport
670 setSegment(nullptr, 0);
671 assert(myEventTime != SUMOTime_MIN);
672 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
673 }
674 // see MSBaseVehicle constructor
677 }
678 }
679 if (myBlockTime != SUMOTime_MAX) {
680 myBlockTime -= offset;
681 }
682 std::istringstream dis(attrs.getString(SUMO_ATTR_DISTANCE));
684 if (stopped) {
685 myStops.front().startedFromState = true;
686 myStops.front().reached = true;
687 }
688}
689
690
691/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define TL(string)
Definition MsgHandler.h:304
#define TLF(string,...)
Definition MsgHandler.h:306
std::shared_ptr< const MSRoute > ConstMSRoutePtr
Definition Route.h:32
SUMOTime DELTA_T
Definition SUMOTime.cpp:38
std::string time2string(SUMOTime t, bool humanReadable)
convert SUMOTime to string (independently of global format setting)
Definition SUMOTime.cpp:91
#define STEPS2TIME(x)
Definition SUMOTime.h:58
#define SIMSTEP
Definition SUMOTime.h:64
#define SUMOTime_MAX
Definition SUMOTime.h:34
#define SUMOTime_MIN
Definition SUMOTime.h:35
const long long int VEHPARS_FORCE_REROUTE
const int STOP_ENDED_SET
const int STOP_STARTED_SET
@ LINKSTATE_ALLWAY_STOP
This is an uncontrolled, all-way stop link.
@ SUMO_ATTR_STARTED
@ SUMO_ATTR_ENDED
@ SUMO_ATTR_DISTANCE
@ SUMO_ATTR_ARRIVALPOS_RANDOMIZED
@ SUMO_ATTR_POSITION
@ SUMO_ATTR_STATE
The state of a link.
T MIN2(T a, T b)
Definition StdDefs.h:80
T MAX2(T a, T b)
Definition StdDefs.h:86
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:49
SUMOTime changeSegment(MEVehicle *veh, SUMOTime leaveTime, MESegment *const toSegment, MSMoveReminder::Notification reason, const bool ignoreLink=false) const
change to the next segment this handles combinations of the following cases: (ending / continuing rou...
Definition MELoop.cpp:79
MESegment * getSegmentForEdge(const MSEdge &e, double pos=0)
Get the segment for a given edge at a given position.
Definition MELoop.cpp:339
bool removeLeaderCar(MEVehicle *v)
Removes the given car from the leading vehicles.
Definition MELoop.cpp:254
void addLeaderCar(MEVehicle *veh, MSLink *link)
Adds the given car to the leading vehicles.
Definition MELoop.cpp:241
A single mesoscopic segment (cell)
Definition MESegment.h:50
static const int PARKING_QUEUE
Definition MESegment.h:53
bool isOpen(const MEVehicle *veh) const
Returns whether the vehicle may use the next link.
SUMOTime getLinkPenalty(const MEVehicle *veh) const
Returns the penalty time for passing a link (if using gMesoTLSPenalty > 0 or gMesoMinorPenalty > 0)
MSLink * getLink(const MEVehicle *veh, bool tlsPenalty=false) const
Returns the link the given car will use when passing the next junction.
double getLength() const
Returns the length of the segment in meters.
Definition MESegment.h:246
const MSEdge & getEdge() const
Returns the edge this segment belongs to.
Definition MESegment.h:366
int getIndex() const
Returns the running index of the segment in the edge (0 is the most upstream).
Definition MESegment.h:230
static bool isInvalid(const MESegment *segment)
whether the given segment is 0 or encodes vaporization
Definition MESegment.h:449
MESegment * getNextSegment() const
Returns the following segment on the same edge (0 if it is the last).
Definition MESegment.h:238
double getConservativeSpeed(SUMOTime &earliestArrival) const
Returns the vehicle's estimated speed taking into account delays.
Position getPosition(const double offset=0) const
Return current position (x/y, cartesian)
double getAverageSpeed() const
Returns the vehicle's estimated average speed on the segment assuming no further delays.
double getAngle() const
Returns the vehicle's direction in degrees.
Definition MEVehicle.cpp:80
double getBackPositionOnLane(const MSLane *lane) const
Get the vehicle's position relative to the given lane.
Definition MEVehicle.cpp:66
bool replaceRoute(ConstMSRoutePtr route, const std::string &info, bool onInit=false, int offset=0, bool addRouteStops=true, bool removeStops=true, std::string *msgReturn=nullptr)
Replaces the current route by the given one.
SUMOTime myEventTime
The (planned) time of leaving the segment (cell)
Definition MEVehicle.h:370
void onRemovalFromNet(const MSMoveReminder::Notification reason)
Called when the vehicle is removed from the network.
void updateDetectorForWriting(MSMoveReminder *rem, SUMOTime currentTime, SUMOTime exitTime)
Updates a single vehicle detector if present.
MEVehicle(SUMOVehicleParameter *pars, ConstMSRoutePtr route, MSVehicleType *type, const double speedFactor)
Constructor.
Definition MEVehicle.cpp:53
BaseInfluencer & getBaseInfluencer()
Returns the velocity/lane influencer.
double getCurrentStoppingTimeSeconds() const
Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty.
bool mayProceed()
Returns whether the vehicle is allowed to pass the next junction, checks also for triggered stops.
double estimateLeaveSpeed(const MSLink *link) const
Returns the vehicle's estimated speed after driving across the link.
void processStop()
ends the current stop and performs loading/unloading
SUMOTime getWaitingTime(const bool accumulated=false) const
Returns the duration for which the vehicle was blocked.
Definition MEVehicle.h:289
bool hasArrived() const
Returns whether this vehicle has already arrived (reached the arrivalPosition on its final edge)
bool moveRoutePointer()
Update when the vehicle enters a new edge in the move step.
int myQueIndex
Index of the que the vehicle is in (important for multiqueue extension)
Definition MEVehicle.h:367
void updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave, const MSMoveReminder::Notification reason=MSMoveReminder::NOTIFICATION_JUNCTION)
Updates all vehicle detectors.
SUMOTime checkStop(SUMOTime time)
Returns until when to stop at the current segment and sets the information that the stop has been rea...
virtual bool isIdling() const
Returns whether the vehicle is trying to re-enter the net.
SUMOTime getLastEntryTime() const
Returns the time the vehicle entered the current segment.
Definition MEVehicle.h:260
double getPositionOnLane() const
Get the vehicle's position along the lane.
Definition MEVehicle.cpp:72
SUMOTime myLastEntryTime
The time the vehicle entered its current segment.
Definition MEVehicle.h:373
BaseInfluencer * myInfluencer
An instance of a velocity/lane influencing instance; built in "getInfluencer".
Definition MEVehicle.h:379
void setApproaching(MSLink *link)
registers vehicle with the given link
void saveState(OutputDevice &out)
Saves the states of a vehicle.
MESegment * getSegment() const
Returns the current segment the vehicle is on.
Definition MEVehicle.h:229
const MSEdge * getCurrentEdge() const
Returns the edge the vehicle is currently at (possibly an internal edge)
Definition MEVehicle.cpp:94
MESegment * mySegment
The segment the vehicle is at.
Definition MEVehicle.h:364
int getQueIndex() const
Returns the index of the que the vehicle is in.
Definition MEVehicle.h:238
int getSegmentIndex() const
void loadState(const SUMOSAXAttributes &attrs, const SUMOTime offset)
Loads the state of this vehicle from the given description.
virtual void setSegment(MESegment *s, int idx=0)
Sets the current segment the vehicle is at together with its que.
Definition MEVehicle.h:220
double getCurrentLinkPenaltySeconds() const
Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty.
SUMOTime getEventTime() const
Returns the (planned) time at which the vehicle leaves its current segment.
Definition MEVehicle.h:211
bool isOnRoad() const
Returns the information whether the vehicle is on a road (is simulated)
bool resumeFromStopping()
double getSpeed() const
Returns the vehicle's estimated speed assuming no delays.
PositionVector getBoundingBox(double offset=0) const
get bounding rectangle
double getSlope() const
Returns the slope of the road at vehicle's position in degrees.
Definition MEVehicle.cpp:87
SUMOTime myBlockTime
The time at which the vehicle was blocked on its current segment.
Definition MEVehicle.h:376
double getRightSideOnEdge(const MSLane *) const
Get the vehicle's lateral position on the edge of the given lane (or its current edge if lane == 0)
The base class for microscopic and mesoscopic vehicles.
std::list< MSStop > myStops
The vehicle's list of stops.
void calculateArrivalParams(bool onInit)
(Re-)Calculates the arrival position and lane from the vehicle parameters
MoveReminderCont myMoveReminders
Currently relevant move reminders.
double myDepartPos
The real depart position.
std::vector< MSVehicleDevice * > myDevices
The devices this vehicle has.
virtual bool replaceRoute(ConstMSRoutePtr route, const std::string &info, bool onInit=false, int offset=0, bool addRouteStops=true, bool removeStops=true, std::string *msgReturn=nullptr)
Replaces the current route by the given one.
const MSVehicleType * myType
This vehicle's type.
double getLength() const
Returns the vehicle's length.
const MSEdge * getEdge() const
Returns the edge the vehicle is currently at.
int getPersonNumber() const
Returns the number of persons.
MSRouteIterator myCurrEdge
Iterator to current route-edge.
StopParVector myPastStops
The list of stops that the vehicle has already reached.
bool hasDeparted() const
Returns whether this vehicle has already departed.
ConstMSRoutePtr myRoute
This vehicle's route.
void addStops(const bool ignoreStopErrors, MSRouteIterator *searchStart=nullptr, bool addRouteStops=true)
Adds stops to the built vehicle.
SUMOTime myDeparture
The real departure time.
int getRoutePosition() const
return index of edge within route
bool myAmRegisteredAsWaiting
Whether this vehicle is registered as waiting for a person or container (for deadlock-recognition)
const SUMOVehicleParameter * myParameter
This vehicle's parameter.
const MSVehicleType & getVehicleType() const
Returns the vehicle's type definition.
bool isStopped() const
Returns whether the vehicle is at a stop.
MSDevice * getDevice(const std::type_info &type) const
Returns a device of the given type if it exists, nullptr otherwise.
int myNumberReroutes
The number of reroutings.
double myArrivalPos
The position on the destination lane where the vehicle stops.
virtual void saveState(OutputDevice &out)
Saves the (common) state of a vehicle.
double myOdometer
A simple odometer to keep track of the length of the route already driven.
int getContainerNumber() const
Returns the number of containers.
A device which collects info on the vehicle trip (mainly on departure and arrival)
bool notifyMove(SUMOTrafficObject &veh, double oldPos, double newPos, double newSpeed)
Checks for waiting steps when the vehicle moves.
void cancelCurrentCustomers()
remove the persons the taxi is currently waiting for from reservations
A device which collects info on the vehicle trip (mainly on departure and arrival)
void updateStopTime(const SUMOTime time)
update stopping time for meso
void recordMesoParkingTimeLoss(SUMOTime waitingTime)
Abstract in-vehicle / in-person device.
Definition MSDevice.h:62
A road/street connecting two junctions.
Definition MSEdge.h:77
const std::vector< MSLane * > & getLanes() const
Returns this edge's lanes.
Definition MSEdge.h:168
double getLength() const
return the length of the edge
Definition MSEdge.h:694
void removeWaiting(const SUMOVehicle *vehicle) const
Removes a vehicle from the list of waiting vehicles.
Definition MSEdge.cpp:1492
static bool gCheckRoutes
Definition MSGlobals.h:91
static MELoop * gMesoNet
mesoscopic simulation infrastructure
Definition MSGlobals.h:112
static bool gUseStopEnded
whether the simulation should replay previous stop times
Definition MSGlobals.h:133
Representation of a lane in the micro simulation.
Definition MSLane.h:84
double getVehicleMaxSpeed(const SUMOTrafficObject *const veh) const
Returns the lane's maximum speed, given a vehicle's speed limit adaptation.
Definition MSLane.h:575
double getRightSideOnEdge() const
Definition MSLane.h:1211
double interpolateLanePosToGeometryPos(double lanePos) const
Definition MSLane.h:555
virtual const PositionVector & getShape(bool) const
Definition MSLane.h:294
double getWidth() const
Returns the lane's width.
Definition MSLane.h:646
const Position geometryPositionAtOffset(double offset, double lateralOffset=0) const
Definition MSLane.h:561
Something on a lane to be noticed about vehicle movement.
Notification
Definition of a vehicle state.
@ NOTIFICATION_VAPORIZED_CALIBRATOR
The vehicle got removed by a calibrator.
@ NOTIFICATION_SEGMENT
The vehicle changes the segment (meso only)
@ NOTIFICATION_JUNCTION
The vehicle arrived at a junction.
@ NOTIFICATION_TELEPORT
The vehicle is being teleported.
void updateDetector(SUMOTrafficObject &veh, double entryPos, double leavePos, SUMOTime entryTime, SUMOTime currentTime, SUMOTime leaveTime, bool cleanUp)
The simulated network and simulation perfomer.
Definition MSNet.h:89
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition MSNet.cpp:199
virtual MSTransportableControl & getContainerControl()
Returns the container control.
Definition MSNet.cpp:1283
SUMOTime getCurrentTimeStep() const
Returns the current simulation step.
Definition MSNet.h:334
bool hasContainers() const
Returns whether containers are simulated.
Definition MSNet.h:425
bool hasPersons() const
Returns whether persons are simulated.
Definition MSNet.h:409
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition MSNet.h:392
virtual MSTransportableControl & getPersonControl()
Returns the person control.
Definition MSNet.cpp:1274
bool triggered
whether an arriving person lets the vehicle continue
Definition MSStop.h:69
bool containerTriggered
whether an arriving container lets the vehicle continue
Definition MSStop.h:71
bool joinTriggered
whether coupling another vehicle (train) the vehicle continue
Definition MSStop.h:73
const MESegment * segment
The segment to stop at (mesosim only)
Definition MSStop.h:52
bool reached
Information whether the stop has been reached.
Definition MSStop.h:75
MSRouteIterator edge
The edge in the route to stop at.
Definition MSStop.h:48
const SUMOVehicleParameter::Stop pars
The stop parameter.
Definition MSStop.h:65
static bool active()
Definition MSStopOut.h:55
void stopStarted(const SUMOVehicle *veh, int numPersons, int numContainers, SUMOTime time)
Definition MSStopOut.cpp:83
static MSStopOut * getInstance()
Definition MSStopOut.h:61
void stopEnded(const SUMOVehicle *veh, const MSStop &stop, bool simEnd=false)
bool loadAnyWaiting(const MSEdge *edge, SUMOVehicle *vehicle, SUMOTime &timeToLoadNext, SUMOTime &stopDuration, MSTransportable *const force=nullptr)
load any applicable transportables Loads any person / container that is waiting on that edge for the ...
void registerOneWaiting()
increases the count of vehicles waiting for a transport to allow recognition of person / container re...
void unregisterOneWaiting()
decreases the count of vehicles waiting for a transport to allow recognition of person / container re...
The car-following model and parameter.
double getWidth() const
Get the width which vehicles of this class shall have when being drawn.
int getPersonCapacity() const
Get this vehicle type's person capacity.
double getLength() const
Get vehicle's length [m].
const std::string & getID() const
Returns the id.
Definition Named.h:74
Static storage of an output device and its base (abstract) implementation.
OutputDevice & writeAttr(const ATTR_TYPE &attr, const T &val, const bool isNull=false)
writes a named attribute
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
void writeParams(OutputDevice &device) const
write Params in the given outputdevice
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
A list of positions.
void append(const PositionVector &v, double sameThreshold=2.0)
double rotationAtOffset(double pos) const
Returns the rotation at the given length.
void move2side(double amount, double maxExtension=100)
move position vector to side using certain amount
double slopeDegreeAtOffset(double pos) const
Returns the slope at the given length.
void extrapolate2D(const double val, const bool onlyFirst=false)
extrapolate position vector in two dimensions (Z is ignored)
PositionVector reverse() const
reverse position vector
static double rand(SumoRNG *rng=nullptr)
Returns a random real number in [0, 1)
Encapsulated SAX-Attributes.
virtual std::string getString(int id, bool *isPresent=nullptr) const =0
Returns the string-value of the named (by its enum-value) attribute.
T get(int attr, const char *objectid, bool &ok, bool report=true) const
Tries to read given attribute assuming it is an int.
virtual bool hasAttribute(int id) const =0
Returns the information whether the named (by its enum-value) attribute is within the current list.
Definition of vehicle stop (position and duration)
SUMOTime ended
the time at which this stop was ended
double endPos
The stopping position end.
Structure representing possible vehicle parameter.
std::vector< std::string > via
List of the via-edges the vehicle must visit.
long long int parametersSet
Information for the router which parameter were set, TraCI may modify this (when changing color)
bool wasSet(long long int what) const
Returns whether the given parameter was set.
int arrivalEdge
(optional) The final edge within the route of the vehicle
#define M_PI
Definition odrSpiral.cpp:45