# IO-Aware GNNs

A comprehensive framework for benchmarking and accelerating Graph Neural Networks (GNNs) through efficient GPU utilization and backend optimization.

## Installation

### Via Makefile (RECOMMENDED)

You need python>=3.11 to install everything. Run these commands - they install everything you need to `.venv` local folder & install pre-commit hooks:

```bash
python3.11 -m venv .venv && source .venv/bin/activate && python -m pip install -U pip && make install-full # full installation
```

For other types of installation, see `Makefile` & `pyproject.toml`

## Launch benchmarking

Configs are placed in `configs` directory. To Launch benchmarking, use `scripts/kernel_launch_comparison.py`

- configs for layers combinations can be found at `configs/kernel_launch_measurements`

Typical worflow is:

```
python scripts/kernel_launch_comparison.py --device <device index> --conv_type <gt/gat_v2/min_aggr/gcn> --conv_params_grid configs/kernels_measurements/<cconfig.yaml> --backends <list of backends> --target_backend <your target backend> --out <path to outfile>
```
