Skip to content

simon-forb/CRaWl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CRaWl (Convolutional Neural Networks for Random Walks)

This repository contains the code for training and testing CRaWl networks. (https://arxiv.org/abs/2102.08786)

Installation:

git clone https://github.com/toenshoff/CRaWl.git
cd CRaWl
conda create --name crawl_env python=3.8
conda activate crawl_env
conda install pytorch=1.7.1 cudatoolkit=10.2 -c pytorch
pip install -r requirements.txt -f https://pytorch-geometric.com/whl/torch-1.7.0+cu102.html

Note that we use cuda 10.2 by default.

Experiments

The scripts directory provides bash scripts to execute both training and testing for all of our main experiments. For example, run the following commands to train and test 5 CRaWl models on ZINC:

bash scripts/train_zinc.sh
bash scripts/test_zinc.sh

The datasets will be automatically downloaded when running the training scripts.

We set random seeds for model initialization, batch generation and the random walks. The scripts use the same random seeds that were used to obtain the reported results in the paper. Note that our implementation uses scatter operations that are non-deterministic for numerical reasons. Training twice with the same seeds will not yield identical models, since the models will diverge through the training steps. We aim to solve this in future versions.

Replicate MOLPCBA Results

Follow the installation procedure above and then run:

bash scripts/train_molpcba.sh
bash scripts/test_molpcba.sh

Note that this script trains 10 models sequentially, which will take quite long. We recommend parallizing the indiviual training runs on multiple machines, if available. Before the training of the first model, it will also take a few minutes to download and preprocess the data.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 97.0%
  • Shell 3.0%