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
74 // interpolation may cause problems with arrivals and calibrators
75 const auto& mesoPos = getEdge()->getMesoPositions();
76 const auto& posIt = mesoPos.find(this);
77 if (posIt != mesoPos.end()) {
78 return posIt->second.first;
79 }
80 }
81 return mySegment == nullptr ? 0. : (double)mySegment->getIndex() * mySegment->getLength();
82}
83
84
85double
87 const MSLane* const lane = getEdge()->getLanes()[MAX2(0, getQueIndex())];
89}
90
91
92double
94 const MSLane* const lane = getEdge()->getLanes()[MAX2(0, getQueIndex())];
96}
97
98
99const MSEdge*
101 return mySegment != nullptr ? &mySegment->getEdge() : getEdge();
102}
103
104
106MEVehicle::getPosition(const double offset) const {
107 const MSLane* const lane = getEdge()->getLanes()[MAX2(0, getQueIndex())];
108 return lane->geometryPositionAtOffset(getPositionOnLane() + offset);
109}
110
111
113MEVehicle::getBoundingBox(double offset) const {
114 double a = getAngle() + M_PI; // angle pointing backwards
115 double l = getLength();
116 Position pos = getPosition();
117 Position backPos = pos + Position(l * cos(a), l * sin(a));
118 PositionVector centerLine;
119 centerLine.push_back(pos);
120 centerLine.push_back(backPos);
121 if (offset != 0) {
122 centerLine.extrapolate2D(offset);
123 }
124 PositionVector result = centerLine;
125 result.move2side(MAX2(0.0, 0.5 * myType->getWidth() + offset));
126 centerLine.move2side(MIN2(0.0, -0.5 * myType->getWidth() - offset));
127 result.append(centerLine.reverse(), POSITION_EPS);
128 return result;
129}
130
131
132double
134 if (getWaitingTime() > 0 || isStopped()) {
135 return 0;
136 } else {
137 return getAverageSpeed();
138 }
139}
140
141
142double
144 // cache for thread safety
145 MESegment* s = mySegment;
146 if (s == nullptr || myQueIndex == MESegment::PARKING_QUEUE) {
147 return 0;
148 } else {
150 getEdge()->getLanes()[myQueIndex]->getVehicleMaxSpeed(this));
151 }
152}
153
154
155double
158 const double v = getSpeed();
159 return MIN2(link->getViaLaneOrLane()->getVehicleMaxSpeed(this),
160 (double)sqrt(2 * link->getLength() * getVehicleType().getCarFollowModel().getMaxAccel() + v * v));
161}
162
163
164double
166 earliestArrival = MAX2(myEventTime, earliestArrival - DELTA_T); // event times have subsecond resolution
167 return mySegment->getLength() / STEPS2TIME(earliestArrival - myLastEntryTime);
168}
169
170
171bool
173 // vehicle has just entered a new edge. Position is 0
174 if (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) { // may happen during teleport
175 return true;
176 }
177 ++myCurrEdge;
178 if ((*myCurrEdge)->isVaporizing()) {
179 return true;
180 }
181 // update via
182 if (myParameter->via.size() > 0 && (*myCurrEdge)->getID() == myParameter->via.front()) {
183 myParameter->via.erase(myParameter->via.begin());
184 }
185 return hasArrived();
186}
187
188
189bool
191 // mySegment may be 0 due to teleporting or arrival
192 return (myCurrEdge == myRoute->end() - 1 || (myParameter->arrivalEdge >= 0 && getRoutePosition() >= myParameter->arrivalEdge)) && (
193 (mySegment == nullptr)
195 || getPositionOnLane() > myArrivalPos - POSITION_EPS);
196}
197
198
199bool
201 return getSegment() != nullptr;
202}
203
204
205bool
207 return false;
208}
209
210
211void
213 if (link != nullptr) {
214 const double speed = getSpeed();
215 link->setApproaching(this, getEventTime() + (link->getState() == LINKSTATE_ALLWAY_STOP ?
216 (SUMOTime)RandHelper::rand((int)2) : 0), // tie braker
217 speed, link->getViaLaneOrLane()->getVehicleMaxSpeed(this), true,
218 speed, getWaitingTime(),
219 // @note: dist is not used by meso (getZipperSpeed is never called)
220 getSegment()->getLength(), 0);
221 }
222}
223
224
225bool
226MEVehicle::replaceRoute(ConstMSRoutePtr newRoute, const std::string& info, bool onInit, int offset, bool addRouteStops, bool removeStops, std::string* msgReturn) {
227 MSLink* const oldLink = mySegment != nullptr ? mySegment->getLink(this) : nullptr;
228 if (MSBaseVehicle::replaceRoute(newRoute, info, onInit, offset, addRouteStops, removeStops, msgReturn)) {
229 if (mySegment != nullptr) {
230 MSLink* const newLink = mySegment->getLink(this);
231 // update approaching vehicle information
232 if (oldLink != newLink) {
233 if (oldLink != nullptr) {
234 oldLink->removeApproaching(this);
235 }
236 setApproaching(newLink);
237 }
238 }
239 return true;
240 }
241 return false;
242}
243
244
247 const SUMOTime initialTime = time;
248 bool hadStop = false;
249 for (MSStop& stop : myStops) {
250 if (stop.joinTriggered) {
251 WRITE_WARNINGF(TL("Join stops are not available in meso yet (vehicle '%', segment '%')."),
252 getID(), mySegment->getID());
253 continue;
254 }
255 if (stop.edge != myCurrEdge || stop.segment != mySegment) {
256 break;
257 }
258 const SUMOTime cur = time;
259 if (stop.duration > 0) { // it might be a triggered stop with duration -1
260 time += stop.duration;
261 }
262 if (stop.pars.until > time) {
263 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
264 // travel time is overestimated of the stop is not at the start of the segment
265 time = stop.pars.until;
266 }
267 if (MSGlobals::gUseStopEnded && stop.pars.ended >= 0) {
268 time = MAX2(cur, stop.pars.ended);
269 }
270 if (!stop.reached) {
271 stop.reached = true;
272 stop.pars.started = myLastEntryTime;
273 stop.endBoarding = stop.pars.extension >= 0 ? time + stop.pars.extension : SUMOTime_MAX;
274 if (MSStopOut::active()) {
275 if (!hadStop) {
277 } else {
278 WRITE_WARNINGF(TL("Vehicle '%' has multiple stops on segment '%', time=% (stop-output will be merged)."),
279 getID(), mySegment->getID(), time2string(time));
280 }
281 }
282 MSDevice_Taxi* taxi = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
283 if (taxi != nullptr) {
284 taxi->notifyMove(*this, 0, 0, 0);
285 }
286 }
287 if (stop.triggered || stop.containerTriggered || stop.joinTriggered) {
288 time = MAX2(time, cur + DELTA_T);
289 }
290 hadStop = true;
291 }
292 MSDevice_Tripinfo* tripinfo = static_cast<MSDevice_Tripinfo*>(getDevice(typeid(MSDevice_Tripinfo)));
293 if (tripinfo != nullptr) {
294 tripinfo->updateStopTime(time - initialTime);
295 }
296 return time;
297}
298
299
300bool
302 if (isStopped()) {
303 const SUMOTime now = SIMSTEP;
304 MSStop& stop = myStops.front();
305 stop.pars.ended = now;
306 for (const auto& rem : myMoveReminders) {
307 rem.first->notifyStopEnded();
308 }
309 if (MSStopOut::active()) {
310 MSStopOut::getInstance()->stopEnded(this, stop);
311 }
312 myPastStops.push_back(stop.pars);
313 myPastStops.back().routeIndex = (int)(stop.edge - myRoute->begin());
317 }
318 myStops.pop_front();
319 if (myEventTime > now) {
320 // if this is an aborted stop we need to change the event time of the vehicle
321 if (MSGlobals::gMesoNet->removeLeaderCar(this)) {
322 myEventTime = now + 1;
323 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
324 }
325 }
326 return true;
327 }
328 return false;
329}
330
331
332double
335 for (const MSStop& stop : myStops) {
336 if (stop.reached) {
337 time += stop.duration;
338 if (stop.pars.until > time) {
339 // @note: this assumes the stop is reached at time. With the way this is called in MESegment (time == entryTime),
340 // travel time is overestimated of the stop is not at the start of the segment
341 time = stop.pars.until;
342 }
343 } else {
344 break;
345 }
346 }
347 return STEPS2TIME(time - myLastEntryTime);
348}
349
350
351void
353 assert(isStopped());
354 double lastPos = -1;
355 bool hadStop = false;
356 while (!myStops.empty()) {
357 MSStop& stop = myStops.front();
358 if (stop.edge != myCurrEdge || stop.segment != mySegment || stop.pars.endPos <= lastPos) {
359 break;
360 }
361 lastPos = stop.pars.endPos;
362 MSNet* const net = MSNet::getInstance();
363 SUMOTime dummy = -1; // boarding- and loading-time are not considered
364 if (hadStop && MSStopOut::active()) {
365 stop.reached = true;
367 }
368 if (net->hasPersons()) {
369 net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
370 }
371 if (net->hasContainers()) {
372 net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy);
373 }
375 hadStop = true;
376 }
377 if (getWaitingTime() > 0) {
378 // entry back onto the road was blocked for some time
379 MSDevice_Tripinfo* tripinfoDevice = static_cast<MSDevice_Tripinfo*>(getDevice(typeid(MSDevice_Tripinfo)));
380 if (tripinfoDevice != nullptr) {
381 tripinfoDevice->recordMesoParkingTimeLoss(getWaitingTime());
382 }
383 }
385}
386
387
388bool
390 if (mySegment == nullptr) {
391 return true;
392 }
393 MSNet* const net = MSNet::getInstance();
394 SUMOTime dummy = -1; // boarding- and loading-time are not considered
395 for (MSStop& stop : myStops) {
396 if (!stop.reached) {
397 break;
398 }
399 if (net->getCurrentTimeStep() > stop.endBoarding) {
400 if (stop.triggered || stop.containerTriggered) {
401 MSDevice_Taxi* taxiDevice = static_cast<MSDevice_Taxi*>(getDevice(typeid(MSDevice_Taxi)));
402 if (taxiDevice != nullptr) {
403 taxiDevice->cancelCurrentCustomers();
404 }
405 stop.triggered = false;
406 stop.containerTriggered = false;
407 }
411 }
412 }
413 if (stop.triggered) {
415 // we could not check this on entering the segment because there may be persons who still want to leave
416 WRITE_WARNINGF(TL("Vehicle '%' ignores triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
417 stop.triggered = false;
421 }
422 } else if (!net->hasPersons() || !net->getPersonControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
426 }
427 return false;
428 }
429 }
430 if (stop.containerTriggered) {
431 if (getVehicleType().getContainerCapacity() == getContainerNumber()) {
432 // we could not check this on entering the segment because there may be containers who still want to leave
433 WRITE_WARNINGF(TL("Vehicle '%' ignores container triggered stop on lane '%' due to capacity constraints."), getID(), stop.lane->getID());
434 stop.containerTriggered = false;
438 }
439 } else if (!net->hasContainers() || !net->getContainerControl().loadAnyWaiting(&mySegment->getEdge(), this, dummy, dummy)) {
443 }
444 return false;
445 }
446 }
447 if (stop.joinTriggered) {
448 // TODO do something useful here
449 return false;
450 }
451 }
452 return mySegment->isOpen(this);
453}
454
455
456double
458 if (mySegment == nullptr) {
459 return 0;
460 } else {
461 return STEPS2TIME(mySegment->getLinkPenalty(this));
462 }
463}
464
465
466void
468 for (MoveReminderCont::iterator i = myMoveReminders.begin(); i != myMoveReminders.end(); ++i) {
469 if (i->first == rem) {
472 getLastEntryTime(), currentTime, exitTime, false);
473#ifdef _DEBUG
474 if (myTraceMoveReminders) {
475 traceMoveReminder("notifyMove", i->first, i->second, true);
476 }
477#endif
478 return;
479 }
480 }
481}
482
483
484void
485MEVehicle::updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave, const MSMoveReminder::Notification reason) {
486 // segments of the same edge have the same reminder so no cleaning up must take place
487 const bool cleanUp = isLeave && (reason != MSMoveReminder::NOTIFICATION_SEGMENT);
488 for (MoveReminderCont::iterator rem = myMoveReminders.begin(); rem != myMoveReminders.end();) {
490 rem->first->updateDetector(*this, mySegment->getIndex() * mySegment->getLength(),
492 getLastEntryTime(), currentTime, exitTime, cleanUp);
493#ifdef _DEBUG
494 if (myTraceMoveReminders) {
495 traceMoveReminder("notifyMove", rem->first, rem->second, true);
496 }
497#endif
498 }
499 if (!isLeave || rem->first->notifyLeave(*this, mySegment == nullptr ? 0 : mySegment->getLength(), reason)) {
500#ifdef _DEBUG
501 if (isLeave && myTraceMoveReminders) {
502 traceMoveReminder("notifyLeave", rem->first, rem->second, true);
503 }
504#endif
505
506 if (isLeave) {
507 rem->second += getEdge()->getLength();
508#ifdef _DEBUG
509 if (myTraceMoveReminders) {
510 traceMoveReminder("adaptedPos", rem->first, rem->second, true);
511 }
512#endif
513 }
514 ++rem;
515 } else {
516#ifdef _DEBUG
517 if (myTraceMoveReminders) {
518 traceMoveReminder("remove", rem->first, rem->second, false);
519 }
520#endif
521 rem = myMoveReminders.erase(rem);
522 }
523 }
526 }
527}
528
529
532 if (myInfluencer == nullptr) {
534 }
535 return *myInfluencer;
536}
537
538
543
544
545void
550
551
552int
554 return getSegment() != nullptr ? getSegment()->getIndex() : -1;
555}
556
557
558double
559MEVehicle::getRightSideOnEdge(const MSLane* /*lane*/) const {
560 if (mySegment == nullptr || mySegment->getIndex() >= getEdge()->getNumLanes()) {
561 return 0;
562 }
563 const MSLane* lane = getEdge()->getLanes()[mySegment->getIndex()];
564 return lane->getRightSideOnEdge() + lane->getWidth() * 0.5 - 0.5 * getVehicleType().getWidth();
565
566}
567
568
569void
571 if (mySegment != nullptr && MESegment::isInvalid(mySegment)) {
572 // segment is vaporization target, do not write this vehicle
573 return;
574 }
576 assert(mySegment == nullptr || *myCurrEdge == &mySegment->getEdge() || mySegment->getEdge().isInternal());
577 std::vector<SUMOTime> internals;
578 internals.push_back(myParameter->parametersSet);
579 internals.push_back(myDeparture);
580 internals.push_back((SUMOTime)distance(myRoute->begin(), myCurrEdge));
581 internals.push_back((SUMOTime)myDepartPos * 1000); // store as mm
582 internals.push_back(mySegment == nullptr ? (SUMOTime) - 1 : (SUMOTime)mySegment->getIndex());
583 internals.push_back((SUMOTime)getQueIndex());
584 internals.push_back(myEventTime);
585 internals.push_back(myLastEntryTime);
586 internals.push_back(myBlockTime);
587 internals.push_back(isStopped());
588 internals.push_back(myPastStops.size());
589 out.writeAttr(SUMO_ATTR_STATE, toString(internals));
590 // save past stops
592 stop.write(out, false);
593 // do not write started and ended twice
594 if ((stop.parametersSet & STOP_STARTED_SET) == 0) {
595 out.writeAttr(SUMO_ATTR_STARTED, time2string(stop.started));
596 }
597 if ((stop.parametersSet & STOP_ENDED_SET) == 0) {
598 out.writeAttr(SUMO_ATTR_ENDED, time2string(stop.ended));
599 }
600 out.closeTag();
601 }
602 // save upcoming stops
603 for (const MSStop& stop : myStops) {
604 stop.write(out);
605 }
606 // save parameters
608 for (MSDevice* dev : myDevices) {
609 dev->saveState(out);
610 }
611 for (const auto& item : myMoveReminders) {
612 item.first->saveReminderState(out, *this);
613 }
614 out.closeTag();
615}
616
617
618void
620 if (attrs.hasAttribute(SUMO_ATTR_POSITION)) {
621 throw ProcessError(TL("Error: Invalid vehicles in state (may be a micro state)!"));
622 }
623 int routeOffset;
624 bool stopped;
625 int pastStops;
626 int segIndex;
627 int queIndex;
628 std::istringstream bis(attrs.getString(SUMO_ATTR_STATE));
630 bis >> myDeparture;
631 bis >> routeOffset;
632 bis >> myDepartPos;
633 bis >> segIndex;
634 bis >> queIndex;
635 bis >> myEventTime;
636 bis >> myLastEntryTime;
637 bis >> myBlockTime;
638 bis >> stopped;
639 bis >> pastStops;
640 myDepartPos /= 1000.; // was stored as mm
641
643 bool ok;
644 myArrivalPos = attrs.get<double>(SUMO_ATTR_ARRIVALPOS_RANDOMIZED, getID().c_str(), ok);
645 }
646
647 // load stops
648 myStops.clear();
650
651 if (hasDeparted()) {
652 myDeparture -= offset;
653 myEventTime -= offset;
654 myLastEntryTime -= offset;
655 myCurrEdge = myRoute->begin() + routeOffset;
656 // fix stops
657 while (pastStops > 0) {
658 for (const auto& rem : myMoveReminders) {
659 rem.first->notifyStopEnded();
660 }
661 myPastStops.push_back(myStops.front().pars);
662 myPastStops.back().routeIndex = (int)(myStops.front().edge - myRoute->begin());
663 myStops.pop_front();
664 pastStops--;
665 }
666 if (segIndex >= 0) {
668 while (seg->getIndex() != (int)segIndex) {
669 seg = seg->getNextSegment();
670 if (seg == nullptr) {
671 throw ProcessError(TLF("Unknown segment '%:%' for vehicle '%' in loaded state.", (*myCurrEdge)->getID(), segIndex, getID()));
672 }
673 }
674 setSegment(seg, queIndex);
675 if (queIndex == MESegment::PARKING_QUEUE) {
676 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
677 getCurrentEdge()->getLanes()[0]->addParking(this);
678 }
679 } else {
680 // on teleport
681 setSegment(nullptr, 0);
682 assert(myEventTime != SUMOTime_MIN);
683 MSGlobals::gMesoNet->addLeaderCar(this, nullptr);
684 }
685 // see MSBaseVehicle constructor
688 }
689 }
690 if (myBlockTime != SUMOTime_MAX) {
691 myBlockTime -= offset;
692 }
693 std::istringstream dis(attrs.getString(SUMO_ATTR_DISTANCE));
695 if (stopped) {
696 myStops.front().startedFromState = true;
697 myStops.front().reached = true;
698 }
699}
700
701
702/****************************************************************************/
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:251
const MSEdge & getEdge() const
Returns the edge this segment belongs to.
Definition MESegment.h:371
int getIndex() const
Returns the running index of the segment in the edge (0 is the most upstream).
Definition MESegment.h:235
static bool isInvalid(const MESegment *segment)
whether the given segment is 0 or encodes vaporization
Definition MESegment.h:454
MESegment * getNextSegment() const
Returns the following segment on the same edge (0 if it is the last).
Definition MESegment.h:243
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:86
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)
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:93
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
bool isInternal() const
return whether this edge is an internal edge
Definition MSEdge.h:269
const std::map< const MEVehicle *, std::pair< double, int > > & getMesoPositions() const
Definition MSEdge.cpp:1734
void removeWaiting(const SUMOVehicle *vehicle) const
Removes a vehicle from the list of waiting vehicles.
Definition MSEdge.cpp:1494
static bool gMesoInterpolatePos
Definition MSGlobals.h:112
static bool gCheckRoutes
Definition MSGlobals.h:91
static MELoop * gMesoNet
mesoscopic simulation infrastructure
Definition MSGlobals.h:115
static bool gUseStopEnded
whether the simulation should replay previous stop times
Definition MSGlobals.h:136
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:1295
SUMOTime getCurrentTimeStep() const
Returns the current simulation step.
Definition MSNet.h:334
bool hasContainers() const
Returns whether containers are simulated.
Definition MSNet.h:435
bool hasPersons() const
Returns whether persons are simulated.
Definition MSNet.h:419
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition MSNet.h:402
virtual MSTransportableControl & getPersonControl()
Returns the person control.
Definition MSNet.cpp:1286
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