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 if (lastAdaptation >= 0) {
263 MSRoutingEngine::initWeightUpdate(lastAdaptation);
264 }
265 MSRoutingEngine::initEdgeWeights(SVC_PASSENGER, lastAdaptation, index);
266 if (OptionsCont::getOptions().getBool("device.rerouting.bike-speeds")) {
268 }
270 for (const MSEdge* e : MSEdge::getAllEdges()) {
271 for (MESegment* segment = MSGlobals::gMesoNet->getSegmentForEdge(*e); segment != nullptr; segment = segment->getNextSegment()) {
272 segment->resetCachedSpeeds();
273 }
274 }
275 }
276 break;
277 }
278 case SUMO_TAG_EDGE: {
279#ifdef HAVE_FOX
281#endif
282 break;
283 }
284 case SUMO_TAG_DELAY: {
285 if (myVCAttrs != nullptr) {
286 delete myVCAttrs;
287 }
288 bool ok;
290 myVCAttrs = attrs.clone();
291 break;
292 }
293 case SUMO_TAG_FLOWSTATE: {
294 bool ok;
296 pars->repetitionsDone = attrs.get<int>(SUMO_ATTR_DONE, pars->id.c_str(), ok);
297 pars->repetitionTotalOffset = attrs.getOptSUMOTimeReporting(SUMO_ATTR_NEXT, pars->id.c_str(), ok, 0);
299 myVehicleParameter = pars;
300 break;
301 }
302 case SUMO_TAG_VTYPE: {
304 break;
305 }
306 case SUMO_TAG_VEHICLE: {
308 myAttrs = attrs.clone();
309 break;
310 }
311 case SUMO_TAG_DEVICE: {
312 myDeviceAttrs.push_back(attrs.clone());
313 break;
314 }
315 case SUMO_TAG_REMINDER: {
316 myReminderAttrs.push_back(attrs.clone());
317 break;
318 }
321 break;
322 }
323 case SUMO_TAG_SEGMENT: {
324 const std::string& segmentID = attrs.getString(SUMO_ATTR_ID);
325 const MSEdge* const edge = MSEdge::dictionary(segmentID.substr(0, segmentID.rfind(":")));
326 int idx = StringUtils::toInt(segmentID.substr(segmentID.rfind(":") + 1));
328 while (idx-- > 0 && mySegment != nullptr) {
330 }
331 if (mySegment == nullptr) {
332 throw ProcessError(TLF("Unknown segment '%' in loaded state.", segmentID));
333 }
334 myQueIndex = 0;
335 break;
336 }
337 case SUMO_TAG_LANE: {
338 bool ok;
339 const std::string laneID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
341 if (myCurrentLane == nullptr) {
342 throw ProcessError(TLF("Unknown lane '%' in loaded state.", laneID));
343 }
344 break;
345 }
347 bool ok;
348 const std::vector<std::string>& vehIDs = attrs.get<std::vector<std::string> >(SUMO_ATTR_VALUE, nullptr, ok, false);
349 std::vector<SUMOVehicle*> vehs;
350 for (const std::string& id : vehIDs) {
351 SUMOVehicle* v = vc.getVehicle(id);
352 // vehicle could be removed due to options
353 if (v != nullptr) {
354 vehs.push_back(v);
355 myArrived.erase(v);
356 }
357 }
359 if (myQueIndex >= mySegment->numQueues()) {
360 throw ProcessError(TLF("Invalid queue index '%' on segment '%'. Check for consistency of lane numbers and queue options.", myQueIndex, mySegment->getID()));
361 }
362 const SUMOTime blockTime = StringUtils::toLong(attrs.getString(SUMO_ATTR_TIME));
363 const SUMOTime entryBlockTime = StringUtils::toLong(attrs.getString(SUMO_ATTR_BLOCKTIME));
364 mySegment->loadState(vehs, blockTime - myOffset, entryBlockTime - myOffset, myQueIndex);
365 myQueIndex++;
366 } else {
368 }
369 break;
370 }
371 case SUMO_TAG_LINK: {
372 bool ok;
373 myCurrentLink = nullptr;
374 const std::string toLaneID = attrs.get<std::string>(SUMO_ATTR_TO, nullptr, ok);
375 for (MSLink* link : myCurrentLane->getLinkCont()) {
376 if (link->getViaLaneOrLane()->getID() == toLaneID) {
377 myCurrentLink = link;
378 }
379 }
380 if (myCurrentLink == nullptr) {
381 throw ProcessError("Unknown link from lane '" + myCurrentLane->getID() + "' to lane '" + toLaneID + "' in loaded state");
382 }
383 break;
384 }
386 bool ok;
387 const std::string vehID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
388 const SUMOTime arrivalTime = attrs.get<SUMOTime>(SUMO_ATTR_ARRIVALTIME, nullptr, ok);
389 const double arrivalSpeed = attrs.get<double>(SUMO_ATTR_ARRIVALSPEED, nullptr, ok);
390 const double leaveSpeed = attrs.get<double>(SUMO_ATTR_DEPARTSPEED, nullptr, ok);
391 const bool setRequest = attrs.get<bool>(SUMO_ATTR_REQUEST, nullptr, ok);
392 const double arrivalSpeedBraking = attrs.get<double>(SUMO_ATTR_ARRIVALSPEEDBRAKING, nullptr, ok);
393 const SUMOTime waitingTime = attrs.get<SUMOTime>(SUMO_ATTR_WAITINGTIME, nullptr, ok);
394 const double dist = attrs.get<double>(SUMO_ATTR_DISTANCE, nullptr, ok);
395 const double latOffset = attrs.getOpt<double>(SUMO_ATTR_POSITION_LAT, nullptr, ok, 0);
396 SUMOVehicle* veh = vc.getVehicle(vehID);
397 myCurrentLink->setApproaching(veh, arrivalTime, arrivalSpeed, leaveSpeed, setRequest, arrivalSpeedBraking, waitingTime, dist, latOffset);
399 MSVehicle* microVeh = dynamic_cast<MSVehicle*>(veh);
400 microVeh->loadPreviousApproaching(myCurrentLink, setRequest, arrivalTime, arrivalSpeed, arrivalSpeedBraking, dist, leaveSpeed);
401 }
402 break;
403 }
406 break;
407 }
410 MSDriveWay::loadState(attrs, element);
411 break;
412 }
413 case SUMO_TAG_PARAM: {
414 bool ok;
415 const std::string key = attrs.get<std::string>(SUMO_ATTR_KEY, nullptr, ok);
416 // circumventing empty string test
417 const std::string val = attrs.hasAttribute(SUMO_ATTR_VALUE) ? attrs.getString(SUMO_ATTR_VALUE) : "";
418 assert(myLastParameterised != 0);
419 if (myLastParameterised != nullptr) {
421 }
422 break;
423 }
425 if (attrs.getString(SUMO_ATTR_TYPE) == "person") {
427 }
428 if (attrs.getString(SUMO_ATTR_TYPE) == "container") {
430 }
431 break;
432 case SUMO_TAG_PERSON:
434 myAttrs = attrs.clone();
435 break;
437 bool ok = true;
438 const std::string signalID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
439 if (!MSNet::getInstance()->getTLSControl().knows(signalID)) {
440 throw InvalidArgument("Rail signal '" + signalID + "' in railSignalConstraints loaded from state is not known");
441 }
443 if (myConstrainedSignal == nullptr) {
444 throw InvalidArgument("Traffic light '" + signalID + "' is not a rail signal");
445 }
446 break;
447 }
448 case SUMO_TAG_PREDECESSOR: // intended fall-through
449 case SUMO_TAG_INSERTION_PREDECESSOR: // intended fall-through
450 case SUMO_TAG_FOE_INSERTION: // intended fall-through
451 case SUMO_TAG_INSERTION_ORDER: // intended fall-through
454 break;
455 case SUMO_TAG_TLLOGIC: {
456 bool ok;
457 const std::string tlID = attrs.get<std::string>(SUMO_ATTR_ID, nullptr, ok);
458 const std::string programID = attrs.get<std::string>(SUMO_ATTR_PROGRAMID, tlID.c_str(), ok);
459 const int phase = attrs.get<int>(SUMO_ATTR_PHASE, tlID.c_str(), ok);
460 const SUMOTime spentDuration = attrs.get<SUMOTime>(SUMO_ATTR_DURATION, tlID.c_str(), ok);
461 const bool active = attrs.get<bool>(SUMO_ATTR_ACTIVE, tlID.c_str(), ok);
463 MSTrafficLightLogic* tl = tlc.get(tlID, programID);
464 if (tl == nullptr) {
465 if (programID == "online") {
466 WRITE_WARNINGF(TL("Ignoring program '%' for traffic light '%' in loaded state"), programID, tlID);
467 return;
468 } else {
469 throw ProcessError("Unknown program '" + programID + "' for traffic light '" + tlID + "'");
470 }
471 }
472 if (phase >= tl->getPhaseNumber()) {
473 throw ProcessError("Invalid phase '" + toString(phase) + "' for traffic light '" + tlID + "'");
474 }
475 // might not be set if the phase happens to match and there are multiple programs
476 tl->loadState(tlc, myTime, phase, spentDuration, active);
477 if (attrs.hasAttribute(SUMO_ATTR_STATE)) {
478 tl->loadExtraState(attrs.get<std::string>(SUMO_ATTR_STATE, tlID.c_str(), ok));
479 }
480 break;
481 }
482 case SUMO_TAG_DISPATCHER: {
483 bool ok = true;
484 SUMOTime next = attrs.get<SUMOTime>(SUMO_ATTR_NEXT, "dispatcher", ok);
487 break;
488 }
489 default:
490 break;
491 }
492}
493
494
495void
498 switch (element) {
499 case SUMO_TAG_PERSON:
500 case SUMO_TAG_CONTAINER: {
502 MSTransportable* transportable = tc.get(myAttrs->getString(SUMO_ATTR_ID));
503 transportable->loadState(myAttrs->getString(SUMO_ATTR_STATE));
504 tc.fixLoadCount(transportable);
505 delete myAttrs;
506 myAttrs = nullptr;
507 break;
508 }
509 case SUMO_TAG_FLOWSTATE: {
511 myVehicleParameter = nullptr;
512 break;
513 }
514 case SUMO_TAG_SNAPSHOT: {
515 if (myVCAttrs == nullptr) {
516 throw ProcessError(TL("Could not load vehicle control state"));
517 }
526 if (myRemoved > 0) {
527 WRITE_MESSAGEF(TL("Removed % vehicles while loading state."), toString(myRemoved));
529 }
530 for (SUMOVehicle* v : myArrived) {
531 // state was created with active option --keep-after-arrival
532 vc.deleteKeptVehicle(v);
533 }
535 for (MSVehicleControl::constVehIt i = vc.loadedVehBegin(); i != vc.loadedVehEnd(); ++i) {
536 MSVehicle* microVeh = dynamic_cast<MSVehicle*>((*i).second);
537 if (microVeh->hasDeparted() && microVeh->getLane() != nullptr) {
538 // occupancy update must happen after all lane states have been loaded
539 microVeh->updateBestLanes();
540 }
541 }
542 }
544 break;
545 }
546 default:
547 break;
548 }
549 if (element != SUMO_TAG_PARAM && myVehicleParameter == nullptr && myCurrentVType == nullptr) {
550 myLastParameterised = nullptr;
551 }
552}
553
554
555void
557 assert(myVehicleParameter != nullptr);
559 // the vehicle was already counted in MSVehicleControl::setState
561 // make a copy because myVehicleParameter is reset in closeVehicle()
562 const std::string vehID = myVehicleParameter->id;
563 if (myVehiclesToRemove.count(vehID) == 0) {
564
565 // devices that influence simulation behavior must replicate stochastic assignment
566 // also, setting the parameter avoids extra calls to MSDevice::myEquipmentRNG (which would pollute replication)
567 std::vector<std::string> deviceNames;
568 for (auto attrs : myDeviceAttrs) {
569 deviceNames.push_back(MSDevice::getDeviceName(attrs->getString(SUMO_ATTR_ID)));
570 }
573 SUMOVehicle* v = vc.getVehicle(vehID);
574 // special case: transportable devices are not assigned by options
575 if (std::find(deviceNames.begin(), deviceNames.end(), "person") != deviceNames.end()) {
576 dynamic_cast<MSBaseVehicle*>(v)->initTransportableDevice(true);
577 }
578 if (std::find(deviceNames.begin(), deviceNames.end(), "container") != deviceNames.end()) {
579 dynamic_cast<MSBaseVehicle*>(v)->initTransportableDevice(false);
580 }
581 // clean up added param after initializing devices in closeVehicle
583 if (v == nullptr) {
584 throw ProcessError(TLF("Could not load vehicle '%' from state", vehID));
585 }
588
589 if (v->hasDeparted()) {
590 // vehicle already departed: disable pre-insertion rerouting and enable regular routing behavior
591 MSDevice_Routing* routingDevice = static_cast<MSDevice_Routing*>(v->getDevice(typeid(MSDevice_Routing)));
592 if (routingDevice != nullptr) {
594 }
597 // register route for deadlock prevention (vehicleStateChanged would not be called otherwise)
599 }
600 vc.handleTriggeredDepart(v, false);
601 if (v->hasArrived()) {
602 myArrived.insert(v);
603 }
604 }
605 while (!myDeviceAttrs.empty()) {
606 const std::string attrID = myDeviceAttrs.back()->getString(SUMO_ATTR_ID);
607 for (MSVehicleDevice* const dev : v->getDevices()) {
608 if (dev->getID() == attrID) {
609 dev->loadState(*myDeviceAttrs.back());
610 }
611 }
612 delete myDeviceAttrs.back();
613 myDeviceAttrs.pop_back();
614 }
615 bool ok = true;
616 while (!myReminderAttrs.empty()) {
617 const std::string attrID = myReminderAttrs.back()->getString(SUMO_ATTR_ID);
618 const SUMOTime time = myReminderAttrs.back()->get<SUMOTime>(SUMO_ATTR_TIME, nullptr, ok, false);
619 const double pos = myReminderAttrs.back()->get<double>(SUMO_ATTR_POSITION, nullptr, ok, false);
620 const auto& remDict = MSNet::getInstance()->getDetectorControl().getAllReminders();
621 auto it = remDict.find(attrID);
622 if (it != remDict.end()) {
623 it->second->loadReminderState(v->getNumericalID(), time, pos);
624 }
625 delete myReminderAttrs.back();
626 myReminderAttrs.pop_back();
627 }
628 } else {
629 const std::string embeddedRouteID = "!" + myVehicleParameter->id;
630 if (MSRoute::hasRoute(embeddedRouteID)) {
631 ConstMSRoutePtr embedded = MSRoute::dictionary(embeddedRouteID);
632 embedded->checkRemoval();
633 }
634 delete myVehicleParameter;
635
636 myVehicleParameter = nullptr;
637 myRemoved++;
638 while (!myDeviceAttrs.empty()) {
639 delete myDeviceAttrs.back();
640 myDeviceAttrs.pop_back();
641 }
642 while (!myReminderAttrs.empty()) {
643 delete myReminderAttrs.back();
644 myReminderAttrs.pop_back();
645 }
646 }
647 delete myAttrs;
648}
649
650
651void
665
666
667/****************************************************************************/
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_LOADERTIME
@ 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:243
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:1120
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:1081
static bool gUseMesoSim
Definition MSGlobals.h:106
static MELoop * gMesoNet
mesoscopic simulation infrastructure
Definition MSGlobals.h:115
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:3800
static void saveRNGStates(OutputDevice &out)
save random number generator states to the given output device
Definition MSLane.cpp:4696
static void loadRNGState(int index, const std::string &state)
load random number generator state for the given rng index
Definition MSLane.cpp:4706
static bool dictionary(const std::string &id, MSLane *lane)
Static (sic!) container methods {.
Definition MSLane.cpp:2520
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:465
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:475
virtual MSTransportableControl & getContainerControl()
Returns the container control.
Definition MSNet.cpp:1295
void setLoaderTime(SUMOTime time)
Definition MSNet.cpp:1127
MSInsertionControl & getInsertionControl()
Returns the insertion control.
Definition MSNet.h:455
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition MSNet.h:402
virtual MSTransportableControl & getPersonControl()
Returns the person control.
Definition MSNet.cpp:1286
MSEdgeControl & getEdgeControl()
Returns the edge control.
Definition MSNet.h:445
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 initWeightUpdate(SUMOTime lastAdaption=- 1)
intialize period edge weight update
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.