Skip to content
forked from yvquanli/GLAM

Code for "An adaptive graph learning method for automated molecular interactions and properties predictions".

License

Notifications You must be signed in to change notification settings

taiwanhuachenyu/GLAM

 
 

Repository files navigation

GLAM

Code for "An adaptive graph learning method for automated molecular interactions and properties predictions".

License: MIT Paper version

Access the paper by this sharedit link: https://rdcu.be/cQP0g

Abstract

Improving drug discovery efficiency is a core and long-standing challenge in drug discovery. For this purpose, many graph learning methods have been developed to search potential drug candidates with fast speed and low cost. In fact, the pursuit of high prediction performance on a limited number of datasets has crystallized their architectures and hyperparameters, making them lose advantage in repurposing to new data generated in drug discovery. Here we propose a flexible method that can adapt to any dataset and make accurate predictions. The proposed method employs an adaptive pipeline to learn from a dataset and output a predictor. Without any manual intervention, the method achieves far better prediction performance on all tested datasets than traditional methods, which are based on hand-designed neural architectures and other fixed items. In addition, we found that the proposed method is more robust than traditional methods and can provide meaningful interpretability. Given the above, the proposed method can serve as a reliable method to predict molecular interactions and properties with high adaptability, performance, robustness and interpretability. This work would take a solid step forward to the purpose of aiding researchers to design better drugs with high efficiency.

Requirements

Our work is implementated based on version 1.7.2 of pyg.

conda >= 4.9.2
PyTorch >= 1.5.0
torch-gemetric == 1.7.2
rdkit >= '2019.03.4'

Installation

First You should choose the Anaconda version that suits your system and install it by:

wget https://repo.anaconda.com/archive/Anaconda3-2021.04-Linux-x86_64.sh
sh Anaconda3-2021.04-Linux-x86_64.sh
# wget https://repo.anaconda.com/archive/Anaconda3-2021.04-MacOSX-x86_64.sh
# sh Anaconda3-2021.04-MacOSX-x86_64.sh

You can install the required dependencies with the following code.

conda create -n GLAM python rdkit pytorch=1.10.0 cudatoolkit=11.1 -c pytorch -c conda-forge --yes
conda activate GLAM
CUDA=cu111
TORCH=1.10.0
pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html 
pip install torch-sparse -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html 
pip install torch-geometric==1.7.2 

If you don't have a gpu or want a cpu version, you can try this:

conda create -n GLAM python rdkit pytorch=1.10.0 cpuonly -c pytorch -c conda-forge --yes
conda activate GLAM
CUDA=cpu
TORCH=1.10.0
pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html 
pip install torch-sparse -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html 
pip install torch-geometric==1.7.2 

Demo

If you have successfully completed the above steps, then you can use the following code to run a demo for a property prediction task.

git clone https://github.com/yvquanli/GLAM.git
cd ./GLAM/src_1gp
python3 demo.py

Dataset

All datasets can be download from these website:

Full preparing for all datasets

If you want preparing the workplace for full runing of the code, you can try this guide. Firstly, you should clone the code:

cd ~
mkdir GLAM; cd GLAM
git clone https://github.com/yvquanli/GLAM.git    # clone the code to ~/GLAM/GLAM

This is the guide for preparing the MoleculeNet dataset:

cd ~
mkdir -p ~/Dataset/GLAM-GP/raw; cd "$_"
wget https://deepchemdata.s3-us-west-1.amazonaws.com/datasets/delaney-processed.csv   # for esol
mv delaney-processed.csv esol.csv
# We recommend that you download, rename, and drag it the ~/Dataset/GLAM-GP/raw directory mannualy.
# ...... (preparing other dataset as above)

This is the guide for preparing the BindingDB and LIT-PCBA dataset:

cd ~
mkdir -p ~/Dataset/GLAM-DTI/raw; cd "$_"
mv ~/GLAM/GLAM/pro_contact_map.zip ./pro_contact_map.zip
unzip ./pro_contact_map.zip

cd bindingdb
wget https://github.com/lifanchen-simm/transformerCPI/blob/master/data/BindingDB.zip 
unzip BindingDB.zip

cd ~/Dataset/GLAM-DTI/raw/lit_pcba_raw
wget http://drugdesign.unistra.fr/LIT-PCBA/Files/full_data.tgz
tar zxvf full_data.tgz -C .
mv full_data/* .

This is the guide for preparing the drug-drug interaction dataset:

mkdir -p ~/Dataset/GLAM-DDI/raw; cd "$_"
wget https://github.com/kexinhuang12345/CASTER/blob/master/DDE/data/unsup_dataset.csv
mv unsup_dataset.csv ddi_total.csv

If you get any error with these guide, please up a issue, and we will refix it.

Full structure of workplace

If you have all the datasets and code ready, you should place these files in the following structure.

.
├── Dataset/  
│   ├── GLAM-DDI/  
│   │   └── raw/  
│   │       └── drugbank_caster/
│   │           └── ddi_total.csv
│   ├── GLAM-DTI/
│   │   └── raw/
│   │       ├── bindingdb/
│   │       │   ├── pro_contact_map/protein_maps_dict.ckpt
│   │       │   ├── train.txt
│   │       │   ├── dev.txt
│   │       │   └── test.txt
│   │       └── lit_pcba_raw/
│   │           ├── raptor_pred/contact_8.5/protein_maps_dict.ckpt
│   │           ├── ALDH1/
│   │           └── ...
│   └── GLAM-GP/
│       └── raw/
│           ├── bace.csv
│           └── ...
└── GLAM/
    ├── LICENSE
    ├── README.md
    ├── src_1gp/
    │   └── ...
    ├── src_2gi_ddi/
    │   └── ...
    └── src_2gi_dti_scr/
        └── ...
  • ./GLAM/src_1gp: The source code for molecular property prediction.
  • ./GLAM/src_2gi_ddi: The source code for molecular pair interaction identification of drug-drug task.
  • ./GLAM/src_2gi_dti_scr: The source code for molecular pair interaction identification of drug-target and screening task.
  • ./Dataset/GLAM-DTI/raw: The raw data must be placed here.
  • ./Dataset/GLAM-DTI/processed: The processed data will be stored here
  • etc...

Usage

Then make sure that run.py can be run and done by

python3 run.py --epochs 1

Then run glam.py by

python3 glam.py [-h] [--dataset DATASET] [--n_init_configs N_INIT_CONFIGS]
                 [--n_low_fidelity_seed n_low_fidelity_seed]
                 [--n_top_blend N_TOP_BLEND]
                 [--n_high_fidelity_seed n_high_fidelity_seed]

optional arguments:

  -h, --help            show this help message and exit
  --dataset DATASET     bindingdb_c, lit_esr1ant
  --n_init_configs N_INIT_CONFIGS
                        n initialized configurations
  --n_low_fidelity_seed n_low_fidelity_seed
                        n run for few epochs
  --n_top_blend N_TOP_BLEND
                        auto blend n models
  --n_high_fidelity_seed n_high_fidelity_seed
                        n run for full epochs with a config

If you want to perform property-slightly-affected structural perturbation with GLAM:

python3 glam.py --dataset physprop_perturb

If you want to perform property-slightly-affected structural perturbation with your model, please feed your model and physprop dataset to TrainerMolRegression and use the pasp() function.

Citation

Li, Y., Hsieh, CY., Lu, R. et al. An adaptive graph learning method for automated molecular interactions and properties predictions. Nat Mach Intell (2022). https://doi.org/10.1038/s42256-022-00501-8

About

Code for "An adaptive graph learning method for automated molecular interactions and properties predictions".

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 89.5%
  • Jupyter Notebook 10.5%