# README

## Dataset

All datasets are located in the `dataset/` folder.
Each **graph** is organized by **split** — `train/`, `valid/`, `test/` — and **every graph** consists of **three files**:

* `clustering.csv` – community/clustering information
* `node_features.csv` – node-level features
* `edge_features.csv` – edge-level features


```
dataset/
├─ train/
│  ├─ 0/
│  │  ├─ clustering.csv
│  │  ├─ node_features.csv
│  │  └─ edge_features.csv
│  ├─ 1/
│  │  ├─ clustering.csv
│  │  ├─ node_features.csv
│  │  └─ edge_features.csv
│  └─ 2/
│     ├─ clustering.csv
│     ├─ node_features.csv
│     └─ edge_features.csv
├─ valid/
│  └─ 0/
│     ├─ clustering.csv
│     ├─ node_features.csv
│     └─ edge_features.csv
└─ test/
   └─ 1/
      ├─ clustering.csv
      ├─ node_features.csv
      └─ edge_features.csv

```
---

## 🧪 Running Experiments

The entry point for experiments is `experiments/main.py`.
Experiment configurations live in `experiments/experiments.yaml`.

### Example configuration

```yaml
- name: variations
  do: false
  parameters:
    "training/use_edge_features": [true, false]
    "training/undirected": [true, false]
    "positional_encoding/num_landmarks": [0, 64, 128, 256]
    "validation/seed": [1, 2, 3, 4, 5]
```

* Set `do: true` to **activate** an experiment.
* Lists in `parameters` create a grid of all parameter combinations.

### Commands

Set up and run:

```bash
python -m venv .venv
source .venv/bin/activate        # Windows: .venv\Scripts\activate
pip install -r requirements.txt
python experiments/main.py
```

Summarize **all results obtained so far**:

```bash
python experiments/results_summary.py
```

---

## 🏁 Baselines

Baseline implementations are included for quick evaluation:

* **Louvain** & **Leiden**: `utils/evaluation/baseliens.py`
* **GAE**: `utils/evaluation/baseline_gae/main.py`
* **DGI**: `utils/evaluation/baseline_dgi/main.py`

