# Learning to Approximate Uniform Facility Location via Graph Neural Networks

## Dataset generation

Please see `generate_fac.ipynb` 

## Experiments

SimpleUFL:  
`python sample_algo.py train.datapath=PATH train.param=0.56`

RecurUFL:  
`python sample_recur.py train.datapath=PATH train.param=0.037`

Gehweiler et al.:  
`python sample_algo_o1.py train.datapath=PATH`

OR-Tools:  
`python solver.py train.datapath=PATH`

GNN training:  
`python run.py train.datapath=PATH gnn.hidden=32 gnn.num_conv_layers=6 train.ckpt=true train.runs=5 train.batchsize=128 train.epoch=1000`

GNN + SimpleUFL:  
`python sample_gnn.py train.datapath=PATH +train.modelpath=MODELPATH gnn.hidden=32 gnn.num_conv_layers=6 +train.seed=14 +train.repeats=1000`

GNN training for clustering:  
`python run.py train.datapath=PATH gnn.hidden=32 gnn.num_conv_layers=6 train.ckpt=true train.runs=5 train.batchsize=128 train.epoch=1000 gnn.square_dist=true`

GNN inference for clustering:  
`python compare_gnn_kmeans.py train.datapath=PATH +train.modelpath=MODELPATH +train.seed=14 +train.repeats=1000 gnn.hidden=32 gnn.num_conv_layers=6 gnn.square_dist=true`

Hyperparameters we use:

| Name             | SimpleUFL | RecurUFL | MPNN layer | MPNN dim. |
|------------------|-----------|----------|--------|-----------|
| Geo-1000-2       | 0.560     | 0.037    | 6      | 32        |
| Geo-1000-5       | 0.423     | 0.166    | 6      | 32        |
| Geo-1000-10      | 0.351     | 0.242    | 6      | 32        |
| Geo-1000-10-den. | 0.319     | 0.291    | 6      | 32        |
| Geo-1000-10-sp.  | 0.423     | 0.031    | 6      | 32        |
| Paris            | 1.417     | 0.095    | 6      | 32        |
| Shanghai         | 1.417     | 0.095    | 10     | 32        |
| London           | 1.292     | 0.086    | 10     | 32        |
| LA               | 1.292     | 0.086    | 10     | 32        |