# Boltzmann Graph Network (BGN)

## Overview
The **Boltzmann Graph Network (BGN)** integrates deterministic GNN aggregation with stochastic RBM-inspired transformations. It is effective across citation networks, heterophilous datasets, and OGB benchmarks. This repository includes the implementation, experiment runner, CSV logging, dataset grouping, and analysis tools.

---

## Dataset Groups

The system supports running experiments by dataset name or dataset group:

```json
{
  "citation": ["cora", "citeseer", "pubmed"],
  "heterophilous": ["cornell", "texas", "wisconsin", "actor"],
  "ogb": ["ogbn-arxiv", "ogbn-products"]
}
```

---

## Installation

```bash
pip install -r requirements.txt
```

---

## Running Experiments

Run on a single dataset:

```bash
python run.py --dataset cora
```

Run on a group of datasets:

```bash
python run.py --dataset citation
python run.py --dataset heterophilous
```

The runner loads the correct config automatically, executes all experiments, and logs results to CSV.

---

## CSV Output

All results are saved automatically:

```
results/benchmark_results.csv
results/benchmark_results.md
```

### CSV Header

```
Timestamp,Method,Dataset,Split,Optimizer,Epochs,Runs,LR,K-Steps,Residual,Forward Sampling,Backward Sampling,Num Layers,Lambda RBM,Loss Type,Val Loss,Val F1 (%),Val F1 Std (%),Test Accuracy (%),Test Accuracy Std (%),Test F1 (%),Test F1 Std (%),Duration (sec)
```

---

## Analyzing Results

Filter by dataset or dataset group:

```bash
python analyze_results.py --filter cora
python analyze_results.py --filter heterophilous
```

The script selects:
- Best model based on validation metrics  
- Corresponding test accuracy/F1  
- Optimal hyperparameters  

---

## Visualizations

```bash
python visualize_results.py
```

Outputs saved to:

```
vis/
```

---

## Benchmark Script

The original benchmark script is still available:

```bash
cd experiments
bash benchmark.sh
```

---
