Skip to main content

Emory Brain Benchmark package

Project description

BrainGB

BrainGB is a python package for testing Graph Neural Networks on Brain Networks.

Installation

To install BrainGB as a package, simply run

pip install BrainGB

Alternatively, you can also download the repository from Github. The main package is under the src folder. If you choose to go with this method, please check the Specification of Dependencies section for dependency requirements.

Getting Started

To import the models detailed in the paper:

from BrainGB import GAT, GCN, BrainNN, GCN

The BrainNN is required and will be served as the parent module of the GAT, GCN models. You may choose either GAT or GCN as the submodule.

To initialize a GCN model

sample: Data = Data()  # A torch geometric data

num_features = data.x.shape[1]
num_nodes = data.x.shape[0]
gcn_model = GCN(num_features, num_nodes)

model = BrainNN(args.pooling, gcn_model, MLP(2 * num_nodes))

To initialize a GAT model, simply replace the GCN with GAT. Both models are customizable. Please refer to the documentation for more details.

Specification of Dependencies

BrainGB depends on the following frameworks:

torch~=1.10.2
numpy~=1.22.2
nni~=2.4
PyYAML~=5.4.1
scikit-learn~=1.0.2
networkx~=2.6.2
scipy~=1.7.3
tensorly~=0.6.0
pandas~=1.4.1
libsvm~=3.23.0.4
matplotlib~=3.4.3
tqdm~=4.62.3
torch-geometric~=2.0.3
h5py~=3.6.0

To install the dependencies, run:

pip install -r requirements.txt

Notice that if you install the package through pip, the dependencies are automatically installed.

Running Example Scripts

The repository also comes with example scripts. To train our model on any of the datasets we tested, simply run:

python -m main.example_main --dataset_name=<dataset_name> [--model_name=<variant>]

The dataset_name is the name of the dataset you want to use. The following datasets are available and tested:

  • HIV
  • PPMI (Can be downloaded here)
  • PNC

The following datasets are also available but not tested:

  • ABIDE
  • BP
  • ABCD

Please place the dataset files in the datasets folder under the package examples folder. Create the folder if it does not exist.

The model_name is the name of the model you want to use. Two choices are available:

  • GCN
  • GAT

Contribution

We welcome contributions to the package. Please feel free to open an issue or pull request.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

BrainGB-1.0.4.tar.gz (14.9 kB view details)

Uploaded Source

Built Distribution

BrainGB-1.0.4-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file BrainGB-1.0.4.tar.gz.

File metadata

  • Download URL: BrainGB-1.0.4.tar.gz
  • Upload date:
  • Size: 14.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for BrainGB-1.0.4.tar.gz
Algorithm Hash digest
SHA256 9de532e800daf8ecf37eb1a76d3ea5f819de725f6b97bc512d53e869fb61d88c
MD5 d17ffa13de9f2e2635997ca083bf385a
BLAKE2b-256 1e962a79318fb4850c65eda2d9b6822c67aceacaac947663b5291cde2fbd5de2

See more details on using hashes here.

File details

Details for the file BrainGB-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: BrainGB-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 18.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for BrainGB-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 999027441e5c3f1ee7a85af369a3fd497041df081d3a46cc5485d5a87c545a6e
MD5 47877a2512bd282bf3d9567be73a6aa4
BLAKE2b-256 44e5a90ffb258ca39869ce250e0d611f644f79d81c10b2b0608411b85829389c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page