LCOV - code coverage report
Current view: top level - src/microsim - MSFrame.cpp (source / functions) Coverage Total Hit
Test: lcov.info Lines: 96.9 % 781 757
Test Date: 2026-06-15 15:46:12 Functions: 100.0 % 4 4

            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              : /****************************************************************************/
        

Generated by: LCOV version 2.0-1