Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
MSFrame.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/****************************************************************************/
24// Sets and checks options for microsim; inits global outputs and settings
25/****************************************************************************/
26#include <config.h>
27
28#include <iostream>
29#include <iomanip>
30#include <fstream>
31#include <ctime>
42#include <microsim/MSJunction.h>
43#include <microsim/MSRoute.h>
44#include <microsim/MSNet.h>
45#include <microsim/MSLane.h>
46#include <microsim/MSEdge.h>
47#include <microsim/MSGlobals.h>
55#include "MSFrame.h"
56
57
58// ===========================================================================
59// method definitions
60// ===========================================================================
61void
64 oc.addCallExample("-b 0 -e 1000 -n net.xml -r routes.xml", TL("start a simulation from time 0 to 1000 with given net and routes"));
65 oc.addCallExample("-c munich_config.cfg", TL("start with a configuration file"));
66 oc.addCallExample("--help", TL("print help"));
67
68 // insert options sub-topics
69 SystemFrame::addConfigurationOptions(oc); // fill this subtopic, too
70 oc.addOptionSubTopic("Input");
71 oc.addOptionSubTopic("Output");
72 oc.addOptionSubTopic("Time");
73 oc.addOptionSubTopic("Processing");
74 oc.addOptionSubTopic("Routing");
75
76 // register configuration options
77 // register input options
78 oc.doRegister("net-file", 'n', new Option_FileName());
79 oc.addSynonyme("net-file", "net");
80 oc.addDescription("net-file", "Input", TL("Load road network description from FILE"));
81 oc.addXMLDefault("net-file", "net");
82
83 oc.doRegister("route-files", 'r', new Option_FileName());
84 oc.addSynonyme("route-files", "routes");
85 oc.addDescription("route-files", "Input", TL("Load routes descriptions from FILE(s)"));
86
87 oc.doRegister("additional-files", 'a', new Option_FileName());
88 oc.addSynonyme("additional-files", "additional");
89 oc.addDescription("additional-files", "Input", TL("Load further descriptions from FILE(s)"));
90
91 oc.doRegister("weight-files", 'w', new Option_FileName());
92 oc.addSynonyme("weight-files", "weights");
93 oc.addDescription("weight-files", "Input", TL("Load edge/lane weights for online rerouting from FILE"));
94 oc.doRegister("weight-attribute", 'x', new Option_String("traveltime"));
95 oc.addSynonyme("weight-attribute", "measure", true);
96 oc.addDescription("weight-attribute", "Input", TL("Name of the xml attribute which gives the edge weight"));
97
98 oc.doRegister("load-state", new Option_FileName());
99 oc.addDescription("load-state", "Input", TL("Loads a network state from FILE"));
100 oc.doRegister("load-state.offset", new Option_String("0", "TIME"));
101 oc.addDescription("load-state.offset", "Input", TL("Shifts all times loaded from a saved state by the given offset"));
102 oc.doRegister("load-state.remove-vehicles", new Option_StringVector(StringVector({""})));
103 oc.addDescription("load-state.remove-vehicles", "Input", TL("Removes vehicles with the given IDs from the loaded state"));
104
105 oc.doRegister("junction-taz", new Option_Bool(false));
106 oc.addDescription("junction-taz", "Input", TL("Initialize a TAZ for every junction to use attributes toJunction and fromJunction"));
107
108 // need to do this here to be able to check for network and route input options
110
111 // register output options
112 oc.doRegister("netstate-dump", new Option_FileName());
113 oc.addSynonyme("netstate-dump", "ndump");
114 oc.addSynonyme("netstate-dump", "netstate");
115 oc.addSynonyme("netstate-dump", "netstate-output");
116 oc.addDescription("netstate-dump", "Output", TL("Save complete network states into FILE"));
117 oc.doRegister("netstate-dump.empty-edges", new Option_Bool(false));
118 oc.addSynonyme("netstate-dump.empty-edges", "netstate.empty-edges");
119 oc.addSynonyme("netstate-dump.empty-edges", "netstate-output.empty-edges");
120 oc.addSynonyme("netstate-dump.empty-edges", "dump-empty-edges", true);
121 oc.addDescription("netstate-dump.empty-edges", "Output", TL("Write also empty edges completely when dumping"));
122 oc.doRegister("netstate-dump.precision", new Option_Integer(2));
123 oc.addSynonyme("netstate-dump.precision", "netstate.precision");
124 oc.addSynonyme("netstate-dump.precision", "netstate-output.precision");
125 oc.addSynonyme("netstate-dump.precision", "dump-precision", true);
126 oc.addDescription("netstate-dump.precision", "Output", TL("Write positions and speeds with the given precision (default 2)"));
127
128 oc.doRegister("emission-output", new Option_FileName());
129 oc.addDescription("emission-output", "Output", TL("Save the emission values of each vehicle"));
130 oc.doRegister("emission-output.precision", new Option_Integer(2));
131 oc.addDescription("emission-output.precision", "Output", TL("Write emission values with the given precision (default 2)"));
132 oc.doRegister("emission-output.geo", new Option_Bool(false));
133 oc.addDescription("emission-output.geo", "Output", TL("Save the positions in emission output using geo-coordinates (lon/lat)"));
134 oc.doRegister("emission-output.step-scaled", new Option_Bool(false));
135 oc.addDescription("emission-output.step-scaled", "Output", TL("Write emission values scaled to the step length rather than as per-second values"));
136 oc.doRegister("emission-output.attributes", new Option_StringVector());
137 oc.addDescription("emission-output.attributes", "Output", TL("List attributes that should be included in the emission output"));
138
139 oc.doRegister("battery-output", new Option_FileName());
140 oc.addDescription("battery-output", "Output", TL("Save the battery values of each vehicle"));
141 oc.doRegister("battery-output.precision", new Option_Integer(2));
142 oc.addDescription("battery-output.precision", "Output", TL("Write battery values with the given precision (default 2)"));
143
144 oc.doRegister("elechybrid-output", new Option_FileName());
145 oc.addDescription("elechybrid-output", "Output", TL("Save the elecHybrid values of each vehicle"));
146 oc.doRegister("elechybrid-output.precision", new Option_Integer(2));
147 oc.addDescription("elechybrid-output.precision", "Output", TL("Write elecHybrid values with the given precision (default 2)"));
148 oc.doRegister("elechybrid-output.aggregated", new Option_Bool(false));
149 oc.addDescription("elechybrid-output.aggregated", "Output", TL("Write elecHybrid values into one aggregated file"));
150
151 oc.doRegister("chargingstations-output", new Option_FileName());
152 oc.addDescription("chargingstations-output", "Output", TL("Write data of charging stations"));
153 oc.doRegister("chargingstations-output.aggregated", new Option_Bool(false));
154 oc.addDescription("chargingstations-output.aggregated", "Output", TL("Write aggregated charging event data instead of single time steps"));
155 oc.doRegister("chargingstations-output.aggregated.write-unfinished", new Option_Bool(false));
156 oc.addDescription("chargingstations-output.aggregated.write-unfinished", "Output", TL("Write aggregated charging event data for vehicles which have not arrived at simulation end"));
157
158 oc.doRegister("overheadwiresegments-output", new Option_FileName());
159 oc.addDescription("overheadwiresegments-output", "Output", TL("Write data of overhead wire segments"));
160
161 oc.doRegister("substations-output", new Option_FileName());
162 oc.addDescription("substations-output", "Output", TL("Write data of electrical substation stations"));
163 oc.doRegister("substations-output.precision", new Option_Integer(2));
164 oc.addDescription("substations-output.precision", "Output", TL("Write substation values with the given precision (default 2)"));
165
166 oc.doRegister("fcd-output", new Option_FileName());
167 oc.addDescription("fcd-output", "Output", TL("Save the Floating Car Data"));
168 oc.doRegister("fcd-output.geo", new Option_Bool(false));
169 oc.addDescription("fcd-output.geo", "Output", TL("Save the Floating Car Data using geo-coordinates (lon/lat)"));
170 oc.doRegister("fcd-output.utm", new Option_Bool(false));
171 oc.addDescription("fcd-output.utm", "Output", TL("Save the Floating Car Data using utm/unshifted coordinates (x/y)"));
172 oc.doRegister("fcd-output.signals", new Option_Bool(false));
173 oc.addDescription("fcd-output.signals", "Output", TL("Add the vehicle signal state to the FCD output (brake lights etc.)"));
174 oc.doRegister("fcd-output.distance", new Option_Bool(false));
175 oc.addDescription("fcd-output.distance", "Output", TL("Add kilometrage to the FCD output (linear referencing)"));
176 oc.doRegister("fcd-output.acceleration", new Option_Bool(false));
177 oc.addDescription("fcd-output.acceleration", "Output", TL("Add acceleration to the FCD output"));
178 oc.doRegister("fcd-output.speed-relative", new Option_Bool(false));
179 oc.addDescription("fcd-output.speed-relative", "Output", TL("Add relative speed (vehicle speed / edge speed limit) to the FCD output"));
180 oc.doRegister("fcd-output.max-leader-distance", new Option_Float(-1));
181 oc.addDescription("fcd-output.max-leader-distance", "Output", TL("Add leader vehicle information to the FCD output (within the given distance)"));
182 oc.doRegister("fcd-output.params", new Option_StringVector());
183 oc.addDescription("fcd-output.params", "Output", TL("Add generic parameter values to the FCD output"));
184 oc.doRegister("fcd-output.filter-edges.input-file", new Option_FileName());
185 oc.addDescription("fcd-output.filter-edges.input-file", "Output", TL("Restrict fcd output to the edge selection from the given input file"));
186 oc.doRegister("fcd-output.attributes", new Option_StringVector());
187 oc.addDescription("fcd-output.attributes", "Output", TL("List attributes that should be included in the FCD output"));
188 oc.doRegister("fcd-output.filter-shapes", new Option_StringVector());
189 oc.addDescription("fcd-output.filter-shapes", "Output", TL("List shape names that should be used to filter the FCD output"));
190
191 oc.doRegister("person-fcd-output", new Option_FileName());
192 oc.addSynonyme("person-fcd-output", "person-fcd");
193 oc.addDescription("person-fcd-output", "Output", TL("Save fcd for persons and container to separate FILE"));
194
195 oc.doRegister("device.ssm.filter-edges.input-file", new Option_FileName());
196 oc.addDescription("device.ssm.filter-edges.input-file", "Output", TL("Restrict SSM device output to the edge selection from the given input file"));
197
198 oc.doRegister("full-output", new Option_FileName());
199 oc.addDescription("full-output", "Output", TL("Save a lot of information for each timestep (very redundant)"));
200
201 oc.doRegister("queue-output", new Option_FileName());
202 oc.addDescription("queue-output", "Output", TL("Save the vehicle queues at the junctions (experimental)"));
203 oc.doRegister("queue-output.period", new Option_String("-1", "TIME"));
204 oc.addDescription("queue-output.period", "Output", TL("Save vehicle queues with the given period"));
205
206 oc.doRegister("vtk-output", new Option_FileName());
207 oc.addDescription("vtk-output", "Output", TL("Save complete vehicle positions inclusive speed values in the VTK Format (usage: /path/out will produce /path/out_$TIMESTEP$.vtp files)"));
208 oc.doRegister("amitran-output", new Option_FileName());
209 oc.addDescription("amitran-output", "Output", TL("Save the vehicle trajectories in the Amitran format"));
210
211
212 oc.doRegister("summary-output", new Option_FileName());
213 oc.addSynonyme("summary-output", "summary");
214 oc.addDescription("summary-output", "Output", TL("Save aggregated vehicle departure info into FILE"));
215
216 oc.doRegister("summary-output.period", new Option_String("-1", "TIME"));
217 oc.addDescription("summary-output.period", "Output", TL("Save summary-output with the given period"));
218
219 oc.doRegister("person-summary-output", new Option_FileName());
220 oc.addDescription("person-summary-output", "Output", TL("Save aggregated person counts into FILE"));
221
222 oc.doRegister("tripinfo-output", new Option_FileName());
223 oc.addSynonyme("tripinfo-output", "tripinfo");
224 oc.addDescription("tripinfo-output", "Output", TL("Save single vehicle trip info into FILE"));
225
226 oc.doRegister("tripinfo-output.write-unfinished", new Option_Bool(false));
227 oc.addDescription("tripinfo-output.write-unfinished", "Output", TL("Write tripinfo output for vehicles which have not arrived at simulation end"));
228
229 oc.doRegister("tripinfo-output.write-undeparted", new Option_Bool(false));
230 oc.addDescription("tripinfo-output.write-undeparted", "Output", TL("Write tripinfo output for vehicles which have not departed at simulation end because of depart delay"));
231
232 oc.doRegister("personinfo-output", new Option_FileName());
233 oc.addSynonyme("personinfo-output", "personinfo");
234 oc.addDescription("personinfo-output", "Output", TL("Save personinfo and containerinfo to separate FILE"));
235
236 oc.doRegister("vehroute-output", new Option_FileName());
237 oc.addSynonyme("vehroute-output", "vehroutes");
238 oc.addDescription("vehroute-output", "Output", TL("Save single vehicle route info into FILE"));
239
240 oc.doRegister("vehroute-output.exit-times", new Option_Bool(false));
241 oc.addSynonyme("vehroute-output.exit-times", "vehroutes.exit-times");
242 oc.addDescription("vehroute-output.exit-times", "Output", TL("Write the exit times for all edges"));
243
244 oc.doRegister("vehroute-output.last-route", new Option_Bool(false));
245 oc.addSynonyme("vehroute-output.last-route", "vehroutes.last-route");
246 oc.addDescription("vehroute-output.last-route", "Output", TL("Write the last route only"));
247
248 oc.doRegister("vehroute-output.sorted", new Option_Bool(false));
249 oc.addSynonyme("vehroute-output.sorted", "vehroutes.sorted");
250 oc.addDescription("vehroute-output.sorted", "Output", TL("Sorts the output by departure time"));
251
252 oc.doRegister("vehroute-output.dua", new Option_Bool(false));
253 oc.addSynonyme("vehroute-output.dua", "vehroutes.dua");
254 oc.addDescription("vehroute-output.dua", "Output", TL("Write the output in the duarouter alternatives style"));
255
256 oc.doRegister("vehroute-output.cost", new Option_Bool(false));
257 oc.addDescription("vehroute-output.cost", "Output", TL("Write costs for all routes"));
258
259 oc.doRegister("vehroute-output.intended-depart", new Option_Bool(false));
260 oc.addSynonyme("vehroute-output.intended-depart", "vehroutes.intended-depart");
261 oc.addDescription("vehroute-output.intended-depart", "Output", TL("Write the output with the intended instead of the real departure time"));
262
263 oc.doRegister("vehroute-output.route-length", new Option_Bool(false));
264 oc.addSynonyme("vehroute-output.route-length", "vehroutes.route-length");
265 oc.addDescription("vehroute-output.route-length", "Output", TL("Include total route length in the output"));
266
267 oc.doRegister("vehroute-output.write-unfinished", new Option_Bool(false));
268 oc.addDescription("vehroute-output.write-unfinished", "Output", TL("Write vehroute output for vehicles which have not arrived at simulation end"));
269
270 oc.doRegister("vehroute-output.skip-ptlines", new Option_Bool(false));
271 oc.addDescription("vehroute-output.skip-ptlines", "Output", TL("Skip vehroute output for public transport vehicles"));
272
273 oc.doRegister("vehroute-output.incomplete", new Option_Bool(false));
274 oc.addDescription("vehroute-output.incomplete", "Output", TL("Include invalid routes and route stubs in vehroute output"));
275
276 oc.doRegister("vehroute-output.stop-edges", new Option_Bool(false));
277 oc.addDescription("vehroute-output.stop-edges", "Output", TL("Include information about edges between stops"));
278
279 oc.doRegister("vehroute-output.speedfactor", new Option_Bool(false));
280 oc.addDescription("vehroute-output.speedfactor", "Output", TL("Write the vehicle speedFactor (defaults to 'true' if departSpeed is written)"));
281
282 oc.doRegister("vehroute-output.internal", new Option_Bool(false));
283 oc.addDescription("vehroute-output.internal", "Output", TL("Include internal edges in the output"));
284
285 oc.doRegister("personroute-output", new Option_FileName());
286 oc.addSynonyme("personroute-output", "personroutes");
287 oc.addDescription("personroute-output", "Output", TL("Save person and container routes to separate FILE"));
288
289 oc.doRegister("link-output", new Option_FileName());
290 oc.addDescription("link-output", "Output", TL("Save links states into FILE"));
291
292 oc.doRegister("railsignal-block-output", new Option_FileName());
293 oc.addDescription("railsignal-block-output", "Output", TL("Save railsignal-blocks into FILE"));
294
295 oc.doRegister("railsignal-vehicle-output", new Option_FileName());
296 oc.addDescription("railsignal-vehicle-output", "Output", TL("Record entry and exit times of vehicles for railsignal blocks into FILE"));
297
298 oc.doRegister("bt-output", new Option_FileName());
299 oc.addDescription("bt-output", "Output", TL("Save bluetooth visibilities into FILE (in conjunction with device.btreceiver and device.btsender)"));
300
301 oc.doRegister("lanechange-output", new Option_FileName());
302 oc.addDescription("lanechange-output", "Output", TL("Record lane changes and their motivations for all vehicles into FILE"));
303
304 oc.doRegister("lanechange-output.started", new Option_Bool(false));
305 oc.addDescription("lanechange-output.started", "Output", TL("Record start of lane change manoeuvres"));
306
307 oc.doRegister("lanechange-output.ended", new Option_Bool(false));
308 oc.addDescription("lanechange-output.ended", "Output", TL("Record end of lane change manoeuvres"));
309
310 oc.doRegister("lanechange-output.xy", new Option_Bool(false));
311 oc.addDescription("lanechange-output.xy", "Output", TL("Record coordinates of lane change manoeuvres"));
312
313 oc.doRegister("stop-output", new Option_FileName());
314 oc.addDescription("stop-output", "Output", TL("Record stops and loading/unloading of passenger and containers for all vehicles into FILE"));
315 oc.doRegister("stop-output.write-unfinished", new Option_Bool(false));
316 oc.addDescription("stop-output.write-unfinished", "Output", TL("Write stop output for stops which have not ended at simulation end"));
317
318 oc.doRegister("collision-output", new Option_FileName());
319 oc.addDescription("collision-output", "Output", TL("Write collision information into FILE"));
320
321 oc.doRegister("edgedata-output", new Option_FileName());
322 oc.addDescription("edgedata-output", "Output", TL("Write aggregated traffic statistics for all edges into FILE"));
323 oc.doRegister("lanedata-output", new Option_FileName());
324 oc.addDescription("lanedata-output", "Output", TL("Write aggregated traffic statistics for all lanes into FILE"));
325
326 oc.doRegister("statistic-output", new Option_FileName());
327 oc.addSynonyme("statistic-output", "statistics-output");
328 oc.addDescription("statistic-output", "Output", TL("Write overall statistics into FILE"));
329
330 oc.doRegister("deadlock-output", new Option_FileName());
331 oc.addDescription("deadlock-output", "Output", TL("Write reports on deadlocks FILE"));
332
333#ifdef _DEBUG
334 oc.doRegister("movereminder-output", new Option_FileName());
335 oc.addDescription("movereminder-output", "Output", TL("Save movereminder states of selected vehicles into FILE"));
336 oc.doRegister("movereminder-output.vehicles", new Option_StringVector());
337 oc.addDescription("movereminder-output.vehicles", "Output", TL("List of vehicle ids which shall save their movereminder states"));
338#endif
339
340 oc.doRegister("save-state.times", new Option_StringVector());
341 oc.addDescription("save-state.times", "Output", TL("Use TIME[] as times at which a network state written"));
342 oc.doRegister("save-state.period", new Option_String("-1", "TIME"));
343 oc.addDescription("save-state.period", "Output", TL("save state repeatedly after TIME period"));
344 oc.doRegister("save-state.period.keep", new Option_Integer(0));
345 oc.addDescription("save-state.period.keep", "Output", TL("Keep only the last INT periodic state files"));
346 oc.doRegister("save-state.prefix", new Option_FileName(StringVector({ "state" })));
347 oc.addDescription("save-state.prefix", "Output", TL("Prefix for network states"));
348 oc.doRegister("save-state.suffix", new Option_String(".xml.gz"));
349 oc.addDescription("save-state.suffix", "Output", TL("Suffix for network states (.xml.gz or .xml)"));
350 oc.doRegister("save-state.files", new Option_FileName());
351 oc.addDescription("save-state.files", "Output", TL("Files for network states"));
352 oc.doRegister("save-state.rng", new Option_Bool(false));
353 oc.addDescription("save-state.rng", "Output", TL("Save random number generator states"));
354 oc.doRegister("save-state.transportables", new Option_Bool(false));
355 oc.addDescription("save-state.transportables", "Output", TL("Save person and container states (experimental)"));
356 oc.doRegister("save-state.constraints", new Option_Bool(false));
357 oc.addDescription("save-state.constraints", "Output", TL("Save rail signal constraints"));
358 oc.doRegister("save-state.precision", new Option_Integer(2));
359 oc.addDescription("save-state.precision", "Output", TL("Write internal state values with the given precision (default 2)"));
360
361 // register the simulation settings
362 oc.doRegister("begin", 'b', new Option_String("0", "TIME"));
363 oc.addDescription("begin", "Time", TL("Defines the begin time in seconds; The simulation starts at this time"));
364
365 oc.doRegister("end", 'e', new Option_String("-1", "TIME"));
366 oc.addDescription("end", "Time", TL("Defines the end time in seconds; The simulation ends at this time"));
367
368 oc.doRegister("step-length", new Option_String("1", "TIME"));
369 oc.addDescription("step-length", "Time", TL("Defines the step duration in seconds"));
370
371 oc.doRegister("step-method.ballistic", new Option_Bool(false));
372 oc.addDescription("step-method.ballistic", "Processing", TL("Whether to use ballistic method for the positional update of vehicles (default is a semi-implicit Euler method)."));
373
374 oc.doRegister("extrapolate-departpos", new Option_Bool(false));
375 oc.addDescription("extrapolate-departpos", "Processing", TL("Whether vehicles that depart between simulation steps should extrapolate the depart position"));
376
377 oc.doRegister("threads", new Option_Integer(1));
378 oc.addDescription("threads", "Processing", TL("Defines the number of threads for parallel simulation"));
379
380 oc.doRegister("lateral-resolution", new Option_Float(-1));
381 oc.addDescription("lateral-resolution", "Processing", TL("Defines the resolution in m when handling lateral positioning within a lane (with -1 all vehicles drive at the center of their lane"));
382
383 // register the processing options
384 oc.doRegister("route-steps", 's', new Option_String("200", "TIME"));
385 oc.addDescription("route-steps", "Processing", TL("Load routes for the next number of seconds ahead"));
386
387 oc.doRegister("no-internal-links", new Option_Bool(false));
388 oc.addDescription("no-internal-links", "Processing", TL("Disable (junction) internal links"));
389
390 oc.doRegister("ignore-junction-blocker", new Option_String("-1", "TIME"));
391 oc.addDescription("ignore-junction-blocker", "Processing", TL("Ignore vehicles which block the junction after they have been standing for SECONDS (-1 means never ignore)"));
392
393 oc.doRegister("ignore-route-errors", new Option_Bool(false));
394 oc.addDescription("ignore-route-errors", "Processing", TL("Do not check whether routes are connected"));
395
396 oc.doRegister("ignore-accidents", new Option_Bool(false));
397 oc.addDescription("ignore-accidents", "Processing", TL("Do not check whether accidents occur"));
398
399 oc.doRegister("collision.action", new Option_String("teleport"));
400 oc.addDescription("collision.action", "Processing", TL("How to deal with collisions: [none,warn,teleport,remove]"));
401
402 oc.doRegister("intermodal-collision.action", new Option_String("warn"));
403 oc.addDescription("intermodal-collision.action", "Processing", TL("How to deal with collisions between vehicle and pedestrian: [none,warn,teleport,remove]"));
404
405 oc.doRegister("collision.stoptime", new Option_String("0", "TIME"));
406 oc.addDescription("collision.stoptime", "Processing", TL("Let vehicle stop for TIME before performing collision.action (except for action 'none')"));
407
408 oc.doRegister("intermodal-collision.stoptime", new Option_String("0", "TIME"));
409 oc.addDescription("intermodal-collision.stoptime", "Processing", TL("Let vehicle stop for TIME before performing intermodal-collision.action (except for action 'none')"));
410
411 oc.doRegister("collision.check-junctions", new Option_Bool(false));
412 oc.addDescription("collision.check-junctions", "Processing", TL("Enables collisions checks on junctions"));
413
414 oc.doRegister("collision.check-junctions.mingap", new Option_Float(0));
415 oc.addDescription("collision.check-junctions.mingap", "Processing", TL("Increase or decrease sensitivity for junction collision check"));
416
417 oc.doRegister("collision.mingap-factor", new Option_Float(-1));
418 oc.addDescription("collision.mingap-factor", "Processing", TL("Sets the fraction of minGap that must be maintained to avoid collision detection. If a negative value is given, the carFollowModel parameter is used"));
419
420 oc.doRegister("keep-after-arrival", new Option_String("0", "TIME"));
421 oc.addDescription("keep-after-arrival", "Processing", TL("After a vehicle arrives, keep it in memory for the given TIME (for TraCI access)"));
422
423 oc.doRegister("max-num-vehicles", new Option_Integer(-1));
424 oc.addDescription("max-num-vehicles", "Processing", TL("Delay vehicle insertion to stay within the given maximum number"));
425
426 oc.doRegister("max-num-persons", new Option_Integer(-1));
427 oc.addDescription("max-num-persons", "Processing", TL("Delay person insertion to stay within the given maximum number"));
428
429 oc.doRegister("max-num-teleports", new Option_Integer(-1));
430 oc.addDescription("max-num-teleports", "Processing", TL("Abort the simulation if the given maximum number of teleports is exceeded"));
431
432 oc.doRegister("scale", new Option_Float(1.));
433 oc.addDescription("scale", "Processing", TL("Scale demand by the given factor (by discarding or duplicating vehicles)"));
434
435 oc.doRegister("scale-suffix", new Option_String("."));
436 oc.addDescription("scale-suffix", "Processing", TL("Suffix to be added when creating ids for cloned vehicles"));
437
438 oc.doRegister("time-to-teleport", new Option_String("300", "TIME"));
439 oc.addDescription("time-to-teleport", "Processing", TL("Specify how long a vehicle may wait until being teleported, defaults to 300, non-positive values disable teleporting"));
440
441 oc.doRegister("time-to-teleport.highways", new Option_String("0", "TIME"));
442 oc.addDescription("time-to-teleport.highways", "Processing", TL("The waiting time after which vehicles on a fast road (speed > 69km/h) are teleported if they are on a non-continuing lane"));
443
444 oc.doRegister("time-to-teleport.highways.min-speed", new Option_Float(69 / 3.6));
445 oc.addDescription("time-to-teleport.highways.min-speed", "Processing", TL("The waiting time after which vehicles on a fast road (default: speed > 69km/h) are teleported if they are on a non-continuing lane"));
446
447 oc.doRegister("time-to-teleport.disconnected", new Option_String("-1", "TIME"));
448 oc.addDescription("time-to-teleport.disconnected", "Processing", TL("The waiting time after which vehicles with a disconnected route are teleported. Negative values disable teleporting"));
449
450 oc.doRegister("time-to-teleport.remove", new Option_Bool(false));
451 oc.addDescription("time-to-teleport.remove", "Processing", TL("Whether vehicles shall be removed after waiting too long instead of being teleported"));
452
453 oc.doRegister("time-to-teleport.remove-constraint", new Option_Bool(false));
454 oc.addDescription("time-to-teleport.remove-constraint", "Processing", TL("Whether rail-signal-constraint based deadlocks shall be cleared by removing a constraint"));
455
456 oc.doRegister("time-to-teleport.ride", new Option_String("-1", "TIME"));
457 oc.addDescription("time-to-teleport.ride", "Processing", TL("The waiting time after which persons / containers waiting for a pickup are teleported. Negative values disable teleporting"));
458
459 oc.doRegister("time-to-teleport.bidi", new Option_String("-1", "TIME"));
460 oc.addDescription("time-to-teleport.bidi", "Processing", TL("The waiting time after which vehicles on bidirectional edges are teleported"));
461
462 oc.doRegister("time-to-teleport.railsignal-deadlock", new Option_String("-1", "TIME"));
463 oc.addDescription("time-to-teleport.railsignal-deadlock", "Processing", TL("The waiting time after which vehicles in a rail-signal based deadlock are teleported"));
464
465 oc.doRegister("waiting-time-memory", new Option_String("100", "TIME"));
466 oc.addDescription("waiting-time-memory", "Processing", TL("Length of time interval, over which accumulated waiting time is taken into account (default is 100s.)"));
467
468 oc.doRegister("startup-wait-threshold", new Option_String("2", "TIME"));
469 oc.addDescription("startup-wait-threshold", "Processing", TL("Minimum consecutive waiting time before applying startupDelay"));
470
471 oc.doRegister("max-depart-delay", new Option_String("-1", "TIME"));
472 oc.addDescription("max-depart-delay", "Processing", TL("How long vehicles wait for departure before being skipped, defaults to -1 which means vehicles are never skipped"));
473
474 oc.doRegister("sloppy-insert", new Option_Bool(false));
475 oc.addDescription("sloppy-insert", "Processing", TL("Whether insertion on an edge shall not be repeated in same step once failed"));
476
477 oc.doRegister("eager-insert", new Option_Bool(false));
478 oc.addDescription("eager-insert", "Processing", TL("Whether each vehicle is checked separately for insertion on an edge"));
479
480 oc.doRegister("emergency-insert", new Option_Bool(false));
481 oc.addDescription("emergency-insert", "Processing", TL("Allow inserting a vehicle in a situation which requires emergency braking"));
482
483 oc.doRegister("insertion-checks", new Option_String("all"));
484 oc.addDescription("insertion-checks", "Processing", TL("Override default value for vehicle attribute insertionChecks"));
485
486 oc.doRegister("random-depart-offset", new Option_String("0", "TIME"));
487 oc.addDescription("random-depart-offset", "Processing", TL("Each vehicle receives a random offset to its depart value drawn uniformly from [0, TIME]"));
488
489 oc.doRegister("lanechange.duration", new Option_String("0", "TIME"));
490 oc.addDescription("lanechange.duration", "Processing", TL("Duration of a lane change maneuver (default 0)"));
491
492 oc.doRegister("lanechange.overtake-right", new Option_Bool(false));
493 oc.addDescription("lanechange.overtake-right", "Processing", TL("Whether overtaking on the right on motorways is permitted"));
494
495 oc.doRegister("tls.all-off", new Option_Bool(false));
496 oc.addDescription("tls.all-off", "Processing", TL("Switches off all traffic lights."));
497
498 oc.doRegister("tls.actuated.show-detectors", new Option_Bool(false));
499 oc.addDescription("tls.actuated.show-detectors", "Processing", TL("Sets default visibility for actuation detectors"));
500
501 oc.doRegister("tls.actuated.jam-threshold", new Option_Float(-1));
502 oc.addDescription("tls.actuated.jam-threshold", "Processing", TL("Sets default jam-threshold parameter for all actuation detectors"));
503
504 oc.doRegister("tls.actuated.detector-length", new Option_Float(0));
505 oc.addDescription("tls.actuated.detector-length", "Processing", TL("Sets default detector length parameter for all actuation detectors"));
506
507 oc.doRegister("tls.delay_based.detector-range", new Option_Float(100));
508 oc.addDescription("tls.delay_based.detector-range", "Processing", TL("Sets default range for detecting delayed vehicles"));
509
510 oc.doRegister("tls.yellow.min-decel", new Option_Float(3.0));
511 oc.addDescription("tls.yellow.min-decel", "Processing", TL("Minimum deceleration when braking at yellow"));
512
513 oc.doRegister("railsignal-moving-block", new Option_Bool(false));
514 oc.addDescription("railsignal-moving-block", "Processing", TL("Let railsignals operate in moving-block mode by default"));
515 oc.addSynonyme("railsignal-moving-block", "railsignal.moving-block");
516
517 oc.doRegister("railsignal.moving-block.default-classes", new Option_StringVector(StringVector({"tram", "cable_car"})));
518 oc.addDescription("railsignal.moving-block.default-classes", "Processing", TL("List vehicle classes that default to moving-block operations"));
519
520 oc.doRegister("railsignal.moving-block.max-dist", new Option_Float(200));
521 oc.addDescription("railsignal.moving-block.max-dist", "Processing", TL("Maximum signal distance above which zipper conflicts are ignored"));
522
523 oc.doRegister("railsignal.max-block-length", new Option_Float(2e4));
524 oc.addDescription("railsignal.max-block-length", "Processing", TL("Do not build blocks longer than FLOAT and issue a warning instead"));
525
526 oc.doRegister("railsignal.default-classes", new Option_StringVector(StringVector({"rail", "rail_fast", "rail_electric", "rail_urban", "subway"})));
527 oc.addDescription("railsignal.default-classes", "Processing", TL("List vehicle classes that uses block-based insertion checks even when the network has no rail signals for them"));
528
529 oc.doRegister("time-to-impatience", new Option_String("180", "TIME"));
530 oc.addDescription("time-to-impatience", "Processing", TL("Specify how long a vehicle may wait until impatience grows from 0 to 1, defaults to 300, non-positive values disable impatience growth"));
531
532 oc.doRegister("default.departspeed", new Option_String("avg"));
533 oc.addDescription("default.departspeed", "Processing", TL("Select default depart speed"));
534
535 oc.doRegister("default.departlane", new Option_String("best_prob"));
536 oc.addDescription("default.departlane", "Processing", TL("Select default depart lane"));
537
538 oc.doRegister("default.action-step-length", new Option_Float(0.0));
539 oc.addDescription("default.action-step-length", "Processing", TL("Length of the default interval length between action points for the car-following and lane-change models (in seconds). If not specified, the simulation step-length is used per default. Vehicle- or VType-specific settings override the default. Must be a multiple of the simulation step-length."));
540
541 oc.doRegister("default.carfollowmodel", new Option_String("Krauss"));
542 oc.addDescription("default.carfollowmodel", "Processing", TL("Select default car following model (Krauss, IDM, ...)"));
543 oc.addSynonyme("default.carfollowmodel", "carfollow.model");
544
545 oc.doRegister("default.speeddev", new Option_Float(-1));
546 oc.addDescription("default.speeddev", "Processing", TL("Select default speed deviation. A negative value implies vClass specific defaults (0.1 for the default passenger class)"));
547
548 oc.doRegister("default.emergencydecel", new Option_String("default"));
549 oc.addDescription("default.emergencydecel", "Processing", TL("Select default emergencyDecel value among ('decel', 'default', FLOAT) which sets the value either to the same as the deceleration value, a vClass-class specific default or the given FLOAT in m/s^2"));
550
551 oc.doRegister("overhead-wire.solver", new Option_Bool(true));
552 oc.addDescription("overhead-wire.solver", "Processing", TL("Use Kirchhoff's laws for solving overhead wire circuit"));
553
554 oc.doRegister("overhead-wire.recuperation", new Option_Bool(true));
555 oc.addDescription("overhead-wire.recuperation", "Processing", TL("Enable recuperation from the vehicle equipped with elecHybrid device into the overhead wire."));
556
557 oc.doRegister("overhead-wire.substation-current-limits", new Option_Bool(true));
558 oc.addDescription("overhead-wire.substation-current-limits", "Processing", TL("Enable current limits of traction substation during solving the overhead wire electrical circuit."));
559
560 oc.doRegister("emergencydecel.warning-threshold", new Option_Float(1));
561 oc.addDescription("emergencydecel.warning-threshold", "Processing", TL("Sets the fraction of emergency decel capability that must be used to trigger a warning."));
562
563 oc.doRegister("parking.maneuver", new Option_Bool(false));
564 oc.addDescription("parking.maneuver", "Processing", TL("Whether parking simulation includes maneuvering time and associated lane blocking"));
565
566 oc.doRegister("use-stop-ended", new Option_Bool(false));
567 oc.addDescription("use-stop-ended", "Processing", TL("Override stop until times with stop ended times when given"));
568
569 oc.doRegister("use-stop-started", new Option_Bool(false));
570 oc.addDescription("use-stop-started", "Processing", TL("Override stop arrival times with stop started times when given"));
571
572 // pedestrian model
573 oc.doRegister("pedestrian.model", new Option_String("striping"));
574 oc.addDescription("pedestrian.model", "Processing", TL("Select among pedestrian models ['nonInteracting', 'striping', 'jupedsim', 'remote']"));
575
576 oc.doRegister("pedestrian.timegap-crossing", new Option_Float(2.));
577 oc.addDescription("pedestrian.timegap-crossing", "Processing", TL("Minimal acceptable gap (in seconds) between two vehicles before starting to cross"));
578
579 oc.doRegister("pedestrian.striping.stripe-width", new Option_Float(0.64));
580 oc.addDescription("pedestrian.striping.stripe-width", "Processing", TL("Width of parallel stripes for segmenting a sidewalk (meters) for use with model 'striping'"));
581
582 oc.doRegister("pedestrian.striping.dawdling", new Option_Float(0.2));
583 oc.addDescription("pedestrian.striping.dawdling", "Processing", TL("Factor for random slow-downs [0,1] for use with model 'striping'"));
584
585 oc.doRegister("pedestrian.striping.mingap-to-vehicle", new Option_Float(0.25));
586 oc.addDescription("pedestrian.striping.mingap-to-vehicle", "Processing", TL("Minimal gap / safety buffer (in meters) from a pedestrian to another vehicle for use with model 'striping'"));
587
588 oc.doRegister("pedestrian.striping.jamtime", new Option_String("300", "TIME"));
589 oc.addDescription("pedestrian.striping.jamtime", "Processing", TL("Time in seconds after which pedestrians start squeezing through a jam when using model 'striping' (non-positive values disable squeezing)"));
590 oc.doRegister("pedestrian.striping.jamtime.crossing", new Option_String("10", "TIME"));
591 oc.addDescription("pedestrian.striping.jamtime.crossing", "Processing", TL("Time in seconds after which pedestrians start squeezing through a jam while on a pedestrian crossing when using model 'striping' (non-positive values disable squeezing)"));
592 oc.doRegister("pedestrian.striping.jamtime.narrow", new Option_String("1", "TIME"));
593 oc.addDescription("pedestrian.striping.jamtime.narrow", "Processing", TL("Time in seconds after which pedestrians start squeezing through a jam while on a narrow lane when using model 'striping'"));
594
595 oc.doRegister("pedestrian.striping.jamfactor", new Option_Float(0.25));
596 oc.addDescription("pedestrian.striping.jamfactor", "Processing", TL("Factor for reducing speed of pedestrian in jammed state"));
597
598 oc.doRegister("pedestrian.striping.reserve-oncoming", new Option_Float(0.0));
599 oc.addDescription("pedestrian.striping.reserve-oncoming", "Processing", TL("Fraction of stripes to reserve for oncoming pedestrians"));
600
601 oc.doRegister("pedestrian.striping.reserve-oncoming.junctions", new Option_Float(0.34));
602 oc.addDescription("pedestrian.striping.reserve-oncoming.junctions", "Processing", TL("Fraction of stripes to reserve for oncoming pedestrians on crossings and walkingareas"));
603
604 oc.doRegister("pedestrian.striping.reserve-oncoming.max", new Option_Float(1.28));
605 oc.addDescription("pedestrian.striping.reserve-oncoming.max", "Processing", TL("Maximum width in m to reserve for oncoming pedestrians"));
606
607 oc.doRegister("pedestrian.striping.legacy-departposlat", new Option_Bool(false));
608 oc.addDescription("pedestrian.striping.legacy-departposlat", "Processing", TL("Interpret departPosLat for walks in legacy style"));
609
610 oc.doRegister("pedestrian.striping.walkingarea-detail", new Option_Integer(4));
611 oc.addDescription("pedestrian.striping.walkingarea-detail", "Processing", TL("Generate INT intermediate points to smooth out lanes within the walkingarea"));
612
613#ifdef HAVE_JUPEDSIM
614 oc.doRegister("pedestrian.jupedsim.step-length", new Option_String("0.01", "TIME"));
615 oc.addDescription("pedestrian.jupedsim.step-length", "Processing", TL("The update interval of the JuPedSim simulation (in seconds)"));
616 oc.doRegister("pedestrian.jupedsim.exit-tolerance", new Option_Float(1.));
617 oc.addDescription("pedestrian.jupedsim.exit-tolerance", "Processing", TL("The distance to accept the JuPedSim arrival point (in meters)"));
618 oc.doRegister("pedestrian.jupedsim.model", new Option_String("CollisionFreeSpeed"));
619 oc.addDescription("pedestrian.jupedsim.model", "Processing", TL("The submodel to use in JuPedSim ('CollisionFreeSpeed', 'CollisionFreeSpeedV2', 'GeneralizedCentrifugalForce', 'SocialForce')"));
620 oc.doRegister("pedestrian.jupedsim.strength-neighbor-repulsion", new Option_Float(8.));
621 oc.addDescription("pedestrian.jupedsim.strength-neighbor-repulsion", "Processing", TL("The neighbor repulsion strength of the JuPedSim model"));
622 oc.doRegister("pedestrian.jupedsim.range-neighbor-repulsion", new Option_Float(.1));
623 oc.addDescription("pedestrian.jupedsim.range-neighbor-repulsion", "Processing", TL("The neighbor repulsion range of the JuPedSim model (in meters)"));
624 oc.doRegister("pedestrian.jupedsim.strength-geometry-repulsion", new Option_Float(5.));
625 oc.addDescription("pedestrian.jupedsim.strength-geometry-repulsion", "Processing", TL("The geometry repulsion strength of the JuPedSim model"));
626 oc.doRegister("pedestrian.jupedsim.range-geometry-repulsion", new Option_Float(.02));
627 oc.addDescription("pedestrian.jupedsim.range-geometry-repulsion", "Processing", TL("The geometry repulsion range of the JuPedSim model (in meters)"));
628 oc.doRegister("pedestrian.jupedsim.wkt", new Option_FileName());
629 oc.addDescription("pedestrian.jupedsim.wkt", "Output", TL("The filename to output the JuPedSim network as WKT"));
630 oc.doRegister("pedestrian.jupedsim.wkt.geo", new Option_Bool(false));
631 oc.addDescription("pedestrian.jupedsim.wkt.geo", "Output", TL("Whether to output JuPedSim network as WKT using geo-coordinates (lon/lat)"));
632 oc.doRegister("pedestrian.jupedsim.py", new Option_FileName());
633 oc.addDescription("pedestrian.jupedsim.py", "Output", TL("The filename to output the JuPedSim setup as Python script"));
634#endif
635
636 oc.doRegister("ride.stop-tolerance", new Option_Float(10.));
637 oc.addDescription("ride.stop-tolerance", "Processing", TL("Tolerance to apply when matching pedestrian and vehicle positions on boarding at individual stops"));
638
639 oc.doRegister("mapmatch.distance", new Option_Float(100));
640 oc.addDescription("mapmatch.distance", "Processing", TL("Maximum distance when mapping input coordinates (fromXY etc.) to the road network"));
641
642 oc.doRegister("mapmatch.junctions", new Option_Bool(false));
643 oc.addDescription("mapmatch.junctions", "Processing", TL("Match positions to junctions instead of edges"));
644
645 oc.doRegister("mapmatch.taz", new Option_Bool(false));
646 oc.addDescription("mapmatch.taz", "Processing", TL("Match positions to taz instead of edges"));
647
648 // generic routing options
649 oc.doRegister("routing-algorithm", new Option_String("dijkstra"));
650 oc.addDescription("routing-algorithm", "Routing",
651 "Select among routing algorithms ['dijkstra', 'astar', 'CH', 'CHWrapper']");
652
653 oc.doRegister("weights.random-factor", new Option_Float(1.));
654 oc.addDescription("weights.random-factor", "Routing", TL("Edge weights for routing are dynamically disturbed by a random factor drawn uniformly from [1,FLOAT)"));
655
656 oc.doRegister("weights.random-factor.dynamic", new Option_Bool(false));
657 oc.addDescription("weights.random-factor.dynamic", "Routing", TL("When using option --weights.random-factor, vary the randomness over time"));
658
659 oc.doRegister("weights.minor-penalty", new Option_Float(1.5));
660 oc.addDescription("weights.minor-penalty", "Routing", TL("Apply the given time penalty when computing minimum routing costs for minor-link internal lanes"));
661
662 oc.doRegister("weights.tls-penalty", new Option_Float(0));
663 oc.addDescription("weights.tls-penalty", "Routing", TL("Apply scaled travel time penalties based on green split when computing minimum routing costs for internal lanes at traffic lights"));
664
665 oc.doRegister("weights.turnaround-penalty", new Option_Float(5.0));
666 oc.addDescription("weights.turnaround-penalty", "Processing", TL("Apply the given time penalty when computing routing costs for turnaround internal lanes"));
667
668 oc.doRegister("weights.reversal-penalty", new Option_Float(60));
669 oc.addDescription("weights.reversal-penalty", "Processing", TL("Apply the given time penalty when computing routing costs for train reversal. Negative values disable reversal"));
670
671 oc.doRegister("weights.priority-factor", new Option_Float(0));
672 oc.addDescription("weights.priority-factor", "Routing", TL("Consider edge priorities in addition to travel times, weighted by factor"));
673
674 oc.doRegister("weights.separate-turns", new Option_Float(0));
675 oc.addDescription("weights.separate-turns", "Routing", TL("Distinguish travel time by turn direction and shift a fraction of the estimated time loss ahead of the intersection onto the internal edges"));
676
677 oc.doRegister("astar.all-distances", new Option_FileName());
678 oc.addDescription("astar.all-distances", "Routing", TL("Initialize lookup table for astar from the given file (generated by marouter --all-pairs-output)"));
679
680 oc.doRegister("astar.landmark-distances", new Option_FileName());
681 oc.addDescription("astar.landmark-distances", "Routing", TL("Initialize lookup table for astar ALT-variant from the given file"));
682
683 oc.doRegister("persontrip.walkfactor", new Option_Float(double(0.75)));
684 oc.addDescription("persontrip.walkfactor", "Routing", TL("Use FLOAT as a factor on pedestrian maximum speed during intermodal routing"));
685
686 oc.doRegister("persontrip.walk-opposite-factor", new Option_Float(1.0));
687 oc.addDescription("persontrip.walk-opposite-factor", "Processing", TL("Use FLOAT as a factor on walking speed against vehicle traffic direction"));
688
689 oc.doRegister("persontrip.transfer.car-walk", new Option_StringVector(StringVector({ "parkingAreas" })));
690 oc.addDescription("persontrip.transfer.car-walk", "Routing",
691 "Where are mode changes from car to walking allowed (possible values: 'parkingAreas', 'ptStops', 'allJunctions' and combinations)");
692
693 oc.doRegister("persontrip.transfer.taxi-walk", new Option_StringVector());
694 oc.addDescription("persontrip.transfer.taxi-walk", "Routing", TL("Where taxis can drop off customers ('allJunctions, 'ptStops', 'parkingAreas')"));
695
696 oc.doRegister("persontrip.transfer.walk-taxi", new Option_StringVector());
697 oc.addDescription("persontrip.transfer.walk-taxi", "Routing", TL("Where taxis can pick up customers ('allJunctions, 'ptStops', 'parkingAreas')"));
698
699 oc.doRegister("persontrip.default.group", new Option_String());
700 oc.addDescription("persontrip.default.group", "Routing", TL("When set, trips between the same origin and destination will share a taxi by default"));
701
702 oc.doRegister("persontrip.taxi.waiting-time", new Option_String("300", "TIME"));
703 oc.addDescription("persontrip.taxi.waiting-time", "Routing", TL("Estimated time for taxi pickup"));
704
705 oc.doRegister("persontrip.ride-public-line", new Option_Bool(false));
706 oc.addDescription("persontrip.ride-public-line", "Routing", TL("Only use the intended public transport line rather than any alternative line that stops at the destination"));
707
708 oc.doRegister("railway.max-train-length", new Option_Float(1000.0));
709 oc.addDescription("railway.max-train-length", "Routing", TL("Use FLOAT as a maximum train length when initializing the railway router"));
710
711 oc.doRegister("replay-rerouting", new Option_Bool(false));
712 oc.addDescription("replay-rerouting", "Routing", TL("Replay exact rerouting sequence from vehroute-output"));
713
714 // devices
715 oc.addOptionSubTopic("Emissions");
716 oc.doRegister("emissions.volumetric-fuel", new Option_Bool(false));
717 oc.addDescription("emissions.volumetric-fuel", "Emissions", TL("Return fuel consumption values in (legacy) unit l instead of mg"));
718
719 oc.doRegister("phemlight-path", new Option_FileName(StringVector({ "./PHEMlight/" })));
720 oc.addDescription("phemlight-path", "Emissions", TL("Determines where to load PHEMlight definitions from"));
721
722 oc.doRegister("phemlight-year", new Option_Integer(0));
723 oc.addDescription("phemlight-year", "Emissions", TL("Enable fleet age modelling with the given reference year in PHEMlight5"));
724
725 oc.doRegister("phemlight-temperature", new Option_Float(INVALID_DOUBLE));
726 oc.addDescription("phemlight-temperature", "Emissions", TL("Set ambient temperature to correct NOx emissions in PHEMlight5"));
727
728 oc.addOptionSubTopic("Communication");
729 oc.addOptionSubTopic("Battery");
731
732 // register report options
733 oc.doRegister("duration-log.disable", new Option_Bool(false));
734 oc.addSynonyme("duration-log.disable", "no-duration-log", false);
735 oc.addDescription("duration-log.disable", "Report", TL("Disable performance reports for individual simulation steps"));
736
737 oc.doRegister("duration-log.statistics", 't', new Option_Bool(false));
738 oc.addDescription("duration-log.statistics", "Report", TL("Enable statistics on vehicle trips"));
739
740 oc.doRegister("no-step-log", new Option_Bool(false));
741 oc.addDescription("no-step-log", "Report", TL("Disable console output of current simulation step"));
742
743 oc.doRegister("step-log.period", new Option_Integer(100));
744 oc.addDescription("step-log.period", "Report", TL("Number of simulation steps between step-log outputs"));
745
746 //remote port 0 if not used
747 oc.addOptionSubTopic("TraCI Server");
748 oc.doRegister("remote-port", new Option_Integer(0));
749 oc.addDescription("remote-port", "TraCI Server", TL("Enables TraCI Server if set"));
750 oc.doRegister("num-clients", new Option_Integer(1));
751 oc.addDescription("num-clients", "TraCI Server", TL("Expected number of connecting clients"));
752
753 oc.addOptionSubTopic("Mesoscopic");
754 oc.doRegister("mesosim", new Option_Bool(false));
755 oc.addDescription("mesosim", "Mesoscopic", TL("Enables mesoscopic simulation"));
756 oc.doRegister("meso-edgelength", new Option_Float(98.0f));
757 oc.addDescription("meso-edgelength", "Mesoscopic", TL("Length of an edge segment in mesoscopic simulation"));
758 oc.doRegister("meso-tauff", new Option_String("1.13", "TIME"));
759 oc.addDescription("meso-tauff", "Mesoscopic", TL("Factor for calculating the net free-free headway time"));
760 oc.doRegister("meso-taufj", new Option_String("1.13", "TIME"));
761 oc.addDescription("meso-taufj", "Mesoscopic", TL("Factor for calculating the net free-jam headway time"));
762 oc.doRegister("meso-taujf", new Option_String("1.73", "TIME"));
763 oc.addDescription("meso-taujf", "Mesoscopic", TL("Factor for calculating the jam-free headway time"));
764 oc.doRegister("meso-taujj", new Option_String("1.4", "TIME"));
765 oc.addDescription("meso-taujj", "Mesoscopic", TL("Factor for calculating the jam-jam headway time"));
766 oc.doRegister("meso-jam-threshold", new Option_Float(-1));
767 oc.addDescription("meso-jam-threshold", "Mesoscopic",
768 "Minimum percentage of occupied space to consider a segment jammed. A negative argument causes thresholds to be computed based on edge speed and tauff (default)");
769 oc.doRegister("meso-multi-queue", new Option_Bool(true));
770 oc.addDescription("meso-multi-queue", "Mesoscopic", TL("Enable multiple queues at edge ends"));
771 oc.doRegister("meso-lane-queue", new Option_Bool(false));
772 oc.addDescription("meso-lane-queue", "Mesoscopic", TL("Enable separate queues for every lane"));
773 oc.doRegister("meso-ignore-lanes-by-vclass", new Option_StringVector(StringVector({ "pedestrian", "bicycle" })));
774 oc.addDescription("meso-ignore-lanes-by-vclass", "Mesoscopic", TL("Do not build queues (or reduce capacity) for lanes allowing only the given vclasses"));
775 oc.addSynonyme("meso-ignore-lanes-by-vclass", "meso.ignore-lanes.by-vclass");
776 oc.doRegister("meso-junction-control", new Option_Bool(false));
777 oc.addDescription("meso-junction-control", "Mesoscopic", TL("Enable mesoscopic traffic light and priority junction handling"));
778 oc.doRegister("meso-junction-control.limited", new Option_Bool(false));
779 oc.addDescription("meso-junction-control.limited", "Mesoscopic",
780 "Enable mesoscopic traffic light and priority junction handling for saturated links. This prevents faulty traffic lights from hindering flow in low-traffic situations");
781 oc.doRegister("meso-tls-penalty", new Option_Float(0));
782 oc.addDescription("meso-tls-penalty", "Mesoscopic",
783 "Apply scaled travel time penalties when driving across tls controlled junctions based on green split instead of checking actual phases");
784 oc.doRegister("meso-tls-flow-penalty", new Option_Float(0));
785 oc.addDescription("meso-tls-flow-penalty", "Mesoscopic",
786 "Apply scaled headway penalties when driving across tls controlled junctions based on green split instead of checking actual phases");
787 oc.doRegister("meso-minor-penalty", new Option_String("0", "TIME"));
788 oc.addDescription("meso-minor-penalty", "Mesoscopic",
789 "Apply fixed time penalty when driving across a minor link. When using --meso-junction-control.limited, the penalty is not applied whenever limited control is active.");
790 oc.doRegister("meso-overtaking", new Option_Bool(false));
791 oc.addDescription("meso-overtaking", "Mesoscopic", TL("Enable mesoscopic overtaking"));
792 oc.doRegister("meso-recheck", new Option_String("0", "TIME"));
793 oc.addDescription("meso-recheck", "Mesoscopic", TL("Time interval for rechecking insertion into the next segment after failure"));
794
795 // add rand options
797 oc.doRegister("thread-rngs", new Option_Integer(64));
798 oc.addDescription("thread-rngs", "Random Number",
799 "Number of pre-allocated random number generators to ensure repeatable multi-threaded simulations (should be at least the number of threads for repeatable simulations).");
800
801 // add GUI options
802 // the reason that we include them in vanilla sumo as well is to make reusing config files easy
803 oc.addOptionSubTopic("GUI Only");
804 oc.doRegister("gui-settings-file", 'g', new Option_FileName());
805 oc.addDescription("gui-settings-file", "GUI Only", TL("Load visualisation settings from FILE"));
806
807 oc.doRegister("quit-on-end", 'Q', new Option_Bool(false));
808 oc.addDescription("quit-on-end", "GUI Only", TL("Quits the GUI when the simulation stops"));
809
810 oc.doRegister("game", 'G', new Option_Bool(false));
811 oc.addDescription("game", "GUI Only", TL("Start the GUI in gaming mode"));
812
813 oc.doRegister("game.mode", new Option_String("tls"));
814 oc.addDescription("game.mode", "GUI Only", TL("Select the game type ('tls', 'drt')"));
815
816 oc.doRegister("start", 'S', new Option_Bool(false));
817 oc.addDescription("start", "GUI Only", TL("Start the simulation after loading"));
818
819 oc.doRegister("delay", 'd', new Option_Float(0.0));
820 oc.addDescription("delay", "GUI Only", TL("Use FLOAT in ms as delay between simulation steps"));
821
822 oc.doRegister("breakpoints", 'B', new Option_StringVector());
823 oc.addDescription("breakpoints", "GUI Only", TL("Use TIME[] as times when the simulation should halt"));
824
825 oc.doRegister("edgedata-files", 'm', new Option_FileName());
826 oc.addSynonyme("edgedata-files", "data-files");
827 oc.addDescription("edgedata-files", "GUI Only", TL("Load edge/lane weights for visualization from FILE"));
828
829 oc.doRegister("alternative-net-file", 'N', new Option_FileName());
830 oc.addDescription("alternative-net-file", "GUI Only", TL("Load a secondary road network for abstract visualization from FILE"));
831
832 oc.doRegister("selection-file", new Option_FileName());
833 oc.addDescription("selection-file", "GUI Only", TL("Load pre-selected elements from FILE"));
834
835 oc.doRegister("demo", 'D', new Option_Bool(false));
836 oc.addDescription("demo", "GUI Only", TL("Restart the simulation after ending (demo mode)"));
837
838 oc.doRegister("disable-textures", 'T', new Option_Bool(false));
839 oc.addDescription("disable-textures", "GUI Only", TL("Do not load background pictures"));
840
841 oc.doRegister("registry-viewport", new Option_Bool(false));
842 oc.addDescription("registry-viewport", "GUI Only", TL("Load current viewport from registry"));
843
844 oc.doRegister("window-size", new Option_StringVector());
845 oc.addDescription("window-size", "GUI Only", TL("Create initial window with the given x,y size"));
846
847 oc.doRegister("window-pos", new Option_StringVector());
848 oc.addDescription("window-pos", "GUI Only", TL("Create initial window at the given x,y position"));
849
850 oc.doRegister("tracker-interval", new Option_String("1", "TIME"));
851 oc.addDescription("tracker-interval", "GUI Only", TL("The aggregation period for value tracker windows"));
852
853#ifdef HAVE_OSG
854 oc.doRegister("osg-view", new Option_Bool(false));
855 oc.addDescription("osg-view", "GUI Only", TL("Start with an OpenSceneGraph view instead of the regular 2D view"));
856#endif
857
858 // gui testing
859 oc.doRegister("gui-testing", new Option_Bool(false));
860 oc.addDescription("gui-testing", "GUI Only", TL("Enable overlay for screen recognition"));
861
862 // gui testing - debug
863 oc.doRegister("gui-testing-debug", new Option_Bool(false));
864 oc.addDescription("gui-testing-debug", "GUI Only", TL("Enable output messages during GUI-Testing"));
865
866 // gui testing - settings output
867 oc.doRegister("gui-testing.setting-output", new Option_FileName());
868 oc.addDescription("gui-testing.setting-output", "GUI Only", TL("Save gui settings in the given settings output file"));
869}
870
871
872void
874 // standard outputs
875 if (OutputDevice::createDeviceByOption("netstate-dump", "netstate", "netstate_file.xsd")) {
876 WRITE_WARNING(TL("Raw netstate dumps are deprecated. Use fcd-output instead."));
877 }
878 OutputDevice::createDeviceByOption("summary-output", "summary", "summary_file.xsd");
879 OutputDevice::createDeviceByOption("person-summary-output", "personSummary", "person_summary_file.xsd");
880 OutputDevice::createDeviceByOption("tripinfo-output", "tripinfos", "tripinfo_file.xsd");
881
882 //extended
883 OutputDevice::createDeviceByOption("fcd-output", "fcd-export", "fcd_file.xsd");
884 OutputDevice::createDeviceByOption("person-fcd-output", "fcd-export", "fcd_file.xsd");
885 OutputDevice::createDeviceByOption("emission-output", "emission-export", "emission_file.xsd");
886 OutputDevice::createDeviceByOption("battery-output", "battery-export", "battery_file.xsd");
887 if (OptionsCont::getOptions().getBool("elechybrid-output.aggregated")) {
888 // RICE_TODO: Add path to elechybrid-output.aggregated xsd file
889 OutputDevice::createDeviceByOption("elechybrid-output", "elecHybrid-export-aggregated", "\" recuperationEnabled=\"" + toString(MSGlobals::gOverheadWireRecuperation));
890 }
891 //OutputDevice::createDeviceByOption("elecHybrid-output", "elecHybrid-export");
892 OutputDevice::createDeviceByOption("chargingstations-output", "chargingstations-export");
893 OutputDevice::createDeviceByOption("overheadwiresegments-output", "overheadWireSegments-export");
894 OutputDevice::createDeviceByOption("substations-output", "substations-export");
895 OutputDevice::createDeviceByOption("full-output", "full-export", "full_file.xsd");
896 OutputDevice::createDeviceByOption("queue-output", "queue-export", "queue_file.xsd", 3);
897 OutputDevice::createDeviceByOption("amitran-output", "trajectories", "amitran/trajectories.xsd\" timeStepSize=\"" + toString(STEPS2MS(DELTA_T)));
898
899 //OutputDevice::createDeviceByOption("vtk-output", "vtk-export");
900 OutputDevice::createDeviceByOption("link-output", "link-output");
901 OutputDevice::createDeviceByOption("railsignal-block-output", "railsignal-block-output");
902 OutputDevice::createDeviceByOption("railsignal-vehicle-output", "railsignal-vehicle-output");
903 OutputDevice::createDeviceByOption("bt-output", "bt-output");
904 OutputDevice::createDeviceByOption("lanechange-output", "lanechanges");
905 OutputDevice::createDeviceByOption("stop-output", "stops", "stopinfo_file.xsd");
906 OutputDevice::createDeviceByOption("collision-output", "collisions", "collision_file.xsd");
907 OutputDevice::createDeviceByOption("statistic-output", "statistics", "statistic_file.xsd");
908 OutputDevice::createDeviceByOption("deadlock-output", "additional", "additional_file.xsd");
909
910#ifdef _DEBUG
911 OutputDevice::createDeviceByOption("movereminder-output", "movereminder-output");
912#endif
913
916}
917
918
919bool
922 bool ok = true;
923 if (!oc.isSet("net-file") && oc.isDefault("remote-port")) {
924 WRITE_ERROR(TL("No network file (-n) specified."));
925 ok = false;
926 }
927 if (oc.getFloat("scale") < 0.) {
928 WRITE_ERROR(TL("Invalid scaling factor."));
929 ok = false;
930 }
931 if (oc.getBool("vehroute-output.exit-times") && !oc.isSet("vehroute-output")) {
932 WRITE_ERROR(TL("A vehroute-output file is needed for exit times."));
933 ok = false;
934 }
935 if (oc.isSet("gui-settings-file") &&
936 oc.getString("gui-settings-file") != "" &&
937 !oc.isUsableFileList("gui-settings-file")) {
938 ok = false;
939 }
940 if (oc.getBool("demo") && oc.isDefault("start")) {
941 oc.setDefault("start", "true");
942 }
943 if (oc.getBool("demo") && oc.getBool("quit-on-end")) {
944 WRITE_ERROR(TL("You can either restart or quit on end."));
945 ok = false;
946 }
947 if (oc.getBool("meso-junction-control.limited") && !oc.getBool("meso-junction-control")) {
948 if (!oc.isDefault("meso-junction-control")) {
949 WRITE_WARNING(TL("The option 'meso-junction-control.limited' implies 'meso-junction-control'."))
950 }
951 oc.setDefault("meso-junction-control", "true");
952 }
953 if (oc.getBool("mesosim")) {
954 if (oc.isDefault("pedestrian.model")) {
955 oc.setDefault("pedestrian.model", "nonInteracting");
956 }
957 }
958 if (string2time(oc.getString("device.fcd.begin")) < 0) {
959 oc.setDefault("device.fcd.begin", oc.getString("begin"));
960 }
961 if (string2time(oc.getString("device.emissions.begin")) < 0) {
962 oc.setDefault("device.emissions.begin", oc.getString("begin"));
963 }
964 const SUMOTime begin = string2time(oc.getString("begin"));
965 const SUMOTime end = string2time(oc.getString("end"));
966 if (begin < 0) {
967 WRITE_ERROR(TL("The begin time should not be negative."));
968 ok = false;
969 }
970 // DELTA_T not yet initialized
971 const SUMOTime deltaT = MAX2((SUMOTime)1, string2time(oc.getString("step-length")));
972 if (begin < TIME2STEPS(1)) {
973 checkStepLengthMultiple(begin, " for begin", deltaT);
974 }
975 if (end != string2time("-1")) {
976 if (end < begin) {
977 WRITE_ERROR(TL("The end time should be after the begin time."));
978 ok = false;
979 }
980 }
981 if (string2time(oc.getString("step-length")) <= 0) {
982 WRITE_ERROR(TL("the minimum step-length is 0.001."));
983 ok = false;
984 }
985 const SUMOTime period = string2time(oc.getString("device.fcd.period"));
986 if (period > 0) {
987 checkStepLengthMultiple(period, " for device.fcd.period", deltaT);
988 }
989 const SUMOTime statePeriod = string2time(oc.getString("save-state.period"));
990 if (statePeriod > 0) {
991 checkStepLengthMultiple(statePeriod, " for save-state.period", deltaT);
992 }
993 for (const std::string& timeStr : oc.getStringVector("save-state.times")) {
994 try {
995 const SUMOTime saveT = string2time(timeStr);
996 if (end > 0 && saveT >= end) {
997 WRITE_WARNINGF(TL("The save-state time=% will not be used before simulation end at %."), timeStr, time2string(end));
998 } else {
999 checkStepLengthMultiple(saveT, " for save-state.times", deltaT, begin);
1000 }
1001 } catch (ProcessError& e) {
1002 WRITE_ERROR("Invalid time '" + timeStr + "' for option 'save-state.times'. " + e.what());
1003 ok = false;
1004 }
1005 }
1006
1007#ifdef _DEBUG
1008 if (oc.isSet("movereminder-output.vehicles") && !oc.isSet("movereminder-output")) {
1009 WRITE_ERROR(TL("option movereminder-output.vehicles requires option movereminder-output to be set"));
1010 ok = false;
1011 }
1012#endif
1013 if (oc.getBool("sloppy-insert")) {
1014 WRITE_WARNING(TL("The option 'sloppy-insert' is deprecated, because it is now activated by default, see the new option 'eager-insert'."));
1015 }
1016 if (string2time(oc.getString("lanechange.duration")) > 0 && oc.getFloat("lateral-resolution") > 0) {
1017 WRITE_ERROR(TL("Only one of the options 'lanechange.duration' or 'lateral-resolution' may be given."));
1018 ok = false;
1019 }
1020 if (oc.getBool("mesosim") && (oc.getFloat("lateral-resolution") > 0 || string2time(oc.getString("lanechange.duration")) > 0)) {
1021 WRITE_ERROR(TL("Sublane dynamics are not supported by mesoscopic simulation."));
1022 ok = false;
1023 }
1024 if (oc.getBool("ignore-accidents")) {
1025 WRITE_WARNING(TL("The option 'ignore-accidents' is deprecated. Use 'collision.action none' instead."));
1026 }
1027 if (oc.getBool("duration-log.statistics") && oc.isDefault("verbose")) {
1028 oc.setDefault("verbose", "true");
1029 }
1030 if (oc.isDefault("precision") && string2time(oc.getString("step-length")) % 10 != 0) {
1031 oc.setDefault("precision", "3");
1032 }
1033 if (oc.isDefault("tracker-interval") && !oc.isDefault("step-length")) {
1034 oc.setDefault("tracker-interval", oc.getString("step-length"));
1035 }
1036 if (oc.getBool("tripinfo-output.write-undeparted")) {
1037 if (!oc.isDefault("tripinfo-output.write-unfinished") && !oc.getBool("tripinfo-output.write-unfinished")) {
1038 WRITE_WARNING(TL("The option tripinfo-output.write-undeparted implies tripinfo-output.write-unfinished."));
1039 }
1040 oc.setDefault("tripinfo-output.write-unfinished", "true");
1041 }
1042 if (oc.getInt("precision") > 2) {
1043 if (oc.isDefault("netstate-dump.precision")) {
1044 oc.setDefault("netstate-dump.precision", toString(oc.getInt("precision")));
1045 }
1046 if (oc.isDefault("emission-output.precision")) {
1047 oc.setDefault("emission-output.precision", toString(oc.getInt("precision")));
1048 }
1049 if (oc.isDefault("battery-output.precision")) {
1050 oc.setDefault("battery-output.precision", toString(oc.getInt("precision")));
1051 }
1052 if (oc.isDefault("elechybrid-output.precision")) {
1053 oc.setDefault("elechybrid-output.precision", toString(oc.getInt("precision")));
1054 }
1055 if (oc.isDefault("substations-output.precision")) {
1056 oc.setDefault("substations-output.precision", toString(oc.getInt("precision")));
1057 }
1058 }
1059 if (!SUMOXMLDefinitions::CarFollowModels.hasString(oc.getString("carfollow.model"))) {
1060 WRITE_ERRORF(TL("Unknown model '%' for option 'carfollow.model'."), oc.getString("carfollow.model"));
1061 ok = false;
1062 }
1063 if (oc.isSet("default.emergencydecel")) {
1064 const std::string val = oc.getString("default.emergencydecel");
1065 if (val != "default" && val != "decel") {
1066 try {
1068 } catch (NumberFormatException&) {
1069 WRITE_ERRORF(TL("Invalid value '%' for option 'default.emergencydecel'. Must be a FLOAT or 'default' or 'decel'."), val);
1070 ok = false;
1071 }
1072 }
1073 }
1074
1075 if (oc.isSet("time-to-teleport.railsignal-deadlock")) {
1076 SUMOTime t1 = string2time(oc.getString("time-to-teleport"));
1077 SUMOTime t2 = string2time(oc.getString("time-to-teleport.railsignal-deadlock"));
1078 if (t1 > 0 && t2 > 0 && t1 <= t2) {
1079 WRITE_WARNINGF(TL("Railsignal-deadlock will not be detected because time-to-teleport (%) is lower than time-to-teleport.railsignal-deadlock (%)."), time2string(t1), time2string(t2));
1080 }
1081 }
1082
1083 oc.doRegister("", new Option_String("-1", "TIME"));
1084
1085
1086 if (oc.getFloat("delay") < 0.0) {
1087 WRITE_ERROR(TL("You need a non-negative delay."));
1088 ok = false;
1089 }
1090 for (const std::string& val : oc.getStringVector("breakpoints")) {
1091 try {
1092 string2time(val);
1093 } catch (ProcessError& e) {
1094 WRITE_ERROR("Invalid time '" + val + "' for option 'breakpoints'. " + e.what());
1095 ok = false;
1096 }
1097 }
1098#ifndef HAVE_FOX
1099 if (oc.getInt("threads") > 1) {
1100 WRITE_ERROR(TL("Parallel simulation is only possible when compiled with Fox."));
1101 ok = false;
1102 }
1103#endif
1104 if (oc.getInt("threads") < 1) {
1105 WRITE_ERROR(TL("You need at least one thread."));
1106 ok = false;
1107 }
1108 if (oc.getInt("threads") > oc.getInt("thread-rngs")) {
1109 WRITE_WARNING(TL("Number of threads exceeds number of thread-rngs. Simulation runs with the same seed may produce different results."));
1110 }
1111 if (oc.getString("game.mode") != "tls" && oc.getString("game.mode") != "drt") {
1112 WRITE_ERROR(TL("game.mode must be one of ['tls', 'drt']"));
1113 ok = false;
1114 }
1115
1116 if (oc.isSet("persontrip.transfer.car-walk")) {
1117 for (const std::string& opt : OptionsCont::getOptions().getStringVector("persontrip.transfer.car-walk")) {
1118 if (opt != "parkingAreas" && opt != "ptStops" && opt != "allJunctions") {
1119 WRITE_ERRORF(TL("Invalid transfer option '%'. Must be one of 'parkingAreas', 'ptStops' or 'allJunctions'."), opt);
1120 ok = false;
1121 }
1122 }
1123 }
1124 if (!oc.isDefault("weights.random-factor") && (oc.isSet("astar.all-distances") || oc.isSet("astar.landmark-distances"))) {
1125 WRITE_WARNING(TL("The option --weights.random-factor should not be used together with astar and precomputed distances."));
1126 }
1127 if (oc.getInt("threads") > 1) {
1128 WRITE_WARNING(TL("The option --threads has known problems and does NOT provide meaningful speedup at this time (https://github.com/eclipse-sumo/sumo/issues/4767). Using it is not recommended!"));
1129 }
1130 if (oc.getBool("mapmatch.junctions") && oc.isDefault("junction-taz")) {
1131 oc.setDefault("junction-taz", "true");
1132 }
1133
1134#ifdef HAVE_JUPEDSIM
1135 const std::string pedestrianJPSModel = oc.getString("pedestrian.jupedsim.model");
1136 const std::vector<std::string> allowedPedestrianJPSModels = {"CollisionFreeSpeed", "CollisionFreeSpeedV2", "GeneralizedCentrifugalForce", "SocialForce"};
1137 if (std::find(allowedPedestrianJPSModels.begin(), allowedPedestrianJPSModels.end(), pedestrianJPSModel) == allowedPedestrianJPSModels.end()) {
1138 WRITE_ERRORF(TL("Invalid JuPedSim model '%'. Must be one of 'CollisionFreeSpeed', 'CollisionFreeSpeedV2', 'GeneralizedCentrifugalForce' or 'SocialForce'."), pedestrianJPSModel);
1139 ok = false;
1140 }
1141#endif
1142
1143 ok &= MSDevice::checkOptions(oc);
1144 ok &= SystemFrame::checkOptions(oc);
1145
1146 return ok;
1147}
1148
1149
1150void
1152 // pre-initialise the network
1153 // set whether empty edges shall be printed on dump
1154 MSGlobals::gOmitEmptyEdgesOnDump = !oc.getBool("netstate-dump.empty-edges");
1155 // set whether internal lanes shall be used
1156 MSGlobals::gUsingInternalLanes = !oc.getBool("no-internal-links");
1157 MSGlobals::gIgnoreJunctionBlocker = string2time(oc.getString("ignore-junction-blocker")) < 0 ?
1158 std::numeric_limits<SUMOTime>::max() : string2time(oc.getString("ignore-junction-blocker"));
1159 // set the grid lock time
1160 MSGlobals::gTimeToGridlock = string2time(oc.getString("time-to-teleport")) < 0 ? 0 : string2time(oc.getString("time-to-teleport"));
1161 MSGlobals::gTimeToImpatience = string2time(oc.getString("time-to-impatience"));
1162 MSGlobals::gTimeToGridlockHighways = string2time(oc.getString("time-to-teleport.highways")) < 0 ? 0 : string2time(oc.getString("time-to-teleport.highways"));
1163 MSGlobals::gGridlockHighwaysSpeed = oc.getFloat("time-to-teleport.highways.min-speed");
1164 MSGlobals::gTimeToTeleportDisconnected = string2time(oc.getString("time-to-teleport.disconnected"));
1165 MSGlobals::gTimeToTeleportBidi = string2time(oc.getString("time-to-teleport.bidi"));
1166 MSGlobals::gTimeToTeleportRSDeadlock = string2time(oc.getString("time-to-teleport.railsignal-deadlock"));
1167 MSGlobals::gRemoveGridlocked = oc.getBool("time-to-teleport.remove");
1168 MSGlobals::gCheck4Accidents = !oc.getBool("ignore-accidents");
1169 MSGlobals::gCheckRoutes = !oc.getBool("ignore-route-errors");
1170 MSGlobals::gEmergencyInsert = oc.getBool("emergency-insert");
1171 MSGlobals::gWeightsSeparateTurns = oc.getFloat("weights.separate-turns");
1172 MSGlobals::gStartupWaitThreshold = string2time(oc.getString("startup-wait-threshold"));
1173 MSGlobals::gLaneChangeDuration = string2time(oc.getString("lanechange.duration"));
1174 MSGlobals::gLateralResolution = oc.getFloat("lateral-resolution");
1176 MSGlobals::gStateLoaded = oc.isSet("load-state");
1177 MSGlobals::gUseMesoSim = oc.getBool("mesosim");
1178 MSGlobals::gMesoLimitedJunctionControl = oc.getBool("meso-junction-control.limited");
1179 MSGlobals::gWaitingTimeMemory = string2time(oc.getString("waiting-time-memory"));
1181 MSGlobals::gOverheadWireSolver = oc.getBool("overhead-wire.solver");
1182 MSGlobals::gOverheadWireRecuperation = oc.getBool("overhead-wire.recuperation");
1183 MSGlobals::gOverheadWireCurrentLimits = oc.getBool("overhead-wire.substation-current-limits");
1185 MSGlobals::gMaxRailSignalBlockLength = oc.getFloat("railsignal.max-block-length");
1186
1188
1189 DELTA_T = string2time(oc.getString("step-length"));
1190
1191 const bool integrationMethodSet = !oc.isDefault("step-method.ballistic");
1192 const bool actionStepLengthSet = !oc.isDefault("default.action-step-length");
1193 MSGlobals::gSemiImplicitEulerUpdate = !oc.getBool("step-method.ballistic");
1194 // Init default value for gActionStepLength
1195 if (MSGlobals::gSemiImplicitEulerUpdate && actionStepLengthSet && !integrationMethodSet) {
1196 WRITE_MESSAGE(TL("Integration method was set to 'ballistic', since a default action step length was specified."));
1198 }
1199 double givenDefaultActionStepLength = oc.getFloat("default.action-step-length");
1201
1202 const std::string defaultEmergencyDecelOption = OptionsCont::getOptions().getString("default.emergencydecel");
1203 if (defaultEmergencyDecelOption == "default") {
1205 } else if (defaultEmergencyDecelOption == "decel") {
1207 } else {
1208 // value already checked in checkOptions()
1209 MSGlobals::gDefaultEmergencyDecel = StringUtils::toDouble(defaultEmergencyDecelOption);
1210 }
1211 MSGlobals::gNumSimThreads = oc.getInt("threads");
1212 MSGlobals::gNumThreads = MAX2(MSGlobals::gNumSimThreads, oc.getInt("device.rerouting.threads"));
1213
1214 MSGlobals::gEmergencyDecelWarningThreshold = oc.getFloat("emergencydecel.warning-threshold");
1215 MSGlobals::gMinorPenalty = oc.getFloat("weights.minor-penalty");
1216 MSGlobals::gTLSPenalty = oc.getFloat("weights.tls-penalty");
1217 MSGlobals::gTurnaroundPenalty = oc.getFloat("weights.turnaround-penalty");
1218
1219 MSGlobals::gModelParkingManoeuver = oc.getBool("parking.maneuver");
1220
1221 MSGlobals::gStopTolerance = oc.getFloat("ride.stop-tolerance");
1222 MSGlobals::gTLSYellowMinDecel = oc.getFloat("tls.yellow.min-decel");
1223 MSGlobals::gUseStopEnded = oc.getBool("use-stop-ended");
1224 MSGlobals::gUseStopStarted = oc.getBool("use-stop-started");
1225
1226 SVCPermissions defaultClasses = 0;
1227 for (const std::string& vClassName : oc.getStringVector("railsignal.default-classes")) {
1228 defaultClasses |= parseVehicleClasses(vClassName);
1229 }
1230 SVCPermissions mBdefaultClasses = 0;
1231 for (const std::string& vClassName : oc.getStringVector("railsignal.moving-block.default-classes")) {
1232 mBdefaultClasses |= parseVehicleClasses(vClassName);
1233 }
1234 MSRailSignalControl::initSignalized(defaultClasses, mBdefaultClasses);
1235 gTaxiClasses = 0;
1236 for (const std::string& vClassName : oc.getStringVector("device.taxi.vclasses")) {
1237 gTaxiClasses |= parseVehicleClasses(vClassName);
1238 }
1239
1240 std::string error;
1241 if (!SUMOVehicleParameter::parseDepartLane(oc.getString("default.departlane"), "options", "",
1244 WRITE_ERROR(error);
1245 }
1246 if (!SUMOVehicleParameter::parseDepartSpeed(oc.getString("default.departspeed"), "options", "",
1249 WRITE_ERROR(error);
1250 }
1251
1252#ifdef _DEBUG
1253 if (oc.isSet("movereminder-output")) {
1254 MSBaseVehicle::initMoveReminderOutput(oc);
1255 }
1256#endif
1257}
1258
1259
1260/****************************************************************************/
long long int SUMOTime
Definition GUI.h:36
#define WRITE_WARNINGF(...)
Definition MsgHandler.h:287
#define WRITE_ERRORF(...)
Definition MsgHandler.h:296
#define WRITE_MESSAGE(msg)
Definition MsgHandler.h:288
#define WRITE_ERROR(msg)
Definition MsgHandler.h:295
#define WRITE_WARNING(msg)
Definition MsgHandler.h:286
#define TL(string)
Definition MsgHandler.h:304
std::vector< std::string > StringVector
Definition of a vector of strings.
Definition Option.h:42
SUMOTime DELTA_T
Definition SUMOTime.cpp:38
bool checkStepLengthMultiple(const SUMOTime t, const std::string &error, SUMOTime deltaT, SUMOTime begin)
check if given SUMOTime is multiple of the step length
Definition SUMOTime.cpp:158
SUMOTime string2time(const std::string &r)
convert string to SUMOTime
Definition SUMOTime.cpp:46
std::string time2string(SUMOTime t, bool humanReadable)
convert SUMOTime to string (independently of global format setting)
Definition SUMOTime.cpp:91
#define TIME2STEPS(x)
Definition SUMOTime.h:60
#define STEPS2MS(x)
Definition SUMOTime.h:62
const int VTYPEPARS_DEFAULT_EMERGENCYDECEL_DEFAULT
const int VTYPEPARS_DEFAULT_EMERGENCYDECEL_DECEL
SVCPermissions parseVehicleClasses(const std::string &allowedS)
Parses the given definition of allowed vehicle classes into the given containers Deprecated classes g...
long long int SVCPermissions
bitset where each bit declares whether a certain SVC may use this edge/lane
int gTaxiClasses
Definition StdDefs.cpp:38
const double INVALID_DOUBLE
invalid double
Definition StdDefs.h:68
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 void initGlobalOptions(const OptionsCont &oc)
init global model parameters
static void init()
Static intialization.
static void insertOptions(OptionsCont &oc)
Inserts options for building devices.
Definition MSDevice.cpp:77
static bool checkOptions(OptionsCont &oc)
check device-specific options
Definition MSDevice.cpp:106
static DepartLaneDefinition & getDefaultDepartLaneDefinition()
Definition MSEdge.h:810
static int & getDefaultDepartLane()
Definition MSEdge.h:814
static void buildStreams()
Builds the streams used possibly by the simulation.
Definition MSFrame.cpp:873
static void setMSGlobals(OptionsCont &oc)
Sets the global microsim-options.
Definition MSFrame.cpp:1151
static void fillOptions()
Inserts options used by the simulation into the OptionsCont-singleton.
Definition MSFrame.cpp:62
static bool checkOptions()
Checks the set options.
Definition MSFrame.cpp:920
static bool gOverheadWireCurrentLimits
Definition MSGlobals.h:127
static double gStopTolerance
The tolerance to apply when matching waiting persons and vehicles.
Definition MSGlobals.h:168
static SUMOTime gTimeToTeleportDisconnected
Definition MSGlobals.h:66
static bool gModelParkingManoeuver
whether parking simulation includes manoeuver time and any associated lane blocking
Definition MSGlobals.h:162
static bool gUseMesoSim
Definition MSGlobals.h:106
static bool gUseStopStarted
Definition MSGlobals.h:134
static double gMinorPenalty
(minimum) time penalty for passing a minor link when routing
Definition MSGlobals.h:155
static SUMOTime gTimeToGridlockHighways
Definition MSGlobals.h:60
static bool gCheckRoutes
Definition MSGlobals.h:91
static double gGridlockHighwaysSpeed
Definition MSGlobals.h:63
static double gWeightsSeparateTurns
Whether turning specific weights are estimated (and how much)
Definition MSGlobals.h:177
static double gTLSPenalty
scaled (minimum) time penalty for passing a tls link when routing
Definition MSGlobals.h:157
static SUMOTime gStartupWaitThreshold
The minimum waiting time before applying startupDelay.
Definition MSGlobals.h:180
static bool gOverheadWireRecuperation
Definition MSGlobals.h:124
static bool gRemoveGridlocked
Definition MSGlobals.h:75
static double gDefaultEmergencyDecel
encoding of the string-option default.emergencydecel
Definition MSGlobals.h:130
static double gTLSYellowMinDecel
The minimum deceleration at a yellow traffic light (only overruled by emergencyDecel)
Definition MSGlobals.h:171
static SUMOTime gTimeToTeleportBidi
Definition MSGlobals.h:69
static double gTurnaroundPenalty
(minimum) time penalty for passing a turnaround link when routing
Definition MSGlobals.h:159
static bool gOverheadWireSolver
Definition MSGlobals.h:121
static double gLateralResolution
Definition MSGlobals.h:100
static bool gSemiImplicitEulerUpdate
Definition MSGlobals.h:53
static int gInsertionChecks
The default value for insertion checks.
Definition MSGlobals.h:186
static SUMOTime gTimeToTeleportRSDeadlock
Definition MSGlobals.h:72
static SUMOTime gTimeToImpatience
Definition MSGlobals.h:78
static bool gStateLoaded
Information whether a state has been loaded.
Definition MSGlobals.h:103
static bool gCheck4Accidents
Definition MSGlobals.h:88
static double gMaxRailSignalBlockLength
The maximum length of a rail signal block.
Definition MSGlobals.h:189
static bool gEmergencyInsert
Definition MSGlobals.h:94
static int gNumSimThreads
how many threads to use for simulation
Definition MSGlobals.h:146
static bool gOmitEmptyEdgesOnDump
Information whether empty edges shall be written on dump.
Definition MSGlobals.h:49
static SUMOTime gIgnoreJunctionBlocker
Definition MSGlobals.h:85
static bool gSublane
whether sublane simulation is enabled (sublane model or continuous lanechanging)
Definition MSGlobals.h:165
static SUMOTime gLaneChangeDuration
Definition MSGlobals.h:97
static bool gMesoLimitedJunctionControl
Definition MSGlobals.h:109
static bool gUseStopEnded
whether the simulation should replay previous stop times
Definition MSGlobals.h:133
static SUMOTime gActionStepLength
default value for the interval between two action points for MSVehicle (defaults to DELTA_T)
Definition MSGlobals.h:118
static SUMOTime gWaitingTimeMemory
length of memory for waiting times (in millisecs)
Definition MSGlobals.h:115
static double gEmergencyDecelWarningThreshold
threshold for warning about strong deceleration
Definition MSGlobals.h:152
static bool gUsingInternalLanes
Information whether the simulation regards internal lanes.
Definition MSGlobals.h:81
static int gNumThreads
how many threads to use
Definition MSGlobals.h:149
static SUMOTime gTimeToGridlock
Definition MSGlobals.h:57
static DepartSpeedDefinition & getDefaultDepartSpeedDefinition()
Definition MSLane.h:1381
static void initCollisionOptions(const OptionsCont &oc)
Definition MSLane.cpp:4535
static double & getDefaultDepartSpeed()
Definition MSLane.h:1385
static void initSignalized(SVCPermissions svc, SVCPermissions mbSvc)
static void init()
Static intialization.
Definition MSStopOut.cpp:44
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.
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)
std::string getString(const std::string &name) const
Returns the string-value of the named option (only for Option_String)
void addSynonyme(const std::string &name1, const std::string &name2, bool isDeprecated=false)
Adds a synonyme for an options name (any order)
bool isDefault(const std::string &name) const
Returns the information whether the named option has still the default value.
bool setDefault(const std::string &name, const std::string &value)
Sets the given value for the named option as new default value.
void doRegister(const std::string &name, Option *o)
Adds an option under the given name.
void addOptionSubTopic(const std::string &topic)
Adds an option subtopic.
bool getBool(const std::string &name) const
Returns the boolean-value of the named option (only for Option_Bool)
const StringVector & getStringVector(const std::string &name) const
Returns the list of string-value of the named option (only for Option_StringVector)
void addXMLDefault(const std::string &name, const std::string &xmlRoot="")
Adds an XML root element to handle by default. The special root "" denotes the default handler.
static OptionsCont & getOptions()
Retrieves the options.
bool isUsableFileList(const std::string &name) const
Checks whether the named option is usable as a file list (with at least a single file)
void addCallExample(const std::string &example, const std::string &desc)
Add a call example.
static bool createDeviceByOption(const std::string &optionName, const std::string &rootElement="", const std::string &schemaFile="", const int maximumDepth=2)
Creates the device using the output definition stored in the named option.
static void insertRandOptions(OptionsCont &oc)
Initialises the given options container with random number options.
static bool parseDepartSpeed(const std::string &val, const std::string &element, const std::string &id, double &speed, DepartSpeedDefinition &dsd, std::string &error)
Validates a given departSpeed value.
static int parseInsertionChecks(const std::string &value)
parses insertion checks
static bool parseDepartLane(const std::string &val, const std::string &element, const std::string &id, int &lane, DepartLaneDefinition &dld, std::string &error)
Validates a given departLane value.
static SUMOTime processActionStepLength(double given)
Checks and converts given value for the action step length from seconds to miliseconds assuring it be...
static StringBijection< SumoXMLTag > CarFollowModels
car following models
static double toDouble(const std::string &sData)
converts a string into the double value described by it by calling the char-type converter
static bool checkOptions(OptionsCont &oc)
checks shared options and sets StdDefs
static void addConfigurationOptions(OptionsCont &oc)
Adds configuration options to the given container.
static void addReportOptions(OptionsCont &oc)
Adds reporting options to the given container.