Skip to content

Implementation codes for NeurIPS23 paper "Spectral Invariant Learning for Dynamic Graphs under Distribution Shifts"

Notifications You must be signed in to change notification settings

wondergo2017/sild

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Spectral Invariant Learning for Dynamic Graphs under Distribution Shifts (SILD)

Github License Poster

This repository contains the code implementation of SILD as described in the paper: Spectral Invariant Learning for Dynamic Graphs under Distribution Shifts (NeurIPS 2023).

Introduction

Figure 1. The framework of SILD.

Dynamic graph neural networks (DyGNNs) currently struggle with handling distribution shifts that are inherent in dynamic graphs. Existing work on DyGNNs with out-of-distribution settings only focuses on the time domain, failing to handle cases involving distribution shifts in the spectral domain.

In this paper, we discover that there exist cases with distribution shifts unobservable in the time domain while observable in the spectral domain, and propose to study distribution shifts on dynamic graphs in the spectral domain for the first time.

To this end, we propose Spectral Invariant Learning for Dynamic Graphs under Distribution Shifts (SILD), which can handle distribution shifts on dynamic graphs by capturing and utilizing invariant and variant spectral patterns. Specifically, we first design a DyGNN with Fourier transform to obtain the ego-graph trajectory spectrums, allowing the mixed dynamic graph patterns to be transformed into separate frequency components. We then develop a disentangled spectrum mask to filter graph dynamics from various frequency components and discover the invariant and variant spectral patterns. Finally, we propose invariant spectral filtering, which encourages the model to rely on invariant patterns for generalization under distribution shifts. Experimental results on synthetic and real-world dynamic graph datasets demonstrate the superiority of our method for both node classification and link prediction tasks under distribution shifts.

The framework is shown in Figure 1.

Installation

We have tested our codes with the following requirements:

  • Python == 3.9
  • Pytorch == 1.12.1+cu113
  • Pytorch-Geometric == 2.0.4+cu113

or

  • Python == 3.9
  • Pytorch == 2.0.1+cu117
  • Pytorch-Geometric == 2.3.0+cu117

Take the latter as an example. Please follow the following steps to create a virtual environment and install the required packages.

Clone the repository:

git clone [email protected]:wondergo2017/sild.git
cd sild

Create a virtual environment:

conda create --name sild python=3.9 -y
conda activate sild

Install dependencies:

pip install torch==2.0.1
pip install torch_geometric==2.3
pip install pyg_lib torch_scatter torch_sparse torch_cluster torch_spline_conv -f https://data.pyg.org/whl/torch-2.0.0+cu117.html

Install DIDA as a library:

pip install -e DIDA/

Install this repo as a library:

pip install -e .

The datasets can be downloaded from google drive.

File Organization & Datasets

The files in this repo are organized as follows:

\data                       # datasets introduced in sild
\DIDA                       # the original codes of the baseline DIDA
\sild
    \data_util              # data utils including data loading, processing, etc. 
    \misc                   # other utils                   
\paper                      # poster, framework, etc.                       
\scripts\
    \aminer                 # scripts for running exps on aminer datasets
        config.py          
        main.py             # main script
        model.py            
        utils.py
        parallel-rep.py     # the script to reproduce results
    \dida_data              # scripts for running exps on DIDA datasets 
        ...
    \syn_SBM                # scripts for running exps on synthetic node classification datasets.
        ...    

Usage

An example to run the model is given as follows: (you may change the gpus in parallel-rep.py)

cd scripts/aminer
python parallel-rep.py -t run

To show the results

python parallel-rep.py -t show

Or if you want to run the model with your defined arguments

python main.py --X XXX

Acknowledgements

The datasets and baseline scripts are modified from the publicly available repos or other resources. We sincerely appreciate their contributions to the research community.

Reference

If you find our repo or paper useful, please star the repo or cite our paper:

@inproceedings{zhang2023spectral,
  title={Spectral Invariant Learning for Dynamic Graphs under Distribution Shifts},
  author={Zhang, Zeyang and Wang, Xin and Zhang, Ziwei and Qin, Zhou and Wen, Weigao and Xue, Hui and Li, Haoyang and Zhu, Wenwu},
  booktitle={Advances in Neural Information Processing Systems},
  year={2023}
}

Contact

If you have any questions, please feel free to contact us ([email protected]) or ([email protected])

Releases

No releases published

Packages

No packages published

Languages