This project provides a solution to the Hierarchical Directed Capacitated Arc Routing Problem (HDCARP).
The project implements multiple approaches:
- Exact methods for solving smaller instances.
- Meta Heuristic algorithms (ea, aco, ils).
- Hybrid algorithm combining Reinforcement Learning (RL) and heuristics.
The project is organized into several directories:
hdcarp/
├── baseline/
│ ├── aco.py # aco algorithm
│ ├── ea.py # ea algorithm
│ ├── ils.py # ea algorithm
│ ├── rl_hyb.py # HRDA algorithm
│ ├── lp.py # exact method
│ ├── meta.py # implemented code of Meta Heuristic algorithms
├── common/
├── env/
│ ├── env.py # Environment setup for the routing problem
│ ├── generator.py # Problem instance generator
├── policy/
│ ├── context.py # Contextual features for the RL model
│ ├── encoder.py # Encoding components
│ ├── decoder.py # Decoding components
│ ├── init.py # Model initialization functions
│ ├── policy.py # Policy network for RL
├── rl/
│ ├── critic.py
│ ├── ppo.py # Proximal Policy Optimization (PPO) algorithm
│ ├── policy.py # Policy network for RL
│ ├── trainer.py
├── .gitignore # Git ignore file
├── requirements.txt # Python dependencies
├── train.py # Main script to start training the models
├── README.md # Project documentation
├── LICENSE # License information
To install the required dependencies, run:
pip install -r requirements.txt
python3 data/gen.py
python3 baseline/ils.py --data_path "data/instances/30/61_20.npz"
python3 baseline/ea.py --data_path "data/instances/30/61_20.npz"
python3 baseline/aco.py --data_path "data/instances/30/61_20.npz"
python3 baseline/lp.py
python3 baseline/rl_infer.py \
--checkpoint_path "best.ckpt" \
--data_path "data/30/61_20.npz"
python3 train.py \
--seed 6868 \
--max_epoch 1000 \
--batch_size 4096 \
--mini_batch_size 512 \
--train_data_size 100000 \
--val_data_size 10000 \
--embed_dim 128 \
--num_encoder_layers 12 \
--num_heads 8 \
--num_loc 20 \
--num_arc 20 \
--variant P \
--checkpoint_dir /home/project/checkpoints/cl123 \
--accelerator gpu \
--devices 1
This project is licensed under the MIT License. See the LICENSE file for more details.
@misc{nguyen2025hybridisingreinforcementlearningheuristics,
title={Hybridising Reinforcement Learning and Heuristics for Hierarchical Directed Arc Routing Problems},
author={Van Quang Nguyen and Quoc Chuong Nguyen and Thu Huong Dang and Truong-Son Hy},
year={2025},
eprint={2501.00852},
archivePrefix={arXiv},
primaryClass={cs.LG},
url={https://arxiv.org/abs/2501.00852},
}
For questions or collaboration inquiries, please reach out to Truong-Son Hy at [email protected]