Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
MSStateHandler.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2012-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/****************************************************************************/
20// Parser and output filter for routes and vehicles state saving and loading
21/****************************************************************************/
22#include <config.h>
23
24#ifdef HAVE_VERSION_H
25#include <version.h>
26#endif
27
28#include <sstream>
34#include <utils/xml/XMLSubSys.h>
48#include <microsim/MSEdge.h>
49#include <microsim/MSLane.h>
50#include <microsim/MSLink.h>
51#include <microsim/MSGlobals.h>
52#include <microsim/MSNet.h>
56#include <microsim/MSRoute.h>
59#include <netload/NLHandler.h>
60#include "MSStateHandler.h"
61
62#include <mesosim/MESegment.h>
63#include <mesosim/MELoop.h>
64
65// ===========================================================================
66// MSStateTimeHandler method definitions
67// ===========================================================================
68
70MSStateHandler::MSStateTimeHandler::getTime(const std::string& fileName) {
71 // build handler and parser
72 MSStateTimeHandler handler;
73 handler.setFileName(fileName);
74 handler.myTime = -1;
75 SUMOSAXReader* parser = XMLSubSys::getSAXReader(handler);
76 try {
77 if (!parser->parseFirst(fileName)) {
78 delete parser;
79 throw ProcessError(TLF("Can not read XML-file '%'.", fileName));
80 }
81 } catch (ProcessError&) {
82 delete parser;
83 throw;
84 }
85 // parse
86 while (parser->parseNext() && handler.myTime != -1);
87 // clean up
88 if (handler.myTime == -1) {
89 delete parser;
90 throw ProcessError(TLF("Could not parse time from state file '%'", fileName));
91 }
92 delete parser;
93 return handler.myTime;
94}
95
96void
102
103// ===========================================================================
104// method definitions
105// ===========================================================================
106MSStateHandler::MSStateHandler(const std::string& file, const SUMOTime offset) :
107 MSRouteHandler(file, true),
108 myOffset(offset),
109 mySegment(nullptr),
110 myCurrentLane(nullptr),
111 myCurrentLink(nullptr),
112 myAttrs(nullptr),
113 myVCAttrs(nullptr),
114 myLastParameterised(nullptr),
115 myRemoved(0),
116 myFlowIndex(-1),
117 myConstrainedSignal(nullptr) {
118 myAmLoadingState = true;
119 const std::vector<std::string> vehIDs = OptionsCont::getOptions().getStringVector("load-state.remove-vehicles");
120 myVehiclesToRemove.insert(vehIDs.begin(), vehIDs.end());
122}
123
124
128
129
130void
131MSStateHandler::saveState(const std::string& file, SUMOTime step, bool usePrefix) {
132 OutputDevice& out = OutputDevice::getDevice(file, usePrefix);
133 const int statePrecision = OptionsCont::getOptions().getInt("save-state.precision");
134 out.setPrecision(statePrecision);
135 const int defaultPrecision = gPrecision;
136 gPrecision = statePrecision;
137 std::map<SumoXMLAttr, std::string> attrs;
138 attrs[SUMO_ATTR_VERSION] = VERSION_STRING;
139 attrs[SUMO_ATTR_TIME] = time2string(step);
140 attrs[SUMO_ATTR_TYPE] = MSGlobals::gUseMesoSim ? "meso" : "micro";
141 if (OptionsCont::getOptions().getBool("save-state.constraints")) {
142 attrs[SUMO_ATTR_CONSTRAINTS] = "1";
143 }
145 attrs[SUMO_ATTR_RAIL] = "1";
146 }
147 out.writeXMLHeader("snapshot", "state_file.xsd", attrs);
148 if (OptionsCont::getOptions().getBool("save-state.rng")) {
149 saveRNGs(out);
152 }
153 }
155 if (dispatcher != nullptr) {
156 // save early to pre-empty initialization from loaded persons
158 }
162 if (OptionsCont::getOptions().getBool("save-state.transportables")) {
163 if (MSNet::getInstance()->hasPersons()) {
166 out.closeTag();
167 }
168 if (MSNet::getInstance()->hasContainers()) {
171 out.closeTag();
172 }
173 }
175 for (MSEdge* const edge : MSEdge::getAllEdges()) {
177 for (MESegment* s = MSGlobals::gMesoNet->getSegmentForEdge(*edge); s != nullptr; s = s->getNextSegment()) {
178 s->saveState(out);
179 }
180 } else {
181 for (MSLane* const lane : edge->getLanes()) {
182 lane->saveState(out);
183 }
184 }
185 }
188 out.close();
189 gPrecision = defaultPrecision;
190}
191
192
193void
195 MSRouteHandler::myStartElement(element, attrs);
197 switch (element) {
198 case SUMO_TAG_SNAPSHOT: {
200 const std::string& version = attrs.getString(SUMO_ATTR_VERSION);
201 if (version != VERSION_STRING) {
202 WRITE_WARNINGF(TL("State was written with sumo version % (present: %)!"), version, VERSION_STRING);
203 }
204 bool ok;
205 if (attrs.getOpt<bool>(SUMO_ATTR_CONSTRAINTS, nullptr, ok, false)) {
207 }
208 if (attrs.getOpt<bool>(SUMO_ATTR_RAIL, nullptr, ok, false)) {
209 // init before loading any vehicles to ensure that driveways are built early
211 }
212 break;
213 }
214 case SUMO_TAG_RNGSTATE: {
215 if (attrs.hasAttribute(SUMO_ATTR_DEFAULT)) {
217 }
220 }
223 }
226 }
229 }
232 }
235 }
236 break;
237 }
238 case SUMO_TAG_RNGLANE: {
239 const int index = attrs.getInt(SUMO_ATTR_INDEX);
240 const std::string state = attrs.getString(SUMO_ATTR_STATE);
241 MSLane::loadRNGState(index, state);
242 break;
243 }
245 bool ok;
246 std::list<MSLane*> activeLanes;
247 const std::vector<std::string>& laneIDs = attrs.get<std::vector<std::string> >(SUMO_ATTR_LANES, nullptr, ok, false);
248 for (const std::string& laneID : laneIDs) {
249 MSLane* lane = MSLane::dictionary(laneID);
250 if (lane == nullptr) {
251 throw ProcessError(TLF("Unknown lane '%' in loaded state.", laneID));
252 }
253 activeLanes.push_back(lane);
254 }
256 break;
257 }
259 bool ok = true;
260 const SUMOTime lastAdaptation = attrs.get<SUMOTime>(SUMO_ATTR_LAST, nullptr, ok);
261 const int index = attrs.get<int>(SUMO_ATTR_INDEX, nullptr, ok);
262 MSRoutingEngine::initEdgeWeights(SVC_PASSENGER, lastAdaptation, index);
263 if (OptionsCont::getOptions().getBool("device.rerouting.bike-speeds")) {
265 }
267 for (const MSEdge* e : MSEdge::getAllEdges()) {
268 for (MESegment* segment = MSGlobals::gMesoNet->getSegmentForEdge(*e); segment != nullptr; segment = segment->getNextSegment()) {
269 segment->resetCachedSpeeds();
270 }
271 }
272 }
273 break;
274 }
275 case SUMO_TAG_EDGE: {
276#ifdef HAVE_FOX
278#endif
279 break;
280 }
281 case SUMO_TAG_DELAY: {
282 if (myVCAttrs != nullptr) {
283 delete myVCAttrs;
284 }
285 myVCAttrs = attrs.clone();
286 break;
287 }
288 case SUMO_TAG_FLOWSTATE: {
289 bool ok;
291 pars->repetitionsDone = attrs.get<int>(SUMO_ATTR_DONE, pars->id.c_str(), ok);
292 pars->repetitionTotalOffset = attrs.getOptSUMOTimeReporting(SUMO_ATTR_NEXT, pars->id.c_str(), ok, 0);
294 myVehicleParameter = pars;
295 break;
296 }
297 case SUMO_TAG_VTYPE: {
299 break;
300 }
301 case SUMO_TAG_VEHICLE: {
303 myAttrs = attrs.clone();
304 break;
305 }
306 case SUMO_TAG_DEVICE: {
307 myDeviceAttrs.push_back(attrs.clone());
308 break;
309 }
310 case SUMO_TAG_REMINDER: {
311 myReminderAttrs.push_back(attrs.clone());
312 break;
313 }
316 break;
317 }
318 case SUMO_TAG_SEGMENT: {
319 const std::string& segmentID = attrs.getString(SUMO_ATTR_ID);
320 const MSEdge* const edge = MSEdge::dictionary(segmentID.substr(0, segmentID.rfind(":")));
321 int idx = StringUtils::toInt(segmentID.substr(segmentID.rfind(":") + 1));
323 while (idx-- > 0 && mySegment != nullptr) {
325 }
326 if (mySegment == nullptr) {
327 throw ProcessError(TLF("Unknown segment '%' in loaded state.", segmentID));
328 }
329 myQueIndex = 0;
330 break;
331 }
332 case SUMO_TAG_LANE: {
333 bool ok;
334 const std::string laneID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
336 if (myCurrentLane == nullptr) {
337 throw ProcessError(TLF("Unknown lane '%' in loaded state.", laneID));
338 }
339 break;
340 }
342 bool ok;
343 const std::vector<std::string>& vehIDs = attrs.get<std::vector<std::string> >(SUMO_ATTR_VALUE, nullptr, ok, false);
344 std::vector<SUMOVehicle*> vehs;
345 for (const std::string& id : vehIDs) {
346 SUMOVehicle* v = vc.getVehicle(id);
347 // vehicle could be removed due to options
348 if (v != nullptr) {
349 vehs.push_back(v);
350 myArrived.erase(v);
351 }
352 }
354 if (myQueIndex >= mySegment->numQueues()) {
355 throw ProcessError(TLF("Invalid queue index '%' on segment '%'. Check for consistency of lane numbers and queue options.", myQueIndex, mySegment->getID()));
356 }
357 const SUMOTime blockTime = StringUtils::toLong(attrs.getString(SUMO_ATTR_TIME));
358 const SUMOTime entryBlockTime = StringUtils::toLong(attrs.getString(SUMO_ATTR_BLOCKTIME));
359 mySegment->loadState(vehs, blockTime - myOffset, entryBlockTime - myOffset, myQueIndex);
360 myQueIndex++;
361 } else {
363 }
364 break;
365 }
366 case SUMO_TAG_LINK: {
367 bool ok;
368 myCurrentLink = nullptr;
369 const std::string toLaneID = attrs.get<std::string>(SUMO_ATTR_TO, nullptr, ok);
370 for (MSLink* link : myCurrentLane->getLinkCont()) {
371 if (link->getViaLaneOrLane()->getID() == toLaneID) {
372 myCurrentLink = link;
373 }
374 }
375 if (myCurrentLink == nullptr) {
376 throw ProcessError("Unknown link from lane '" + myCurrentLane->getID() + "' to lane '" + toLaneID + "' in loaded state");
377 }
378 break;
379 }
381 bool ok;
382 const std::string vehID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
383 const SUMOTime arrivalTime = attrs.get<SUMOTime>(SUMO_ATTR_ARRIVALTIME, nullptr, ok);
384 const double arrivalSpeed = attrs.get<double>(SUMO_ATTR_ARRIVALSPEED, nullptr, ok);
385 const double leaveSpeed = attrs.get<double>(SUMO_ATTR_DEPARTSPEED, nullptr, ok);
386 const bool setRequest = attrs.get<bool>(SUMO_ATTR_REQUEST, nullptr, ok);
387 const double arrivalSpeedBraking = attrs.get<double>(SUMO_ATTR_ARRIVALSPEEDBRAKING, nullptr, ok);
388 const SUMOTime waitingTime = attrs.get<SUMOTime>(SUMO_ATTR_WAITINGTIME, nullptr, ok);
389 const double dist = attrs.get<double>(SUMO_ATTR_DISTANCE, nullptr, ok);
390 const double latOffset = attrs.getOpt<double>(SUMO_ATTR_POSITION_LAT, nullptr, ok, 0);
391 SUMOVehicle* veh = vc.getVehicle(vehID);
392 myCurrentLink->setApproaching(veh, arrivalTime, arrivalSpeed, leaveSpeed, setRequest, arrivalSpeedBraking, waitingTime, dist, latOffset);
394 MSVehicle* microVeh = dynamic_cast<MSVehicle*>(veh);
395 microVeh->loadPreviousApproaching(myCurrentLink, setRequest, arrivalTime, arrivalSpeed, arrivalSpeedBraking, dist, leaveSpeed);
396 }
397 break;
398 }
401 break;
402 }
405 MSDriveWay::loadState(attrs, element);
406 break;
407 }
408 case SUMO_TAG_PARAM: {
409 bool ok;
410 const std::string key = attrs.get<std::string>(SUMO_ATTR_KEY, nullptr, ok);
411 // circumventing empty string test
412 const std::string val = attrs.hasAttribute(SUMO_ATTR_VALUE) ? attrs.getString(SUMO_ATTR_VALUE) : "";
413 assert(myLastParameterised != 0);
414 if (myLastParameterised != nullptr) {
416 }
417 break;
418 }
420 if (attrs.getString(SUMO_ATTR_TYPE) == "person") {
422 }
423 if (attrs.getString(SUMO_ATTR_TYPE) == "container") {
425 }
426 break;
427 case SUMO_TAG_PERSON:
429 myAttrs = attrs.clone();
430 break;
432 bool ok = true;
433 const std::string signalID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
434 if (!MSNet::getInstance()->getTLSControl().knows(signalID)) {
435 throw InvalidArgument("Rail signal '" + signalID + "' in railSignalConstraints loaded from state is not known");
436 }
438 if (myConstrainedSignal == nullptr) {
439 throw InvalidArgument("Traffic light '" + signalID + "' is not a rail signal");
440 }
441 break;
442 }
443 case SUMO_TAG_PREDECESSOR: // intended fall-through
444 case SUMO_TAG_INSERTION_PREDECESSOR: // intended fall-through
445 case SUMO_TAG_FOE_INSERTION: // intended fall-through
446 case SUMO_TAG_INSERTION_ORDER: // intended fall-through
449 break;
450 case SUMO_TAG_TLLOGIC: {
451 bool ok;
452 const std::string tlID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
453 const std::string programID = attrs.get<std::string>(SUMO_ATTR_PROGRAMID, tlID.c_str(), ok);
454 const int phase = attrs.get<int>(SUMO_ATTR_PHASE, tlID.c_str(), ok);
455 const SUMOTime spentDuration = attrs.get<SUMOTime>(SUMO_ATTR_DURATION, tlID.c_str(), ok);
456 const bool active = attrs.get<bool>(SUMO_ATTR_ACTIVE, tlID.c_str(), ok);
458 MSTrafficLightLogic* tl = tlc.get(tlID, programID);
459 if (tl == nullptr) {
460 if (programID == "online") {
461 WRITE_WARNINGF(TL("Ignoring program '%' for traffic light '%' in loaded state"), programID, tlID);
462 return;
463 } else {
464 throw ProcessError("Unknown program '" + programID + "' for traffic light '" + tlID + "'");
465 }
466 }
467 if (phase >= tl->getPhaseNumber()) {
468 throw ProcessError("Invalid phase '" + toString(phase) + "' for traffic light '" + tlID + "'");
469 }
470 // might not be set if the phase happens to match and there are multiple programs
471 tl->loadState(tlc, myTime, phase, spentDuration, active);
472 if (attrs.hasAttribute(SUMO_ATTR_STATE)) {
473 tl->loadExtraState(attrs.get<std::string>(SUMO_ATTR_STATE, tlID.c_str(), ok));
474 }
475 break;
476 }
477 case SUMO_TAG_DISPATCHER: {
478 bool ok = true;
479 SUMOTime next = attrs.get<SUMOTime>(SUMO_ATTR_NEXT, "dispatcher", ok);
482 break;
483 }
484 default:
485 break;
486 }
487}
488
489
490void
493 switch (element) {
494 case SUMO_TAG_PERSON:
495 case SUMO_TAG_CONTAINER: {
497 MSTransportable* transportable = tc.get(myAttrs->getString(SUMO_ATTR_ID));
498 transportable->loadState(myAttrs->getString(SUMO_ATTR_STATE));
499 tc.fixLoadCount(transportable);
500 delete myAttrs;
501 myAttrs = nullptr;
502 break;
503 }
504 case SUMO_TAG_FLOWSTATE: {
506 myVehicleParameter = nullptr;
507 break;
508 }
509 case SUMO_TAG_SNAPSHOT: {
510 if (myVCAttrs == nullptr) {
511 throw ProcessError(TL("Could not load vehicle control state"));
512 }
521 if (myRemoved > 0) {
522 WRITE_MESSAGEF(TL("Removed % vehicles while loading state."), toString(myRemoved));
524 }
525 for (SUMOVehicle* v : myArrived) {
526 // state was created with active option --keep-after-arrival
527 vc.deleteKeptVehicle(v);
528 }
530 for (MSVehicleControl::constVehIt i = vc.loadedVehBegin(); i != vc.loadedVehEnd(); ++i) {
531 MSVehicle* microVeh = dynamic_cast<MSVehicle*>((*i).second);
532 if (microVeh->hasDeparted() && microVeh->getLane() != nullptr) {
533 // occupancy update must happen after all lane states have been loaded
534 microVeh->updateBestLanes();
535 }
536 }
537 }
539 break;
540 }
541 default:
542 break;
543 }
544 if (element != SUMO_TAG_PARAM && myVehicleParameter == nullptr && myCurrentVType == nullptr) {
545 myLastParameterised = nullptr;
546 }
547}
548
549
550void
552 assert(myVehicleParameter != nullptr);
554 // the vehicle was already counted in MSVehicleControl::setState
556 // make a copy because myVehicleParameter is reset in closeVehicle()
557 const std::string vehID = myVehicleParameter->id;
558 if (myVehiclesToRemove.count(vehID) == 0) {
559
560 // devices that influence simulation behavior must replicate stochastic assignment
561 // also, setting the parameter avoids extra calls to MSDevice::myEquipmentRNG (which would pollute replication)
562 std::vector<std::string> deviceNames;
563 for (auto attrs : myDeviceAttrs) {
564 deviceNames.push_back(MSDevice::getDeviceName(attrs->getString(SUMO_ATTR_ID)));
565 }
568 SUMOVehicle* v = vc.getVehicle(vehID);
569 // special case: transportable devices are not assigned by options
570 if (std::find(deviceNames.begin(), deviceNames.end(), "person") != deviceNames.end()) {
571 dynamic_cast<MSBaseVehicle*>(v)->initTransportableDevice(true);
572 }
573 if (std::find(deviceNames.begin(), deviceNames.end(), "container") != deviceNames.end()) {
574 dynamic_cast<MSBaseVehicle*>(v)->initTransportableDevice(false);
575 }
576 // clean up added param after initializing devices in closeVehicle
578 if (v == nullptr) {
579 throw ProcessError(TLF("Could not load vehicle '%' from state", vehID));
580 }
583
584 if (v->hasDeparted()) {
585 // vehicle already departed: disable pre-insertion rerouting and enable regular routing behavior
586 MSDevice_Routing* routingDevice = static_cast<MSDevice_Routing*>(v->getDevice(typeid(MSDevice_Routing)));
587 if (routingDevice != nullptr) {
589 }
592 // register route for deadlock prevention (vehicleStateChanged would not be called otherwise)
594 }
595 vc.handleTriggeredDepart(v, false);
596 if (v->hasArrived()) {
597 myArrived.insert(v);
598 }
599 }
600 while (!myDeviceAttrs.empty()) {
601 const std::string attrID = myDeviceAttrs.back()->getString(SUMO_ATTR_ID);
602 for (MSVehicleDevice* const dev : v->getDevices()) {
603 if (dev->getID() == attrID) {
604 dev->loadState(*myDeviceAttrs.back());
605 }
606 }
607 delete myDeviceAttrs.back();
608 myDeviceAttrs.pop_back();
609 }
610 bool ok = true;
611 while (!myReminderAttrs.empty()) {
612 const std::string attrID = myReminderAttrs.back()->getString(SUMO_ATTR_ID);
613 const SUMOTime time = myReminderAttrs.back()->get<SUMOTime>(SUMO_ATTR_TIME, nullptr, ok, false);
614 const double pos = myReminderAttrs.back()->get<double>(SUMO_ATTR_POSITION, nullptr, ok, false);
615 const auto& remDict = MSNet::getInstance()->getDetectorControl().getAllReminders();
616 auto it = remDict.find(attrID);
617 if (it != remDict.end()) {
618 it->second->loadReminderState(v->getNumericalID(), time, pos);
619 }
620 delete myReminderAttrs.back();
621 myReminderAttrs.pop_back();
622 }
623 } else {
624 const std::string embeddedRouteID = "!" + myVehicleParameter->id;
625 if (MSRoute::hasRoute(embeddedRouteID)) {
626 ConstMSRoutePtr embedded = MSRoute::dictionary(embeddedRouteID);
627 embedded->checkRemoval();
628 }
629 delete myVehicleParameter;
630
631 myVehicleParameter = nullptr;
632 myRemoved++;
633 while (!myDeviceAttrs.empty()) {
634 delete myDeviceAttrs.back();
635 myDeviceAttrs.pop_back();
636 }
637 while (!myReminderAttrs.empty()) {
638 delete myReminderAttrs.back();
639 myReminderAttrs.pop_back();
640 }
641 }
642 delete myAttrs;
643}
644
645
646void
660
661
662/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define WRITE_MESSAGEF(...)
Definition MsgHandler.h:289
#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 string2time(const std::string &r)
convert string to SUMOTime
Definition SUMOTime.cpp:46
std::string time2string(SUMOTime t, bool humanReadable)
convert SUMOTime to string (independently of global format setting)
Definition SUMOTime.cpp:91
@ SVC_PASSENGER
vehicle is a passenger car (a "normal" car)
@ SVC_BICYCLE
vehicle is a bicycle
@ SUMO_TAG_RAILSIGNAL_CONSTRAINTS
Constraints on switching a rail signal.
@ SUMO_TAG_BIDI_PREDECESSOR
Predecessor constraint for rail signal before bidirectional section.
@ SUMO_TAG_LINK
Link information for state-saving.
@ SUMO_TAG_TRANSPORTABLES
@ SUMO_TAG_APPROACHING
Link-approaching vehicle information for state-saving.
@ SUMO_TAG_INSERTION_PREDECESSOR
Predecessor constraint on insertion before rail signal.
@ SUMO_TAG_DEVICE
@ SUMO_TAG_VTYPE
description of a vehicle/person/container type
@ SUMO_TAG_SUBDRIVEWAY
@ SUMO_TAG_RNGLANE
@ SUMO_TAG_EDGECONTROL
the internal state for edge control
@ SUMO_TAG_FLOWSTATE
a flow state definition (used when saving and loading simulatino state)
@ SUMO_TAG_VEHICLE
description of a vehicle
@ SUMO_TAG_RAILSIGNAL_CONSTRAINT_TRACKER
Saved state for constraint tracker.
@ SUMO_TAG_RNGSTATE
@ SUMO_TAG_REMINDER
@ SUMO_TAG_DISPATCHER
Dispatcher state for saving.
@ SUMO_TAG_DELAY
@ SUMO_TAG_TLLOGIC
a traffic light logic
@ SUMO_TAG_FOE_INSERTION
Predecessor constraint on switching a rail signal.
@ SUMO_TAG_CONTAINER
@ SUMO_TAG_VIEWSETTINGS_VEHICLES
@ SUMO_TAG_ROUTINGENGINE
the internal state for MSRoutingEngine
@ SUMO_TAG_SNAPSHOT
@ SUMO_TAG_LANE
begin/end of the description of a single lane
@ SUMO_TAG_SEGMENT
segment of a lane
@ SUMO_TAG_PARAM
parameter associated to a certain key
@ SUMO_TAG_INSERTION_ORDER
Predecessor constraint on insertion before rail signal.
@ SUMO_TAG_PERSON
@ SUMO_TAG_VEHICLETRANSFER
@ SUMO_TAG_DRIVEWAY
Saved driveway information.
@ SUMO_TAG_PREDECESSOR
Predecessor constraint on switching a rail signal.
@ SUMO_TAG_EDGE
begin/end of the description of an edge
@ SUMO_ATTR_DONE
@ SUMO_ATTR_LAST
@ SUMO_ATTR_NUMBER
@ SUMO_ATTR_ARRIVALSPEED
@ SUMO_ATTR_CONSTRAINTS
@ SUMO_ATTR_DEPART
@ SUMO_ATTR_RNG_INSERTIONCONTROL
@ SUMO_ATTR_ARRIVALTIME
@ SUMO_ATTR_WAITINGTIME
@ SUMO_ATTR_VALUE
@ SUMO_ATTR_RNG_DRIVERSTATE
@ SUMO_ATTR_BEGIN
weights: time range begin
@ SUMO_ATTR_POSITION_LAT
@ SUMO_ATTR_PHASE
@ SUMO_ATTR_LANES
@ SUMO_ATTR_DEFAULT
@ SUMO_ATTR_ARRIVALSPEEDBRAKING
@ SUMO_ATTR_DECEL
@ SUMO_ATTR_NEXT
succesor phase index
@ SUMO_ATTR_RNG_DEVICE_TOC
@ SUMO_ATTR_INDEX
@ SUMO_ATTR_BLOCKTIME
@ SUMO_ATTR_DEPARTSPEED
@ SUMO_ATTR_TO
@ SUMO_ATTR_END
weights: time range end
@ SUMO_ATTR_RNG_DEVICE_BT
@ SUMO_ATTR_DISTANCE
@ SUMO_ATTR_SPEEDFACTOR
@ SUMO_ATTR_TYPE
@ SUMO_ATTR_VERSION
@ SUMO_ATTR_ID
@ SUMO_ATTR_RAIL
@ SUMO_ATTR_PROGRAMID
@ SUMO_ATTR_RNG_ROUTEHANDLER
@ SUMO_ATTR_DURATION
@ SUMO_ATTR_RNG_DEVICE
@ SUMO_ATTR_REQUEST
@ SUMO_ATTR_KEY
@ SUMO_ATTR_POSITION
@ SUMO_ATTR_STATE
The state of a link.
@ SUMO_ATTR_TIME
trigger: the time of the step
@ SUMO_ATTR_ACTIVE
int gPrecision
the precision for floating point outputs
Definition StdDefs.cpp:27
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:49
void setFileName(const std::string &name)
Sets the current file name.
MESegment * getSegmentForEdge(const MSEdge &e, double pos=0)
Get the segment for a given edge at a given position.
Definition MELoop.cpp:339
A single mesoscopic segment (cell)
Definition MESegment.h:50
int numQueues() const
return the number of queues
Definition MESegment.h:215
void loadState(const std::vector< SUMOVehicle * > &vehs, const SUMOTime blockTime, const SUMOTime entryBlockTime, const int queIdx)
Loads the state of this segment with the given parameters.
MESegment * getNextSegment() const
Returns the following segment on the same edge (0 if it is the last).
Definition MESegment.h:238
The base class for microscopic and mesoscopic vehicles.
bool hasDeparted() const
Returns whether this vehicle has already departed.
const std::map< std::string, MSMoveReminder * > & getAllReminders()
retrieve reminders of all detectors (for loading state)
static SumoRNG * getRNG()
A device that performs vehicle rerouting based on current edge speeds.
bool notifyEnter(SUMOTrafficObject &veh, MSMoveReminder::Notification reason, const MSLane *enteredLane=0)
Computes a new route on vehicle insertion.
static SUMOTime getNextDispatchTime()
static void finalizeLoadState()
call during state loading after all transportables are loaded
static void initDispatch(SUMOTime next=-1)
initialize the dispatch algorithm
static MSDispatch * getDispatchAlgorithm()
static SumoRNG * getResponseTimeRNG()
static const std::string LOADSTATE_DEVICENAMES
Definition MSDevice.h:102
static SumoRNG * getEquipmentRNG()
Definition MSDevice.h:92
static std::string getDeviceName(const std::string &id)
extracts the deviceName from the id (which includes holder id) and is subject to special cases
Definition MSDevice.cpp:173
An algorithm that performs distpach for a taxi fleet.
Definition MSDispatch.h:114
virtual void loadState(const SUMOSAXAttributes &attrs)
Loads the state of the device from the given description.
virtual void saveState(OutputDevice &out, SUMOTime nextDispatch) const
Saves the state of the device.
static bool haveDriveWays()
Definition MSDriveWay.h:72
static void loadState(const SUMOSAXAttributes &attrs, int tag)
void setActiveLanes(std::list< MSLane * > lanes)
Reconstruct the current state.
void saveState(OutputDevice &out)
Saves the current state into the given stream.
A road/street connecting two junctions.
Definition MSEdge.h:77
static const MSEdgeVector & getAllEdges()
Returns all edges with a numerical id.
Definition MSEdge.cpp:1118
static bool dictionary(const std::string &id, MSEdge *edge)
Inserts edge into the static dictionary Returns true if the key id isn't already in the dictionary....
Definition MSEdge.cpp:1079
static bool gUseMesoSim
Definition MSGlobals.h:106
static MELoop * gMesoNet
mesoscopic simulation infrastructure
Definition MSGlobals.h:112
bool addFlow(SUMOVehicleParameter *const pars, int index=-1)
Adds parameter for a vehicle flow for departure.
void alreadyDeparted(SUMOVehicle *veh)
stops trying to emit the given vehicle (because it already departed)
SumoRNG * getFlowRNG()
retrieve internal RNG
void saveState(OutputDevice &out)
Saves the current state into the given stream.
Representation of a lane in the micro simulation.
Definition MSLane.h:84
void loadState(const std::vector< SUMOVehicle * > &vehs)
Loads the state of this segment with the given parameters.
Definition MSLane.cpp:3790
static void saveRNGStates(OutputDevice &out)
save random number generator states to the given output device
Definition MSLane.cpp:4686
static void loadRNGState(int index, const std::string &state)
load random number generator state for the given rng index
Definition MSLane.cpp:4696
static bool dictionary(const std::string &id, MSLane *lane)
Static (sic!) container methods {.
Definition MSLane.cpp:2510
const std::vector< MSLink * > & getLinkCont() const
returns the container with all links !!!
Definition MSLane.h:735
@ NOTIFICATION_DEPARTED
The vehicle has departed (was inserted into the network)
@ NEWROUTE
The vehicle got a new route.
MSDetectorControl & getDetectorControl()
Returns the detector control.
Definition MSNet.h:455
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition MSNet.cpp:199
MSTLLogicControl & getTLSControl()
Returns the tls logics control.
Definition MSNet.h:465
virtual MSTransportableControl & getContainerControl()
Returns the container control.
Definition MSNet.cpp:1283
MSInsertionControl & getInsertionControl()
Returns the insertion control.
Definition MSNet.h:445
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition MSNet.h:392
virtual MSTransportableControl & getPersonControl()
Returns the person control.
Definition MSNet.cpp:1274
MSEdgeControl & getEdgeControl()
Returns the edge control.
Definition MSNet.h:435
static void loadState(const SUMOSAXAttributes &attrs)
loads the constraint state from the given attrs
static void clearAll()
Remove all constraints before quick-loading state.
void vehicleStateChanged(const SUMOVehicle *const vehicle, MSNet::VehicleState to, const std::string &info="")
Called if a vehicle changes its state.
static MSRailSignalControl & getInstance()
A signal for rails.
Parser and container for routes during their loading.
bool myAmLoadingState
whether a state file is being loaded
virtual void myStartElement(int element, const SUMOSAXAttributes &attrs) override
Called on the opening of a tag;.
static SumoRNG * getParsingRNG()
get parsing RNG
virtual void closeVehicle() override
Ends the processing of a vehicle (note: is virtual because is reimplemented in MSStateHandler)
static void dict_saveState(OutputDevice &out)
Saves all known routes into the given stream.
Definition MSRoute.cpp:268
static bool hasRoute(const std::string &id)
returns whether a route with the given id exists
Definition MSRoute.cpp:159
static bool dictionary(const std::string &id, ConstMSRoutePtr route)
Adds a route to the dictionary.
Definition MSRoute.cpp:116
static void saveState(OutputDevice &out)
Saves the state (i.e. recorded speeds)
static void initEdgeWeights(SUMOVehicleClass svc, SUMOTime lastAdaption=-1, int index=-1)
initialize the edge weights if not done before
static void loadState(const SUMOSAXAttributes &attrs)
Loads the state.
handler to read only the simulation time from a state
static SUMOTime getTime(const std::string &fileName)
parse time from state file
void myStartElement(int element, const SUMOSAXAttributes &attrs)
Callback method for an opening tag to implement by derived classes.
MSRailSignal * myConstrainedSignal
rail signal for which constraints are being loaded
SUMOSAXAttributes * myAttrs
cached attrs (used when loading vehicles or transportables)
MSStateHandler(const std::string &file, const SUMOTime offset)
standard constructor
static void saveState(const std::string &file, SUMOTime step, bool usePrefix=true)
Saves the current state.
int myQueIndex
que index
SUMOTime myTime
time
std::set< std::string > myVehiclesToRemove
vehicles that shall be removed when loading state
int myRemoved
vehicles that were removed when loading state
MSLink * myCurrentLink
current link being loaded
MESegment * mySegment
segment
MSLane * myCurrentLane
current lane being loaded
static void saveRNGs(OutputDevice &out)
save the state of random number generators
const SUMOTime myOffset
offset
Parameterised * myLastParameterised
the last object that potentially carries parameters
void closeVehicle()
Ends the processing of a vehicle.
void myStartElement(int element, const SUMOSAXAttributes &attrs)
Called on the opening of a tag;.
std::vector< SUMOSAXAttributes * > myDeviceAttrs
cached device and reminder attrs (used when loading vehicles)
std::vector< SUMOSAXAttributes * > myReminderAttrs
SUMOSAXAttributes * myVCAttrs
cached attrs for delayed loading of MSVehicleControl state
std::set< SUMOVehicle * > myArrived
vehicles that have arrived
void myEndElement(int element)
Called when a closing tag occurs.
int myFlowIndex
index of the currently parse flowState
virtual ~MSStateHandler()
standard destructor
MSTrafficLightLogic * getDefault() const
return the default program (that last used program except TRACI_PROGRAM)
A class that stores and controls tls and switching of their programs.
bool knows(const std::string &id) const
Returns the information whether the named tls is stored.
void saveState(OutputDevice &out)
Saves the current tls states into the given stream.
TLSLogicVariants & get(const std::string &id) const
Returns the variants of a named tls.
The parent class for traffic light logics.
virtual int getPhaseNumber() const =0
Returns the number of phases.
virtual void loadState(MSTLLogicControl &tlcontrol, SUMOTime t, int step, SUMOTime spentDuration, bool active)
restores the tls state
virtual void loadExtraState(const std::string &)
void loadState(const std::string &state)
Reconstruct the current state.
void fixLoadCount(const MSTransportable *transportable)
decrement counter to avoid double counting transportables loaded from state
void saveState(OutputDevice &out)
Saves the current state into the given stream.
MSTransportable * get(const std::string &id) const
Returns the named transportable, if existing.
void loadState(const std::string &state)
Reconstructs the current state.
The class responsible for building and deletion of vehicles.
void discountStateRemoved(int n)
discount vehicles that were removed during state loading
SUMOVehicle * getVehicle(const std::string &id) const
Returns the vehicle with the given id.
void deleteKeptVehicle(SUMOVehicle *veh)
when a vehicle is kept after arrival, schedule later deletion
std::map< std::string, SUMOVehicle * >::const_iterator constVehIt
Definition of the internal vehicles map iterator.
constVehIt loadedVehBegin() const
Returns the begin of the internal vehicle map.
void handleTriggeredDepart(SUMOVehicle *v, bool add)
register / unregister depart-triggered vehicles with edges
void saveState(OutputDevice &out)
Saves the current state into the given stream.
constVehIt loadedVehEnd() const
Returns the end of the internal vehicle map.
void setState(int runningVehNo, int loadedVehNo, int endedVehNo, double totalDepartureDelay, double totalTravelTime, double maxSpeedFactor, double minDecel)
Sets the current state variables as loaded from the stream.
Abstract in-vehicle device.
Representation of a vehicle in the micro simulation.
Definition MSVehicle.h:77
void updateBestLanes(bool forceRebuild=false, const MSLane *startLane=0)
computes the best lanes to use in order to continue the route
const MSLane * getLane() const
Returns the lane the vehicle is on.
Definition MSVehicle.h:581
void loadPreviousApproaching(MSLink *link, bool setRequest, SUMOTime arrivalTime, double arrivalSpeed, double arrivalSpeedBraking, double dist, double leaveSpeed)
static MSVehicleTransfer * getInstance()
Returns the instance of this object.
void saveState(OutputDevice &out)
Saves the current state into the given stream.
void loadState(const SUMOSAXAttributes &attrs, const SUMOTime offset, MSVehicleControl &vc)
Loads one transfer vehicle state from the given description.
static Parameterised * addPredecessorConstraint(int element, const SUMOSAXAttributes &attrs, MSRailSignal *rs)
const std::string & getID() const
Returns the id.
Definition Named.h:74
static SumoRNG * getRNG()
int getInt(const std::string &name) const
Returns the int-value of the named option (only for Option_Integer)
const StringVector & getStringVector(const std::string &name) const
Returns the list of string-value of the named option (only for Option_StringVector)
static OptionsCont & getOptions()
Retrieves the options.
Static storage of an output device and its base (abstract) implementation.
void close()
Closes the device and removes it from the dictionary.
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
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 setPrecision(int precision=gPrecision)
Sets the precision or resets it to default.
static OutputDevice & getDevice(const std::string &name, bool usePrefix=true)
Returns the described OutputDevice.
bool writeXMLHeader(const std::string &rootElement, const std::string &schemaFile, std::map< SumoXMLAttr, std::string > attrs=std::map< SumoXMLAttr, std::string >(), bool includeConfig=true)
Writes an XML header with optional configuration.
virtual void setParameter(const std::string &key, const std::string &value)
Sets a parameter.
static void loadState(const std::string &state, SumoRNG *rng=nullptr)
load rng state from string
Definition RandHelper.h:244
static std::string saveState(SumoRNG *rng=nullptr)
save rng state to string
Definition RandHelper.h:231
bool myAllowInternalRoutes
whether references to internal routes are allowed in this context
SUMOVehicleParameter * myVehicleParameter
Parameter of the current vehicle, trip, person, container or flow.
SUMOVTypeParameter * myCurrentVType
The currently parsed vehicle type.
virtual void myEndElement(int element)
Called when a closing tag occurs.
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 getOpt(int attr, const char *objectid, bool &ok, T defaultValue=T(), bool report=true) const
Tries to read given attribute assuming it is an int.
SUMOTime getOptSUMOTimeReporting(int attr, const char *objectid, bool &ok, SUMOTime defaultValue, bool report=true) const
Tries to read given attribute assuming it is a SUMOTime.
T get(int attr, const char *objectid, bool &ok, bool report=true) const
Tries to read given attribute assuming it is an int.
virtual SUMOSAXAttributes * clone() const =0
return a new deep-copy attributes object
virtual bool hasAttribute(int id) const =0
Returns the information whether the named (by its enum-value) attribute is within the current list.
int getInt(int id) const
Returns the int-value of the named (by its enum-value) attribute.
double getFloat(int id) const
Returns the double-value of the named (by its enum-value) attribute.
SAX-reader encapsulation containing binary reader.
bool parseFirst(std::string systemID)
Start parsing the given file using parseFirst of myXMLReader.
bool parseNext()
Continue a progressive parse started by parseFirst.
virtual NumericalID getNumericalID() const =0
return the numerical ID which is only for internal usage
virtual MSDevice * getDevice(const std::type_info &type) const =0
Returns a device of the given type if it exists or nullptr if not.
virtual const SUMOVehicleParameter & getParameter() const =0
Returns the vehicle's parameter (including departure definition)
virtual bool hasArrived() const =0
Returns whether this object has arrived.
Representation of a vehicle.
Definition SUMOVehicle.h:63
virtual void setChosenSpeedFactor(const double factor)=0
virtual const std::vector< MSVehicleDevice * > & getDevices() const =0
Returns this vehicle's devices.
virtual bool hasDeparted() const =0
Returns whether this vehicle has departed.
virtual void loadState(const SUMOSAXAttributes &attrs, const SUMOTime offset)=0
Loads the state of this vehicle from the given description.
Structure representing possible vehicle parameter.
long long int repetitionsDone
The number of times the vehicle was already inserted.
SUMOTime repetitionTotalOffset
The offset between depart and the time for the next vehicle insertions.
std::string id
The vehicle's id.
static SUMOVehicleParameter * parseFlowAttributes(SumoXMLTag tag, const SUMOSAXAttributes &attrs, const bool hardFail, const bool needID, const SUMOTime beginDefault, const SUMOTime endDefault, const bool allowInternalRoutes=false)
Parses a flow's attributes.
static long long int toLong(const std::string &sData)
converts a string into the long value described by it by calling the char-type converter,...
static int toInt(const std::string &sData)
converts a string into the integer value described by it by calling the char-type converter,...
static SUMOSAXReader * getSAXReader(SUMOSAXHandler &handler, const bool isNet=false, const bool isRoute=false)
Builds a reader and assigns the handler to it.