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-2025 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
94MEVehicle::getPosition(const double offset) const {
95 const MSLane* const lane = getEdge()->getLanes()[0];
96 return lane->geometryPositionAtOffset(getPositionOnLane() + offset);
97}
98
100MEVehicle::getBoundingBox(double offset) const {
101 double a = getAngle() + M_PI; // angle pointing backwards
102 double l = getLength();
103 Position pos = getPosition();
104 Position backPos = pos + Position(l * cos(a), l * sin(a));
105 PositionVector centerLine;
106 centerLine.push_back(pos);
107 centerLine.push_back(backPos);
108 if (offset != 0) {
109 centerLine.extrapolate2D(offset);
110 }
111 PositionVector result = centerLine;
112 result.move2side(MAX2(0.0, 0.5 * myType->getWidth() + offset));
113 centerLine.move2side(MIN2(0.0, -0.5 * myType->getWidth() - offset));
114 result.append(centerLine.reverse(), POSITION_EPS);
115 return result;
116}
117
118double
120 if (getWaitingTime() > 0 || isStopped()) {
121 return 0;
122 } else {
123 return getAverageSpeed();
124 }
125}
126
127
128double
130 // cache for thread safety
131 MESegment* s = mySegment;
132 if (s == nullptr || myQueIndex == MESegment::PARKING_QUEUE) {
133 return 0;
134 } else {
136 getEdge()->getLanes()[myQueIndex]->getVehicleMaxSpeed(this));
137 }
138}
139
140
141double
144 const double v = getSpeed();
145 return MIN2(link->getViaLaneOrLane()->getVehicleMaxSpeed(this),
146 (double)sqrt(2 * link->getLength() * getVehicleType().getCarFollowModel().getMaxAccel() + v * v));
147}
148
149
150double
152 earliestArrival = MAX2(myEventTime, earliestArrival - DELTA_T); // event times have subsecond resolution
153 return mySegment->getLength() / STEPS2TIME(earliestArrival - myLastEntryTime);
154}
155
156
157bool
159 // vehicle has just entered a new edge. Position is 0
160 if (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) { // may happen during teleport
161 return true;
162 }
163 ++myCurrEdge;
164 if ((*myCurrEdge)->isVaporizing()) {
165 return true;
166 }
167 // update via
168 if (myParameter->via.size() > 0 && (*myCurrEdge)->getID() == myParameter->via.front()) {
169 myParameter->via.erase(myParameter->via.begin());
170 }
171 return hasArrived();
172}
173
174
175bool
177 // mySegment may be 0 due to teleporting or arrival
178 return (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) && (
179 (mySegment == nullptr)
181 || getPositionOnLane() > myArrivalPos - POSITION_EPS);
182}
183
184
185bool
187 return getSegment() != nullptr;
188}
189
190
191bool
193 return false;
194}
195
196
197void
199 if (link != nullptr) {
200 const double speed = getSpeed();
201 link->setApproaching(this, getEventTime() + (link->getState() == LINKSTATE_ALLWAY_STOP ?
202 (SUMOTime)RandHelper::rand((int)2) : 0), // tie braker
203 speed, link->getViaLaneOrLane()->getVehicleMaxSpeed(this), true,
204 speed, getWaitingTime(),
205 // @note: dist is not used by meso (getZipperSpeed is never called)
206 getSegment()->getLength(), 0);
207 }
208}
209
210
211bool
212MEVehicle::replaceRoute(ConstMSRoutePtr newRoute, const std::string& info, bool onInit, int offset, bool addRouteStops, bool removeStops, std::string* msgReturn) {
213 MSLink* const oldLink = mySegment != nullptr ? mySegment->getLink(this) : nullptr;
214 if (MSBaseVehicle::replaceRoute(newRoute, info, onInit, offset, addRouteStops, removeStops, msgReturn)) {
215 if (mySegment != nullptr) {
216 MSLink* const newLink = mySegment->getLink(this);
217 // update approaching vehicle information
218 if (oldLink != newLink) {
219 if (oldLink != nullptr) {
220 oldLink->removeApproaching(this);
221 }
222 setApproaching(newLink);
223 }
224 }
225 return true;
226 }
227 return false;
228}
229
230
233 const SUMOTime initialTime = time;
234 bool hadStop = false;
235 for (MSStop& stop : myStops) {
236 if (stop.joinTriggered) {
237 WRITE_WARNINGF(TL("Join stops are not available in meso yet (vehicle '%', segment '%')."),
238 getID(), mySegment->getID());
239 continue;
240 }
241 if (stop.edge != myCurrEdge || stop.segment != mySegment) {
242 break;
243 }
244 const SUMOTime cur = time;
245 if (stop.duration > 0) { // it might be a triggered stop with duration -1
246 time += stop.duration;
247 }
248 if (stop.pars.until > time) {
249 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
250 // travel time is overestimated of the stop is not at the start of the segment
251 time = stop.pars.until;
252 }
253 if (MSGlobals::gUseStopEnded && stop.pars.ended >= 0) {
254 time = MAX2(cur, stop.pars.ended);
255 }
256 if (!stop.reached) {
257 stop.reached = true;
258 stop.pars.started = myLastEntryTime;
259 stop.endBoarding = stop.pars.extension >= 0 ? time + stop.pars.extension : SUMOTime_MAX;
260 if (MSStopOut::active()) {
261 if (!hadStop) {
263 } else {
264 WRITE_WARNINGF(TL("Vehicle '%' has multiple stops on segment '%', time=% (stop-output will be merged)."),
265 getID(), mySegment->getID(), time2string(time));
266 }
267 }
268 MSDevice_Taxi* taxi = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
269 if (taxi != nullptr) {
270 taxi->notifyMove(*this, 0, 0, 0);
271 }
272 }
273 if (stop.triggered || stop.containerTriggered || stop.joinTriggered) {
274 time = MAX2(time, cur + DELTA_T);
275 }
276 hadStop = true;
277 }
278 MSDevice_Tripinfo* tripinfo = static_cast<MSDevice_Tripinfo*>(getDevice(typeid(MSDevice_Tripinfo)));
279 if (tripinfo != nullptr) {
280 tripinfo->updateStopTime(time - initialTime);
281 }
282 return time;
283}
284
285
286bool
288 if (isStopped()) {
289 const SUMOTime now = SIMSTEP;
290 MSStop& stop = myStops.front();
291 stop.pars.ended = now;
292 for (const auto& rem : myMoveReminders) {
293 rem.first->notifyStopEnded();
294 }
295 if (MSStopOut::active()) {
297 }
298 myPastStops.push_back(stop.pars);
299 myPastStops.back().routeIndex = (int)(stop.edge - myRoute->begin());
303 }
304 myStops.pop_front();
305 if (myEventTime > now) {
306 // if this is an aborted stop we need to change the event time of the vehicle
307 if (MSGlobals::gMesoNet->removeLeaderCar(this)) {
308 myEventTime = now + 1;
309 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
310 }
311 }
312 return true;
313 }
314 return false;
315}
316
317
318double
321 for (const MSStop& stop : myStops) {
322 if (stop.reached) {
323 time += stop.duration;
324 if (stop.pars.until > time) {
325 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
326 // travel time is overestimated of the stop is not at the start of the segment
327 time = stop.pars.until;
328 }
329 } else {
330 break;
331 }
332 }
333 return STEPS2TIME(time - myLastEntryTime);
334}
335
336
337void
339 assert(isStopped());
340 double lastPos = -1;
341 bool hadStop = false;
342 while (!myStops.empty()) {
343 MSStop& stop = myStops.front();
344 if (stop.edge != myCurrEdge || stop.segment != mySegment || stop.pars.endPos <= lastPos) {
345 break;
346 }
347 lastPos = stop.pars.endPos;
348 MSNet* const net = MSNet::getInstance();
349 SUMOTime dummy = -1; // boarding- and loading-time are not considered
350 if (hadStop && MSStopOut::active()) {
351 stop.reached = true;
353 }
354 if (net->hasPersons()) {
355 net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
356 }
357 if (net->hasContainers()) {
358 net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
359 }
361 hadStop = true;
362 }
364}
365
366
367bool
369 if (mySegment == nullptr) {
370 return true;
371 }
372 MSNet* const net = MSNet::getInstance();
373 SUMOTime dummy = -1; // boarding- and loading-time are not considered
374 for (MSStop& stop : myStops) {
375 if (!stop.reached) {
376 break;
377 }
378 if (net->getCurrentTimeStep() > stop.endBoarding) {
379 if (stop.triggered || stop.containerTriggered) {
380 MSDevice_Taxi* taxiDevice = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
381 if (taxiDevice != nullptr) {
382 taxiDevice->cancelCurrentCustomers();
383 }
384 stop.triggered = false;
385 stop.containerTriggered = false;
386 }
390 }
391 }
392 if (stop.triggered) {
394 // we could not check this on entering the segment because there may be persons who still want to leave
395 WRITE_WARNINGF(TL("Vehicle '%' ignores triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
396 stop.triggered = false;
400 }
401 } else if (!net->hasPersons() || !net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
405 }
406 return false;
407 }
408 }
409 if (stop.containerTriggered) {
410 if (getVehicleType().getContainerCapacity() == getContainerNumber()) {
411 // we could not check this on entering the segment because there may be containers who still want to leave
412 WRITE_WARNINGF(TL("Vehicle '%' ignores container triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
413 stop.containerTriggered = false;
417 }
418 } else if (!net->hasContainers() || !net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
422 }
423 return false;
424 }
425 }
426 if (stop.joinTriggered) {
427 // TODO do something useful here
428 return false;
429 }
430 }
431 return mySegment->isOpen(this);
432}
433
434
435double
437 if (mySegment == nullptr) {
438 return 0;
439 } else {
440 return STEPS2TIME(mySegment->getLinkPenalty(this));
441 }
442}
443
444
445void
447 for (MoveReminderCont::iterator i = myMoveReminders.begin(); i != myMoveReminders.end(); ++i) {
448 if (i->first == rem) {
451 getLastEntryTime(), currentTime, exitTime, false);
452#ifdef _DEBUG
453 if (myTraceMoveReminders) {
454 traceMoveReminder("notifyMove", i->first, i->second, true);
455 }
456#endif
457 return;
458 }
459 }
460}
461
462
463void
464MEVehicle::updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave, const MSMoveReminder::Notification reason) {
465 // segments of the same edge have the same reminder so no cleaning up must take place
466 const bool cleanUp = isLeave && (reason != MSMoveReminder::NOTIFICATION_SEGMENT);
467 for (MoveReminderCont::iterator rem = myMoveReminders.begin(); rem != myMoveReminders.end();) {
469 rem->first->updateDetector(*this, mySegment->getIndex() * mySegment->getLength(),
471 getLastEntryTime(), currentTime, exitTime, cleanUp);
472#ifdef _DEBUG
473 if (myTraceMoveReminders) {
474 traceMoveReminder("notifyMove", rem->first, rem->second, true);
475 }
476#endif
477 }
478 if (!isLeave || rem->first->notifyLeave(*this, mySegment->getLength(), reason)) {
479#ifdef _DEBUG
480 if (isLeave && myTraceMoveReminders) {
481 traceMoveReminder("notifyLeave", rem->first, rem->second, true);
482 }
483#endif
484
485 if (isLeave) {
486 rem->second += getEdge()->getLength();
487#ifdef _DEBUG
488 if (myTraceMoveReminders) {
489 traceMoveReminder("adaptedPos", rem->first, rem->second, true);
490 }
491#endif
492 }
493 ++rem;
494 } else {
495#ifdef _DEBUG
496 if (myTraceMoveReminders) {
497 traceMoveReminder("remove", rem->first, rem->second, false);
498 }
499#endif
500 rem = myMoveReminders.erase(rem);
501 }
502 }
505 }
506}
507
508
511 if (myInfluencer == nullptr) {
513 }
514 return *myInfluencer;
515}
516
517
522
523
524void
529
530
531int
533 return getSegment() != nullptr ? getSegment()->getIndex() : -1;
534}
535
536
537double
538MEVehicle::getRightSideOnEdge(const MSLane* /*lane*/) const {
539 if (mySegment == nullptr || mySegment->getIndex() >= getEdge()->getNumLanes()) {
540 return 0;
541 }
542 const MSLane* lane = getEdge()->getLanes()[mySegment->getIndex()];
543 return lane->getRightSideOnEdge() + lane->getWidth() * 0.5 - 0.5 * getVehicleType().getWidth();
544
545}
546
547
548void
550 if (mySegment != nullptr && MESegment::isInvalid(mySegment)) {
551 // segment is vaporization target, do not write this vehicle
552 return;
553 }
555 assert(mySegment == nullptr || *myCurrEdge == &mySegment->getEdge());
556 std::vector<SUMOTime> internals;
557 internals.push_back(myParameter->parametersSet);
558 internals.push_back(myDeparture);
559 internals.push_back((SUMOTime)distance(myRoute->begin(), myCurrEdge));
560 internals.push_back((SUMOTime)myDepartPos * 1000); // store as mm
561 internals.push_back(mySegment == nullptr ? (SUMOTime) - 1 : (SUMOTime)mySegment->getIndex());
562 internals.push_back((SUMOTime)getQueIndex());
563 internals.push_back(myEventTime);
564 internals.push_back(myLastEntryTime);
565 internals.push_back(myBlockTime);
566 out.writeAttr(SUMO_ATTR_STATE, toString(internals));
567 // save past stops
569 stop.write(out, false);
570 // do not write started and ended twice
571 if ((stop.parametersSet & STOP_STARTED_SET) == 0) {
572 out.writeAttr(SUMO_ATTR_STARTED, time2string(stop.started));
573 }
574 if ((stop.parametersSet & STOP_ENDED_SET) == 0) {
575 out.writeAttr(SUMO_ATTR_ENDED, time2string(stop.ended));
576 }
577 out.closeTag();
578 }
579 // save upcoming stops
580 for (const MSStop& stop : myStops) {
581 stop.write(out);
582 }
583 // save parameters
585 for (MSDevice* dev : myDevices) {
586 dev->saveState(out);
587 }
588 for (const auto& item : myMoveReminders) {
589 item.first->saveReminderState(out, *this);
590 }
591 out.closeTag();
592}
593
594
595void
597 if (attrs.hasAttribute(SUMO_ATTR_POSITION)) {
598 throw ProcessError(TL("Error: Invalid vehicles in state (may be a micro state)!"));
599 }
600 int routeOffset;
601 int segIndex;
602 int queIndex;
603 std::istringstream bis(attrs.getString(SUMO_ATTR_STATE));
605 bis >> myDeparture;
606 bis >> routeOffset;
607 bis >> myDepartPos;
608 bis >> segIndex;
609 bis >> queIndex;
610 bis >> myEventTime;
611 bis >> myLastEntryTime;
612 bis >> myBlockTime;
613 myDepartPos /= 1000.; // was stored as mm
614
616 bool ok;
617 myArrivalPos = attrs.get<double>(SUMO_ATTR_ARRIVALPOS_RANDOMIZED, getID().c_str(), ok);
618 }
619
620 // load stops
621 myStops.clear();
623
624 if (hasDeparted()) {
625 myDeparture -= offset;
626 myEventTime -= offset;
627 myLastEntryTime -= offset;
628 myCurrEdge = myRoute->begin() + routeOffset;
629 if (segIndex >= 0) {
631 while (seg->getIndex() != (int)segIndex) {
632 seg = seg->getNextSegment();
633 if (seg == nullptr) {
634 throw ProcessError(TLF("Unknown segment '%:%' for vehicle '%' in loaded state.", (*myCurrEdge)->getID(), segIndex, getID()));
635 }
636 }
637 setSegment(seg, queIndex);
638 if (queIndex == MESegment::PARKING_QUEUE) {
639 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
640 }
641 } else {
642 // on teleport
643 setSegment(nullptr, 0);
644 assert(myEventTime != SUMOTime_MIN);
645 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
646 }
647 // see MSBaseVehicle constructor
650 }
651 }
652 if (myBlockTime != SUMOTime_MAX) {
653 myBlockTime -= offset;
654 }
655 std::istringstream dis(attrs.getString(SUMO_ATTR_DISTANCE));
657}
658
659
660/****************************************************************************/
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:55
#define SIMSTEP
Definition SUMOTime.h:61
#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:46
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:340
bool removeLeaderCar(MEVehicle *v)
Removes the given car from the leading vehicles.
Definition MELoop.cpp:251
void addLeaderCar(MEVehicle *veh, MSLink *link)
Adds the given car to the leading vehicles.
Definition MELoop.cpp:238
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:244
const MSEdge & getEdge() const
Returns the edge this segment belongs to.
Definition MESegment.h:364
int getIndex() const
Returns the running index of the segment in the edge (0 is the most upstream).
Definition MESegment.h:228
static bool isInvalid(const MESegment *segment)
whether the given segment is 0 or encodes vaporization
Definition MESegment.h:447
MESegment * getNextSegment() const
Returns the following segment on the same edge (0 if it is the last).
Definition MESegment.h:236
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)
Definition MEVehicle.cpp:94
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:365
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:284
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:362
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:255
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:368
BaseInfluencer * myInfluencer
An instance of a velocity/lane influencing instance; built in "getInfluencer".
Definition MEVehicle.h:374
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:224
MESegment * mySegment
The segment the vehicle is at.
Definition MEVehicle.h:359
int getQueIndex() const
Returns the index of the que the vehicle is in.
Definition MEVehicle.h:233
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:215
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:206
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:371
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
Abstract in-vehicle / in-person device.
Definition MSDevice.h:62
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:693
void removeWaiting(const SUMOVehicle *vehicle) const
Removes a vehicle from the list of waiting vehicles.
Definition MSEdge.cpp:1470
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:574
double getRightSideOnEdge() const
Definition MSLane.h:1200
double interpolateLanePosToGeometryPos(double lanePos) const
Definition MSLane.h:554
virtual const PositionVector & getShape(bool) const
Definition MSLane.h:294
double getWidth() const
Returns the lane's width.
Definition MSLane.h:640
const Position geometryPositionAtOffset(double offset, double lateralOffset=0) const
Definition MSLane.h:560
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:186
virtual MSTransportableControl & getContainerControl()
Returns the container control.
Definition MSNet.cpp:1259
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:1250
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:54
void stopStarted(const SUMOVehicle *veh, int numPersons, int numContainers, SUMOTime time)
Definition MSStopOut.cpp:82
void stopEnded(const SUMOVehicle *veh, const SUMOVehicleParameter::Stop &stop, const std::string &laneOrEdgeID, bool simEnd=false)
static MSStopOut * getInstance()
Definition MSStopOut.h:60
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 SumoXMLAttr attr, const T &val)
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