Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/chao1224/Geom3D
Geom3D: Geometric Modeling on 3D Structures, NeurIPS 2023
https://github.com/chao1224/Geom3D
3d 3d-structures ai4science biology chemistry crystals drugs equivariance geometry group invariance material molecules physics proteins symmetry
Last synced: 2 months ago
JSON representation
Geom3D: Geometric Modeling on 3D Structures, NeurIPS 2023
- Host: GitHub
- URL: https://github.com/chao1224/Geom3D
- Owner: chao1224
- License: mit
- Created: 2023-06-07T17:27:56.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-06-05T03:18:58.000Z (8 months ago)
- Last Synced: 2024-10-10T22:14:19.813Z (3 months ago)
- Topics: 3d, 3d-structures, ai4science, biology, chemistry, crystals, drugs, equivariance, geometry, group, invariance, material, molecules, physics, proteins, symmetry
- Language: Python
- Homepage: https://openreview.net/forum?id=ygXSNrIU1p
- Size: 870 KB
- Stars: 108
- Watchers: 2
- Forks: 10
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- top-life-sciences - **chao1224/Geom3D** - structures`, `ai4science`, `biology`, `chemistry`, `crystals`, `drugs`, `equivariance`, `geometry`, `group`, `invariance`, `material`, `molecules`, `physics`, `proteins`, `symmetry`<br><img src='https://github.com/HubTou/topgh/blob/main/icons/gstars.png'> 105 <img src='https://github.com/HubTou/topgh/blob/main/icons/forks.png'> 9 <img src='https://github.com/HubTou/topgh/blob/main/icons/watchers.png'> 2 <img src='https://github.com/HubTou/topgh/blob/main/icons/code.png'> Python <img src='https://github.com/HubTou/topgh/blob/main/icons/license.png'> MIT license <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2024-06-05 03:18:58 | (Ranked by starred repositories)
README
# Symmetry-Informed Geometric Representation for Molecules, Proteins, and Crystalline Materials
Authors: Shengchao Liu, Weitao Du, Yanjing Li, Zhuoxinran Li, Zhiling Zheng, Chenru Duan, Zhiming Ma, Omar Yaghi, Anima Anandkumar, Christian Borgs, Jennifer Chayes, Hongyu Guo, Jian Tang
[[ArXiv](https://arxiv.org/abs/2306.09375)]
This is **Geom3D**, a platfrom for geometric modeling on 3D structures:
## Environment
### Conda
Setup the anaconda
```bash
wget https://repo.continuum.io/archive/Anaconda3-2019.10-Linux-x86_64.sh
bash Anaconda3-2019.10-Linux-x86_64.sh -b
export PATH=$PWD/anaconda3/bin:$PATH
```### Packages
Start with some basic packages.
```bash
conda create -n Geom3D python=3.7
conda activate Geom3D
conda install -y -c rdkit rdkit
conda install -y numpy networkx scikit-learn
conda install -y -c conda-forge -c pytorch pytorch=1.9.1
conda install -y -c pyg -c conda-forge pyg=2.0.2
pip install ogb==1.2.1pip install sympy
pip install ase
pip install lie_learn # for TFN and SE3-Trans
pip install packaging # for SEGNN
pip3 install e3nn # for SEGNNpip install transformers # for smiles
pip install selfies # for selfiespip install atom3d # for Atom3D
pip install cffi # for Atom3D
pip install biopython # for Atom3Dpip install cython # for pyximport
conda install -y -c conda-forge py-xgboost-cpu # for XGB
```## Datasets
We cover three types of datasets:
- Small Molecules
- QM9
- MD17
- rMD17
- COLL
- Proteins
- EC
- FOLD
- Small Molecules and Proteins
- LBA
- LEP
- Materials
- MatBench
- QMOFFor dataset acquisition:
- We provide a set of raw and processed dataset [HuggingFace](https://huggingface.co/datasets/chao1224/Geom3D_data). You can download the data using `python download_data.py` under `./data`.
- Please refer to the [data](./data) folder for more details.## Overview of Models
### Representation Models
Geom3D includes the following representation models:
- [SchNet, NeurIPS'18](https://papers.nips.cc/paper_files/paper/2017/hash/303ed4c69846ab36c2904d3ba8573050-Abstract.html)
- [TFN, NeurIPS'18 Workshop](https://arxiv.org/abs/1802.08219)
- [DimeNet, ICLR'20](https://openreview.net/forum?id=B1eWbxStPH)
- [SE(3)-Trans, NeurIPS'20](https://proceedings.neurips.cc//paper/2020/hash/15231a7ce4ba789d13b722cc5c955834-Abstract.html)
- [EGNN, ICML'21](http://proceedings.mlr.press/v139/satorras21a.html)
- [PaiNN, ICML'21](https://arxiv.org/abs/2102.03150)
- [GemNet, NeurIPS'21](https://proceedings.neurips.cc/paper/2021/hash/35cf8659cfcb13224cbd47863a34fc58-Abstract.html)
- [SphereNet, ICLR'22](https://openreview.net/forum?id=givsRXsOt9r)
- [SEGNN, ICLR'22](https://openreview.net/forum?id=_xwr8gOBeV1)
- [NequIP, Nature Communications'22](https://www.nature.com/articles/s41467-022-29939-5)
- [Allegro, Nature Communications'23](https://www.nature.com/articles/s41467-023-36329-y)
- [Equiformer, ICLR'23](https://openreview.net/forum?id=KwmPfARgOTD)
- [GVP-GNN, ICLR'21](https://openreview.net/forum?id=1YLJDvSx6J4)
- [IEConv, ICLR'21](https://openreview.net/forum?id=l0mSUROpwY)
- [GearNet, ICLR'23](https://openreview.net/forum?id=to3qCB3tOh9)
- [ProNet, ICLR'23](https://openreview.net/forum?id=9X-hgLDLYkQ)
- [CDConv, ICLR'23](https://openreview.net/forum?id=P5Z-Zl9XJ7)We also include the following 7 1D models and 11 2D models (specifically for small molecules):
- 1D Fingerprints: MLP, RF, XGB
- 1D SMILES: CNN, BERT
- 1D Selfies: CNN, BERT
- 2D topology:
- [GCN, NeurIPS'2015](https://arxiv.org/abs/1509.09292)
- [ENN-S2S, ICML'17](https://arxiv.org/abs/1704.01212)
- [GraphSAGE, NeurIPS'17](https://arxiv.org/abs/1706.02216)
- [GAT, ICLR'2018](https://openreview.net/forum?id=rJXMpikCZ)
- [GIN, ICLR'2019](https://openreview.net/forum?id=ryGs6iA5Km)
- [D-MPNN, ACS-JCIM'2019](https://pubs.acs.org/doi/10.1021/acs.jcim.9b00237)
- [N-Gram Graph, NeurIPS'2019](https://arxiv.org/abs/1806.09206)
- [PNA, NeurIPS'2020](https://arxiv.org/abs/2004.05718)
- [Graphormer, NeurIPS'21](https://openreview.net/forum?id=OeWooOxFwDa)
- [AWARE, TMLR'2022](https://openreview.net/forum?id=TWSTyYd2Rl)
- [GraphGPS, NeurIPS'22](https://arxiv.org/abs/2205.12454)Notice that there is no pretraining considered at this stage. For geoemtric pretraining models, please check the following section.
### Geometric Pretraining
We include the following 14 geometric pretraining methods:
- Pure 3D:
- Supervised
- Atom Type Prediction
- Distance Prediction
- Angle Prediction
- 3D InfoGraph, from [GeoSSL, ICLR'23](https://openreview.net/forum?id=CjTHVo1dvR)
- GeoSSL-RR, from [GeoSSL, ICLR'23](https://openreview.net/forum?id=CjTHVo1dvR)
- GeoSSL-InfoNCE, from [GeoSSL, ICLR'23](https://openreview.net/forum?id=CjTHVo1dvR)
- GeoSSL-EBM-NCE, from [GeoSSL, ICLR'23](https://openreview.net/forum?id=CjTHVo1dvR)
- [GeoSSL-DDM, ICLR'23](https://openreview.net/forum?id=CjTHVo1dvR)
- [GeoSSL-DDM-1L, ICLR'23](https://openreview.net/forum?id=tYIMtogyee)
- [3D-EMGP, AAAI'23](https://arxiv.org/abs/2207.08824)
- Joint 2D-3D:
- [GraphMVP, ICLR'22](https://openreview.net/forum?id=xQUe1pOKPam)
- [3D InfoMax, ICML'22](https://proceedings.mlr.press/v162/stark22a.html)
- [MoleculeSDE, ICML'23](https://arxiv.org/abs/2305.18407)## Scripts
The python scripts can be found in `examples_3D`. We list the bash scripts (and hyperparameters) in `scripts`. For example, the bash script for SchNet on QM9 is:
```
cd examples_3Dexport model_3d=SchNet
export dataset=QM9
export task_list=(mu alpha homo lumo gap r2 zpve u0 u298 h298 g298 cv)export lr_list=(5e-4)
export lr_scheduler_list=(CosineAnnealingLR)
export split=customized_01
export seed=42
export emb_dim_list=(128 300)
export batch_size_list=(128)export epochs=1000
for task in "${task_list[@]}"; do
for lr in "${lr_list[@]}"; do
for lr_scheduler in "${lr_scheduler_list[@]}"; do
for emb_dim in "${emb_dim_list[@]}"; do
for batch_size in "${batch_size_list[@]}"; doexport output_model_dir=output/random/"$model_3d"/"$dataset"/"$task"_"$split"_"$seed"/"$lr"_"$lr_scheduler"_"$emb_dim"_"$batch_size"_"$epochs"
export output_file="$output_model_dir"/result.out
mkdir -p "$output_model_dir"python finetune_QM9.py \
--model_3d="$model_3d" --dataset="$dataset" --epochs="$epochs" \
--task="$task" \
--split="$split" --seed="$seed" \
--batch_size="$batch_size" \
--emb_dim="$emb_dim" \
--lr="$lr" --lr_scheduler="$lr_scheduler" --no_eval_train --print_every_epoch=1 --num_workers=8 \
--output_model_dir="$output_model_dir" \
> "$output_file"
done
done
done
done
done
```Now only the bash scripts for QM9 are available. We will release the complete version soon, together with Notebook demo. Please stay tuned.
## Checkpoints
Checkpoints for all the pretraining and downstream tasks will be released soon.
## Cite us
Feel free to cite this work if you find it useful to you!
```
@article{liu2023symmetry,
title={Symmetry-Informed Geometric Representation for Molecules, Proteins, and Crystalline Materials},
author={Liu, Shengchao and Du, Weitao and Li, Yanjing and Li, Zhuoxinran and Zheng, Zhiling and Duan, Chenru and Ma, Zhiming and Yaghi, Omar and Anandkumar, Anima and Borgs, Christian and others},
journal={arXiv preprint arXiv:2306.09375},
year={2023}
}
```