Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
RORouteDef.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2002-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// Base class for a vehicle's route definition
21/****************************************************************************/
22#include <config.h>
23
24#include <string>
25#include <iterator>
26#include <algorithm>
29#include <utils/common/Named.h>
35#include "ROEdge.h"
36#include "RORoute.h"
39#include "RORouteDef.h"
40#include "ROVehicle.h"
41
42// ===========================================================================
43// static members
44// ===========================================================================
45bool RORouteDef::myUsingJTRR(false);
47
48// ===========================================================================
49// method definitions
50// ===========================================================================
51RORouteDef::RORouteDef(const std::string& id, const int lastUsed,
52 const bool tryRepair, const bool mayBeDisconnected) :
53 Named(StringUtils::convertUmlaute(id)),
54 myPrecomputed(nullptr), myLastUsed(lastUsed), myTryRepair(tryRepair),
55 myMayBeDisconnected(mayBeDisconnected),
56 myDiscardSilent(false) {
57}
58
59
61 for (std::vector<RORoute*>::iterator i = myAlternatives.begin(); i != myAlternatives.end(); i++) {
62 if (myRouteRefs.count(*i) == 0) {
63 delete *i;
64 }
65 }
66}
67
68
69void
73
74
75void
77 std::copy(alt->myAlternatives.begin(), alt->myAlternatives.end(),
78 back_inserter(myAlternatives));
79 std::copy(alt->myAlternatives.begin(), alt->myAlternatives.end(),
80 std::inserter(myRouteRefs, myRouteRefs.end()));
81}
82
83
86 SUMOTime begin, const ROVehicle& veh) const {
87 if (myPrecomputed == nullptr) {
88 preComputeCurrentRoute(router, begin, veh);
89 }
90 return myPrecomputed;
91}
92
93
94void
96 for (int i = 0; i < (int)myAlternatives.size();) {
97 if (i != myLastUsed || mySkipNewRoutes) {
98 if (myAlternatives[i]->isPermitted(veh, errorHandler)) {
99 i++;
100 } else {
101 myAlternatives.erase(myAlternatives.begin() + i);
102 if (myLastUsed > i) {
103 myLastUsed--;
104 }
105 }
106 } else {
107 i++;
108 }
109 }
110}
111
112
113void
115 SUMOTime begin, const ROVehicle& veh) const {
116 myNewRoute = false;
118 const bool ignoreErrors = oc.getBool("ignore-errors");
119 const bool hasRestrictions = RONet::getInstance()->hasParamRestrictions();
120 assert(myAlternatives[0]->getEdgeVector().size() > 0);
122 if (myAlternatives[0]->getFirst()->prohibits(&veh, hasRestrictions) && (!oc.getBool("repair.from")
123 // do not try to reassign starting edge for trip input
124 || myMayBeDisconnected || myAlternatives[0]->getEdgeVector().size() < 2)) {
125 mh->inform("Vehicle '" + veh.getID() + "' is not allowed to depart on edge '" +
126 myAlternatives[0]->getFirst()->getID() + "'.");
127 return;
128 } else if (myAlternatives[0]->getLast()->prohibits(&veh, hasRestrictions) && (!oc.getBool("repair.to")
129 // do not try to reassign destination edge for trip input
130 || myMayBeDisconnected || myAlternatives[0]->getEdgeVector().size() < 2)) {
131 // this check is not strictly necessary unless myTryRepair is set.
132 // However, the error message is more helpful than "no connection found"
133 mh->inform("Vehicle '" + veh.getID() + "' is not allowed to arrive on edge '" +
134 myAlternatives[0]->getLast()->getID() + "'.");
135 return;
136 }
137 const bool skipTripRouting = (oc.exists("write-trips") && oc.getBool("write-trips")
139 if ((myTryRepair && !skipTripRouting) || myUsingJTRR) {
140 ConstROEdgeVector newEdges;
141 if (repairCurrentRoute(router, begin, veh, myAlternatives[0]->getEdgeVector(), newEdges)) {
142 if (myAlternatives[0]->getEdgeVector() != newEdges) {
143 if (!myMayBeDisconnected) {
144 WRITE_WARNINGF(TL("Repaired route of vehicle '%'."), veh.getID());
145 }
146 myNewRoute = true;
147 RGBColor* col = myAlternatives[0]->getColor() != nullptr ? new RGBColor(*myAlternatives[0]->getColor()) : nullptr;
148 myPrecomputed = new RORoute(myID, 0, myAlternatives[0]->getProbability(), newEdges, col, myAlternatives[0]->getStops());
149 } else {
151 }
152 }
153 return;
154 }
156 || OptionsCont::getOptions().getBool("remove-loops")) {
157 if (skipTripRouting || myAlternatives[myLastUsed]->isValid(veh, ignoreErrors)) {
159 }
160 } else {
161 // build a new route to test whether it is better
163 ConstROEdgeVector edges;
164 if (repairCurrentRoute(router, begin, veh, oldEdges, edges, true)) {
165 if (edges.front()->isTazConnector()) {
166 edges.erase(edges.begin());
167 }
168 if (edges.back()->isTazConnector()) {
169 edges.pop_back();
170 }
171 // check whether the same route was already used
172 int existing = -1;
173 for (int i = 0; i < (int)myAlternatives.size(); i++) {
174 if (edges == myAlternatives[i]->getEdgeVector()) {
175 existing = i;
176 break;
177 }
178 }
179 if (existing >= 0) {
180 myPrecomputed = myAlternatives[existing];
181 } else {
182 RGBColor* col = myAlternatives[0]->getColor() != nullptr ? new RGBColor(*myAlternatives[0]->getColor()) : nullptr;
183 myPrecomputed = new RORoute(myID, 0, 1, edges, col, myAlternatives[0]->getStops());
184 myNewRoute = true;
185 }
186 }
187 }
188}
189
190
191bool
193 SUMOTime begin, const ROVehicle& veh,
194 ConstROEdgeVector oldEdges, ConstROEdgeVector& newEdges,
195 bool isTrip) const {
196 MsgHandler* mh = (OptionsCont::getOptions().getBool("ignore-errors") ?
198 RONet* net = RONet::getInstance();
199 const int initialSize = (int)oldEdges.size();
200 const bool hasRestrictions = RONet::getInstance()->hasParamRestrictions();
201 if (net->hasProhibitions() && router.supportsProhibitions()) {
202 if (net->getProhibitions().size() > 0 && !router.hasProhibitions()) {
203 router.prohibit(net->getProhibitions());
204 }
205 net->updateLaneProhibitions(begin);
206 }
207 if (initialSize == 1) {
208 if (myUsingJTRR) {
210 bool ok = router.compute(oldEdges.front(), nullptr, &veh, begin, newEdges);
211 myDiscardSilent = ok && newEdges.size() == 0;
212 } else {
213 newEdges = oldEdges;
214 }
215 } else {
216 if (oldEdges.front()->prohibits(&veh, hasRestrictions)) {
217 // option repair.from is in effect
218 const std::string& frontID = oldEdges.front()->getID();
219 for (ConstROEdgeVector::iterator i = oldEdges.begin(); i != oldEdges.end();) {
220 if ((*i)->prohibits(&veh, hasRestrictions) || (*i)->isInternal()) {
221 i = oldEdges.erase(i);
222 } else {
223 WRITE_MESSAGE("Changing invalid starting edge '" + frontID
224 + "' to '" + (*i)->getID() + "' for vehicle '" + veh.getID() + "'.");
225 break;
226 }
227 }
228 }
229 if (oldEdges.size() == 0) {
230 mh->inform("Could not find new starting edge for vehicle '" + veh.getID() + "'.");
231 return false;
232 }
233 if (oldEdges.back()->prohibits(&veh, hasRestrictions)) {
234 // option repair.to is in effect
235 const std::string& backID = oldEdges.back()->getID();
236 // oldEdges cannot get empty here, otherwise we would have left the stage when checking "from"
237 while (oldEdges.back()->prohibits(&veh, hasRestrictions) || oldEdges.back()->isInternal()) {
238 oldEdges.pop_back();
239 }
240 WRITE_MESSAGE("Changing invalid destination edge '" + backID
241 + "' to edge '" + oldEdges.back()->getID() + "' for vehicle '" + veh.getID() + "'.");
242 }
243 std::vector<ROVehicle::Mandatory> mandatory = veh.getMandatoryEdges(oldEdges.front(), oldEdges.back());
244 assert(mandatory.size() >= 2);
245 // removed prohibited
246 for (ConstROEdgeVector::iterator i = oldEdges.begin(); i != oldEdges.end();) {
247 if ((*i)->prohibits(&veh, hasRestrictions) || (*i)->isInternal()) {
248 // no need to check the mandatories here, this was done before
249 WRITE_MESSAGEF(TL("Removing invalid edge '%' from route for vehicle '%'."), (*i)->getID(), veh.getID());
250 i = oldEdges.erase(i);
251 } else {
252 ++i;
253 }
254 }
255 // reconnect remaining edges
256 if (mandatory.size() > oldEdges.size() && initialSize > 2) {
257 WRITE_MESSAGEF(TL("There are stop edges which were not part of the original route for vehicle '%'."), veh.getID());
258 }
259 ConstROEdgeVector targets;
260 bool checkPositions = false;
261 if (mandatory.size() >= oldEdges.size()) {
262 for (auto m : mandatory) {
263 targets.push_back(m.edge);
264 checkPositions |= m.pos >= 0;
265 }
266 } else {
267 targets = oldEdges;
268 }
269 newEdges.push_back(targets.front());
270 auto nextMandatory = mandatory.begin() + 1;
271 int lastMandatory = 0;
272 for (ConstROEdgeVector::const_iterator i = targets.begin() + 1;
273 i != targets.end() && nextMandatory != mandatory.end(); ++i) {
274 const ROEdge* prev = *(i - 1);
275 const ROEdge* cur = *i;
276 if (prev->isConnectedTo(*cur, veh.getVClass()) && (!isRailway(veh.getVClass()) || prev->getBidiEdge() != cur)) {
277 newEdges.push_back(cur);
278 } else {
279 if (initialSize > 2) {
280 // only inform if the input is (probably) not a trip
281 WRITE_MESSAGEF(TL("Edge '%' not connected to edge '%' for vehicle '%'."), (*(i - 1))->getID(), (*i)->getID(), veh.getID());
282 }
283 const ROEdge* last = newEdges.back();
284 newEdges.pop_back();
285 if (last->isTazConnector() && newEdges.size() > 1) {
286 // assume this was a viaTaz
287 last = newEdges.back();
288 newEdges.pop_back();
289 }
290 if (veh.hasJumps() && (nextMandatory - 1)->isJump) {
291 while (*i != nextMandatory->edge) {
292 ++i;
293 }
294 newEdges.push_back(last);
295 newEdges.push_back(*i);
296 //std::cout << " skipJump mIndex=" << (nextMandatory - 1 - mandatory.begin()) << " last=" << last->getID() << " next=" << (*i)->getID() << " newEdges=" << toString(newEdges) << "\n";
297 } else {
298 if (veh.getID() == "10.T0.1-13-P-j26-1.2.H.0") {
299 std::cout << " beforeRepair newEdges=" << toString(newEdges) << " last=" << last->getID() << "\n";
300 }
301
302 int numEdgesBefore = (int)newEdges.size();
303 // router.setHint(targets.begin(), i, &veh, begin);
304 if (myTryRepair && lastMandatory < (int)newEdges.size() && last != newEdges[lastMandatory]) {
306 }
307 bool ok;
308 if (checkPositions
309 && mandatory[i - targets.begin() - 1].pos >= 0
310 && mandatory[i - targets.begin()].pos >= 0) {
311 ok = router.compute(
312 last, mandatory[i - targets.begin() - 1].pos,
313 *i, mandatory[i - targets.begin()].pos,
314 &veh, begin, newEdges);
315 } else {
316 ok = router.compute(last, *i, &veh, begin, newEdges);
317 }
318 router.setMsgHandler(mh);
319 if (!ok) {
320 // backtrack: try to route from last mandatory edge to next mandatory edge
321 // XXX add option for backtracking in smaller increments
322 // (i.e. previous edge to edge after *i)
323 // we would then need to decide whether we have found a good
324 // tradeoff between faithfulness to the input data and detour-length
325 if (lastMandatory >= (int)newEdges.size() || last == newEdges[lastMandatory] || !backTrack(router, i, lastMandatory, nextMandatory->edge, newEdges, veh, begin)) {
326 mh->inform("Mandatory edge '" + (*i)->getID() + "' not reachable by vehicle '" + veh.getID() + "'.");
327 return false;
328 }
329 } else if (!myMayBeDisconnected && !isTrip && last != (*i)) {
330 double airDist = last->getToJunction()->getPosition().distanceTo(
331 (*i)->getFromJunction()->getPosition());
332 double repairDist = 0;
333 for (auto it2 = (newEdges.begin() + numEdgesBefore + 1); it2 != newEdges.end() && it2 != newEdges.end() - 1; it2++) {
334 repairDist += (*it2)->getLength();
335 }
336 const double detourFactor = repairDist / MAX2(airDist, 1.0);
337 const double detour = MAX2(0.0, repairDist - airDist);
338 const double maxDetourFactor = OptionsCont::getOptions().getFloat("repair.max-detour-factor");
339 if (detourFactor > maxDetourFactor) {
340 WRITE_MESSAGEF(" Backtracking to avoid detour of %m for gap of %m)", detour, airDist);
341 backTrack(router, i, lastMandatory, nextMandatory->edge, newEdges, veh, begin);
342 } else if (detourFactor > 1.1) {
343 WRITE_MESSAGEF(" Taking detour of %m to avoid gap of %m)", detour, airDist);
344 }
345 }
346 if (veh.getID() == "10.T0.1-13-P-j26-1.2.H.0") {
347 std::cout << " at=" << numEdgesBefore << " before=" << numEdgesBefore << " after=" << newEdges.size() << " new=" << toString(newEdges) << "\n";
348 }
349 }
350 }
351 if (*i == nextMandatory->edge) {
352 nextMandatory++;
353 lastMandatory = (int)newEdges.size() - 1;
354 }
355 }
356 if (veh.getParameter().via.size() > 0 && veh.getParameter().stops.size() > 0) {
357 // check consistency of stops and vias
358 auto it = newEdges.begin();
359 for (const auto& stop : veh.getParameter().stops) {
360 const ROEdge* e = net->getEdge(stop.edge);
361 it = std::find(it, newEdges.end(), e);
362 if (it == newEdges.end()) {
363 mh->inform("Stop edge '" + e->getID() + "' is inconsistent with via edges for vehicle '" + veh.getID() + "'.");
364 return false;
365 }
366 }
367 }
368 }
369 return true;
370}
371
372
373bool
375 ConstROEdgeVector::const_iterator& i, int lastMandatory, const ROEdge* nextMandatory,
376 ConstROEdgeVector& newEdges, const ROVehicle& veh, SUMOTime begin) {
377 ConstROEdgeVector edges;
378 bool ok = router.compute(newEdges[lastMandatory], nextMandatory, &veh, begin, edges, true);
379 if (!ok) {
380 return false;
381 }
382
383 while (*i != nextMandatory) {
384 ++i;
385 }
386 newEdges.erase(newEdges.begin() + lastMandatory + 1, newEdges.end());
387 std::copy(edges.begin() + 1, edges.end(), back_inserter(newEdges));
388 return true;
389}
390
391
392RORoute*
394 const ROVehicle* const veh, RORoute* current, SUMOTime begin,
395 MsgHandler* errorHandler) {
396 RORoute* replaced = nullptr;
397 if (myTryRepair || myUsingJTRR) {
398 if (myNewRoute) {
399 replaced = myAlternatives[0];
400 myAlternatives[0] = current;
401 }
402 if (!router.isValid(current->getEdgeVector(), veh, STEPS2TIME(begin))) {
403 delete replaced;
404 throw ProcessError("Route '" + getID() + "' (vehicle '" + veh->getID() + "') is not valid.");
405 }
406 double costs = router.recomputeCosts(current->getEdgeVector(), veh, begin);
407 if (veh->hasJumps()) {
408 // @todo: jumpTime should be applied in recomputeCost to ensure the
409 // correctness of time-dependent traveltimes
410 costs += STEPS2TIME(veh->getJumpTime());
411 }
412 current->setCosts(costs);
413 return replaced;
414 }
415 // add the route when it's new
416 if (myAlternatives.back()->getProbability() < 0 || !myAlternatives.back()->isPermitted(veh, errorHandler)) {
417 if (myAlternatives.back()->getProbability() >= 0 && errorHandler == MsgHandler::getErrorInstance()) {
418 throw ProcessError("Route '" + current->getID() + "' (vehicle '" + veh->getID() + "') is not valid.");
419 }
420 delete myAlternatives.back();
421 myAlternatives.pop_back();
422 }
423 if (myNewRoute) {
424 myAlternatives.push_back(current);
425 }
426 // recompute the costs and (when a new route was added) scale the probabilities
427 const double scale = double(myAlternatives.size() - 1) / double(myAlternatives.size());
428 for (RORoute* const alt : myAlternatives) {
429 if (!router.isValid(alt->getEdgeVector(), veh, STEPS2TIME(begin))) {
430 throw ProcessError("Route '" + current->getID() + "' (vehicle '" + veh->getID() + "') is not valid.");
431 }
432 // recompute the costs for all routes
433 const double newCosts = router.recomputeCosts(alt->getEdgeVector(), veh, begin);
434 assert(myAlternatives.size() != 0);
435 if (myNewRoute) {
436 if (alt == current) {
437 // set initial probability and costs
438 alt->setProbability(1. / (double) myAlternatives.size());
439 alt->setCosts(newCosts);
440 } else {
441 // rescale probs for all others
442 alt->setProbability(alt->getProbability() * scale);
443 }
444 }
446 }
447 assert(myAlternatives.size() != 0);
449 const bool keepRoute = RouteCostCalculator<RORoute, ROEdge, ROVehicle>::getCalculator().keepRoute();
450 if (!RouteCostCalculator<RORoute, ROEdge, ROVehicle>::getCalculator().keepAllRoutes() && !keepRoute) {
451 // remove with probability of 0 (not mentioned in Gawron)
452 for (std::vector<RORoute*>::iterator i = myAlternatives.begin(); i != myAlternatives.end();) {
453 if ((*i)->getProbability() == 0) {
454 delete *i;
455 i = myAlternatives.erase(i);
456 } else {
457 i++;
458 }
459 }
460 }
461 int maxNumber = RouteCostCalculator<RORoute, ROEdge, ROVehicle>::getCalculator().getMaxRouteNumber();
462 if ((int)myAlternatives.size() > maxNumber) {
463 const RORoute* last = myAlternatives[myLastUsed];
464 // only keep the routes with highest probability
465 sort(myAlternatives.begin(), myAlternatives.end(), [](const RORoute * const a, const RORoute * const b) {
466 return a->getProbability() > b->getProbability();
467 });
468 if (keepRoute) {
469 for (int i = 0; i < (int)myAlternatives.size(); i++) {
470 if (myAlternatives[i] == last) {
471 myLastUsed = i;
472 break;
473 }
474 }
475 if (myLastUsed >= maxNumber) {
477 myLastUsed = maxNumber - 1;
478 }
479 }
480 for (std::vector<RORoute*>::iterator i = myAlternatives.begin() + maxNumber; i != myAlternatives.end(); i++) {
481 delete *i;
482 }
483 myAlternatives.erase(myAlternatives.begin() + maxNumber, myAlternatives.end());
484 }
485 // rescale probabilities
486 double newSum = 0.;
487 for (const RORoute* const alt : myAlternatives) {
488 newSum += alt->getProbability();
489 }
490 assert(newSum > 0);
491 // @note newSum may be larger than 1 for numerical reasons
492 for (RORoute* const alt : myAlternatives) {
493 alt->setProbability(alt->getProbability() / newSum);
494 }
495
496 // find the route to use
497 if (!keepRoute) {
498 double chosen = RandHelper::rand();
499 myLastUsed = 0;
500 for (const RORoute* const alt : myAlternatives) {
501 chosen -= alt->getProbability();
502 if (chosen <= 0) {
503 return nullptr;
504 }
505 myLastUsed++;
506 }
507 }
508 return nullptr;
509}
510
511const ROEdge*
513 return myAlternatives.back()->getFirst();
514}
515
516
517const ROEdge*
519 return myAlternatives.back()->getLast();
520}
521
522
525 bool asAlternatives, bool withExitTimes, bool withCost, bool withLength) const {
526 if (asAlternatives) {
528 for (int i = 0; i != (int)myAlternatives.size(); i++) {
529 myAlternatives[i]->writeXMLDefinition(dev, veh, true, true, withExitTimes, withLength);
530 }
531 dev.closeTag();
532 return dev;
533 } else {
534 return myAlternatives[myLastUsed]->writeXMLDefinition(dev, veh, withCost, false, withExitTimes, withLength);
535 }
536}
537
538
540RORouteDef::copy(const std::string& id, const SUMOTime stopOffset) const {
542 for (const RORoute* const route : myAlternatives) {
543 RGBColor* col = route->getColor() != nullptr ? new RGBColor(*route->getColor()) : nullptr;
544 RORoute* newRoute = new RORoute(id, route->getCosts(), route->getProbability(), route->getEdgeVector(), col, route->getStops());
545 newRoute->addStopOffset(stopOffset);
546 result->addLoadedAlternative(newRoute);
547 }
548 return result;
549}
550
551
552double
554 double sum = 0.;
555 for (std::vector<RORoute*>::const_iterator i = myAlternatives.begin(); i != myAlternatives.end(); i++) {
556 sum += (*i)->getProbability();
557 }
558 return sum;
559}
560
561
562/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define WRITE_MESSAGEF(...)
Definition MsgHandler.h:289
#define WRITE_MESSAGE(msg)
Definition MsgHandler.h:288
#define TL(string)
Definition MsgHandler.h:304
std::vector< const ROEdge * > ConstROEdgeVector
Definition ROEdge.h:57
#define STEPS2TIME(x)
Definition SUMOTime.h:58
bool isRailway(SVCPermissions permissions)
Returns whether an edge with the given permissions is a (exclusive) railway edge.
@ SUMO_TAG_ROUTE_DISTRIBUTION
distribution of a route
@ SUMO_ATTR_LAST
T MAX2(T a, T b)
Definition StdDefs.h:86
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:49
static MsgHandler * getErrorInstance()
Returns the instance to add errors to.
virtual void inform(std::string msg, bool addType=true)
adds a new error to the list
static MsgHandler * getWarningInstance()
Returns the instance to add warnings to.
Base class for objects which have an id.
Definition Named.h:54
std::string myID
The name of the object.
Definition Named.h:125
const std::string & getID() const
Returns the id.
Definition Named.h:74
A storage for options typed value containers)
Definition OptionsCont.h:89
double getFloat(const std::string &name) const
Returns the double-value of the named option (only for Option_Float)
bool exists(const std::string &name) const
Returns the information whether the named option is known.
bool getBool(const std::string &name) const
Returns the boolean-value of the named option (only for Option_Bool)
static OptionsCont & getOptions()
Retrieves the options.
Static storage of an output device and its base (abstract) implementation.
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.
double distanceTo(const Position &p2) const
returns the euclidean distance in 3 dimensions
Definition Position.h:263
A basic edge for routing applications.
Definition ROEdge.h:73
const ROEdge * getBidiEdge() const
return opposite superposable/congruent edge, if it exist and 0 else
Definition ROEdge.h:563
const RONode * getToJunction() const
Definition ROEdge.h:550
bool isTazConnector() const
Definition ROEdge.h:174
bool isConnectedTo(const ROEdge &e, const SUMOVehicleClass vClass, bool ignoreTransientPermissions=false) const
returns the information whether this edge is directly connected to the given
Definition ROEdge.cpp:461
The router's network representation.
Definition RONet.h:63
static RONet * getInstance()
Returns the pointer to the unique instance of RONet (singleton).
Definition RONet.cpp:56
void updateLaneProhibitions(SUMOTime begin)
Definition RONet.cpp:1008
bool hasProhibitions() const
Definition RONet.h:466
bool hasParamRestrictions() const
Definition RONet.h:103
ROEdge * getEdge(const std::string &name) const
Retrieves an edge from the network.
Definition RONet.h:179
const Prohibitions & getProhibitions() const
Definition RONet.h:470
const Position & getPosition() const
Returns the position of the node.
Definition RONode.h:67
SUMOVehicleClass getVClass() const
Definition RORoutable.h:127
const std::string & getID() const
Returns the id of the routable.
Definition RORoutable.h:98
const SUMOVehicleParameter & getParameter() const
Returns the definition of the vehicle / person parameter.
Definition RORoutable.h:75
Base class for a vehicle's route definition.
Definition RORouteDef.h:53
const ROEdge * getOrigin() const
bool repairCurrentRoute(SUMOAbstractRouter< ROEdge, ROVehicle > &router, SUMOTime begin, const ROVehicle &veh, ConstROEdgeVector oldEdges, ConstROEdgeVector &newEdges, bool isTrip=false) const
Builds the complete route (or chooses her from the list of alternatives, when existing)
static bool backTrack(SUMOAbstractRouter< ROEdge, ROVehicle > &router, ConstROEdgeVector::const_iterator &i, int lastMandatory, const ROEdge *nextMandatory, ConstROEdgeVector &newEdges, const ROVehicle &veh, SUMOTime begin)
backtrack to last mandatory edge and route to next mandatory
RORoute * myPrecomputed
precomputed route for out-of-order computation
Definition RORouteDef.h:165
void addLoadedAlternative(RORoute *alternative)
Adds a single alternative loaded from the file An alternative may also be generated during DUA.
RORoute * addAlternative(SUMOAbstractRouter< ROEdge, ROVehicle > &router, const ROVehicle *const, RORoute *current, SUMOTime begin, MsgHandler *errorHandler)
Adds an alternative to the list of routes and returns the route that was replaced or nullptr.
RORouteDef(const std::string &id, const int lastUsed, const bool tryRepair, const bool mayBeDisconnected)
Constructor.
double getOverallProb() const
Returns the sum of the probablities of the contained routes.
std::vector< RORoute * > myAlternatives
The alternatives.
Definition RORouteDef.h:171
OutputDevice & writeXMLDefinition(OutputDevice &dev, const ROVehicle *const veh, bool asAlternatives, bool withExitTimes, bool withCost, bool withLength) const
Saves the built route / route alternatives.
RORoute * buildCurrentRoute(SUMOAbstractRouter< ROEdge, ROVehicle > &router, SUMOTime begin, const ROVehicle &veh) const
Triggers building of the complete route (via preComputeCurrentRoute) or returns precomputed route.
const bool myMayBeDisconnected
Definition RORouteDef.h:180
void addAlternativeDef(const RORouteDef *alternative)
Adds an alternative loaded from the file.
virtual ~RORouteDef()
Destructor.
bool myDiscardSilent
Whether this route should be silently discarded.
Definition RORouteDef.h:183
void preComputeCurrentRoute(SUMOAbstractRouter< ROEdge, ROVehicle > &router, SUMOTime begin, const ROVehicle &veh) const
Builds the complete route (or chooses her from the list of alternatives, when existing)
static bool myUsingJTRR
Definition RORouteDef.h:185
bool myNewRoute
Information whether a new route was generated.
Definition RORouteDef.h:177
const bool myTryRepair
Definition RORouteDef.h:179
int myLastUsed
Index of the route used within the last step.
Definition RORouteDef.h:168
std::set< RORoute * > myRouteRefs
Routes which are deleted someplace else.
Definition RORouteDef.h:174
static bool mySkipNewRoutes
Definition RORouteDef.h:186
const ROEdge * getDestination() const
RORouteDef * copy(const std::string &id, const SUMOTime stopOffset) const
Returns a deep copy of the route definition.
void validateAlternatives(const ROVehicle *veh, MsgHandler *errorHandler)
removes invalid alternatives and raise an error or warning
A complete router's route.
Definition RORoute.h:52
void addStopOffset(const SUMOTime offset)
Adapts the until time of all stops by the given offset.
Definition RORoute.h:196
const ConstROEdgeVector & getEdgeVector() const
Returns the list of edges this route consists of.
Definition RORoute.h:152
void setCosts(double costs)
Sets the costs of the route.
Definition RORoute.cpp:64
A vehicle as used by router.
Definition ROVehicle.h:51
SUMOTime getJumpTime() const
Definition ROVehicle.h:128
SUMOTime getDepartureTime() const
Returns the time the vehicle starts at, 0 for triggered vehicles.
Definition ROVehicle.h:93
bool hasJumps() const
Definition ROVehicle.h:124
std::vector< Mandatory > getMandatoryEdges(const ROEdge *requiredStart, const ROEdge *requiredEnd) const
static double rand(SumoRNG *rng=nullptr)
Returns a random real number in [0, 1)
Abstract base class providing static factory method.
static RouteCostCalculator< R, E, V > & getCalculator()
void setMsgHandler(MsgHandler *const errorMsgHandler)
virtual void prohibit(const Prohibitions &toProhibit)
virtual bool supportsProhibitions() const
virtual bool compute(const E *from, const E *to, const V *const vehicle, SUMOTime msTime, std::vector< const E * > &into, bool silent=false)=0
Builds the route between the given edges using the minimum effort at the given time The definition of...
bool isValid(const std::vector< const E * > &edges, const V *const v, double t) const
virtual double recomputeCosts(const std::vector< const E * > &edges, const V *const v, SUMOTime msTime, double *lengthp=nullptr) const
std::vector< std::string > via
List of the via-edges the vehicle must visit.
std::vector< Stop > stops
List of the stops the vehicle will make, TraCI may add entries here.
Some static methods for string processing.
Definition StringUtils.h:40
NLOHMANN_BASIC_JSON_TPL_DECLARATION void swap(nlohmann::NLOHMANN_BASIC_JSON_TPL &j1, nlohmann::NLOHMANN_BASIC_JSON_TPL &j2) noexcept(//NOLINT(readability-inconsistent-declaration-parameter-name) is_nothrow_move_constructible< nlohmann::NLOHMANN_BASIC_JSON_TPL >::value &&//NOLINT(misc-redundant-expression) is_nothrow_move_assignable< nlohmann::NLOHMANN_BASIC_JSON_TPL >::value)
exchanges the values of two JSON objects
Definition json.hpp:21884