Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
SUMORouteHandler.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
21// Parser for routes during their loading
22/****************************************************************************/
23#include <config.h>
24
30#include <utils/xml/XMLSubSys.h>
31
32#include "SUMORouteHandler.h"
33
34
35// ===========================================================================
36// method definitions
37// ===========================================================================
38
39SUMORouteHandler::SUMORouteHandler(const std::string& file, const std::string& expectedRoot, const bool hardFail) :
40 SUMOSAXHandler(file, expectedRoot),
41 myHardFail(hardFail),
42 myVehicleParameter(nullptr),
43 myLastDepart(-1),
44 myActiveRouteColor(nullptr),
45 myCurrentCosts(0.),
46 myCurrentVType(nullptr),
47 myBeginDefault(OptionsCont::getOptions().exists("begin") ? string2time(OptionsCont::getOptions().getString("begin")) : 0),
48 myEndDefault(OptionsCont::getOptions().exists("end") ? string2time(OptionsCont::getOptions().getString("end")) : -1),
49 myFirstDepart(-1),
50 myInsertStopEdgesAt(-1),
51 myAllowInternalRoutes(false) {
52}
53
54
59
60
61bool
65 WRITE_WARNINGF(TL("Route file should be sorted by departure time, ignoring '%'!"), myVehicleParameter->id);
66 return false;
67 }
68 }
69 return true;
70}
71
72
73void
75 // register only non public transport to parse all public transport lines in advance
78 if (myFirstDepart == -1) {
80 }
81 }
82 // else: we don't know when this vehicle will depart. keep the previous known depart time
83}
84
85
86void
88 myElementStack.push_back(element);
89 switch (element) {
91 case SUMO_TAG_PERSON:
93 // if myVehicleParameter is nullptr this will do nothing
94 delete myVehicleParameter;
95 // we set to nullptr to have a consistent state if the parsing fails
96 myVehicleParameter = nullptr;
99 if (element != SUMO_TAG_VEHICLE) {
100 addTransportable(attrs, element == SUMO_TAG_PERSON);
101 }
102 break;
103 case SUMO_TAG_FLOW:
104 // delete if myVehicleParameter isn't null
105 if (myVehicleParameter) {
106 delete myVehicleParameter;
107 myVehicleParameter = nullptr;
108 }
109 // parse vehicle parameters
110 // might be called to parse vehicles from additional file in the
111 // context of quickReload. In this case, rerouter flows must be ignored
112 if (myElementStack.size() == 1 || myElementStack[myElementStack.size() - 2] != SUMO_TAG_CALIBRATOR) {
114 }
115 // check if myVehicleParameter was successfully created
116 if (myVehicleParameter) {
117 // check tag
118 if (myVehicleParameter->routeid.empty()) {
119 // open a route flow (It could be a flow with embedded route)
120 openFlow(attrs);
121 } else {
122 // open a route flow
123 openRouteFlow(attrs);
124 }
126 }
127 break;
130 // delete if myVehicleParameter isn't null
131 if (myVehicleParameter) {
132 delete myVehicleParameter;
133 myVehicleParameter = nullptr;
134 }
135 // create a new flow
138 break;
139 case SUMO_TAG_VTYPE:
140 // delete if myCurrentVType isn't null
141 if (myCurrentVType != nullptr) {
142 delete myCurrentVType;
143 myCurrentVType = nullptr;
144 }
145 // create a new vType
147 myParamStack.push_back(myCurrentVType);
148 break;
151 break;
152 case SUMO_TAG_ROUTE:
153 openRoute(attrs);
154 break;
157 break;
158 case SUMO_TAG_STOP:
159 myParamStack.push_back(addStop(attrs));
160 break;
161 case SUMO_TAG_TRIP: {
162 // delete if myVehicleParameter isn't null
163 if (myVehicleParameter) {
164 delete myVehicleParameter;
165 myVehicleParameter = nullptr;
166 }
167 // parse vehicle parameters
169 // check if myVehicleParameter was successfully created
170 if (myVehicleParameter) {
173 // open trip
174 openTrip(attrs);
176 }
177 break;
178 }
180 addPersonTrip(attrs);
181 break;
182 case SUMO_TAG_WALK:
183 addWalk(attrs);
184 break;
185 case SUMO_TAG_INTERVAL: {
186 bool ok;
188 myEndDefault = attrs.getSUMOTimeReporting(SUMO_ATTR_END, nullptr, ok);
189 break;
190 }
191 case SUMO_TAG_RIDE:
192 addRide(attrs);
193 break;
195 addTransport(attrs);
196 break;
198 addTranship(attrs);
199 break;
200 case SUMO_TAG_PARAM:
201 addParam(attrs);
202 break;
203 default:
204 // parse embedded car following model information
205 if (myCurrentVType != nullptr) {
206 WRITE_WARNINGF(TL("Defining car-following parameters in a nested element is deprecated in vType '%', use attributes instead!"), myCurrentVType->id);
208 if (myHardFail) {
209 throw ProcessError(TL("Invalid parsing embedded VType"));
210 } else {
211 WRITE_ERROR(TL("Invalid parsing embedded VType"));
212 }
213 }
214 }
215 break;
216 }
217}
218
219
220void
222 switch (element) {
223 case SUMO_TAG_STOP:
224 myParamStack.pop_back();
225 break;
226 case SUMO_TAG_ROUTE:
227 closeRoute();
228 break;
229 case SUMO_TAG_VTYPE:
230 closeVType();
231 delete myCurrentVType;
232 myCurrentVType = nullptr;
233 myParamStack.pop_back();
234 break;
235 case SUMO_TAG_PERSON:
236 closePerson();
237 delete myVehicleParameter;
238 myVehicleParameter = nullptr;
239 myParamStack.pop_back();
240 break;
243 delete myVehicleParameter;
244 myVehicleParameter = nullptr;
245 myParamStack.pop_back();
246 break;
249 delete myVehicleParameter;
250 myVehicleParameter = nullptr;
251 myParamStack.pop_back();
252 break;
255 delete myVehicleParameter;
256 myVehicleParameter = nullptr;
257 myParamStack.pop_back();
258 break;
259 case SUMO_TAG_VEHICLE:
260 if (myVehicleParameter == nullptr) {
261 break;
262 }
264 myVehicleParameter->repetitionNumber++; // for backwards compatibility
265 // it is a flow, thus no break here
267 } else {
268 closeVehicle();
269 delete myVehicleParameter;
270 myVehicleParameter = nullptr;
271 myParamStack.pop_back();
272 break;
273 }
274 case SUMO_TAG_FLOW:
275 if (myVehicleParameter) {
276 closeFlow();
277 delete myVehicleParameter;
278 myParamStack.pop_back();
279 }
280 myVehicleParameter = nullptr;
282 break;
283 case SUMO_TAG_TRIP:
284 closeTrip();
285 delete myVehicleParameter;
286 myVehicleParameter = nullptr;
287 myParamStack.pop_back();
289 break;
292 break;
295 break;
297 case SUMO_TAG_RIDE:
300 case SUMO_TAG_WALK:
301 if (myParamStack.size() == 2) {
302 myParamStack.pop_back();
303 }
304 break;
306 myBeginDefault = string2time(OptionsCont::getOptions().getString("begin"));
308 break;
309 default:
310 break;
311 }
312 myElementStack.pop_back();
313}
314
315
317SUMORouteHandler::checkStopPos(double& startPos, double& endPos, const double laneLength, const double minLength, const bool friendlyPos) {
318 if (minLength > laneLength) {
320 }
321 if (startPos < 0) {
322 startPos += laneLength;
323 }
324 if (endPos < 0) {
325 endPos += laneLength;
326 }
327 if ((endPos < minLength) || (endPos > laneLength)) {
328 if (!friendlyPos) {
330 }
331 if (endPos < minLength) {
332 endPos = minLength;
333 }
334 if (endPos > laneLength) {
335 endPos = laneLength;
336 }
337 }
338 if ((startPos < 0) || (startPos > (endPos - minLength))) {
339 if (!friendlyPos) {
341 }
342 if (startPos < 0) {
343 startPos = 0;
344 }
345 if (startPos > (endPos - minLength)) {
346 startPos = endPos - minLength;
347 }
348 }
349 return STOPPOS_VALID;
350}
351
352
353bool
354SUMORouteHandler::isStopPosValid(const double startPos, const double endPos, const double laneLength, const double minLength, const bool friendlyPos) {
355 // declare dummy start and end positions
356 double dummyStartPos = startPos;
357 double dummyEndPos = endPos;
358 // return checkStopPos
359 return (checkStopPos(dummyStartPos, dummyEndPos, laneLength, minLength, friendlyPos) == STOPPOS_VALID);
360}
361
362
367
368
373
374
375void
377 bool ok = true;
378 const std::string key = attrs.get<std::string>(SUMO_ATTR_KEY, nullptr, ok);
379 // only continue if key isn't empty
380 if (ok && (key.size() > 0)) {
381 // circumventing empty string test
382 std::string val = attrs.hasAttribute(SUMO_ATTR_VALUE) ? attrs.getString(SUMO_ATTR_VALUE) : "";
383 // check special params that must be interpreted as relative paths
384 if ((myVehicleParameter != nullptr || myCurrentVType != nullptr)
385 && (key == "device.toc.file" || key == "device.ssm.file")) {
387 }
388 // add parameter in current created element
389 if (!myParamStack.empty()) {
390 myParamStack.back()->setParameter(key, val);
391 }
392 }
393}
394
395
396bool
397SUMORouteHandler::parseStop(SUMOVehicleParameter::Stop& stop, const SUMOSAXAttributes& attrs, std::string errorSuffix, MsgHandler* const errorOutput) {
398 stop.parametersSet = 0;
399 if (attrs.hasAttribute(SUMO_ATTR_ARRIVAL)) {
401 }
402 if (attrs.hasAttribute(SUMO_ATTR_DURATION)) {
404 }
405 if (attrs.hasAttribute(SUMO_ATTR_UNTIL)) {
407 }
408 if (attrs.hasAttribute(SUMO_ATTR_STARTED)) {
410 }
411 if (attrs.hasAttribute(SUMO_ATTR_ENDED)) {
413 }
416 }
417 if (attrs.hasAttribute(SUMO_ATTR_ENDPOS)) {
419 }
420 if (attrs.hasAttribute(SUMO_ATTR_STARTPOS)) {
422 }
425 }
428 }
429 // legacy attribute
432 }
433 if (attrs.hasAttribute(SUMO_ATTR_PARKING)) {
435 }
436 if (attrs.hasAttribute(SUMO_ATTR_EXPECTED)) {
438 }
441 }
444 }
445 if (attrs.hasAttribute(SUMO_ATTR_TRIP_ID)) {
447 }
448 if (attrs.hasAttribute(SUMO_ATTR_SPLIT)) {
450 }
451 if (attrs.hasAttribute(SUMO_ATTR_JOIN)) {
453 }
454 if (attrs.hasAttribute(SUMO_ATTR_LINE)) {
456 }
457 if (attrs.hasAttribute(SUMO_ATTR_SPEED)) {
459 }
460 if (attrs.hasAttribute(SUMO_ATTR_ONDEMAND)) {
462 }
463 if (attrs.hasAttribute(SUMO_ATTR_PRIORITY)) {
465 }
466 if (attrs.hasAttribute(SUMO_ATTR_JUMP)) {
468 }
471 }
472 bool ok = true;
473 stop.busstop = attrs.getOpt<std::string>(SUMO_ATTR_BUS_STOP, nullptr, ok, "");
474 stop.busstop = attrs.getOpt<std::string>(SUMO_ATTR_TRAIN_STOP, nullptr, ok, stop.busstop);
475 stop.chargingStation = attrs.getOpt<std::string>(SUMO_ATTR_CHARGING_STATION, nullptr, ok, "");
476 stop.overheadWireSegment = attrs.getOpt<std::string>(SUMO_ATTR_OVERHEAD_WIRE_SEGMENT, nullptr, ok, "");
477 stop.containerstop = attrs.getOpt<std::string>(SUMO_ATTR_CONTAINER_STOP, nullptr, ok, "");
478 stop.parkingarea = attrs.getOpt<std::string>(SUMO_ATTR_PARKING_AREA, nullptr, ok, "");
479 if (stop.busstop != "") {
480 errorSuffix = " at '" + stop.busstop + "'" + errorSuffix;
481 } else if (stop.chargingStation != "") {
482 errorSuffix = " at '" + stop.chargingStation + "'" + errorSuffix;
483 } else if (stop.overheadWireSegment != "") {
484 errorSuffix = " at '" + stop.overheadWireSegment + "'" + errorSuffix;
485 } else if (stop.containerstop != "") {
486 errorSuffix = " at '" + stop.containerstop + "'" + errorSuffix;
487 } else if (stop.parkingarea != "") {
488 errorSuffix = " at '" + stop.parkingarea + "'" + errorSuffix;
489 } else if (attrs.hasAttribute(SUMO_ATTR_LANE)) {
490 errorSuffix = " on lane '" + attrs.get<std::string>(SUMO_ATTR_LANE, nullptr, ok) + "'" + errorSuffix;
491 } else if (attrs.hasAttribute(SUMO_ATTR_EDGE)) {
492 errorSuffix = " on edge '" + attrs.get<std::string>(SUMO_ATTR_EDGE, nullptr, ok) + "'" + errorSuffix;
493 } else {
494 errorSuffix = " at undefined location" + errorSuffix;
495 }
496 // speed for counting as stopped
497 stop.speed = attrs.getOpt<double>(SUMO_ATTR_SPEED, nullptr, ok, 0);
498 if (stop.speed < 0) {
499 errorOutput->inform(TLF("Speed cannot be negative for stop%.", errorSuffix));
500 return false;
501 }
502
503 // get the standing duration
504 bool expectTrigger = !attrs.hasAttribute(SUMO_ATTR_DURATION) && !attrs.hasAttribute(SUMO_ATTR_UNTIL) && !attrs.hasAttribute(SUMO_ATTR_SPEED);
505 std::vector<std::string> triggers = attrs.getOpt<std::vector<std::string> >(SUMO_ATTR_TRIGGERED, nullptr, ok);
506 // legacy
507 if (attrs.getOpt<bool>(SUMO_ATTR_CONTAINER_TRIGGERED, nullptr, ok, false)) {
508 triggers.push_back(toString(SUMO_TAG_CONTAINER));
509 }
510 SUMOVehicleParameter::parseStopTriggers(triggers, expectTrigger, stop);
511 stop.arrival = attrs.getOptSUMOTimeReporting(SUMO_ATTR_ARRIVAL, nullptr, ok, -1);
512 stop.duration = attrs.getOptSUMOTimeReporting(SUMO_ATTR_DURATION, nullptr, ok, -1);
513 stop.until = attrs.getOptSUMOTimeReporting(SUMO_ATTR_UNTIL, nullptr, ok, -1);
514 if (!expectTrigger && (!ok || (stop.duration < 0 && stop.until < 0 && stop.speed == 0))) {
515 errorOutput->inform(TLF("Invalid duration or end time is given for a stop%.", errorSuffix));
516 return false;
517 }
518 if (triggers.size() > 0 && stop.speed > 0) {
519 errorOutput->inform(TLF("Triggers and waypoints cannot be combined%.", errorSuffix));
520 return false;
521 }
522 stop.extension = attrs.getOptSUMOTimeReporting(SUMO_ATTR_EXTENSION, nullptr, ok, -1);
523 const bool defaultParking = (stop.triggered || stop.containerTriggered || stop.parkingarea != "");
524 stop.parking = attrs.getOpt<ParkingType>(SUMO_ATTR_PARKING, nullptr, ok, defaultParking ? ParkingType::OFFROAD : ParkingType::ONROAD);
525 if ((stop.parkingarea != "") && (stop.parking == ParkingType::ONROAD)) {
526 WRITE_WARNINGF(TL("Stop at parkingArea overrides attribute 'parking' for stop%."), errorSuffix);
528 }
529
530 // expected persons
531 const std::vector<std::string>& expected = attrs.getOpt<std::vector<std::string> >(SUMO_ATTR_EXPECTED, nullptr, ok);
532 stop.awaitedPersons.insert(expected.begin(), expected.end());
533 if (stop.awaitedPersons.size() > 0) {
534 stop.triggered = true;
535 if ((stop.parametersSet & STOP_PARKING_SET) == 0) {
537 }
538 }
539
540 // permitted transportables
541 const std::vector<std::string>& permitted = attrs.getOpt<std::vector<std::string> >(SUMO_ATTR_PERMITTED, nullptr, ok);
542 stop.permitted.insert(permitted.begin(), permitted.end());
543
544 // expected containers
545 const std::vector<std::string>& expectedContainers = attrs.getOpt<std::vector<std::string> >(SUMO_ATTR_EXPECTED_CONTAINERS, nullptr, ok);
546 stop.awaitedContainers.insert(expectedContainers.begin(), expectedContainers.end());
547 if (stop.awaitedContainers.size() > 0) {
548 stop.containerTriggered = true;
549 if ((stop.parametersSet & STOP_PARKING_SET) == 0) {
551 }
552 }
553 // public transport trip id
554 stop.tripId = attrs.getOpt<std::string>(SUMO_ATTR_TRIP_ID, nullptr, ok, "");
555 stop.split = attrs.getOpt<std::string>(SUMO_ATTR_SPLIT, nullptr, ok, "");
556 stop.join = attrs.getOpt<std::string>(SUMO_ATTR_JOIN, nullptr, ok, "");
557 stop.line = attrs.getOpt<std::string>(SUMO_ATTR_LINE, nullptr, ok, "");
558
559 const std::string idx = attrs.getOpt<std::string>(SUMO_ATTR_INDEX, nullptr, ok, "end");
560 if (idx == "end") {
561 stop.index = STOP_INDEX_END;
562 } else if (idx == "fit") {
563 stop.index = STOP_INDEX_FIT;
564 } else {
565 stop.index = attrs.get<int>(SUMO_ATTR_INDEX, nullptr, ok);
566 if (!ok || stop.index < 0) {
567 errorOutput->inform(TLF("Invalid 'index' for stop%.", errorSuffix));
568 return false;
569 }
570 }
571 stop.started = attrs.getOptSUMOTimeReporting(SUMO_ATTR_STARTED, nullptr, ok, -1);
572 stop.ended = attrs.getOptSUMOTimeReporting(SUMO_ATTR_ENDED, nullptr, ok, -1);
573 stop.posLat = attrs.getOpt<double>(SUMO_ATTR_POSITION_LAT, nullptr, ok, INVALID_DOUBLE);
574 stop.actType = attrs.getOpt<std::string>(SUMO_ATTR_ACTTYPE, nullptr, ok, "");
575 stop.onDemand = attrs.getOpt<bool>(SUMO_ATTR_ONDEMAND, nullptr, ok, false);
576 stop.priority = attrs.getOpt<double>(SUMO_ATTR_PRIORITY, nullptr, ok, -1);
577 stop.jump = attrs.getOptSUMOTimeReporting(SUMO_ATTR_JUMP, nullptr, ok, -1);
578 stop.jumpUntil = attrs.getOptSUMOTimeReporting(SUMO_ATTR_JUMP_UNTIL, nullptr, ok, -1);
579 stop.collision = attrs.getOpt<bool>(SUMO_ATTR_COLLISION, nullptr, ok, false);
580 return true;
581}
582
583
584/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:288
#define WRITE_ERROR(msg)
Definition MsgHandler.h:296
#define TL(string)
Definition MsgHandler.h:305
#define TLF(string,...)
Definition MsgHandler.h:307
SUMOTime string2time(const std::string &r)
convert string to SUMOTime
Definition SUMOTime.cpp:46
const int STOP_ARRIVAL_SET
const int STOP_DURATION_SET
const int STOP_INDEX_END
const int STOP_POSLAT_SET
const int STOP_EXPECTED_SET
const long long int VEHPARS_FORCE_REROUTE
const int STOP_SPEED_SET
const int STOP_JUMP_UNTIL_SET
const int STOP_UNTIL_SET
const int STOP_LINE_SET
const int STOP_PARKING_SET
const int STOP_TRIP_ID_SET
const int STOP_PERMITTED_SET
const int STOP_SPLIT_SET
const int STOP_START_SET
const int STOP_JOIN_SET
const int STOP_EXTENSION_SET
const int STOP_INDEX_FIT
const int STOP_ENDED_SET
const int STOP_TRIGGER_SET
const int STOP_PRIORITY_SET
const int STOP_JUMP_SET
const int STOP_ONDEMAND_SET
const int STOP_END_SET
const int STOP_STARTED_SET
const int STOP_EXPECTED_CONTAINERS_SET
@ GIVEN
The time is given.
SumoXMLTag
Numbers representing SUMO-XML - element names.
@ SUMO_TAG_INTERVAL
an aggreagated-output interval
@ SUMO_TAG_VTYPE
description of a vehicle/person/container type
@ SUMO_TAG_WALK
@ SUMO_TAG_TRANSHIP
@ SUMO_TAG_CONTAINERFLOW
@ SUMO_TAG_STOP
stop for vehicles
@ SUMO_TAG_VEHICLE
description of a vehicle
@ SUMO_TAG_ROUTE_DISTRIBUTION
distribution of a route
@ SUMO_TAG_FLOW
a flow definition using from and to edges or a route
@ SUMO_TAG_TRANSPORT
@ SUMO_TAG_CONTAINER
@ SUMO_TAG_ROUTE
description of a route
@ SUMO_TAG_RIDE
@ SUMO_TAG_VTYPE_DISTRIBUTION
distribution of a vehicle type
@ SUMO_TAG_PARAM
parameter associated to a certain key
@ SUMO_TAG_PERSON
@ SUMO_TAG_PERSONTRIP
@ SUMO_TAG_CALIBRATOR
A calibrator placed over edge.
@ SUMO_TAG_PERSONFLOW
@ SUMO_TAG_TRIP
a single trip definition (used by router)
ParkingType
Numbers representing special SUMO-XML-attribute values Information on whether a car is parking on the...
@ SUMO_ATTR_CONTAINER_TRIGGERED
@ SUMO_ATTR_STARTPOS
@ SUMO_ATTR_PARKING
@ SUMO_ATTR_EXTENSION
@ SUMO_ATTR_LANE
@ SUMO_ATTR_COLLISION
@ SUMO_ATTR_SPEED
@ SUMO_ATTR_STARTED
@ SUMO_ATTR_VALUE
@ SUMO_ATTR_CONTAINER_STOP
@ SUMO_ATTR_PARKING_AREA
@ SUMO_ATTR_EDGE
@ SUMO_ATTR_BUS_STOP
@ SUMO_ATTR_TRAIN_STOP
@ SUMO_ATTR_ENDPOS
@ SUMO_ATTR_SPLIT
@ SUMO_ATTR_ACTTYPE
@ SUMO_ATTR_BEGIN
weights: time range begin
@ SUMO_ATTR_POSITION_LAT
@ SUMO_ATTR_EXPECTED
@ SUMO_ATTR_PRIORITY
@ SUMO_ATTR_LINE
@ SUMO_ATTR_CHARGING_STATION
@ SUMO_ATTR_OVERHEAD_WIRE_SEGMENT
@ SUMO_ATTR_ENDED
@ SUMO_ATTR_ONDEMAND
@ SUMO_ATTR_INDEX
@ SUMO_ATTR_ARRIVAL
@ SUMO_ATTR_TRIP_ID
@ SUMO_ATTR_END
weights: time range end
@ SUMO_ATTR_PERMITTED
@ SUMO_ATTR_JOIN
@ SUMO_ATTR_JUMP
@ SUMO_ATTR_EXPECTED_CONTAINERS
@ SUMO_ATTR_UNTIL
@ SUMO_ATTR_JUMP_UNTIL
@ SUMO_ATTR_TRIGGERED
@ SUMO_ATTR_DURATION
@ SUMO_ATTR_KEY
#define FALLTHROUGH
Definition StdDefs.h:39
const double INVALID_DOUBLE
invalid double
Definition StdDefs.h:68
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
static std::string checkForRelativity(const std::string &filename, const std::string &basePath)
Returns the path from a configuration so that it is accessible from the current working directory.
const std::string & getFileName() const
returns the current file name
virtual void inform(std::string msg, bool addType=true)
adds a new error to the list
A storage for options typed value containers)
Definition OptionsCont.h:89
static OptionsCont & getOptions()
Retrieves the options.
bool parseStop(SUMOVehicleParameter::Stop &stop, const SUMOSAXAttributes &attrs, std::string errorSuffix, MsgHandler *const errorOutput)
parses attributes common to all stops
virtual void openTrip(const SUMOSAXAttributes &attrs)=0
opens a trip for reading
StopPos
enum for stops
void registerLastDepart()
save last depart (only to be used if vehicle is not discarded)
virtual void openFlow(const SUMOSAXAttributes &attrs)=0
opens a flow for reading
virtual void closeContainer()=0
Ends the processing of a container.
SUMOTime myFirstDepart
the first read departure time
virtual void addWalk(const SUMOSAXAttributes &attrs)=0
add a fully specified walk
static bool isStopPosValid(const double startPos, const double endPos, const double laneLength, const double minLength, const bool friendlyPos)
check if start and end position of a stop is valid
SUMOTime myBeginDefault
The default value for flow begins.
SUMORouteHandler(const std::string &file, const std::string &expectedRoot, const bool hardFail)
standard constructor
virtual void openRouteDistribution(const SUMOSAXAttributes &attrs)=0
opens a route distribution for reading
bool myAllowInternalRoutes
whether references to internal routes are allowed in this context
std::string myActiveRouteID
The id of the current route.
virtual void openRoute(const SUMOSAXAttributes &attrs)=0
opens a route for reading
virtual void openVehicleTypeDistribution(const SUMOSAXAttributes &attrs)=0
opens a type distribution for reading
virtual ~SUMORouteHandler()
standard destructor
virtual void closeVehicle()=0
Ends the processing of a vehicle.
virtual void closeFlow()=0
Ends the processing of a flow.
virtual void closePersonFlow()=0
Ends the processing of a person flow.
std::vector< Parameterised * > myParamStack
The stack of currently parsed parameterised objects.
SUMOVehicleParameter * myVehicleParameter
Parameter of the current vehicle, trip, person, container or flow.
virtual void addRide(const SUMOSAXAttributes &attrs)=0
Processing of a ride.
virtual void addTranship(const SUMOSAXAttributes &attrs)=0
Processing of a tranship.
SUMOTime getLastDepart() const
Returns the last loaded depart time.
const bool myHardFail
flag to enable or disable hard fails
std::vector< int > myElementStack
hierarchy of elements being parsed
SUMOVTypeParameter * myCurrentVType
The currently parsed vehicle type.
virtual void addTransport(const SUMOSAXAttributes &attrs)=0
Processing of a transport.
virtual void closeRoute(const bool mayBeDisconnected=false)=0
virtual void closePerson()=0
Ends the processing of a person.
SUMOTime myLastDepart
The insertion time of the vehicle read last.
SUMOTime myEndDefault
The default value for flow ends.
virtual void closeVehicleTypeDistribution()=0
closes (ends) the building of a distribution
static StopPos checkStopPos(double &startPos, double &endPos, const double laneLength, const double minLength, const bool friendlyPos)
check start and end position of a stop
virtual void myStartElement(int element, const SUMOSAXAttributes &attrs)
Called on the opening of a tag;.
void addParam(const SUMOSAXAttributes &attrs)
assign arbitrary vehicle parameters
virtual void closeContainerFlow()=0
Ends the processing of a container flow.
virtual Parameterised * addStop(const SUMOSAXAttributes &attrs)=0
Processing of a stop.
virtual void closeTrip()=0
Ends the processing of a trip.
SUMOTime getFirstDepart() const
returns the first departure time that was ever read
virtual void openRouteFlow(const SUMOSAXAttributes &attrs)=0
opens a route flow for reading
int myInsertStopEdgesAt
where stop edges can be inserted into the current route (-1 means no insertion)
virtual void addTransportable(const SUMOSAXAttributes &attrs, const bool isPerson)
Processing of a person or container.
virtual void addPersonTrip(const SUMOSAXAttributes &attrs)=0
add a routing request for a walking or intermodal person
virtual void myEndElement(int element)
Called when a closing tag occurs.
virtual void closeVType()=0
Ends the processing of a vehicle type.
virtual void closeRouteDistribution()=0
closes (ends) the building of a distribution
virtual bool checkLastDepart()
Checks whether the route file is sorted by departure time if needed.
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 bool hasAttribute(int id) const =0
Returns the information whether the named (by its enum-value) attribute is within the current list.
SUMOTime getSUMOTimeReporting(int attr, const char *objectid, bool &ok, bool report=true) const
Tries to read given attribute assuming it is a SUMOTime.
SAX-handler base for SUMO-files.
std::string id
The vehicle type's id.
Definition of vehicle stop (position and duration)
SUMOTime started
the time at which this stop was reached
ParkingType parking
whether the vehicle is removed from the net while stopping
SUMOTime extension
The maximum time extension for boarding / loading.
double speed
the speed at which this stop counts as reached (waypoint mode)
std::string parkingarea
(Optional) parking area if one is assigned to the stop
std::string split
the id of the vehicle (train portion) that splits of upon reaching this stop
std::string line
the new line id of the trip within a cyclical public transport route
double posLat
the lateral offset when stopping
bool onDemand
whether the stop may be skipped
std::string chargingStation
(Optional) charging station if one is assigned to the stop
std::string overheadWireSegment
(Optional) overhead line segment if one is assigned to the stop
std::set< std::string > permitted
IDs of persons or containers that may board/load at this stop.
SUMOTime jumpUntil
earlierst jump end if there shall be a jump from this stop to the next route edge
int parametersSet
Information for the output which parameter were set.
double priority
priority for weighting/skipping stops
int index
at which position in the stops list
SUMOTime jump
transfer time if there shall be a jump from this stop to the next route edge
std::string join
the id of the vehicle (train portion) to which this vehicle shall be joined
SUMOTime until
The time at which the vehicle may continue its journey.
std::string actType
act Type (only used by Persons) (used by netedit)
bool triggered
whether an arriving person lets the vehicle continue
SUMOTime ended
the time at which this stop was ended
std::set< std::string > awaitedPersons
IDs of persons the vehicle has to wait for until departing.
std::set< std::string > awaitedContainers
IDs of containers the vehicle has to wait for until departing.
std::string busstop
(Optional) bus stop if one is assigned to the stop
std::string tripId
id of the trip within a cyclical public transport route
std::string containerstop
(Optional) container stop if one is assigned to the stop
bool containerTriggered
whether an arriving container lets the vehicle continue
bool collision
Whether this stop was triggered by a collision.
SUMOTime arrival
The (expected) time at which the vehicle reaches the stop.
SUMOTime duration
The stopping duration.
long long int parametersSet
Information for the router which parameter were set, TraCI may modify this (when changing color)
std::string routeid
The vehicle's route id.
std::string id
The vehicle's id.
DepartDefinition departProcedure
Information how the vehicle shall choose the depart time.
std::string line
The vehicle's line (mainly for public transport)
static void parseStopTriggers(const std::vector< std::string > &triggers, bool expectTrigger, Stop &stop)
parses stop trigger values
static SUMOVTypeParameter * beginVTypeParsing(const SUMOSAXAttributes &attrs, const bool hardFail, const std::string &file)
Starts to parse a vehicle type.
static bool parseCFMParams(SUMOVTypeParameter *into, const SumoXMLTag element, const SUMOSAXAttributes &attrs, const bool nestedCFM)
Parses Car Following Mode params.
static SUMOVehicleParameter * parseVehicleAttributes(int element, const SUMOSAXAttributes &attrs, const bool hardFail, const bool optionalID=false, const bool skipDepart=false, const bool allowInternalRoutes=false)
Parses a vehicle's attributes.
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.