This repository contains the source code used in the computational experiments of the paper: Traffic Signal Control under Stochastic Traffic Demand and Vehicle Turning via Decentralized Decomposition Approaches.
We build a two-stage stochastic program based on the Cell Transmission Model (CTM) for traffic signal control under stochastic traffic conditions. We design a distributed algorithm combining ADMM and Benders decomposition to solve the model. Here is the detailed code.
Traffic Signal Control under Stochastic Traffic Demand and Vehicle Turning via Decentralized Decomposition Approaches
Xinyu Fei, Xingmin Wang, Xian Yu, Yiheng Feng, Henry Liu, Siqian Shen, Yafeng Yin
European Journal of Operational Research, 2023@article{fei2023traffic, title={Traffic signal control under stochastic traffic demand and vehicle turning via decentralized decomposition approaches}, author={Fei, Xinyu and Wang, Xingmin and Yu, Xian and Feng, Yiheng and Liu, Henry and Shen, Siqian and Yin, Yafeng}, journal={European Journal of Operational Research}, volume={310}, number={2}, pages={712--736}, year={2023}, publisher={Elsevier} }
- Python >= 3.8 (our test is based on Python 3.8)
- Libraries:
- gurobipy
- matplotlib
- networkx
- numpy>=1.20.3
- osmnx
- scipy
- tqdm
- Clone the repository
- Set up a virtual environment (optional)
- Install dependencies by
pip install -r requirements.txt
You can test our synthetic data instances by running
python fake_instance_main.py
- If you want to test your own instances, you can set your own osm map file as input. You can also change the number of scenarios, ADMM iterations, and Benders decomposition iterations. An example command line is
python fake_instance_main.py --mapfile="map_data/fake_instance/1-8.osm" \
--scenario=20 --numadmm=10 --numbenders=4
- If you want to generate a baseline signal plan, you can call function
for node_id, node in fake_instance_simulator.nodes.items():
if node.type == "signalized":
fake_instance_simulator.generate_naive_signal_plan(node_id)
- If you want to simply run the evaluation of a given traffic signal plan, you can comment the following lines and
rerun the file
fake_instance_main.py
fake_instance_optimizer.run()
fake_instance_optimizer.draw_signal()
- If you want to solve the centralized two-stage stochastic program directly by Gurobi, please follow the commands:
cd opt/centralized
python Gurobi_Stochastic.py
You can change the synthetic network size and other parameters in opt/centralized/data_global.py
.
Here is the layout of this repository.
ctm-signal-opt-sharing/
|- apps
|- evaluate_signal.py
|- ctm
|- build_ctm.py
...
|- map_data
|- fake_instance
|- 1-1.osm
...
|- mtldp
|- apps
|- mtlmap
|- tools
|- opt
|- centralized
|- ADMM_optimizer.py
...
fake_instance_main.py
apps
: the function to evaluate a given traffic signal planctm
: all the functions to build a ctm modelmap_data
: our sample synthetic datamtldp
: our tools to generate and read osm map filesopt
: our optimizer algorithm code, including centralized version in the foldercentralized
, and decentralized algorithms.
Xinyu Fei (xinyuf@umich.edu), for algorithms and CTM model
Xingmin Wang (xingminw@umich.edu), for data processing and CTM model
Xinyu Fei (xinyuf@umich.edu)
Siqian Shen (siqian@umich.edu)