# Benchmarking GNNs by aligning graphs

The `ngab` (Noisy Graph Alignment Benchmark) package simplifies benchmarking and training GNNs on Graph Alignment datasets.
It is based on PyTorch and the default models are written using the Pytorch Geometric package.

Several functionalities are provided:
- Generating datasets
- Training GNNs and benchmarking them using the Graph Alignment Bencgmark methodology.
- Using pretrained GNNs for generating GAPE (Graph Alignment Positional Encodings)

# Graph Alignment problem for benchmarking

## Dataset generation

We provide several command line application to generate graph matching datasets:

- **ga-generate-er** : Generate Erdos-Renyi GA datasets.
- **ga-generate-aqsol** : Generate GA datasets based on the AQSOL dataset
- **ga-generate-karateclub** : Generate GA datasets based on the KarateClub Benchmark dataset.
- **ga-generate-corafull** : Generate GA datasets based on the CoraFull Benchmark dataset.
- **ga-generate-ogbn-arxiv** : Generate GA datasets based on the OGBN-Arxiv Benchmark dataset.
- **ga-generate-pcqm4mv2** : Generate GA datasets based on the PCQM4Mv2 Benchmark dataset.

To know more about them run:

`ga-generate-er --help`

`ga-generate-aqsol --help`

`ga-generate-karateclub --help`

`ga-generate-corafull --help`

`ga-generate-ogbn-arxiv --help`

`ga-generate-pcqm4mv2 --help`


Once you have a dataset, you can print key statistics with `ga-data-stats`

## Training

### Architectures in the library (`ngab.models`)

Use the `ga-train` command line tool to train a Siamese Graph Matching model. (run `ga-train --help`).

### Custom architectures

Use the API.


# Running the Repo

We use [uv](https://docs.astral.sh/uv/) to manage the python project. See the documentation for a complete guide.

### Quick installation (Linux and MacOS)

`curl -LsSf https://astral.sh/uv/install.sh | sh`

`echo 'eval "$(uv generate-shell-completion bash)"' >> ~/.bashrc`

`echo 'eval "$(uv generate-shell-completion zsh)"' >> ~/.zshrc`

You may have to restart you shell.



