Towards General Algorithm Discovery for Combinatorial Optimization: Learning Symbolic Branching Policy from Bipartite Graph
This is the code of paper Towards General Algorithm Discovery for Combinatorial Optimization: Learning Symbolic Branching Policy from Bipartite Graph. [Paper]
We revise the official scip (version 6.0.1) to add interfaces for Symb4CO. To install the revised scip:
- Download the official scipoptsuite 6.0.1 from here.
- Replace the folder
./scipoptsuite-6.0.1/scip
(i.e., the folder of scip) with our revised version provided here.
Attention! The revised scip is in the
symb4co-iclr2024
branch, not themain
!
- Installing the revised scip 6.0.1 via cmake following the official instructions.
P.S.: You can refer to the git commits of our revised scip 6.0.1 to identify the changes, compared with the original scip 6.0.1 and the revised version provided in learn2branch.
We revise the PySCIPOpt to add interfaces for Symb4CO. To install the revised PySCIPOpt:
- Specify the installation path of scip 6.0.1
export SCIPOPTDIR='/path/to/where/you/installation'
- Install the revised PySCIPOpt
pip install git+https://github.com/MIRALab-USTC/PySCIPOpt.git@symb4co-iclr2024
Attention! The revised PySCIPOpt is in the
symb4co-iclr2024
branch, not themaster
!
P.S.: You can refer to the last git commit of our revised PySCIPOpt to identify what has been revised, compared with the version provided in learn2branch.
We list the required python 3.9 packages in ./requirement.txt
.
P.S.: We found inconsistent Pytorch might lead to unknown RuntimeError.
The instance and the dataset generation is based on the codes implemented by Gupta et al. To generate them, run
# generate CO instances
python 01_generate_instances.py indset
# generate full strong branching datasets
python 02_generate_dataset.py indset
# indset can be replaced to cauctions, setcover, and facilities
If you do not want to train new symbolic policies, you can directly use our trained ones in ./expressions
via
# To evaluate the imitation learning accuracy
python 04_test_gs4co.py indset
# To evaluate the end-to-end performance of learned graph symbolic policies
python 05_evaluate_gs4co.py indset
To train symbolic policies, run
python 03_train_gs4co.py instance_kwargs.instance_type=indset