# Meta-EGN
The official implementation of the paper *Unsupervised Learning for Combinatorial Optimization Needs Meta Learning*

- Here is the tutorial on how to train Meta-EGN on max clique:

1.go to the max_clique/configs/config file, enter the path of your folder

2.go to the max_clique/dataset folder, run the following codes to generate the dataset

```Python
python twitter_train.py
```

```Python
python twitter_val.py
```

```Python
python twitter_test.py
```

3. go back to max_clique folder, run

```Python
sh maml.sh
```

4. To test with the model, run

```Python
sh test.sh
```

5.To fine-tune with the model, run

```Python
sh finetune.sh
```

For all the other tasks and datasets, the formulation are basically the same, the functions to replace are provided in each folder.

- Environment requirment:
```Python
Python 3.8
PyTotch 1.9.0
PyTorch Geometric 1.7.2
Gurobi 9.5
Networkx
numpy
pickle 
tqdm
yaml
```
We now have provided the code to re-produce the results in the paper for:

MC in twitter, COLLAB, IMDB, RB500

MVC in twitter

MIS on RRGs

(Document unfinished)
