## Learning-Augmented Online Covering Problems

This is the source code accompanying paper
"Learning-Augmented Online Covering Problems"

## Requirements

To run this code you will need:

– Python 3.6+ (with pandas and matplotlib for drawing plots)
- Gurobi 11.0+ (academic licenses are free for researchers)

## Usage

We provide the necessary parts of the dataset (exact track of the Hitting Set Challenge). 
The full dataset (rather large) can be found at https://github.com/MarioGrobler/PACE2025-instances 

To run our experiments on the PACE2025 dataset, do, e.g.,:

FILEPATH="PACE2025-instances/hs/exact/exact_001.hgr"

python3 experiments.py $FILEPATH Greedy >> files/hs/greedy/result_001.csv
python3 experiments.py $FILEPATH IP >> files/hs/ip/result_001.csv 

To run our experiments on the random graphs, do, e.g.,:

python3 experiments.py 1 Greedy >> files/synthetic/greedy/result_001.csv
python3 experiments.py 1 IP >> files/synthetic/ip/result_001.csv 

Note that the latter method (IP) requires Gurobi. Running all 100 instances takes about 100 hours.

For your convenience, we provide the results of the experiments on all instances in the folder files.

In order to generate the plots and the statistics from the paper, go to the plots file and run the jupyter notebook file.