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