Skip to content
forked from cvignac/DiGress

code for the paper "DiGress: Discrete Denoising diffusion for graph generation"

License

Notifications You must be signed in to change notification settings

inouye-lab/DiGress

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DiGress: Discrete Denoising diffusion models for graph generation (ICLR 2023)

Warning: The code has been updated after experiments were run for the paper. If you don't manage to reproduce the paper results, please write to us so that we can investigate the issue.

For the conditional generation experiments, check the guidance branch.

Environment installation

  • Download anaconda/miniconda if needed
  • Create a rdkit environment that directly contains rdkit: conda create -c conda-forge -n digress rdkit python=3.9
  • Install graph-tool (https://graph-tool.skewed.de/): conda install -c conda-forge graph-tool
  • Install the nvcc drivers for your cuda version. For example, conda install -c "nvidia/label/cuda-11.3.1" cuda-nvcc
  • Install pytorch 1.10 or 1.11 (https://pytorch.org/)
  • Install pytorch-geometric. Your version should match the pytorch version that is installed (https://pytorch-geometric.readthedocs.io/en/latest/notes/installation.html)
  • Install other packages using the requirement file: pip install -r requirements.txt
  • Install mini-moses: pip install git+https://github.com/igor-krawczuk/mini-moses
  • Run pip install -e .

Download the data

Run the code

  • All code is currently launched through python3 main.py. Check hydra documentation (https://hydra.cc/) for overriding default parameters.
  • To run the debugging code: python3 main.py +experiment=debug.yaml. We advise to try to run the debug mode first before launching full experiments.
  • To run a code on only a few batches: python3 main.py general.name=test.
  • To run the continuous model: python3 main.py model=continuous
  • To run the discrete model: python3 main.py
  • You can specify the dataset with python3 main.py dataset=guacamol. Look at configs/dataset for the list of datasets that are currently available

Checkpoints

We uploaded pretrained models for the Planar and SBM datasets. If you need other checkpoints, please write to us.

Planar: https://drive.switch.ch/index.php/s/tZCjJ6VXU2Z3FIh SBM: https://drive.switch.ch/index.php/s/rxWFVQX4Cu4Vq5j

Cite the paper

@article{vignac2022digress,
  title={DiGress: Discrete Denoising diffusion for graph generation},
  author={Vignac, Clement and Krawczuk, Igor and Siraudin, Antoine and Wang, Bohan and Cevher, Volkan and Frossard, Pascal},
  journal={arXiv preprint arXiv:2209.14734},
  year={2022}
}

About

code for the paper "DiGress: Discrete Denoising diffusion for graph generation"

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 69.9%
  • C++ 30.1%