Eclipse SUMO - Simulation of Urban MObility
ROFrame.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-2024 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 // Sets and checks options for routing
21 /****************************************************************************/
22 #include <config.h>
23 
24 #include <iostream>
25 #include <ctime>
26 #include <stdlib.h>
28 #include <utils/options/Option.h>
32 #include <utils/common/ToString.h>
33 #include <utils/common/SUMOTime.h>
35 #include "ROFrame.h"
36 
37 
38 // ===========================================================================
39 // method definitions
40 // ===========================================================================
41 void
42 ROFrame::fillOptions(OptionsCont& oc, const bool isDUA, const bool isMA) {
43  // register options
44  // register I/O options
45  oc.doRegister("output-file", 'o', new Option_FileName());
46  oc.addSynonyme("output-file", "output");
47  oc.addDescription("output-file", "Output", TL("Write generated routes to FILE"));
48 
49  oc.doRegister("vtype-output", new Option_FileName());
50  if (!isMA) {
51  oc.addSynonyme("vtype-output", "vtype");
52  }
53  oc.addDescription("vtype-output", "Output", TL("Write used vehicle types into separate FILE"));
54 
55  oc.doRegister("keep-vtype-distributions", new Option_Bool(false));
56  oc.addDescription("keep-vtype-distributions", "Output", TL("Keep vTypeDistribution ids when writing vehicles and their types"));
57 
58  oc.doRegister("emissions.volumetric-fuel", new Option_Bool(false));
59  oc.addDescription("emissions.volumetric-fuel", "Output", TL("Return fuel consumption values in (legacy) unit l instead of mg"));
60 
61  oc.doRegister("net-file", 'n', new Option_FileName());
62  oc.addSynonyme("net-file", "net");
63  oc.addDescription("net-file", "Input", TL("Use FILE as SUMO-network to route on"));
64 
65  oc.doRegister("named-routes", new Option_Bool(false));
66  oc.addDescription("named-routes", "Output", TL("Write vehicles that reference routes by their id"));
67 
68  oc.doRegister("additional-files", 'a', new Option_FileName());
69  oc.addSynonyme("additional-files", "d", true);
70  oc.addSynonyme("additional-files", "additional");
71  oc.addSynonyme("additional-files", "taz-files");
72  oc.addSynonyme("additional-files", "districts", true);
73  oc.addDescription("additional-files", "Input", TL("Read additional network data (districts, bus stops) from FILE(s)"));
74 
75  oc.doRegister("route-files", 'r', new Option_FileName());
76  oc.addSynonyme("route-files", "flow-files", true);
77  oc.addSynonyme("route-files", "flows", true);
78  oc.addSynonyme("route-files", "f", true);
79  oc.addSynonyme("route-files", "alternative-files", true);
80  oc.addSynonyme("route-files", "alternatives-files", true);
81  oc.addSynonyme("route-files", "trip-files", true);
82  oc.addSynonyme("route-files", "trips", true);
83  if (isDUA) {
84  // to make the transition from --trip-files easier, but has a conflict with jtrrouter
85  oc.addSynonyme("route-files", "t", true);
86  }
87  oc.addDescription("route-files", "Input", TL("Read sumo routes, alternatives, flows, and trips from FILE(s)"));
88 
89  oc.doRegister("phemlight-path", new Option_FileName(StringVector({ "./PHEMlight/" })));
90  oc.addDescription("phemlight-path", "Input", TL("Determines where to load PHEMlight definitions from"));
91 
92  oc.doRegister("phemlight-year", new Option_Integer(0));
93  oc.addDescription("phemlight-year", "Input", TL("Enable fleet age modelling with the given reference year in PHEMlight5"));
94 
95  oc.doRegister("phemlight-temperature", new Option_Float(INVALID_DOUBLE));
96  oc.addDescription("phemlight-temperature", "Input", TL("Set ambient temperature to correct NOx emissions in PHEMlight5"));
97 
98  if (isDUA || isMA) {
99  oc.doRegister("weight-files", 'w', new Option_FileName());
100  oc.addSynonyme("weight-files", "weights");
101  oc.addDescription("weight-files", "Input", TL("Read network weights from FILE(s)"));
102 
103  oc.doRegister("lane-weight-files", new Option_FileName());
104  oc.addDescription("lane-weight-files", "Input", TL("Read lane-based network weights from FILE(s)"));
105 
106  oc.doRegister("weight-attribute", 'x', new Option_String("traveltime"));
107  oc.addSynonyme("weight-attribute", "measure", true);
108  oc.addDescription("weight-attribute", "Input", TL("Name of the xml attribute which gives the edge weight"));
109  }
110 
111  // need to do this here to be able to check for network and route input options
113 
114  // register the time settings
115  oc.doRegister("begin", 'b', new Option_String("0", "TIME"));
116  oc.addDescription("begin", "Time", TL("Defines the begin time; Previous trips will be discarded"));
117 
118  oc.doRegister("end", 'e', new Option_String("-1", "TIME"));
119  oc.addDescription("end", "Time", TL("Defines the end time; Later trips will be discarded; Defaults to the maximum time that SUMO can represent"));
120 
121  // register the processing options
122  oc.doRegister("ignore-errors", new Option_Bool(false));
123  oc.addSynonyme("ignore-errors", "continue-on-unbuild", true);
124  oc.addSynonyme("ignore-errors", "dismiss-loading-errors", true);
125  oc.addDescription("ignore-errors", "Report", TL("Continue if a route could not be build"));
126 
127  oc.doRegister("max-alternatives", new Option_Integer(5));
128  oc.addDescription("max-alternatives", "Processing", TL("Prune the number of alternatives to INT"));
129 
130  oc.doRegister("with-taz", new Option_Bool(false));
131  oc.addDescription("with-taz", "Processing", TL("Use origin and destination zones (districts) for in- and output"));
132 
133  oc.doRegister("junction-taz", new Option_Bool(false));
134  oc.addDescription("junction-taz", "Input", TL("Initialize a TAZ for every junction to use attributes toJunction and fromJunction"));
135 
136  if (!isMA) {
137  oc.doRegister("unsorted-input", new Option_Bool(false));
138  oc.addSynonyme("unsorted-input", "unsorted");
139  oc.addDescription("unsorted-input", "Processing", TL("Assume input is unsorted"));
140 
141  oc.doRegister("route-steps", 's', new Option_String("200", "TIME"));
142  oc.addDescription("route-steps", "Processing", TL("Load routes for the next number of seconds ahead"));
143 
144  oc.doRegister("no-internal-links", new Option_Bool(false));
145  oc.addDescription("no-internal-links", "Processing", TL("Disable (junction) internal links"));
146 
147  oc.doRegister("randomize-flows", new Option_Bool(false));
148  oc.addDescription("randomize-flows", "Processing", TL("generate random departure times for flow input"));
149 
150  oc.doRegister("remove-loops", new Option_Bool(false));
151  oc.addDescription("remove-loops", "Processing", TL("Remove loops within the route; Remove turnarounds at start and end of the route"));
152 
153  oc.doRegister("repair", new Option_Bool(false));
154  oc.addDescription("repair", "Processing", TL("Tries to correct a false route"));
155 
156  oc.doRegister("repair.from", new Option_Bool(false));
157  oc.addDescription("repair.from", "Processing", TL("Tries to correct an invalid starting edge by using the first usable edge instead"));
158 
159  oc.doRegister("repair.to", new Option_Bool(false));
160  oc.addDescription("repair.to", "Processing", TL("Tries to correct an invalid destination edge by using the last usable edge instead"));
161 
162  oc.doRegister("mapmatch.distance", new Option_Float(100));
163  oc.addDescription("mapmatch.distance", "Processing", TL("Maximum distance when mapping input coordinates (fromXY etc.) to the road network"));
164 
165  oc.doRegister("mapmatch.junctions", new Option_Bool(false));
166  oc.addDescription("mapmatch.junctions", "Processing", TL("Match positions to junctions instead of edges"));
167 
168  oc.doRegister("bulk-routing", new Option_Bool(false));
169  oc.addDescription("bulk-routing", "Processing", TL("Aggregate routing queries with the same origin"));
170  }
171 
172  oc.doRegister("routing-threads", new Option_Integer(0));
173  oc.addDescription("routing-threads", "Processing", TL("The number of parallel execution threads used for routing"));
174 
175  if (isDUA || isMA) {
176  oc.doRegister("routing-algorithm", new Option_String("dijkstra"));
177  oc.addDescription("routing-algorithm", "Processing", TL("Select among routing algorithms ['dijkstra', 'astar', 'CH', 'CHWrapper']"));
178  }
179 
180  oc.doRegister("restriction-params", new Option_StringVector());
181  oc.addDescription("restriction-params", "Processing", TL("Comma separated list of param keys to compare for additional restrictions"));
182 
183  if (isDUA || isMA) {
184  oc.doRegister("weights.interpolate", new Option_Bool(false));
185  oc.addSynonyme("weights.interpolate", "interpolate", true);
186  oc.addDescription("weights.interpolate", "Processing", TL("Interpolate edge weights at interval boundaries"));
187 
188  oc.doRegister("weights.expand", new Option_Bool(false));
189  oc.addSynonyme("weights.expand", "expand-weights", true);
190  oc.addDescription("weights.expand", "Processing", TL("Expand the end of the last loaded weight interval to infinity"));
191  }
192 
193  oc.doRegister("weights.minor-penalty", new Option_Float(1.5));
194  oc.addDescription("weights.minor-penalty", "Processing", TL("Apply the given time penalty when computing routing costs for minor-link internal lanes"));
195 
196  oc.doRegister("weights.tls-penalty", new Option_Float(0));
197  oc.addDescription("weights.tls-penalty", "Processing", TL("Apply the given time penalty when computing routing costs across a traffic light"));
198 
199  if (!isMA) {
200  // register defaults options
201  oc.doRegister("departlane", new Option_String());
202  oc.addDescription("departlane", "Defaults", TL("Assigns a default depart lane"));
203 
204  oc.doRegister("departpos", new Option_String());
205  oc.addDescription("departpos", "Defaults", TL("Assigns a default depart position"));
206 
207  oc.doRegister("departspeed", new Option_String());
208  oc.addDescription("departspeed", "Defaults", TL("Assigns a default depart speed"));
209 
210  oc.doRegister("arrivallane", new Option_String());
211  oc.addDescription("arrivallane", "Defaults", TL("Assigns a default arrival lane"));
212 
213  oc.doRegister("arrivalpos", new Option_String());
214  oc.addDescription("arrivalpos", "Defaults", TL("Assigns a default arrival position"));
215 
216  oc.doRegister("arrivalspeed", new Option_String());
217  oc.addDescription("arrivalspeed", "Defaults", TL("Assigns a default arrival speed"));
218 
219  oc.doRegister("defaults-override", new Option_Bool(false));
220  oc.addDescription("defaults-override", "Defaults", TL("Defaults will override given values"));
221  }
222 
223  // register report options
224  oc.doRegister("stats-period", new Option_Integer(-1));
225  oc.addDescription("stats-period", "Report", TL("Defines how often statistics shall be printed"));
226 
227  oc.doRegister("no-step-log", new Option_Bool(false));
228  oc.addDescription("no-step-log", "Report", TL("Disable console output of route parsing step"));
229 }
230 
231 
232 bool
234  // check whether the output is valid and can be build
235  if (!oc.isSet("output-file")) {
236  WRITE_ERROR(TL("No output specified."));
237  return false;
238  }
239  //
240  if (oc.getInt("max-alternatives") < 1) {
241  WRITE_ERROR(TL("A positive number of alternatives must be enabled."));
242  return false;
243  }
244 #ifndef HAVE_FOX
245  if (oc.getInt("routing-threads") > 1) {
246  WRITE_ERROR(TL("Parallel routing is only possible when compiled with Fox."));
247  return false;
248  }
249 #endif
250  return true;
251 }
252 
253 
254 /****************************************************************************/
#define WRITE_ERROR(msg)
Definition: MsgHandler.h:304
#define TL(string)
Definition: MsgHandler.h:315
std::vector< std::string > StringVector
Definition of a vector of strings.
Definition: Option.h:42
const double INVALID_DOUBLE
invalid double
Definition: StdDefs.h:64
A storage for options typed value containers)
Definition: OptionsCont.h:89
void addDescription(const std::string &name, const std::string &subtopic, const std::string &description)
Adds a description for an option.
bool isSet(const std::string &name, bool failOnNonExistant=true) const
Returns the information whether the named option is set.
int getInt(const std::string &name) const
Returns the int-value of the named option (only for Option_Integer)
void addSynonyme(const std::string &name1, const std::string &name2, bool isDeprecated=false)
Adds a synonyme for an options name (any order)
void doRegister(const std::string &name, Option *o)
Adds an option under the given name.
Definition: OptionsCont.cpp:76
static bool checkOptions(OptionsCont &oc)
Checks whether options are valid.
Definition: ROFrame.cpp:233
static void fillOptions(OptionsCont &oc, const bool isDUA=false, const bool isMA=false)
Inserts options used by routing applications into the OptionsCont-singleton.
Definition: ROFrame.cpp:42
static void addReportOptions(OptionsCont &oc)
Adds reporting options to the given container.
Definition: SystemFrame.cpp:67