/deepsnap

Python library assists deep learning on graphs

Primary LanguagePythonMIT LicenseMIT

DeepSNAP

PyPI License Build Status Downloads Repo size

Documentation | Examples | Colab Notebooks

DeepSNAP is a Python library to assist efficient deep learning on graphs. DeepSNAP features in its support for flexible graph manipulation, standard pipeline, heterogeneous graphs and simple API.

DeepSNAP bridges powerful graph libraries such as NetworkX and deep learning framework PyTorch Geometric. With an intuitive and easy-than-ever API, DeepSNAP addresses the above pain points:

  • DeepSNAP currently supports a NetworkX-based backend (also SnapX-based backend for homogeneous undirected graph), allowing users to seamlessly call hundreds of graph algorithms available to manipulate / transform the graphs, even at every training iteration.
  • DeepSNAP provides a standard pipeline for dataset split, negative sampling and defining node/edge/graph-level objectives, which are transparent to users.
  • DeepSNAP provides efficient support for flexible and general heterogeneous GNNs, that supports both node and edge heterogeneity, and allows users to control how messages are parameterized and passed.
  • DeepSNAP has an easy-to-use API that works seamlessly with existing GNN models / datasets implemented in PyTorch Geometric. There is close to zero learning curve if the user is familiar with PyTorch Geometric.

Installation

To install the DeepSNAP, ensure PyTorch Geometric and NetworkX are installed. Then:

$ pip install deepsnap

Or build from source:

$ git clone https://github.com/snap-stanford/deepsnap
$ cd deepsnap
$ pip install .

Example

Examples using DeepSNAP are provided within the code repository.

$ git clone https://github.com/snap-stanford/deepsnap

Node classification:

$ cd deepsnap/examples/node_classification # node classification
$ python node_classification_planetoid.py

Link prediction:

$ cd deepsnap/examples/link_prediction # link prediction
$ python link_prediction_cora.py

Graph classification:

$ cd deepsnap/examples/graph_classification # graph classification
$ python graph_classification_TU.py

Documentation

For comprehensive overview, introduction, tutorial and example, please refer to Full Documentation