Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
ROEdge.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-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/****************************************************************************/
24// A basic edge for routing applications
25/****************************************************************************/
26#include <config.h>
27
30#include <algorithm>
31#include <cassert>
32#include <iostream>
36#include "ROLane.h"
37#include "RONet.h"
38#include "ROVehicle.h"
39#include "ROEdge.h"
40
41
42// ===========================================================================
43// static member definitions
44// ===========================================================================
45bool ROEdge::myInterpolate = false;
46bool ROEdge::myHaveTTWarned = false;
47bool ROEdge::myHaveEWarned = false;
50double ROEdge::myMinEdgePriority(std::numeric_limits<double>::max());
52
53
54// ===========================================================================
55// method definitions
56// ===========================================================================
57ROEdge::ROEdge(const std::string& id, RONode* from, RONode* to, int index, const int priority, const std::string& type, const std::string& routingType) :
58 Named(id),
59 myFromJunction(from),
60 myToJunction(to),
61 myIndex(index),
62 myPriority(priority),
63 myType(type),
64 myRoutingType(routingType),
65 mySpeed(-1),
66 myLength(0),
67 myAmSink(false),
68 myAmSource(false),
69 myUsingTTTimeLine(false),
70 myUsingETimeLine(false),
71 mySpeedRestrictions(nullptr),
72 myCombinedPermissions(0),
73 myOtherTazConnector(nullptr),
74 myTimePenalty(0) {
75 while ((int)myEdges.size() <= index) {
76 myEdges.push_back(0);
77 }
78 myEdges[index] = this;
79 if (from == nullptr && to == nullptr) {
80 // TAZ edge, no lanes
82 } else {
83 // TODO we should not calculate the boundary here, the position for the nodes is not valid yet
84 myBoundary.add(from->getPosition());
86 }
87}
88
89
90ROEdge::ROEdge(const std::string& id, const RONode* from, const RONode* to, SVCPermissions p) :
91 Named(id),
92 myFromJunction(const_cast<RONode*>(from)),
93 myToJunction(const_cast<RONode*>(to)),
94 myIndex(-1),
95 myPriority(0),
96 myType(""),
97 mySpeed(std::numeric_limits<double>::max()),
98 myLength(0),
99 myAmSink(false),
100 myAmSource(false),
101 myUsingTTTimeLine(false),
102 myUsingETimeLine(false),
103 myCombinedPermissions(p),
104 myOtherTazConnector(nullptr),
105 myTimePenalty(0)
106{ }
107
108
110 for (ROLane* const lane : myLanes) {
111 delete lane;
112 }
116}
117
118
119void
121 const double speed = lane->getSpeed();
122 if (speed > mySpeed) {
123 mySpeed = speed;
124 myLength = lane->getLength();
125 }
126 mySpeed = speed > mySpeed ? speed : mySpeed;
127 myLanes.push_back(lane);
128
129 // integrate new allowed classes
131}
132
133
134void
135ROEdge::addSuccessor(ROEdge* s, ROEdge* via, std::string) {
136 if (isInternal()) {
137 // for internal edges after an internal junction,
138 // this is called twice and only the second call counts
139 myFollowingEdges.clear();
140 myFollowingViaEdges.clear();
141 }
142 if (find(myFollowingEdges.begin(), myFollowingEdges.end(), s) == myFollowingEdges.end()) {
143 myFollowingEdges.push_back(s);
144 myFollowingViaEdges.push_back(std::make_pair(s, via));
145 if (isTazConnector() && s->getFromJunction() != nullptr) {
147 }
148 if (!isInternal()) {
149 s->myApproachingEdges.push_back(this);
150 if (s->isTazConnector() && getToJunction() != nullptr) {
151 s->myBoundary.add(getToJunction()->getPosition());
152 }
153 }
154 if (via != nullptr) {
155 if (via->myApproachingEdges.size() == 0) {
156 via->myApproachingEdges.push_back(this);
157 }
158 }
159 }
160}
161
162
163void
164ROEdge::addEffort(double value, double timeBegin, double timeEnd) {
165 myEfforts.add(timeBegin, timeEnd, value);
166 myUsingETimeLine = true;
167}
168
169
170void
171ROEdge::addTravelTime(double value, double timeBegin, double timeEnd) {
172 myTravelTimes.add(timeBegin, timeEnd, value);
173 myUsingTTTimeLine = true;
174}
175
176
177double
178ROEdge::getEffort(const ROVehicle* const veh, double time) const {
179 double ret = 0;
180 if (!getStoredEffort(time, ret)) {
181 return myLength / getMaxSpeed(veh);
182 }
183 return ret;
184}
185
186
187double
188ROEdge::getDistanceTo(const ROEdge* other, const bool doBoundaryEstimate) const {
189 assert(this != other);
190 if (doBoundaryEstimate) {
191 return myBoundary.distanceTo2D(other->myBoundary);
192 }
193 if (isTazConnector()) {
194 if (other->isTazConnector()) {
195 return myBoundary.distanceTo2D(other->myBoundary);
196 }
198 }
199 if (other->isTazConnector()) {
200 return other->myBoundary.distanceTo2D(getToJunction()->getPosition());
201 }
202 return getLanes()[0]->getShape()[-1].distanceTo2D(other->getLanes()[0]->getShape()[0]);
203 //return getToJunction()->getPosition().distanceTo2D(other->getFromJunction()->getPosition());
204}
205
206
207bool
208ROEdge::hasLoadedTravelTime(double time) const {
210}
211
212
213double
214ROEdge::getTravelTime(const ROVehicle* const veh, double time) const {
215 if (myUsingTTTimeLine) {
216 if (myTravelTimes.describesTime(time)) {
217 double lineTT = myTravelTimes.getValue(time);
218 if (myInterpolate) {
219 const double inTT = lineTT;
220 const double split = (double)(myTravelTimes.getSplitTime(time, time + inTT) - time);
221 if (split >= 0) {
222 lineTT = myTravelTimes.getValue(time + inTT) * ((double)1. - split / inTT) + split;
223 }
224 }
225 return MAX2(getMinimumTravelTime(veh), lineTT);
226 } else {
227 if (!myHaveTTWarned) {
228 WRITE_WARNINGF(TL("No interval matches passed time=% in edge '%'.\n Using edge's length / max speed."), time, myID);
229 myHaveTTWarned = true;
230 }
231 }
232 }
233 const double speed = veh != nullptr ? getMaxSpeed(veh) : mySpeed;
234 return myLength / speed + myTimePenalty;
235}
236
237
238double
239ROEdge::getNoiseEffort(const ROEdge* const edge, const ROVehicle* const veh, double time) {
240 double ret = 0;
241 if (!edge->getStoredEffort(time, ret)) {
243 }
244 return ret;
245}
246
247
248bool
249ROEdge::getStoredEffort(double time, double& ret) const {
250 if (myUsingETimeLine) {
251 if (!myEfforts.describesTime(time)) {
252 if (!myHaveEWarned) {
253 WRITE_WARNINGF(TL("No interval matches passed time=% in edge '%'.\n Using edge's length / edge's speed."), time, myID);
254 myHaveEWarned = true;
255 }
256 return false;
257 }
258 if (myInterpolate) {
259 const double inTT = myTravelTimes.getValue(time);
260 const double ratio = (myEfforts.getSplitTime(time, time + inTT) - time) / inTT;
261 if (ratio >= 0.) {
262 ret = ratio * myEfforts.getValue(time) + (1. - ratio) * myEfforts.getValue(time + inTT);
263 return true;
264 }
265 }
266 ret = myEfforts.getValue(time);
267 return true;
268 }
269 return false;
270}
271
272
273int
275 if (myAmSink) {
276 return 0;
277 }
278 return (int) myFollowingEdges.size();
279}
280
281
282int
284 if (myAmSource) {
285 return 0;
286 }
287 return (int) myApproachingEdges.size();
288}
289
290
291const ROEdge*
293 const ROEdge* result = this;
294 while (result->isInternal()) {
295 assert(myApproachingEdges.size() == 1);
296 result = result->myApproachingEdges.front();
297 }
298 return result;
299}
300
301
302
303const ROEdge*
305 const ROEdge* result = this;
306 while (result->isInternal()) {
307 assert(myFollowingEdges.size() == 1);
308 result = result->myFollowingEdges.front();
309 }
310 return result;
311}
312
313
314void
315ROEdge::buildTimeLines(const std::string& measure, const bool boundariesOverride) {
316 if (myUsingETimeLine) {
317 double value = myLength / mySpeed;
318 const SUMOEmissionClass c = PollutantsInterface::getClassByName("HBEFA4/default");
319 if (measure == "CO") {
320 value = PollutantsInterface::compute(c, PollutantsInterface::CO, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
321 }
322 if (measure == "CO2") {
323 value = PollutantsInterface::compute(c, PollutantsInterface::CO2, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
324 }
325 if (measure == "HC") {
326 value = PollutantsInterface::compute(c, PollutantsInterface::HC, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
327 }
328 if (measure == "PMx") {
329 value = PollutantsInterface::compute(c, PollutantsInterface::PM_X, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
330 }
331 if (measure == "NOx") {
332 value = PollutantsInterface::compute(c, PollutantsInterface::NO_X, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
333 }
334 if (measure == "fuel") {
335 value = PollutantsInterface::compute(c, PollutantsInterface::FUEL, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
336 }
337 if (measure == "electricity") {
338 value = PollutantsInterface::compute(c, PollutantsInterface::ELEC, mySpeed, 0, 0, nullptr) * value; // @todo: give correct slope
339 }
340 myEfforts.fillGaps(value, boundariesOverride);
341 }
342 if (myUsingTTTimeLine) {
343 myTravelTimes.fillGaps(myLength / mySpeed + myTimePenalty, boundariesOverride);
344 }
345}
346
347
348void
349ROEdge::cacheParamRestrictions(const std::vector<std::string>& restrictionKeys) {
350 for (const std::string& key : restrictionKeys) {
351 const std::string value = getParameter(key, "1e40");
353 }
354}
355
356
357double
359 return myLanes.empty() ? 1. : myLanes[0]->getShape().length() / myLanes[0]->getLength();
360}
361
362
363bool
364ROEdge::allFollowersProhibit(const ROVehicle* const vehicle) const {
365 for (ROEdgeVector::const_iterator i = myFollowingEdges.begin(); i != myFollowingEdges.end(); ++i) {
366 if (!(*i)->prohibits(vehicle)) {
367 return false;
368 }
369 }
370 return true;
371}
372
373
374const ROEdgeVector&
376 return myEdges;
377}
378
379
380const Position
382 const double middle = (stop.endPos + stop.startPos) / 2.;
384 return (edge->getFromJunction()->getPosition() + edge->getToJunction()->getPosition()) * (middle / edge->getLength());
385}
386
387
388const ROEdgeVector&
390 if (vClass == SVC_IGNORING || !RONet::getInstance()->hasPermissions() || isTazConnector()) {
391 return myFollowingEdges;
392 }
393#ifdef HAVE_FOX
394 FXMutexLock locker(myLock);
395#endif
396 std::map<SUMOVehicleClass, ROEdgeVector>::const_iterator i = myClassesSuccessorMap.find(vClass);
397 if (i != myClassesSuccessorMap.end()) {
398 // can use cached value
399 return i->second;
400 }
401 // this vClass is requested for the first time. rebuild all successors
402 std::set<ROEdge*> followers;
403 for (const ROLane* const lane : myLanes) {
404 if ((lane->getPermissions() & vClass) != 0) {
405 for (const auto& next : lane->getOutgoingViaLanes()) {
406 if ((next.first->getPermissions() & vClass) != 0 && (next.second == nullptr || (next.second->getPermissions() & vClass) != 0)) {
407 followers.insert(&next.first->getEdge());
408 }
409 }
410 }
411 }
412 // also add district edges (they are not connected at the lane level
413 for (ROEdgeVector::const_iterator it = myFollowingEdges.begin(); it != myFollowingEdges.end(); ++it) {
414 if ((*it)->isTazConnector()) {
415 followers.insert(*it);
416 }
417 }
418 myClassesSuccessorMap[vClass].insert(myClassesSuccessorMap[vClass].begin(),
419 followers.begin(), followers.end());
420 return myClassesSuccessorMap[vClass];
421}
422
423
425ROEdge::getViaSuccessors(SUMOVehicleClass vClass, bool /*ignoreTransientPermissions*/) const {
426 if (vClass == SVC_IGNORING || !RONet::getInstance()->hasPermissions() || isTazConnector()) {
427 return myFollowingViaEdges;
428 }
429#ifdef HAVE_FOX
430 FXMutexLock locker(myLock);
431#endif
432 std::map<SUMOVehicleClass, ROConstEdgePairVector>::const_iterator i = myClassesViaSuccessorMap.find(vClass);
433 if (i != myClassesViaSuccessorMap.end()) {
434 // can use cached value
435 return i->second;
436 }
437 // this vClass is requested for the first time. rebuild all successors
438 std::set<std::pair<const ROEdge*, const ROEdge*> > followers;
439 for (const ROLane* const lane : myLanes) {
440 if ((lane->getPermissions() & vClass) != 0) {
441 for (const auto& next : lane->getOutgoingViaLanes()) {
442 if ((next.first->getPermissions() & vClass) != 0 && (next.second == nullptr || (next.second->getPermissions() & vClass) != 0)) {
443 followers.insert(std::make_pair(&next.first->getEdge(), next.second));
444 }
445 }
446 }
447 }
448 // also add district edges (they are not connected at the lane level
449 for (const ROEdge* e : myFollowingEdges) {
450 if (e->isTazConnector()) {
451 followers.insert(std::make_pair(e, e));
452 }
453 }
454 myClassesViaSuccessorMap[vClass].insert(myClassesViaSuccessorMap[vClass].begin(),
455 followers.begin(), followers.end());
456 return myClassesViaSuccessorMap[vClass];
457}
458
459
460bool
461ROEdge::isConnectedTo(const ROEdge& e, const SUMOVehicleClass vClass, bool ignoreTransientPermissions) const {
462 // @todo needs to be used with #12501
463 UNUSED_PARAMETER(ignoreTransientPermissions);
464 const ROEdgeVector& followers = getSuccessors(vClass);
465 return std::find(followers.begin(), followers.end(), &e) != followers.end();
466}
467
468bool
469ROEdge::initPriorityFactor(double priorityFactor) {
470 myPriorityFactor = priorityFactor;
471 double maxEdgePriority = -std::numeric_limits<double>::max();
472 for (ROEdge* edge : myEdges) {
473 maxEdgePriority = MAX2(maxEdgePriority, (double)edge->getPriority());
474 myMinEdgePriority = MIN2(myMinEdgePriority, (double)edge->getPriority());
475 }
476 myEdgePriorityRange = maxEdgePriority - myMinEdgePriority;
477 if (myEdgePriorityRange == 0) {
478 WRITE_WARNING(TL("Option weights.priority-factor does not take effect because all edges have the same priority."));
480 return false;
481 }
482 return true;
483}
484
485
486/****************************************************************************/
std::vector< std::string > & split(const std::string &s, char delim, std::vector< std::string > &elems)
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define WRITE_WARNING(msg)
Definition MsgHandler.h:286
#define TL(string)
Definition MsgHandler.h:304
std::vector< ROEdge * > ROEdgeVector
std::vector< std::pair< const ROEdge *, const ROEdge * > > ROConstEdgePairVector
Definition ROEdge.h:58
std::vector< ROEdge * > ROEdgeVector
Definition ROEdge.h:56
const SVCPermissions SVCAll
all VClasses are allowed
long long int SVCPermissions
bitset where each bit declares whether a certain SVC may use this edge/lane
int SUMOEmissionClass
SUMOVehicleClass
Definition of vehicle classes to differ between different lane usage and authority types.
@ SVC_IGNORING
vehicles ignoring classes
T MIN2(T a, T b)
Definition StdDefs.h:80
T MAX2(T a, T b)
Definition StdDefs.h:86
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
Definition Boundary.cpp:75
double distanceTo2D(const Position &p) const
returns the euclidean distance in the x-y-plane
Definition Boundary.cpp:262
static double computeNoise(SUMOEmissionClass c, double v, double a)
Returns the noise produced by the a vehicle of the given type at the given speed.
Base class for objects which have an id.
Definition Named.h:54
std::string myID
The name of the object.
Definition Named.h:125
virtual const std::string getParameter(const std::string &key, const std::string defaultValue="") const
Returns the value for a given key.
static double compute(const SUMOEmissionClass c, const EmissionType e, const double v, const double a, const double slope, const EnergyParams *param)
Returns the amount of the emitted pollutant given the vehicle type and state (in mg/s or ml/s for fue...
static SUMOEmissionClass getClassByName(const std::string &eClass, const SUMOVehicleClass vc=SVC_IGNORING)
Checks whether the string describes a known vehicle class.
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
A basic edge for routing applications.
Definition ROEdge.h:73
bool allFollowersProhibit(const ROVehicle *const vehicle) const
Returns whether this edge succeeding edges prohibit the given vehicle to pass them.
Definition ROEdge.cpp:364
static double myPriorityFactor
Coefficient for factoring edge priority into routing weight.
Definition ROEdge.h:688
const ROEdge * getNormalBefore() const
if this edge is an internal edge, return its first normal predecessor, otherwise the edge itself
Definition ROEdge.cpp:292
double getDistanceTo(const ROEdge *other, const bool doBoundaryEstimate=false) const
optimistic distance heuristic for use in routing
Definition ROEdge.cpp:188
const ROEdge * getNormalAfter() const
if this edge is an internal edge, return its first normal successor, otherwise the edge itself
Definition ROEdge.cpp:304
void addEffort(double value, double timeBegin, double timeEnd)
Adds a weight value.
Definition ROEdge.cpp:164
bool hasLoadedTravelTime(double time) const
Returns whether a travel time for this edge was loaded.
Definition ROEdge.cpp:208
static double getStoredEffort(const ROEdge *const edge, const ROVehicle *const, double time)
Definition ROEdge.h:496
ReversedEdge< ROEdge, ROVehicle > * myReversedRoutingEdge
a reversed version for backward routing
Definition ROEdge.h:701
void buildTimeLines(const std::string &measure, const bool boundariesOverride)
Builds the internal representation of the travel time/effort.
Definition ROEdge.cpp:315
std::vector< ROLane * > myLanes
This edge's lanes.
Definition ROEdge.h:665
static bool initPriorityFactor(double priorityFactor)
initialize priority factor range
Definition ROEdge.cpp:469
static ROEdgeVector myEdges
Definition ROEdge.h:685
bool myAmSource
Definition ROEdge.h:631
RailEdge< ROEdge, ROVehicle > * myRailwayRoutingEdge
Definition ROEdge.h:704
const RONode * getToJunction() const
Definition ROEdge.h:545
bool myUsingTTTimeLine
Information whether the time line shall be used instead of the length value.
Definition ROEdge.h:635
std::map< SUMOVehicleClass, ROEdgeVector > myClassesSuccessorMap
The successors available for a given vClass.
Definition ROEdge.h:695
bool isTazConnector() const
Definition ROEdge.h:174
std::map< SUMOVehicleClass, ROConstEdgePairVector > myClassesViaSuccessorMap
The successors with vias available for a given vClass.
Definition ROEdge.h:698
std::vector< double > myParamRestrictions
cached value of parameters which may restrict access
Definition ROEdge.h:683
bool myUsingETimeLine
Information whether the time line shall be used instead of the length value.
Definition ROEdge.h:640
const RONode * getFromJunction() const
Definition ROEdge.h:541
virtual void addLane(ROLane *lane)
Adds a lane to the edge while loading.
Definition ROEdge.cpp:120
ValueTimeLine< double > myEfforts
Container storing passing time varying over time for the edge.
Definition ROEdge.h:638
bool isInternal() const
return whether this edge is an internal edge
Definition ROEdge.h:160
virtual ~ROEdge()
Destructor.
Definition ROEdge.cpp:109
int getNumSuccessors() const
Returns the number of edges this edge is connected to.
Definition ROEdge.cpp:274
Boundary myBoundary
The bounding rectangle of end nodes incoming or outgoing edges for taz connectors or of my own start ...
Definition ROEdge.h:677
static double getNoiseEffort(const ROEdge *const edge, const ROVehicle *const veh, double time)
Definition ROEdge.cpp:239
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
static bool myInterpolate
Information whether to interpolate at interval boundaries.
Definition ROEdge.h:643
const ROConstEdgePairVector & getViaSuccessors(SUMOVehicleClass vClass=SVC_IGNORING, bool ignoreTransientPermissions=false) const
Returns the following edges including vias, restricted by vClass.
Definition ROEdge.cpp:425
double getTravelTime(const ROVehicle *const veh, double time) const
Returns the travel time for this edge.
Definition ROEdge.cpp:214
double getMinimumTravelTime(const ROVehicle *const veh) const
Returns a lower bound for the travel time on this edge without using any stored timeLine.
Definition ROEdge.h:453
double myLength
The length of the edge.
Definition ROEdge.h:628
bool myAmSink
whether the edge is a source or a sink
Definition ROEdge.h:631
const ROEdgeVector & getSuccessors(SUMOVehicleClass vClass=SVC_IGNORING) const
Returns the following edges, restricted by vClass.
Definition ROEdge.cpp:389
void addTravelTime(double value, double timeBegin, double timeEnd)
Adds a travel time value.
Definition ROEdge.cpp:171
void cacheParamRestrictions(const std::vector< std::string > &restrictionKeys)
Definition ROEdge.cpp:349
int getNumPredecessors() const
Returns the number of edges connected to this edge.
Definition ROEdge.cpp:283
static double myEdgePriorityRange
the difference between maximum and minimum priority for all edges
Definition ROEdge.h:692
double myTimePenalty
flat penalty when computing traveltime
Definition ROEdge.h:680
SVCPermissions myCombinedPermissions
The list of allowed vehicle classes combined across lanes.
Definition ROEdge.h:668
static const Position getStopPosition(const SUMOVehicleParameter::Stop &stop)
return the coordinates of the center of the given stop
Definition ROEdge.cpp:381
static bool myHaveTTWarned
Information whether the edge has reported missing weights.
Definition ROEdge.h:648
double getEffort(const ROVehicle *const veh, double time) const
Returns the effort for this edge.
Definition ROEdge.cpp:178
const std::vector< ROLane * > & getLanes() const
Returns this edge's lanes.
Definition ROEdge.h:553
double getLengthGeometryFactor() const
return a lower bound on shape.length() / myLength that is
Definition ROEdge.cpp:358
double getLength() const
Returns the length of the edge.
Definition ROEdge.h:225
ROEdgeVector myFollowingEdges
List of edges that may be approached from this edge.
Definition ROEdge.h:651
double getMaxSpeed(const RORoutable *const veh) const
Definition ROEdge.h:463
FlippedEdge< ROEdge, RONode, ROVehicle > * myFlippedRoutingEdge
An extended version of the reversed edge for backward routing (used for the arc flag router)
Definition ROEdge.h:703
ROConstEdgePairVector myFollowingViaEdges
Definition ROEdge.h:653
ValueTimeLine< double > myTravelTimes
Container storing passing time varying over time for the edge.
Definition ROEdge.h:633
virtual void addSuccessor(ROEdge *s, ROEdge *via=nullptr, std::string dir="")
Adds information about a connected edge.
Definition ROEdge.cpp:135
static double myMinEdgePriority
Minimum priority for all edges.
Definition ROEdge.h:690
static bool myHaveEWarned
Information whether the edge has reported missing weights.
Definition ROEdge.h:646
static const ROEdgeVector & getAllEdges()
Returns all ROEdges.
Definition ROEdge.cpp:375
ROEdge(const std::string &id, RONode *from, RONode *to, int index, const int priority, const std::string &type, const std::string &routingType)
Constructor.
Definition ROEdge.cpp:57
ROEdgeVector myApproachingEdges
List of edges that approached this edge.
Definition ROEdge.h:656
double mySpeed
The maximum speed allowed on this edge.
Definition ROEdge.h:625
A single lane the router may use.
Definition ROLane.h:48
double getLength() const
Returns the length of the lane.
Definition ROLane.h:70
SVCPermissions getPermissions() const
Returns the list of allowed vehicle classes.
Definition ROLane.h:86
double getSpeed() const
Returns the maximum speed allowed on this lane.
Definition ROLane.h:78
static RONet * getInstance()
Returns the pointer to the unique instance of RONet (singleton).
Definition RONet.cpp:56
ROEdge * getEdge(const std::string &name) const
Retrieves an edge from the network.
Definition RONet.h:178
Base class for nodes used by the router.
Definition RONode.h:46
const Position & getPosition() const
Returns the position of the node.
Definition RONode.h:67
const SUMOVTypeParameter * getType() const
Returns the type of the routable.
Definition RORoutable.h:86
A vehicle as used by router.
Definition ROVehicle.h:50
SUMOEmissionClass emissionClass
The emission class of this vehicle.
Definition of vehicle stop (position and duration)
std::string lane
The lane to stop at.
double startPos
The stopping position start.
double endPos
The stopping position end.
static std::string getEdgeIDFromLane(const std::string laneID)
return edge id when given the lane ID
static double toDouble(const std::string &sData)
converts a string into the double value described by it by calling the char-type converter
double getSplitTime(double low, double high) const
Returns the time point at which the value changes.
bool describesTime(double time) const
Returns whether a value for the given time is known.
T getValue(double time) const
Returns the value for the given time.
void fillGaps(T value, bool extendOverBoundaries=false)
Sets a default value for all unset intervals.
void add(double begin, double end, T value)
Adds a value for a time interval into the container.
#define UNUSED_PARAMETER(x)
Definition json.hpp:4471