Developers: Tom Peham and Robert Wille
The European Train Control System (ETCS) strives to harmonize and improve train control systems throughout Europe. One particular aspect is the utilization of virtual subsections which allow for a much higher degree of freedom and provide significant potential for increasing the efficiency in today’s train schedules. However, exploiting this potential is a highly non-trivial task which, thus far, mainly relied on manual labor. In our work at the Chair for Design Automation of the Technical University of Munich, we aim for introducing methods for design automation which aid designers of corresponding railway networks and train schedules.
In a first attempt (described in [1]), we developed an initial solution which utilizes satisfiability solvers to generate, verify, and optimize train layout and/or schedules. In a follow-up work we used an improved method for optimizing schedules with the added freedom of Virtual Subsections (described in [2]
[1] Robert Wille and Tom Peham and Judith Przigoda and Nils Przigoda. "Towards Automatic Design and Verification for Level 3 of the European Train Control System". Design, Automation and Test in Europe (DATE), 2021 (pdf)
[2] Tom Peham and Judith Przigoda and Nils Przigoda and Robert Wille. "Optimal Railway Routing Using Virtual Subsections". Reliability, Safety and Security of Railway Systems (RSSRail), 2022 (pdf)
If you have any questions, feel free to contact us via etcs.cda@xcit.tum.de or by creating an issue on GitHub.
The package has been tested under Linux (Ubuntu 18.04, 64-bit) and should be compatible with any current version of g++ supporting C++17 and a minimum CMake version of 3.13. The project also requires the Z3 theorem prover. It can be installed in any of the following ways:
- Under Ubuntu 18.04 and newer:
sudo apt install z3
- Download pre-built binaries from https://github.com/Z3Prover/z3/releases and copy the files to the respective system directories
- Build Z3 from source and install it to the system
To build the tool go to the project folder and execute the following:
- Configure CMake
cmake -S . -B build -DCMAKE_BUILD_TYPE=Release
- Build the respective target.
cmake --build ./build --config Release
To use the tool from [1] run
./da_etcs_sat [option] <input file>
Options can be:
-f ... verify given schedule, no layout generation
-s ... verify schedule, layout generation
-o ... optimize schedule, layout generation
If no options are given then all design tasks will be performed in that order.
To use the tool from [2] run
./da_etcs_astar <input file>
The input file describes the track layout as an undirected graph and the train schedule. For now, however, you will find the current BNF of the file format given below. The example-folder contains some examples (in fact, the examples used in [1]). Moreover, the file runningExample_annotated.txt in the example-folder also includes an annotated version, which hopefully helps in getting an idea of the format.
#> input_file ::== [integer] [integer] nl nl (track nl)* nl [fork nl]* nl (train)* (*number of nodes, max timesteps, ...*)
#> track ::== edge integer integer integer integer (*edge, length, speed limit, ttd*)
#> fork ::== node node node
#> train ::== integer integer integer edge nl (stop nl)* nl (*speed, length, departure time, start edge, ...*)
#> node ::== 0 | 1 | ... | number_of_nodes-1
#> edge ::== node node
#> stop ::== integer edge (*arrival time, stop edge*)
#> nl ::== newline
Please note, that the A* based version from [2] uses a slightly different input format (as can be seen in the benchmark folder). These input formats will be unified in a future release soon.
#> output_file ::== ("SAT" nl (vss nl)* nl (route nl)* ) | "UNSAT""
#> vss ::== node* (*nodes belonging to same vss*)
#> route ::== 0 ": " edge* nl | ... | maxTime-1 ": " edge* nl (*train routes are ordered the same as trains in input file*)
If you use our tool for your research, we would be thankful if you referred to it by citing the following publications:
@inproceedings{wille2021etcs,
title={Towards Automatic Design and Verification for Level 3 of the European Train Control System},
author={Robert Wille and Tom Peham and Judith Przigoda and Nils Przigoda},
booktitle={Design, Automation and Test in Europe (DATE)},
year={2021}
}
@inproceedings{peham2022etcs,
title={Optimal Railway Routing Using Virtual Subsections},
author={Tom Peham and Judith Przigoda and Nils Przigoda and Robert Wille},
booktitle={Reliability, Safety and Security of Railway Systems (RSSRail)},
year={2022}
}