Skip to content

Latest commit

 

History

History
95 lines (61 loc) · 4.2 KB

README.md

File metadata and controls

95 lines (61 loc) · 4.2 KB

gnn-x-bench

Benchmarking GNN explainers.

Requirements

The easiest way to install the dependencies is via conda. Once you have conda installed, run this command:

conda env create -f env.yml

If you want to install dependencies manually, we tested our code in Python 3.9.7 using the following main dependencies:

Experiments were conducted using the Ubuntu 18.04 operating system on an NVIDIA DGX Station equipped with four V100 GPU cards, each having 128GB of GPU memory. The system also included 256GB of RAM and a 20-core Intel Xeon E5-2698 v4 2.2 GHz CPU.

Usage

Data installation

Every datasets except for Graph-SST2 is ready to install from PyTorch Geometric libraries. For Graph-SST2, you can download the dataset from here and put it in data/ directory.

Then, you can run the following command to preprocess the data. This will preprocess every dataset including generating noisy variants of four datasets.

python source/data_utils.py

Training Base GNNs

We provide the pretrained models for every dataset and gnn architectures. However, if you want to train the models from scratch, you can run the following command:

python source/basegnn.py --dataset <dataset_name> --gnn_type <gnn_type> --runs 1

We modified GAT, GIN, SAGE implementation of PyTorch Geometric to support our training pipeline. You can find the modified version of the code in source/wrappers/ directory.

Training Explainers

We provide the pretrained models for every dataset and inductive explainers. However, you may want to train the explainers from scratch.

Each explainer has their own code and training pipeline. You can find the code for each explainer in source/ directory.

We also provide shell scripts to run the explainers. You can find the scripts in main directory. For example, to run the GNNExplainer, you can run the following command:

./gnnexplainer.sh

Please check the script files to see which command should be run to receive which results.

Explanations and Evaluation

We provide the explanations and evaluation scores for every dataset and explainer. You can find the explanations in data/<dataset_name>/<explainer_name> directory.

If you want to reproduce the evaluations, you can run the following command:

./generate_results.sh

Reproducibility Experiments

Reproducibility experiments needs the explanations from the explainers. It trains from-scratch GNNs using the explanations and evaluate them. We use top-1 to top-10 from explanations and re-train them.

We already provide our run performance but, you can run the following command to run reproducibility experiments:

./reproducibility.sh

Visualization

We use the following files to plot and print the results:

Links:
GNNX-BENCH: Unravelling the Utility of Perturbation-based GNN Explainers through In-depth Benchmarking
Slides Poster