Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
duarouter_main.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/****************************************************************************/
20// Main for DUAROUTER
21/****************************************************************************/
22#include <config.h>
23
24#ifdef HAVE_VERSION_H
25#include <version.h>
26#endif
27
28#include <iostream>
29#include <string>
30#include <limits.h>
31#include <ctime>
32#include <memory>
33#include <xercesc/sax/SAXException.hpp>
34#include <xercesc/sax/SAXParseException.hpp>
42#ifdef HAVE_FOX
44#endif
55#include <utils/xml/XMLSubSys.h>
56#include <router/ROFrame.h>
57#include <router/ROLoader.h>
58#include <router/RONet.h>
59#include <router/ROEdge.h>
60#include "RODUAEdgeBuilder.h"
61#include "RODUAFrame.h"
62
63
64// ===========================================================================
65// functions
66// ===========================================================================
67/* -------------------------------------------------------------------------
68 * data processing methods
69 * ----------------------------------------------------------------------- */
75void
76initNet(RONet& net, ROLoader& loader, OptionsCont& oc) {
77 // load the net
78 RODUAEdgeBuilder builder;
79 ROEdge::setGlobalOptions(oc.getBool("weights.interpolate"));
80 loader.loadNet(net, builder);
81 // load the weights when wished/available
82 if (oc.isSet("weight-files")) {
83 loader.loadWeights(net, "weight-files", oc.getString("weight-attribute"), false, oc.getBool("weights.expand"));
84 }
85 if (oc.isSet("lane-weight-files")) {
86 loader.loadWeights(net, "lane-weight-files", oc.getString("weight-attribute"), true, oc.getBool("weights.expand"));
87 }
88 if (oc.getBool("skip-new-routes")) {
90 }
91}
92
93
97void
99 // initialise the loader
100 loader.openRoutes(net);
101 // build the router
104 const std::string measure = oc.getString("weight-attribute");
105 const std::string routingAlgorithm = oc.getString("routing-algorithm");
106 const double priorityFactor = oc.getFloat("weights.priority-factor");
107 const SUMOTime begin = string2time(oc.getString("begin"));
108 const SUMOTime end = oc.isDefault("end") ? SUMOTime_MAX : string2time(oc.getString("end"));
110
111 if (oc.isSet("restriction-params") &&
112 (routingAlgorithm == "CH" || routingAlgorithm == "CHWrapper")) {
113 throw ProcessError(TLF("Routing algorithm '%' does not support restriction-params", routingAlgorithm));
114 }
115
116 if (measure == "traveltime" && priorityFactor == 0) {
117 if (routingAlgorithm == "dijkstra") {
118 router = new DijkstraRouter<ROEdge, ROVehicle>(ROEdge::getAllEdges(), oc.getBool("ignore-errors"), ttFunction, nullptr, false, nullptr, net.hasPermissions(), oc.isSet("restriction-params"));
119 } else if (routingAlgorithm == "astar") {
121 std::shared_ptr<const AStar::LookupTable> lookup;
122 if (oc.isSet("astar.all-distances")) {
123 lookup = std::make_shared<const AStar::FLT>(oc.getString("astar.all-distances"), (int)ROEdge::getAllEdges().size());
124 } else if (oc.isSet("astar.landmark-distances")) {
125 /* CHRouterWrapper<ROEdge, ROVehicle> chrouter(
126 ROEdge::getAllEdges(), true, &ROEdge::getTravelTimeStatic,
127 begin, end, SUMOTime_MAX, 1); */
129 std::vector<ReversedEdge<ROEdge, ROVehicle>*> reversed;
130 for (ROEdge* edge : ROEdge::getAllEdges()) {
131 reversed.push_back(edge->getReversedRoutingEdge());
132 }
133 for (ReversedEdge<ROEdge, ROVehicle>* redge : reversed) {
134 redge->init();
135 }
137 ROVehicle defaultVehicle(SUMOVehicleParameter(), nullptr, net.getVehicleTypeSecure(DEFAULT_VTYPE_ID), &net);
138 ROMapMatcher* mapMatcher = dynamic_cast<ROMapMatcher*>(loader.getRouteHandler());
139 lookup = std::make_shared<const AStar::LMLT>(oc.getString("astar.landmark-distances"), ROEdge::getAllEdges(), &forward, &backward, &defaultVehicle,
140 oc.isSet("astar.save-landmark-distances") ? oc.getString("astar.save-landmark-distances") : "", oc.getInt("routing-threads"), mapMatcher);
141 }
142 router = new AStar(ROEdge::getAllEdges(), oc.getBool("ignore-errors"), ttFunction, lookup, net.hasPermissions(), oc.isSet("restriction-params"));
143 } else if (routingAlgorithm == "CH" && !net.hasPermissions()) {
144 const SUMOTime weightPeriod = (oc.isSet("weight-files") ?
145 string2time(oc.getString("weight-period")) :
147 router = new CHRouter<ROEdge, ROVehicle>(
148 ROEdge::getAllEdges(), oc.getBool("ignore-errors"), ttFunction, SVC_IGNORING, weightPeriod, net.hasPermissions(), oc.isSet("restriction-params"));
149 } else if (routingAlgorithm == "CHWrapper" || routingAlgorithm == "CH") {
150 // use CHWrapper instead of CH if the net has permissions
151 const SUMOTime weightPeriod = (oc.isSet("weight-files") ?
152 string2time(oc.getString("weight-period")) :
155 ROEdge::getAllEdges(), oc.getBool("ignore-errors"), ttFunction,
156 begin, end, weightPeriod, net.hasPermissions(), oc.getInt("routing-threads"));
157 } else if (routingAlgorithm == "arcflag") {
159 constexpr auto NUMBER_OF_LEVELS = 5; //or 4 or 8
160 ROVehicle defaultVehicle(SUMOVehicleParameter(), nullptr, net.getVehicleTypeSecure(DEFAULT_VTYPE_ID), &net);
162 partition->init(&defaultVehicle);
165 partition, oc.getBool("ignore-errors"), ttFunction, reversedTtFunction, (oc.isSet("weight-files") ? string2time(oc.getString("weight-period")) : SUMOTime_MAX),
166 nullptr, nullptr, net.hasPermissions(), oc.isSet("restriction-params"));
167 } else {
168 throw ProcessError(TLF("Unknown routing Algorithm '%'!", routingAlgorithm));
169 }
170 } else {
171 if (measure == "traveltime") {
172 if (ROEdge::initPriorityFactor(priorityFactor)) {
174 }
175 } else if (measure == "CO") {
176 op = &ROEdge::getEmissionEffort<PollutantsInterface::CO>;
177 } else if (measure == "CO2") {
178 op = &ROEdge::getEmissionEffort<PollutantsInterface::CO2>;
179 } else if (measure == "PMx") {
180 op = &ROEdge::getEmissionEffort<PollutantsInterface::PM_X>;
181 } else if (measure == "HC") {
182 op = &ROEdge::getEmissionEffort<PollutantsInterface::HC>;
183 } else if (measure == "NOx") {
184 op = &ROEdge::getEmissionEffort<PollutantsInterface::NO_X>;
185 } else if (measure == "fuel") {
186 op = &ROEdge::getEmissionEffort<PollutantsInterface::FUEL>;
187 } else if (measure == "electricity") {
188 op = &ROEdge::getEmissionEffort<PollutantsInterface::ELEC>;
189 } else if (measure == "noise") {
191 } else {
193 }
194 if (measure != "traveltime" && !net.hasLoadedEffort()) {
195 WRITE_WARNINGF(TL("No weight data was loaded for attribute '%'."), measure);
196 }
198 ROEdge::getAllEdges(), oc.getBool("ignore-errors"), op, ttFunction, false, nullptr, net.hasPermissions(), oc.isSet("restriction-params"));
199 }
200 const int carWalk = SUMOVehicleParserHelper::parseCarWalkTransfer(oc, true);
201 double taxiWait = STEPS2TIME(string2time(OptionsCont::getOptions().getString("persontrip.taxi.waiting-time")));
202
203 RailwayRouter<ROEdge, ROVehicle>* railRouter = nullptr;
204 if (net.hasBidiEdges()) {
205 railRouter = new RailwayRouter<ROEdge, ROVehicle>(ROEdge::getAllEdges(), true, op, ttFunction, false, net.hasPermissions(),
206 oc.isSet("restriction-params"),
207 oc.getFloat("railway.max-train-length"),
208 oc.getFloat("weights.reversal-penalty"));
209 }
211 new ROIntermodalRouter(RONet::adaptIntermodalRouter, carWalk, taxiWait, routingAlgorithm),
212 railRouter);
213 // process route definitions
214 try {
215 net.openOutput(oc);
216 loader.processRoutes(begin, end, string2time(oc.getString("route-steps")), net, provider);
217 net.writeIntermodal(oc, provider.getIntermodalRouter());
218 // end the processing
219 net.cleanup();
220 } catch (ProcessError&) {
221 net.cleanup();
222 throw;
223 }
224}
225
226
227/* -------------------------------------------------------------------------
228 * main
229 * ----------------------------------------------------------------------- */
230int
231main(int argc, char** argv) {
233 oc.setApplicationDescription(TL("Shortest path router and DUE computer for the microscopic, multi-modal traffic simulation SUMO."));
234 oc.setApplicationName("duarouter", "Eclipse SUMO duarouter " VERSION_STRING);
235 int ret = 0;
236 RONet* net = nullptr;
237 try {
240 OptionsIO::setArgs(argc, argv);
242 if (oc.processMetaOptions(argc < 2)) {
244 return 0;
245 }
247 XMLSubSys::setValidation(oc.getString("xml-validation"), oc.getString("xml-validation.net"), oc.getString("xml-validation.routes"));
248#ifdef HAVE_FOX
249 if (oc.getInt("routing-threads") > 1) {
250 // make the output aware of threading
252 }
253#endif
256 throw ProcessError();
257 }
259 // load data
260 ROLoader loader(oc, false, !oc.getBool("no-step-log"));
261 net = new RONet();
262 initNet(*net, loader, oc);
263 // build routes
264 try {
265 computeRoutes(*net, loader, oc);
266 } catch (XERCES_CPP_NAMESPACE::SAXParseException& e) {
267 WRITE_ERROR(toString(e.getLineNumber()));
268 ret = 1;
269 } catch (XERCES_CPP_NAMESPACE::SAXException& e) {
270 WRITE_ERROR(StringUtils::transcode(e.getMessage()));
271 ret = 1;
272 }
273 if (MsgHandler::getErrorInstance()->wasInformed() || ret != 0) {
274 throw ProcessError();
275 }
276 } catch (const ProcessError& e) {
277 if (std::string(e.what()) != std::string("Process Error") && std::string(e.what()) != std::string("")) {
278 WRITE_ERROR(e.what());
279 }
280 MsgHandler::getErrorInstance()->inform("Quitting (on error).", false);
281 ret = 1;
282#ifndef _DEBUG
283 } catch (const std::exception& e) {
284 if (std::string(e.what()) != std::string("")) {
285 WRITE_ERROR(e.what());
286 }
287 MsgHandler::getErrorInstance()->inform("Quitting (on error).", false);
288 ret = 1;
289 } catch (...) {
290 MsgHandler::getErrorInstance()->inform("Quitting (on unknown error).", false);
291 ret = 1;
292#endif
293 }
294 delete net;
296 if (ret == 0) {
297 std::cout << "Success." << std::endl;
298 }
299 return ret;
300}
301
302
303/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define WRITE_ERROR(msg)
Definition MsgHandler.h:295
#define TL(string)
Definition MsgHandler.h:304
#define TLF(string,...)
Definition MsgHandler.h:306
IntermodalRouter< ROEdge, ROLane, RONode, ROVehicle > ROIntermodalRouter
Definition RORoutable.h:42
SUMOTime string2time(const std::string &r)
convert string to SUMOTime
Definition SUMOTime.cpp:46
#define STEPS2TIME(x)
Definition SUMOTime.h:55
#define SUMOTime_MAX
Definition SUMOTime.h:34
const std::string DEFAULT_VTYPE_ID
@ SVC_IGNORING
vehicles ignoring classes
double gWeightsRandomFactor
Definition StdDefs.cpp:35
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
Computes the shortest path through a network using the A* algorithm.
Definition AStarRouter.h:76
Computes the shortest path through a contracted network.
Definition CHRouter.h:59
Computes the shortest path through a contracted network.
Computes the shortest path through a network using the Dijkstra algorithm.
The edge type representing backward edges with flipped nodes.
Definition FlippedEdge.h:43
Partitions the router's network wrt a k-d tree subdivision scheme.
void init(const V *const vehicle)
Initialize the k-d tree wrt to the given vehicle's permissions.
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 void initOutputOptions()
init output options
static void setFactory(Factory func)
Sets the factory function to use for new MsgHandlers.
Definition MsgHandler.h:64
static MsgHandler * create(MsgType type)
A storage for options typed value containers)
Definition OptionsCont.h:89
bool isSet(const std::string &name, bool failOnNonExistant=true) const
Returns the information whether the named option is set.
double getFloat(const std::string &name) const
Returns the double-value of the named option (only for Option_Float)
int getInt(const std::string &name) const
Returns the int-value of the named option (only for Option_Integer)
void setApplicationName(const std::string &appName, const std::string &fullName)
Sets the application name.
std::string getString(const std::string &name) const
Returns the string-value of the named option (only for Option_String)
bool isDefault(const std::string &name) const
Returns the information whether the named option has still the default value.
void setApplicationDescription(const std::string &appDesc)
Sets the application description.
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.
bool processMetaOptions(bool missingOptions)
Checks for help and configuration output, returns whether we should exit.
static void setArgs(int argc, char **argv)
Stores the command line arguments for later parsing.
Definition OptionsIO.cpp:58
static void getOptions(const bool commandLineOnly=false)
Parses the command line arguments and loads the configuration.
Definition OptionsIO.cpp:74
Interface for building instances of duarouter-edges.
static void fillOptions()
Inserts options used by duarouter into the OptionsCont-singleton.
static bool checkOptions()
Checks set options from the OptionsCont-singleton for being valid for usage within duarouter.
A basic edge for routing applications.
Definition ROEdge.h:73
static double getStoredEffort(const ROEdge *const edge, const ROVehicle *const, double time)
Definition ROEdge.h:494
static bool initPriorityFactor(double priorityFactor)
initialize priority factor range
Definition ROEdge.cpp:470
static double getTravelTimeStaticPriorityFactor(const ROEdge *const edge, const ROVehicle *const veh, double time)
Return traveltime weighted by edge priority (scaled penalty for low-priority edges)
Definition ROEdge.h:449
static double getNoiseEffort(const ROEdge *const edge, const ROVehicle *const veh, double time)
Definition ROEdge.cpp:239
static double getTravelTimeStaticRandomized(const ROEdge *const edge, const ROVehicle *const veh, double time)
Definition ROEdge.h:437
static void setGlobalOptions(const bool interpolate)
Definition ROEdge.h:509
static double getTravelTimeStatic(const ROEdge *const edge, const ROVehicle *const veh, double time)
Returns the travel time for the given edge.
Definition ROEdge.h:433
static const ROEdgeVector & getAllEdges()
Returns all ROEdges.
Definition ROEdge.cpp:376
The data loader.
Definition ROLoader.h:54
bool loadWeights(RONet &net, const std::string &optionName, const std::string &measure, const bool useLanes, const bool boundariesOverride)
Loads the net weights.
Definition ROLoader.cpp:259
SUMORouteHandler * getRouteHandler()
Definition ROLoader.cpp:313
void processRoutes(const SUMOTime start, const SUMOTime end, const SUMOTime increment, RONet &net, const RORouterProvider &provider)
Loads routes from all previously build route loaders.
Definition ROLoader.cpp:198
virtual void loadNet(RONet &toFill, ROAbstractEdgeBuilder &eb)
Loads the network.
Definition ROLoader.cpp:108
void openRoutes(RONet &net)
Builds and opens all route loaders.
Definition ROLoader.cpp:168
The router's network representation.
Definition RONet.h:63
SUMOVTypeParameter * getVehicleTypeSecure(const std::string &id)
Retrieves the named vehicle type.
Definition RONet.cpp:408
bool hasBidiEdges() const
return whether the network contains bidirectional rail edges
Definition RONet.h:445
void cleanup()
closes the file output for computed routes and deletes associated threads if necessary
Definition RONet.cpp:384
void openOutput(const OptionsCont &options)
Opens the output for computed routes.
Definition RONet.cpp:339
void writeIntermodal(const OptionsCont &options, ROIntermodalRouter &router) const
Writes the intermodal network and weights if requested.
Definition RONet.cpp:365
static void adaptIntermodalRouter(ROIntermodalRouter &router)
Definition RONet.cpp:886
bool hasPermissions() const
Definition RONet.cpp:931
bool hasLoadedEffort() const
whether efforts were loaded from file
Definition RONet.cpp:942
static void setSkipNew()
Definition RORouteDef.h:152
A vehicle as used by router.
Definition ROVehicle.h:50
static void initRandGlobal(SumoRNG *which=nullptr)
Reads the given random number options and initialises the random number generator in accordance.
the edge type representing backward edges
IntermodalRouter< E, L, N, V > & getIntermodalRouter() const
Structure representing possible vehicle parameter.
static int parseCarWalkTransfer(const OptionsCont &oc, const bool hasTaxi)
static std::string transcode(const XMLCh *const data)
converts a 0-terminated XMLCh* array (usually UTF-16, stemming from Xerces) into std::string in UTF-8
static void close()
Closes all of an applications subsystems.
static bool checkOptions(OptionsCont &oc)
checks shared options and sets StdDefs
static void setValidation(const std::string &validationScheme, const std::string &netValidationScheme, const std::string &routeValidationScheme)
Enables or disables validation.
Definition XMLSubSys.cpp:83
static void init()
Initialises the xml-subsystem.
Definition XMLSubSys.cpp:56
int main(int argc, char **argv)
void initNet(RONet &net, ROLoader &loader, OptionsCont &oc)
void computeRoutes(RONet &net, ROLoader &loader, OptionsCont &oc)