Train Simulation#
This page describes simulations of trains in SUMO. To build an intermodal simulation scenario with trains, additional steps have to be taken in comparison to a plain vehicular simulation.
Building a network for train simulation#
Railways#
Railways can be imported from OSM. They can also be explicitly specified using the existing vClasses.
Parallel Tracks#
If a railway has parallel tracks, these must be modelled as distinct edge elements instead of a single edge with multiple "lanes".
OSM#
Types#
When importing from OSM the following railway types are distinguished by default (via <SUMO_HOME>/data/typemap/osmNetconvert.typ.xml):
- tram
- subway
- light_rail
- rail
- highspeed
Electrification#
Whenever a railway is electrified, the vClasses rail, rail_electric and rail_fast are permitted to drive there. Otherwise, only vClass rail is allowed.
Usage#
By loading the additional typemap <SUMO_HOME>/data/typemap/osmNetconvertRailUsage.typ.xml, additional usage information is exported for the edge types:
- main
- branch
- industrial
- military
- test
- tourism
This will lead to compound edge type ids such as railway.rail|usage.main.
Track numbers#
Local track numbers (mostly in train stations) are exported as edge parameter track_ref. These values are shown in the edge parameter dialog and can also be used for coloring (color by param, streetwise).
Bidirectional track usage#
In reality all tracks can be used in either direction if the need arises but many rails are used in only one direction most of the time. In SUMO, bidirectional track usage must be enabled explicitly. This simplifies routing as rails will only be used in their preferred direction most of the time.
Bidirectional track usage is modeled by two edges that have their
geometries exactly reversed and using the attribute spreadType="center". This will result
in lane geometries that are overlaid exactly. These edges are referred
to as superposed (alternatively as bidirectional rail edges). In the
.net.xml file these edges are marked with bidi="<REVERSE_EDGE_ID>" but this is a generated
attribute and not to be set by the user.
When Rail signals are placed at both ends of a bidirectional track they will restrict its usage to one direction at a time.
Bidirectional rails in sumo-gui#
Visualization of bidirectional tracks has a distinct style and dedicated settings.
Working with bidirectional tracks in netedit#
- To show both edges that constitute a bidirectional track, activate
  edge visualization option spread bidirectional railways/roads (see visualization settings). Both edges will be
  drawn narrower and with a side-offset to make them both visible
  without overlap.- this is highly recommended when using connection mode to define connections among bidirectional tracks as it's otherwise hard to distinguish the affected edges
- the pre-defined gui setting scheme 'rail' automatically activates the spread ... setting.
 
- To find (and highlight) all bidirectional tracks, use attribute selection and search for attribute bidi with a value of 1
- Create bidirectional tracks as explained here
Routing in bidirectional networks#
When train tracks can be used in both directions, there is considerable freedom for trains when searching a path through the network. To reduce the number of conflicts (when two vehicles want to use the same track in opposite directions), the preferred direction for each track can be defined and factored into the routing decision. There are two ways in which this may be accomplished. They work the same way during network preparation but differ in their effects during simulation. Both methods are discussed below.
Using priority-factor#
This method is suitable for rail-only simulation because the option it uses affects all vehicles in the simulation and may have adverse effects on road traffic. It's advantage lies in it's simplicity because it requires only a single option.
To express routing preferences, the edges in the preferred direction and on the
preferred side may be assigned a higher priority value (using edge attribute priority).
This value will be taken into account during routing when setting option --weights.priority-factor FLOAT  (applicable to
sumo and duarouter).
At the default option value of 0. Edge priority is ignored when routing. When setting a positive value, the edges with the lowest priority receive a penalty factor to their estimated travel time of 1 + FLOAT (where FLOAT is the option argument) whereas the edges with the highest priority receive no penalty. Edges with medium priority will receive an intermediate penalty according to the following code:
 MinEdgePriority : minimum priority value of all edges
 MaxEdgePriority : maximum priority value of all edges
 EdgePriorityRange = MaxEdgePriority - MinEdgePriority
 relativeInversePrio = 1 - ((edgePriority - MinEdgePriority) / EdgePriorityRange)
 effort =  traveltime * (1 + relativeInversePrio * PriorityFactor)
Note
When either trains or road vehicles are routed only outside the simulation this method can also be used for combined simulations by (by routing trains and cars separately and only using the option for train routing).
Using routingType and preference definitions#
This method is suitable for multi-modal simulations where road and rail vehicles must be routed in the same simulation. It also permits distinguishing fine-grained routing preferences (i.e. between regular rail service which adheres to the default directions and special service vehicles that may use any track in either direction).
To express routing preferences, each rail edge should have it's routingType set corresponding to it's status as being in the main direction or in reverse to the main direction. While routingType may be an arbitrary string value, the existing netconvert tooling supports setting a routingType that takes on string values between '4' and '0' where '4' corresponds to the main direction and '0' to the reverse of the main direction (with values in between denoting different levels of certainty about directionality).
The effect that each routingType takes during routing is expressed by loading <preference> elements from an additional file:
During routing, the estimated travelTime of an edge with the given routingType is divided by the given priority value for an applicable vClass (or vType).
The following example has the same effect as setting option weights.priority-factor 1 (but only applies to vClass rail).
<additional >
    <preference routingType="4" vClasses="rail" priority="1"/>
    <preference routingType="3" vClasses="rail" priority="0.8"/>
    <preference routingType="2" vClasses="rail" priority="0.67"/>
    <preference routingType="1" vClasses="rail" priority="0.57"/>
    <preference routingType="0" vClasses="rail" priority="0.5"/>
</additional>
The following example has the same effect as setting option weights.priority-factor 3 (but only applies to vTypes train1 and train2).
<additional >
    <preference routingType="4" vTypes="train1 train2" priority="1"/>
    <preference routingType="3" vClasses="rail" priority="0.57"/>
    <preference routingType="2" vClasses="rail" priority="0.40"/>
    <preference routingType="1" vClasses="rail" priority="0.31"/>
    <preference routingType="0" vClasses="rail" priority="0.25"/>
</additional>
Setting edge priority and routingType#
The priority and corresponding routingType values can either be assigned by the user or computed heuristically by netconvert as explained below.
Note, that in both heuristics each railway edge will have their priority attribute set and it's routingType will be set equal the numerical priority value (converted to a string).
Priority from partially restricted directionality#
If some of the tracks in the network are uni-directional these can be used to define the main direction and this property can be extrapolated based on geometry (straightness) and topology (switches) onto the rest of the network This is done by setting the option --railway.topology.direction-priority. The assigned priority values are:
- 4: unidirectional track
- 3: main direction of bidirectional track
- 2: undetermined main direction (straight continuation from different directions of unidirectional track)
- 1: undetermined main direction (no continuation from unidirectional track)
- 0: reverse of main direction of bidirectional track
Priority from partially defined values#
If some of the tracks in the network have priority values defined (by convention with the values 0 and 4) these can be used to define the main direction and this property can be extrapolated based on geometry (straightness) and topology (switches) onto the rest of the network This is done by setting the option --railway.topology.extend-priority. The assigned priority for the other network edges also range from 1 to 3 just as above.
Importing bidirectional tracks from OSM#
When importing networks from
OSM, rails tagged with railway:preferred_direction:both are
automatically imported as superposed edges.
Handling Problems in bidirectional railway networks#
Commonly, rail networks import from OSM are incomplete in regard to bidirectional track usage. One example would be terminal tracks which a train can only leave by reversing direction. netconvert provides several options to deal with this problem:
- --railway.topology.output <FILE>: Identify problematic tracks (i.e. for manual correction).
- --railway.topology.repair : Automatically fixes problems by analyzing rail network topology and adding bidirectional tracks
- --railway.topology.repair.minimal : Apply automated fixes but only those which are needed for the operation loaded public transport lines
- --railway.topology.repair.connect-straight : Allow bidirectional rail use wherever rails with opposite directions meet at a straight angle
- --railway.topology.repair.stop-turn : Add turn-around connections at all loaded stops (to enable direction reversal).
- --railway.topology.all-bidi : make all tracks usable in both directions.
- --railway.topology.all-bidi.input-file : Load edge ids from text file and make those tracks usable in both directions. (one edge id per line, optionally prefixed with 'edge:' as in a selection file created with netedit).
Rail Signals#
Definition#
The node type
rail_signal may be used to define signals which implement Automatic Block
Signaling.
When working with bidirectional tracks, rail signals will affect both directions of travel by default. This can be changed in netedit or by patching with a connection file with attribute uncontrolled.
Import#
When importing rail networks from OSM, the rules for what counts as a rail signal can be customized to adapt to the local level of database detail.
By setting the netconvert-option --railway.signals.discard all signals can be removed from a network.
Heuristic generation#
By setting the netconvert-option --railway.signal.guess-by-stops, additional signal based on loaded public transport stops. Stops are either loaded from the input (i.e. OSM) or with option --ptstop-files.
For each public transport stop, at most two signals will be added:
- a signal at the end of the stop edge (unless the node happens to be a switch)
- a signal at the start of the stop edge or the next upstream edge that is at least 200m upstream of the stop edge end (unless the node happens to be a switch)
The minimum distance of 200m between the two signals can be customized with option --osm.stop-outout.length.train.
Rail Crossings#
The node type
rail_crossing may be used to define railway crossings. At these nodes trains will
always have the right of way and road vehicles get a red light until
there is a safe gap between approaching trains.
When importing networks from OpenStreetMap, rail crossings will be imported automatically. For other input data sources the crossings may have to be specified via additional xml files or set via netedit after importing.
Rail Crossing Parameters#
The following parameters may be defined in an additional file to configure timing and behavior of a rail crossing (example below). Time values are in seconds.
- time-gap : time headway of approaching train that triggers closing the crossing (default 15)
- space-gap : space headway of approaching train that triggers closing the crossing (default -1, which disables this check)
- min-green-time : minimum green time for opening the crossing when another train is approaching (default 5)
- opening-delay : time after train has passed the crossing before the opening sequence starts (default 3)
- opening-time : time for opening the crossing (indicated by red-yellow state 'u') (default 3)
- yellow-time : time for closing the crossing (default 3)
When setting parameters, id indicates the id of the rail-crossing junction and programID is always '0'.
<additional>
    <tlLogic id="C" programID="0">
        <param key="time-gap" value="15.0"/>
        <param key="space-gap" value="-1.0"/>
        <param key="min-green-time" value="5.0"/>
        <param key="opening-delay" value="3.0"/>
        <param key="opening-time" value="3.0"/>
        <param key="yellow-time" value="5.0"/>
    </tlLogic>
</additional>
Kilometrage (Mileage, Chainage)#
Edges support the attribute distance to denote the distance at the start of the edge relative to some point of reference for a linear referencing scheme. When the distance metric decreases along the forward direction of the edge, this is indicated by using a negative sign for the distance value.
The distance value along an edge is computed as:
  |edgeDistance + vehiclePos|
Edge distance is imported from OSM and can also be be set along a route in netedit
The distances value can be written in fcd-output using option --fcd-output.distance. It may then be used for plotting by plot_trajectories.py using the code k (i.e. -t kt). The distances can also be visualized in sumo-gui (color edges by distance).
Note
Negative distance values are not currently supported (pending introduction of another attribute)
Modelling Trains#
There is a dedicated carFollowMode for trains which can be activated by
setting carFollowModel="Rail" trainType="<TYPE>" in the <vType> definition. Allowed values for trainType are
- Freight
- ICE1
- ICE3
- RB425
- RB628
- REDosto7
- NGT400
- NGT400_16
- MireoPlusB
- MireoPlusH
- custom
These types model traction and rolling resistance for particular trains. To represent the behavior of arbitrary trains, the "custom" trainType may be used (see below). Alternatively, any other car following model may be used and configured with appropriate acceleration / deceleration parameters.
Custom dynamics model with tabular data#
The vType attributes speedTable, tractionTable and resistanceTable can be used to specify a custom interpolation table for traction and resistance.
Each attribute is interpreted as a table column where the rows defines the traction and resistance for the corresponding speed.
The speeds must be given in m/s whereas the traction and resistance forces are in kN. Intermediate values are obtained by linear interpolation.
Example:
    <vType id="0" vClass="rail" carFollowModel="Rail" trainType="custom"
           speedTable="0 2.78 5.56 8.33 11.11 13.89 16.67 19.44 22.22 25 27.78 30.56 33.33"
           tractionTable="300 300 263 179 135 108 90 77 67.5 60 54 49 45"
           resistanceTable="2 4 8.5 14 22 31 41.5 54 68 83.5 111 120 140"/>
Custom dynamics model with parameterized curves#
The vType attributes maxPower and maxTraction can be used to specify the traction curve for a given speed (in m/s) according to the formula:
traction_kN = min(maxPower / speed, maxTraction
The vType attributes resCoef_quadratic, resCoef_linear and resCoef_constant can be usd to specify the resistance curve for a given speed (in m/s) according to the formula:
resistance_kN =  resCoef_quadratic * speed * speed + resCoef_linear * speed + resCoef_constant
Example:
   <vType id="0" vClass="rail" carFollowModel="Rail" trainType="custom" maxPower="2350" maxTraction="150"
        resCoef_quadratic="0.00028" resCoef_linear="0.00003" resCoef_constant="1.670"/>
The attributes
Train Schedules#
Train schedules are defined in the same way as for any other type of public transport.

Generated by plotXMLAttributes.py.
Train Interaction#
When simulation trains on a network with railway signals, trains will
only enter a block (a section of edges between signals) if it is free of
other trains. When there are no rail signals or multiple trains have
been inserted in the same block, they will automatically keep a safe
distance according to their car following model. When using carFollowModel="Rail", trains
will always keep enough distance to the leading train to come to a safe
stop even if the lead train was to stop instantly.
Reversing Direction#
Trains will reverse direction if all of the following conditions are met:
- The head of the train is on a normal edge (not on an intersection / railway switch)
- The whole length of the train is located on rail-edges that allow bidirectional use.
- The speed of the train is below 0.1m/s.
- The train does not have any further stops on the current edge
- The succeeding edges in the train's route are the reverse-direction edges of those it is currently on
- 
There is a "turn-around" connection from the current train edge to the reverse direction edge Note When importing public transport stops with option --ptstop-output, all bidirectional edges with a public transport stop will have the necessary turn-around connection and thus be eligible for reversing. 
Caution
Undesirable train reversals may occur due to invalid stop assignment (i.e. assigning the reverse stop). The tool checkReversals.py can be used to search for unexpected reversals.
Portion working#
Trains can be split and joined (divided and coupled) at stops. If a person or container travels in a train that is split or joined and wants to continue traveling in the new part, it requires a distinct <ride> or <transport> element in it's plan. No delay for boarding or loading will occur in the simulation for this.
Splitting a train#
To split a train, the following input definition can be used. The rear half of the train is defined as a new vehicle which depart value split. The train train that is being split must define the 'split' attribute in its stop definition referencing the id of the rear half.
   <vType id="train" vClass="rail"/>
    <vType id="splitTrain" vClass="rail" length="50"/>
    <trip id="t0" type="train" depart="0.00" from="a" to="c">
        <stop busStop="B" duration="60.00" split="t1"/>
    </trip>
    <trip id="t1" type="splitTrain" depart="split" from="b" to="e">
        <stop busStop="B" duration="60.00"/>
    </trip>
When defined this way, The rear part of the train will be created as a new simulation vehicle once the first part has reached the stop. After stopping, The front half of the train will continue with reduced length.
If the vehicle that is split if (with depart="split") uses attribute departPos="splitFront" it will instead be inserted at front and the part that keeps its id will be positioned in the rear.
Joining two trains#
To join two trains, they have to stop at in close proximity (i.e. at the same <busStop> or <trainStop>) and then one of them is removed (referred to as the joining train) and the other made longer (referred to as the continuing train.
The continuing train requires a stop with attribute triggered="join". By default this train will only continue its route after another train has joined with it and wait indefinitely for this condition.
However, by setting stop attribute extension, waiting for the trigger condition can be aborted (as for any other condition).
The joining train requires a stop with attribute join="VEH_ID" where VEH_ID denotes the id of the continuing train.
The joining operating consists of having the joining train arrive and disappear from the simulation and the continuing train to be made longer according to the length of the joining train. The following conditions must be met for the joining operation to take place:
- the continuing train has fulfilled its stopping duration (defined by attributes durationanduntil)
- the joining train has fulfilled its stopping duration (defined by attributes durationanduntil)
- the trains are in close proximity in either of the two ways:- the continuing train has its back is on the same lane as the joining train and the gap between them is less than the minGap of the joining train +1m
- the joining train has its back on the same lane as the continuing train and the gap between the trains is less the minGap of the continuing train +1m
 
The following is an example definition for joining two trains:
    <vType id="train" vClass="rail"/>
    <vType id="splitTrain" vClass="rail" length="50"/>
    <trip id="t0" type="splitTrain" depart="0.00" from="a" to="c">
        <stop busStop="B" duration="60.00" triggered="join"/>
    </trip>
    <trip id="t1" type="splitTrain" depart="30" from="d" to="b">
        <stop busStop="B" duration="5.00" join="t0"/>
    </trip>
Caution
if the joined train is in the front and covers multiple edges, then these must all match the route of the continuing train. Also the joining train should have the join-stop on the last edge of its route.
Rail Signal Behavior#
Rail signals perform the following safety functions automatically
- a) guard the track up to the next rail signal (signal block) so that only one train can enter this section at a time. This prevents rear-end collisions.
- b) guard the track so that vehicles from different branches (flanks) cannot enter the same section. This prevents flanking collisions.
- c) guard the track so that vehicles cannot enter bidirectional sections at the same time. This prevents head-on collisions.
- d) prevent deadlocks on bidirectional sections
Functionality a) corresponds to the "classic" safety behavior of rail signals (PZB). When option --railsignal-moving-block is set or individual signals are configured with parameter moving-block (see below), feature a) is disabled and trains will use their configured carFollowModel (i.e. 'Rail') for distance keeping. This is similar to the LZB safety system when used with extremely short virtual blocks.
To switch a signal into moving-block-mode, the following additional file may be loaded:
<additional xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://sumo.dlr.de/xsd/additional_file.xsd">
    <tlLogic id="gneJ8" programID="0">
        <param key="moving-block" value="true"/>
    </tlLogic>
</additional>
Parameter moving-block may also be updated at runtime with traci.trafficlight.setParameter.
Schedule Constraints#
Additionally, rail signals can enforce train ordering to ensure that a scheduled order at stations can be kept. To make use of this, the following elements can be loaded from an additional file:
   <railSignalConstraints id="A">
        <predecessor tripId="t0" tl="D" foes="t1" limit="2"/>
        <predecessor tripId="t0" tl="C" foes="t2"/>
        <insertionPredecessor tripId="t3" tl="E" foes="t4"/>
    </railSignalConstraints>
predecessor constraint#
This constrain defines that a given vehicle id (or tripId) can only pass the current signal after some other vehicle ('foe') with the given id or tripId has passed signal 'tl'. The foe vehicle must have been the last vehicle to do so or it must have been one of the last 'limit' vehicles at the time of switching green.
insertionPredecessor constraint#
This constrain defines that a given vehicle id (or tripId) can only be inserted on the block leading up to the current signal after some other vehicle ('foe') with the given id or tripId has passed signal 'tl'. The foe vehicle must have been the last vehicle to do so or it must have been one of the last 'limit' vehicles at the time of switching green.
Constraint Attributes#
| Attribute Name | Value Type | Description | 
|---|---|---|
| tripId | id (string) | The 'tripId' param of a vehicle or the id of a vehicle to which this constraint applies | 
| tl | id (string) | The id of a railSignal | 
| foes | ids (string list) | The ids of one or more vehicles that must have passed tl before the parent rail signal permits tripID to pass | 
| limit | int | The number of intermediate vehicles that may pass tl after the foes before the constraint is evaluated for tripId. default: number of given foes. (setting a high number has now downside besides memory use but setting a low number may cause the constraint to block tripId indefinitely because the ids of the passed foes were overwritten by later trains) | 
| active | bool | Whether this constraint is active (inactive constraints may still be retrieved via TraCI) | 
constraints generation#
Constraints can be generated using the tool generateRailSignalConstraints.py by using a route file with stops that define a schedule.
Deadlocks#
If the graph of relationships between trains that wait for another train ever forms a circle, then no train can ever advance and the simulation is in a state of deadlock. The default behavior of rail signals is to anticipate most such problems and prevent a train from passing a signal if that movement would form a deadlock. However, the default logic only handles the most common cases that involve two or three trains (and a few situations with four trains).
- Deadlocks may appear from an interplay of four or more trains.
- The signal logic does not prevent deadlocks that involve loaded signal constraints
To deal with deadlock problems, the simulation provides multiple strategies explained in the following.
Deadlock detection#
By setting option --time-to-teleport.railsignal-deadlock TIME deadlocks are detected if one of the vehicles involved has been waiting for the given TIME. If option --deadlock-output FILE is also set, then any detected deadlocks will be written to the given file.
Note
It is recommended to also set option --time-to-teleport -1 to disabled teleporting based on waiting time since, trains may sometimes have to wait much longer than cars (which teleport after 300s by default).
Deadlock resolution#
In case a deadlock is detected, the vehicle that has been waiting in this deadlock for the longest time will be teleported to the next available network edge to break the deadlock. If option --time-to-teleport.remove is set, the vehicle will instead be removed from the simulation.
By setting option --time-to-teleport.remove-constraint, a constraint involved in the deadlock will be deactivated to break the deadlock rather than teleporting or removing a vehicle. This option is highly recommended when working with constraints. But doesn't take effect otherwise.
If option --deadlock-output FILE is set, then the deactivated constraint will also be included in the recorded deadlock.
Deadlock prevention#
The prevent complex deadlocks that happened without the use of constraints, the recorded deadlocks from a previous simulation can be loaded as an additional file. This will selectively add additional checks to the rail signal logic to prevent any deadlock constelation among the list of signals that were part of the recorded deadlocks.
Caution
The deadlock file must be loaded before any trains (which is only an issue if trains are loaded with option --additional-files).
TraCI#
Rail signals and rail crossings can be controlled with function traci.trafficlight.setRedYellowGreenState. They can also be switched off with traci.trafficlight.setProgram(tlsID, "off"). In either case, normal operations can be resumed by reactivating the default program "0": traci.trafficlight.setProgram(tlsID, "0").
Trains can be controlled just like cars by using the traci.vehicle functions. Furthermore the following functions are available for rail signals:
- traci.trafficlight.getBlockingVehicles(tlsID, linkIndex): Returns the list of vehicles that are blocking the subsequent block for the given tls-linkIndex from the perspective of the closest vehicle upstream of the signal
- traci.trafficlight.getRivalVehicles(tlsID, linkIndex): Returns the list of vehicles that also wish to enter the subsequent block for the given tls-linkIndex (regardless of priority) from the perspective of the closest vehicle upstream of the signal
- traci.trafficlight.getPriorityVehicles(tlsID, linkIndex): Returns the list of vehicles that also wish to enter the subsequent block for the given tls-linkIndex (only those with higher priority) from the perspective of the closest vehicle upstream of the signal
Constraints#
Constraints can be queried and modified via TraCI:
- getConstraints(tlsID, tripId=""): Returns the list of rail signal constraints for the given rail signal. If tripId is not "", only constraints with the given tripId are returned. Otherwise, all constraints are returned
- getConstraintsByFoe(foeSignal, foeId=""): Returns the list of rail signal constraints that have the given rail signal id as their foeSignal. If foeId is not "", only constraints with the given foeId are returned. Otherwise, all constraints are returned
- addConstraint(tlsID, tripId, foeSignal, foeId, type=0, limit=0): add constraint with the given values (type 0 is a predecessor constraint, 1 insertion predecessor, 2 foe insertion, ...)
- swapConstraints(tlsID, tripId, foeSignal, foeId): Reverse the given constraint and return list of new constraints that were created (by swapping) to avoid deadlock.
- removeConstraints(tlsID, tripId, foeSignal, foeId): remove constraints with the given values. Any combination of inputs may be set to "" to act as a wildcard filter """
- updateConstraints(vehID, tripId=""): remove any constraints related to the given tripId if the vehicle with the given vehID no longer passes the respective rail signals (i.e. after rerouting).- if tripId is the empty string, the current tripId param of the vehicle is used
- if the tripId would have changed in the part of the route affected by rerouting, the function must be called once for each individual tripId involved.
 
Visualization#
Trains#
The length of railway carriages, locomotive and the gap between the carriages can be configured using the following generic vType parameters:
- locomotiveLength
- carriageLength
- carriageGap
- carriageImages
These parameters control the appearance of trains in sumo-gui when drawing vehicles with the style 'simple shapes'.
By default, the front of the train will be indicated by a darker carriage color and a front windscreen. This can be disabled by setting locomotiveLength="0".
The parameter carriageImages accepts a comma-separated list of image file names to enable distinct images when using vehicle style 'raster images'.
Network#
By default, railway tracks are shown in sumo-gui in a distinct style:
- tracks and crossties are rendered instead of filled shapes when zoomed in (configurable with visualization setting show rails)
- turning arrows are not shown
- the white bar that indicates right of way is not drawn
- junction shapes are not shown and the internal edges that make up a railway switch are always visible (can be changed setting junction coloring to any scheme other than uniform)
- traffic light (rail signal) indicators are drawn with an offset to the right to indicate the direction in which the signal is applied
- for each pair of edges that make up a bidirectional track, only of is drawn to avoid artifacts. To make both edges visible (i.e. for selecting or otherwise interacting with that edge), the visualization setting spread bidirectional railways/roads in the Streets tab can be activated
- the pre-defined gui setting scheme "Rail" can be used to activate the following settings that are helpful for diagnosing a railway simulation- spread bidirectional railways/roads
- coloring junctions by type (making rail signals more visible)
- constant junction size (making rail signals bigger when zoomed out)
- show lane direction (direction is otherwise hard to judge for uni-directional tracks)
- vehicles are shown as simple shapes to ensure articulated train shapes follow curves
 
Signaling#
Rail signal states are shown in sumo-gui as red or green colored bars which are offset towards the righthand side of the track in driving direction. The offset thus indicates the direction of movement to which the signal applies.
The following Objects provide extra information in their context menu to help understand signal switching:
- rail_signal / tlLogic (accessible by right-clicking on the red/green bar)- req driveway: The driveWay request by the closest approaching vehicle
- blocking: The list of foe vehicles which are blocking the requested driveway
- blocking driveways: The list of foe driveways which are blocking the requested driveway
- rival: The list of potential foe vehicles that are approaching a foe driveway
- priority: The list of foe vehicles that are approaching a foe driveway and have received priority over the vehicle that approaches the requested driveway
- constraint: A description of the railSignalConstraint which applies to the closest approaching vehicle and causes this signal to show red
 
- vehicle- driveways: The list of driveways which this vehicle currently occupies
 
- lane- param:insertionBlocked:VEHICLE_ID: The driveway requested by VEHICLE_ID on which insertion is currently blocked
- blocking DRIVEWAY_ID: The list of foe vehicles which are blocking the insertion driveway with DRIVEWAY_ID
- driveWays blocking DRIVEWAY_ID: the list of foe driveways which are blocking the requested driveway with DRIVEWAY_ID
 
Note
Street coloring mode by insertion backlog helps to identify the tracks on which insertion is currently blocked.
Abstract Networks#
Road networks are most often modelled according to their actual layout in cartesian space. Such networks have all distances and angles in the same proportions as those of geographical map.
In the railway domain it is often useful to work with schematic (also called abstract) networks instead of (or in addition to) geographical networks. Such abstract networks can make it easier so see all tracks and switches on a single screen without zooming and panning. SUMO supports working with abstract maps in the following ways:
- all roads and tracks can have a custom "length" value that differs from their visual length. This allows to separate the visualization of the network from its simulation behavior (w.r.t. distance traveled).
- sumo-gui supports loading an abstract map of a network along with a geographical map by using options -n geo.net.xml -N abstract.net.xml. The two networks must have the exact same topology and may only differ in their geometry.- The user may switch between the visualization of either geometry via the hotkey Ctrl + K or by setting Street visualization setting secondary shape.
- All outputs that include geometry information (i.e. fcd-output) will be according to the network loaded with option -n
 
- the tool abstractRail.py can be used to convert geographic rail networks in abstract rail networks
Outputs#
Rail simulation provides optional outputs related to driveways (Fahrstraßen)
railsignal-block-output#
By setting option --railsignal-block-output FILE, an output file that contains informations for every drivway / signaling block is written.
| Element / Attribute Name | Value Type | Description | 
|---|---|---|
| driveway / id | id (string) | The if of the driveWay. See below for interpretation | 
| driveway/ vehicle | id | The id of the first train that used this driveWay | 
| driveway / edges | list of edgeIDs | The complete route of the vehicle that first used this drivway | 
| forward / lanes | list of laneIDs | The list of lanes up to the next signal or the network border | 
| bidi / lanes | list of laneIDs | The list of oncoming lanes that are in conflict with this driveway | 
| flank / lanes | list of laneIDs | The list of flanking lanes that are in conflict with this driveway | 
| conflictLinks / signals | list of strings | The list of short signal link names ( | 
| foes / driveways | list of driveWay ids | The list of foes driveways. A train may not enter a driveway if any of it's foe driveways is occupied (unless a <siding>definition exists for that foe and the siding is currently usable). | 
| sidings / foe | driveWay id | The foe driveWay to which the following list of <siding>elements applies | 
| siding / start | edgeID | The edge on which that siding starts | 
| siding / end | edgeID | The edge on which that siding ends | 
| siding / length | float | The length of the siding in meters (a Train may not use a siding if it is shorter than it's own length) | 
| deadlock / foes | list of driveWay ids | The list of foe driveways that could create a deadlock toghether with the current driveway. If all foes are occupied, the current driveway must not be entered (only present when <deadlock>elements where loaded into the simulation | 
Driveway IDs#
- normal driveway: <RAIL_SIGNAL_ID>.<INDEX>
- depart driveway: <JUNCTION_ID>.d<INDEX>
- subDriveway (Teilfahrstraße): <DRIVEWAY_ID>.<INDEX>
railsignal-vehicle-output#
By setting option --railsignal-vehicle-output FILE, an output file that contains occupancy informations for every driveway is written. This file provides the times whenever a vehicle has entered or left a driveway.
| Element / Attribute Name | Value Type | Description | 
|---|---|---|
| driveWay / id | id (string) | The driveWay to which the following <entry>and<exit>elements apply | 
| subDriveWay / id | id (string) | The driveWay to which the following <entry>and<exit>elements apply | 
| entry / id | id (string) | The id of the vehicle that entered the driveway | 
| entry / time | float or HH:MM:SS | The time at which the vehicle entered the driveWay | 
| entry / reason | string | The reason for entering the driveWay | 
| exit / id | id (string) | The id of the vehicle that left the driveway | 
| exit / time | float or HH:MM:SS | The time at which the vehicle left the driveWay | 
| exit / reason | string | The reason for leaving the driveWay | 
Miscellaneous#
- Error checking for railway schedules can be done with the tool checkStopOrder.py
- The tool scheduleStats.py can be used to check how closely simulated train behavior conforms to a loaded rail schedule w.r.t. punctuality and expected traveltimes between stops.
Limitations#
- Individual rail cars / coupling / uncoupling cannot currently be modeled
- Distant signals (Vorsignale) are not modelled. Instead trains act as if always having full visibility onto the next main signal
- Delay of railroad switches is not modelled
- Overlap (Durchrutschweg) after a rail signal (which guarantuess safety if a red signal is violated), is currently not modelled by the rail signal safety assessment
- Axle counters are assumed after every signal and every railway switch and correspondingly, partial driveways (Teilfahrstraßen) are used in the most efficient manner
- Stretching and shorting of long trains is not modelled
- Operational restrictings on reversing trains (Shunting) are not modelled. Trains may reverse according to their defined route and move at normal speeds / acceleration in either direction (subject to rail signal safety rules).
