![]() |
Eclipse SUMO - Simulation of Urban MObility
|
Computes routes using junction turning percentages. More...
#include <ROJTRRouter.h>
Public Types | |
typedef double(* | Operation) (const ROEdge *const, const ROVehicle *const, double) |
Type of the function that is used to retrieve the edge effort. More... | |
Public Member Functions | |
void | buildPathFrom (const typename SUMOAbstractRouter< ROEdge, ROVehicle >::EdgeInfo *rbegin, std::vector< const ROEdge * > &edges) |
Builds the path from marked edges. More... | |
virtual SUMOAbstractRouter< ROEdge, ROVehicle > * | clone () |
virtual bool | compute (const ROEdge *from, const ROEdge *to, const ROVehicle *const vehicle, SUMOTime msTime, std::vector< const ROEdge * > &into, bool silent=false)=0 |
Builds the route between the given edges using the minimum effort at the given time The definition of the effort depends on the wished routing scheme. More... | |
bool | compute (const ROEdge *from, double fromPos, const ROEdge *to, double toPos, const ROVehicle *const vehicle, SUMOTime msTime, std::vector< const ROEdge * > &into, bool silent=false) |
Builds the route between the given edges using the minimum effort at the given time, also taking into account position along the edges to ensure currect handling of looped routes The definition of the effort depends on the wished routing scheme. More... | |
bool | computeLooped (const ROEdge *from, const ROEdge *to, const ROVehicle *const vehicle, SUMOTime msTime, std::vector< const ROEdge * > &into, bool silent=false) |
Builds the route between the given edges using the minimum effort at the given time if from == to, return the shortest looped route. More... | |
void | endQuery (int visits) |
const SUMOAbstractRouter< ROEdge, ROVehicle >::EdgeInfo & | getEdgeInfo (int index) const |
double | getEffort (const ROEdge *const e, const ROVehicle *const v, double t) const |
double | getTravelTime (const ROEdge *const e, const ROVehicle *const v, const double t, const double effort) const |
const std::string & | getType () const |
void | init (const int edgeID, const SUMOTime msTime) |
bool | isProhibited (const ROEdge *const edge, const ROVehicle *const vehicle) const |
virtual void | prohibit (const std::vector< ROEdge * > &toProhibit) |
double | recomputeCosts (const std::vector< const ROEdge * > &edges, const ROVehicle *const v, double fromPos, double toPos, SUMOTime msTime, double *lengthp=nullptr) const |
double | recomputeCosts (const std::vector< const ROEdge * > &edges, const ROVehicle *const v, SUMOTime msTime, double *lengthp=nullptr) const |
virtual void | reset (const ROVehicle *const vehicle) |
reset internal caches, used by CHRouter More... | |
ROJTRRouter (bool unbuildIsWarningOnly, bool acceptAllDestinations, int maxEdges, bool ignoreClasses, bool allowLoops, bool discountSources) | |
Constructor. More... | |
void | setAutoBulkMode (const bool mode) |
virtual void | setBulkMode (const bool mode) |
double | setHint (const typename std::vector< const ROEdge * >::const_iterator routeBegin, const typename std::vector< const ROEdge * >::const_iterator routeEnd, const ROVehicle *const v, SUMOTime msTime) |
void | startQuery () |
void | updateViaCost (const ROEdge *const prev, const ROEdge *const e, const ROVehicle *const v, double &time, double &effort, double &length) const |
void | updateViaEdgeCost (const ROEdge *viaEdge, const ROVehicle *const v, double &time, double &effort, double &length) const |
~ROJTRRouter () | |
Destructor. More... | |
Implementatios of SUMOAbstractRouter | |
bool | compute (const ROEdge *from, const ROEdge *to, const ROVehicle *const vehicle, SUMOTime time, ConstROEdgeVector &into, bool silent=false) |
Computes a route. More... | |
double | recomputeCosts (const ConstROEdgeVector &edges, const ROVehicle *const v, SUMOTime msTime) const |
Recomputes the costs of a route. More... | |
Protected Attributes | |
bool | myAmClean |
whether we are already initialized More... | |
bool | myAutoBulkMode |
whether we are currently trying to detect bulk mode automatically More... | |
bool | myBulkMode |
whether we are currently operating several route queries in a bulk More... | |
std::vector< typename SUMOAbstractRouter< ROEdge, ROVehicle >::EdgeInfo > | myEdgeInfos |
The container of edge information. More... | |
MsgHandler *const | myErrorMsgHandler |
the handler for routing errors More... | |
std::vector< typename SUMOAbstractRouter< ROEdge, ROVehicle >::EdgeInfo * > | myFound |
list of visited Edges (for resetting) More... | |
std::vector< typename SUMOAbstractRouter< ROEdge, ROVehicle >::EdgeInfo * > | myFrontierList |
A container for reusage of the min edge heap. More... | |
const bool | myHavePermissions |
whether edge permissions need to be considered More... | |
const bool | myHaveRestrictions |
whether edge restrictions need to be considered More... | |
Operation | myOperation |
The object's operation to perform. More... | |
std::vector< ROEdge * > | myProhibited |
The list of explicitly prohibited edges. More... | |
Operation | myTTOperation |
The object's operation to perform for travel times. More... | |
Private Attributes | |
const bool | myAcceptAllDestination |
Whether all edges may be used as route end. More... | |
const bool | myAllowLoops |
Whether a vehicle may reuse a road. More... | |
const bool | myDiscountSources |
Whether upstream flows shall be discounted from source flows. More... | |
const bool | myIgnoreClasses |
Whether vehicle class information shall be ignored. More... | |
const int | myMaxEdges |
The maximum number of edges a route may have. More... | |
long long int | myNumQueries |
long long int | myQueryStartTime |
the time spent querying in milliseconds More... | |
long long int | myQueryTimeSum |
long long int | myQueryVisits |
counters for performance logging More... | |
const std::string | myType |
the type of this router More... | |
const bool | myUnbuildIsWarningOnly |
Whether unbuildable routes shall be reported as warniings, not errors. More... | |
Computes routes using junction turning percentages.
Definition at line 43 of file ROJTRRouter.h.
|
inherited |
Type of the function that is used to retrieve the edge effort.
Definition at line 92 of file SUMOAbstractRouter.h.
ROJTRRouter::ROJTRRouter | ( | bool | unbuildIsWarningOnly, |
bool | acceptAllDestinations, | ||
int | maxEdges, | ||
bool | ignoreClasses, | ||
bool | allowLoops, | ||
bool | discountSources | ||
) |
Constructor.
[in] | unbuildIsWarningOnly | Whether not closed routes shall not yield in an error |
[in] | acceptAllDestinations | If false, only sinks will be used as final edges |
[in] | maxEdges | The maximum number of edges a route may have |
[in] | ignoreClasses | Whether routing shall be done without regarding vehicle classes |
[in] | allowLoops | Whether a vehicle may reuse a road |
[in] | discountSources | Whether upstream flow shall be discounted from source flows |
Definition at line 33 of file ROJTRRouter.cpp.
Referenced by clone().
ROJTRRouter::~ROJTRRouter | ( | ) |
Destructor.
Definition at line 46 of file ROJTRRouter.cpp.
|
inlineinherited |
Builds the path from marked edges.
Definition at line 359 of file SUMOAbstractRouter.h.
|
inlinevirtual |
Implements SUMOAbstractRouter< ROEdge, ROVehicle >.
Definition at line 62 of file ROJTRRouter.h.
References myAcceptAllDestination, myAllowLoops, myDiscountSources, myIgnoreClasses, myMaxEdges, myUnbuildIsWarningOnly, and ROJTRRouter().
|
pure virtualinherited |
Builds the route between the given edges using the minimum effort at the given time The definition of the effort depends on the wished routing scheme.
bool ROJTRRouter::compute | ( | const ROEdge * | from, |
const ROEdge * | to, | ||
const ROVehicle *const | vehicle, | ||
SUMOTime | time, | ||
ConstROEdgeVector & | into, | ||
bool | silent = false |
||
) |
Computes a route.
The description how routes are computed is given in the user documentation
[in] | from | The edge the vehicle starts at |
[in] | to | The destination edge - invalid here |
[in] | vehicle | The vehicle to compute the route for |
[in] | time | The departure time of the vehicle |
[filled] | into The list of edges to store the route into |
Definition at line 50 of file ROJTRRouter.cpp.
References ROJTREdge::chooseNext(), MsgHandler::getErrorInstance(), Named::getID(), ROJTREdge::getSourceFlow(), ROEdge::getTravelTime(), MsgHandler::getWarningInstance(), MsgHandler::inform(), ROEdge::isSink(), myAcceptAllDestination, myAllowLoops, myDiscountSources, myIgnoreClasses, myMaxEdges, myUnbuildIsWarningOnly, ROEdge::prohibits(), and STEPS2TIME.
|
inlineinherited |
Builds the route between the given edges using the minimum effort at the given time, also taking into account position along the edges to ensure currect handling of looped routes The definition of the effort depends on the wished routing scheme.
Definition at line 183 of file SUMOAbstractRouter.h.
|
inlineinherited |
Builds the route between the given edges using the minimum effort at the given time if from == to, return the shortest looped route.
Definition at line 198 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 334 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 169 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 325 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 231 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 165 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 136 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 227 of file SUMOAbstractRouter.h.
|
inlinevirtualinherited |
Definition at line 347 of file SUMOAbstractRouter.h.
double ROJTRRouter::recomputeCosts | ( | const ConstROEdgeVector & | edges, |
const ROVehicle *const | v, | ||
SUMOTime | msTime | ||
) | const |
Recomputes the costs of a route.
[in] | edges | The route |
[in] | v | The vehicle that belongs to the route |
[in] | msTime | The departure time of the vehicle |
|
inlineinherited |
Definition at line 282 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 261 of file SUMOAbstractRouter.h.
|
inlinevirtualinherited |
reset internal caches, used by CHRouter
Definition at line 161 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 343 of file SUMOAbstractRouter.h.
|
inlinevirtualinherited |
Definition at line 339 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 294 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 329 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 245 of file SUMOAbstractRouter.h.
|
inlineinherited |
Definition at line 235 of file SUMOAbstractRouter.h.
|
private |
Whether all edges may be used as route end.
Definition at line 96 of file ROJTRRouter.h.
|
private |
Whether a vehicle may reuse a road.
Definition at line 105 of file ROJTRRouter.h.
|
protectedinherited |
whether we are already initialized
Definition at line 385 of file SUMOAbstractRouter.h.
|
protectedinherited |
whether we are currently trying to detect bulk mode automatically
Definition at line 382 of file SUMOAbstractRouter.h.
|
protectedinherited |
whether we are currently operating several route queries in a bulk
Definition at line 379 of file SUMOAbstractRouter.h.
|
private |
Whether upstream flows shall be discounted from source flows.
Definition at line 108 of file ROJTRRouter.h.
|
protectedinherited |
The container of edge information.
Definition at line 397 of file SUMOAbstractRouter.h.
|
protectedinherited |
the handler for routing errors
Definition at line 370 of file SUMOAbstractRouter.h.
|
protectedinherited |
list of visited Edges (for resetting)
Definition at line 402 of file SUMOAbstractRouter.h.
|
protectedinherited |
A container for reusage of the min edge heap.
Definition at line 400 of file SUMOAbstractRouter.h.
|
protectedinherited |
whether edge permissions need to be considered
Definition at line 388 of file SUMOAbstractRouter.h.
|
protectedinherited |
whether edge restrictions need to be considered
Definition at line 391 of file SUMOAbstractRouter.h.
|
private |
Whether vehicle class information shall be ignored.
Definition at line 102 of file ROJTRRouter.h.
|
private |
The maximum number of edges a route may have.
Definition at line 99 of file ROJTRRouter.h.
|
privateinherited |
Definition at line 410 of file SUMOAbstractRouter.h.
|
protectedinherited |
The object's operation to perform.
Definition at line 373 of file SUMOAbstractRouter.h.
|
protectedinherited |
The list of explicitly prohibited edges.
Definition at line 394 of file SUMOAbstractRouter.h.
|
privateinherited |
the time spent querying in milliseconds
Definition at line 412 of file SUMOAbstractRouter.h.
|
privateinherited |
Definition at line 413 of file SUMOAbstractRouter.h.
|
privateinherited |
counters for performance logging
Definition at line 409 of file SUMOAbstractRouter.h.
|
protectedinherited |
The object's operation to perform for travel times.
Definition at line 376 of file SUMOAbstractRouter.h.
|
privateinherited |
the type of this router
Definition at line 406 of file SUMOAbstractRouter.h.
|
private |
Whether unbuildable routes shall be reported as warniings, not errors.
Definition at line 93 of file ROJTRRouter.h.