Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/agemagician/ProtTrans
ProtTrans is providing state of the art pretrained language models for proteins. ProtTrans was trained on thousands of GPUs from Summit and hundreds of Google TPUs using Transformers Models.
https://github.com/agemagician/ProtTrans
Last synced: 3 months ago
JSON representation
ProtTrans is providing state of the art pretrained language models for proteins. ProtTrans was trained on thousands of GPUs from Summit and hundreds of Google TPUs using Transformers Models.
- Host: GitHub
- URL: https://github.com/agemagician/ProtTrans
- Owner: agemagician
- License: afl-3.0
- Created: 2020-05-11T11:55:08.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-01-31T17:02:05.000Z (12 months ago)
- Last Synced: 2024-10-29T19:58:22.087Z (3 months ago)
- Language: Jupyter Notebook
- Homepage:
- Size: 55.6 MB
- Stars: 1,118
- Watchers: 32
- Forks: 153
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-biochem-ai - ProtTrans (2021) - acid characters without using other biochemistry knowledge (for example, AlphaFold2 uses Multiple Sequence Alignment). Pure protein strings are feeded to BERT/T5 and protein vectors are produced as a result. These protein vectors then are in turn fed to standard MLPs for protein property prediction tasks. (Libraries on Molecule AI / 3D)
- awesome-protein-design-software - ProtTrans - [paper](https://ieeexplore.ieee.org/document/9477085) - a transformer model of protein sequence (ProtT5) (General protein language models)
- StarryDivineSky - agemagician/ProtTrans
README
ProtTrans
[ProtTrans](https://github.com/agemagician/ProtTrans/) is providing **state of the art pre-trained models for proteins**. ProtTrans was trained on **thousands of GPUs from Summit** and **hundreds of Google TPUs** using various **Transformer models**.
Have a look at our paper [ProtTrans: cracking the language of lifeβs code through self-supervised deep learning and high performance computing](https://doi.org/10.1109/TPAMI.2021.3095381) for more information about our work.
This repository will be updated regulary with **new pre-trained models for proteins** as part of supporting **bioinformatics** community in general, and **Covid-19 research** specifically through our [Accelerate SARS-CoV-2 research with transfer learning using pre-trained language modeling models](https://covid19-hpc-consortium.org/projects/5ed56e51a21132007ebf57bf) project.
Table of Contents
=================
* [ βοΈΒ News](#news)
* [ πΒ Installation](#install)
* [ πΒ Quick Start](#quick)
* [ βοΈΒ Models Availability](#models)
* [ βοΈΒ Dataset Availability](#datasets)
* [ πΒ Usage ](#usage)
* [ π§¬Β Feature Extraction (FE)](#feature-extraction)
* [ πΒ Logits extraction](#logits-extraction)
* [ π₯Β Fine Tuning (FT)](#fine-tuning)
* [ π§ Β Prediction](#prediction)
* [ βοΈΒ Protein Sequences Generation ](#protein-generation)
* [ π§Β Visualization ](#visualization)
* [ πΒ Benchmark ](#benchmark)
* [ πΒ Original downstream Predictions ](#results)
* [ πΒ Followup use-cases ](#inaction)
* [ πΒ Comparisons to other tools ](#comparison)
* [ β€οΈΒ Community and Contributions ](#community)
* [ π«Β Have a question? ](#question)
* [ π€Β Found a bug? ](#bug)
* [ β Β Requirements ](#requirements)
* [ π€΅Β Team ](#team)
* [ π°Β Sponsors ](#sponsors)
* [ πΒ License ](#license)
* [ βοΈΒ Citation ](#citation)
## βοΈΒ News
* **2023/07/14: [FineTuning with LoRA]( https://github.com/agemagician/ProtTrans/tree/master/Fine-Tuning) provides a notebooks on how to fine-tune ProtT5 on both, per-residue and per-protein tasks, using Low-Rank Adaptation (LoRA) for efficient finetuning (thanks @0syrys !).**
* 2022/11/18: Availability: [LambdaPP](https://embed.predictprotein.org/) offers a simple web-service to access ProtT5-based predictions and UniProt now offers to download [pre-computed ProtT5 embeddings](https://www.uniprot.org/help/embeddings) for a subset of selected organisms.
## πΒ Installation
All our models are available via huggingface/transformers:
```console
pip install torch
pip install transformers
pip install sentencepiece
```
For more details, please follow the instructions for [transformers installations](https://huggingface.co/docs/transformers/installation).A recently introduced [change in the T5-tokenizer](https://github.com/huggingface/transformers/pull/24565) results in `UnboundLocalError: cannot access local variable 'sentencepiece_model_pb2` and can either be fixed by installing [this PR](https://github.com/huggingface/transformers/pull/25684) or by manually installing:
```console
pip install protobuf
```
If you are using a transformer version after [this PR](https://github.com/huggingface/transformers/pull/24565), you will see [this warning](https://github.com/huggingface/transformers/blob/main/src/transformers/models/t5/tokenization_t5.py#L167).
Explicitly setting `legacy=True` will result in expected behavor and will avoid the warning. You can also safely ignore the warning as `legacy=True` is [the default](https://github.com/huggingface/transformers/blob/main/src/transformers/models/t5/tokenization_t5.py#L175).
## πΒ Quick Start
Example for how to derive embeddings from our best-performing protein language model, ProtT5-XL-U50 (aka ProtT5); also available as [colab](https://colab.research.google.com/drive/1h7F5v5xkE_ly-1bTQSu-1xaLtTP2TnLF?usp=sharing):
```python
from transformers import T5Tokenizer, T5EncoderModel
import torch
import redevice = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')
# Load the tokenizer
tokenizer = T5Tokenizer.from_pretrained('Rostlab/prot_t5_xl_half_uniref50-enc', do_lower_case=False)# Load the model
model = T5EncoderModel.from_pretrained("Rostlab/prot_t5_xl_half_uniref50-enc").to(device)# only GPUs support half-precision currently; if you want to run on CPU use full-precision (not recommended, much slower)
model.to(torch.float32) if device==torch.device("cpu")# prepare your protein sequences as a list
sequence_examples = ["PRTEINO", "SEQWENCE"]# replace all rare/ambiguous amino acids by X and introduce white-space between all amino acids
sequence_examples = [" ".join(list(re.sub(r"[UZOB]", "X", sequence))) for sequence in sequence_examples]# tokenize sequences and pad up to the longest sequence in the batch
ids = tokenizer(sequence_examples, add_special_tokens=True, padding="longest")input_ids = torch.tensor(ids['input_ids']).to(device)
attention_mask = torch.tensor(ids['attention_mask']).to(device)# generate embeddings
with torch.no_grad():
embedding_repr = model(input_ids=input_ids, attention_mask=attention_mask)# extract residue embeddings for the first ([0,:]) sequence in the batch and remove padded & special tokens ([0,:7])
emb_0 = embedding_repr.last_hidden_state[0,:7] # shape (7 x 1024)
# same for the second ([1,:]) sequence but taking into account different sequence lengths ([1,:8])
emb_1 = embedding_repr.last_hidden_state[1,:8] # shape (8 x 1024)# if you want to derive a single representation (per-protein embedding) for the whole protein
emb_0_per_protein = emb_0.mean(dim=0) # shape (1024)
```We also have a [script](https://github.com/agemagician/ProtTrans/blob/master/Embedding/prott5_embedder.py) which simplifies deriving per-residue and per-protein embeddings from ProtT5 for a given FASTA file:
```
python prott5_embedder.py --input sequences/some.fasta --output embeddings/residue_embeddings.h5
python prott5_embedder.py --input sequences/some.fasta --output embeddings/protein_embeddings.h5 --per_protein 1
```
## βοΈΒ Models Availability| Model | Hugging Face | Zenodo | Colab |
| ----------------------------- | :------------------------------------------------------------------------: |:---------------------------------------------:|---------------------------------------------:|
| ProtT5-XL-UniRef50 (also **ProtT5-XL-U50**) | [Download](https://huggingface.co/Rostlab/prot_t5_xl_uniref50/tree/main) | [Download](https://zenodo.org/record/4644188) | [**Colab**](https://colab.research.google.com/drive/1TUj-ayG3WO52n5N50S7KH9vtt6zRkdmj?usp=sharing)|
| ProtT5-XL-BFD | [Download](https://huggingface.co/Rostlab/prot_t5_xl_bfd/tree/main) | [Download](https://zenodo.org/record/4633924) |
| ProtT5-XXL-UniRef50 | [Download](https://huggingface.co/Rostlab/prot_t5_xxl_uniref50/tree/main) | [Download](https://zenodo.org/record/4652717) |
| ProtT5-XXL-BFD | [Download](https://huggingface.co/Rostlab/prot_t5_xxl_bfd/tree/main) | [Download](https://zenodo.org/record/4635302) |
| ProtBert-BFD | [Download](https://huggingface.co/Rostlab/prot_bert_bfd/tree/main) | [Download](https://zenodo.org/record/4633647) |
| ProtBert | [Download](https://huggingface.co/Rostlab/prot_bert/tree/main) | [Download](https://zenodo.org/record/4633691) |
| ProtAlbert | [Download](https://huggingface.co/Rostlab/prot_albert/tree/main) | [Download](https://zenodo.org/record/4633687) |
| ProtXLNet | [Download](https://huggingface.co/Rostlab/prot_xlnet/tree/main) | [Download](https://zenodo.org/record/4633987) |
| ProtElectra-Generator-BFD | [Download](https://huggingface.co/Rostlab/prot_electra_generator_bfd/tree/main) | [Download](https://zenodo.org/record/4633813) |
| ProtElectra-Discriminator-BFD | [Download](https://huggingface.co/Rostlab/prot_electra_discriminator_bfd/tree/main) | [Download](https://zenodo.org/record/4633717) |
## βοΈΒ Datasets Availability
| Dataset | Dropbox |
| ----------------------------- | :---------------------------------------------------------------------------: |
| NEW364 | [Download](https://www.dropbox.com/s/g49lb352ij4cnt7/NEW364.csv?dl=1) |
| Netsurfp2 | [Download](https://www.dropbox.com/s/98hovta9qjmmiby/Train_HHblits.csv?dl=1) |
| CASP12 | [Download](https://www.dropbox.com/s/te0vn0t7ocdkra7/CASP12_HHblits.csv?dl=1) |
| CB513 | [Download](https://www.dropbox.com/s/9mat2fqqkcvdr67/CB513_HHblits.csv?dl=1) |
| TS115 | [Download](https://www.dropbox.com/s/68pknljl9la8ax3/TS115_HHblits.csv?dl=1) |
| DeepLoc Train | [Download](https://www.dropbox.com/s/vgdqcl4vzqm9as0/deeploc_per_protein_train.csv?dl=1) |
| DeepLoc Test | [Download](https://www.dropbox.com/s/jfzuokrym7nflkp/deeploc_per_protein_test.csv?dl=1) |How to use ProtTrans:
* π§¬Β Feature Extraction (FE):
Please check:
[Embedding Section](https://github.com/agemagician/ProtTrans/tree/master/Embedding). [Colab](https://colab.research.google.com/drive/1TUj-ayG3WO52n5N50S7KH9vtt6zRkdmj?usp=sharing) example for feature extraction via ProtT5-XL-U50
* πΒ Logits Extraction:
For ProtT5-logits extraction, please check:
[VESPA logits script](https://github.com/Rostlab/VESPA#step-3-log-odds-ratio-of-masked-marginal-probabilities).
* π₯Β Fine Tuning (FT):
Please check:
[Fine Tuning Section](https://github.com/agemagician/ProtTrans/tree/master/Fine-Tuning). More information coming soon.
* π§ Β Prediction:
Please check:
[Prediction Section](https://github.com/agemagician/ProtTrans/tree/master/Prediction). [Colab](https://colab.research.google.com/drive/1TUj-ayG3WO52n5N50S7KH9vtt6zRkdmj?usp=sharing) example for secondary structure prediction via ProtT5-XL-U50 and [Colab](https://colab.research.google.com/drive/1W5fI20eKLtHpaeeGDcKuXsgeiwujeczX?usp=sharing) example for subcellular localization prediction as well as differentiation between membrane-bound and water-soluble proteins via ProtT5-XL-U50.
* βοΈΒ Protein Sequences Generation:
Please check:
[Generate Section](https://github.com/agemagician/ProtTrans/tree/master/Generate). More information coming soon.
* π§Β Visualization:
Please check:
[Visualization Section](https://github.com/agemagician/ProtTrans/tree/master/Visualization). More information coming soon.
* πΒ Benchmark:
Please check:
[Benchmark Section](https://github.com/agemagician/ProtTrans/tree/master/Benchmark). More information coming soon.
## πΒ Original downstream Predictions
* π§¬Β Secondary Structure Prediction (Q3):
| Model | CASP12 | TS115 | CB513 |
| -------------------------- | :----------------: | :-------------: | :-------------: |
| ProtT5-XL-UniRef50 | 81 | 87 | 86 |
| ProtT5-XL-BFD | 77 | 85 | 84 |
| ProtT5-XXL-UniRef50 | 79 | 86 | 85 |
| ProtT5-XXL-BFD | 78 | 85 | 83 |
| ProtBert-BFD | 76 | 84 | 83 |
| ProtBert | 75 | 83 | 81 |
| ProtAlbert | 74 | 82 | 79 |
| ProtXLNet | 73 | 81 | 78 |
| ProtElectra-Generator | 73 | 78 | 76 |
| ProtElectra-Discriminator | 74 | 81 | 79 |
| ProtTXL | 71 | 76 | 74 |
| ProtTXL-BFD | 72 | 75 | 77 |π Predict your sequence live on [predictprotein.org](https://predictprotein.org).
* π§¬Β Secondary Structure Prediction (Q8):
| Model | CASP12 | TS115 | CB513 |
| -------------------------- | :----------------: | :-------------: | :-------------: |
| ProtT5-XL-UniRef50 | 70 | 77 | 74 |
| ProtT5-XL-BFD | 66 | 74 | 71 |
| ProtT5-XXL-UniRef50 | 68 | 75 | 72 |
| ProtT5-XXL-BFD | 66 | 73 | 70 |
| ProtBert-BFD | 65 | 73 | 70 |
| ProtBert | 63 | 72 | 66 |
| ProtAlbert | 62 | 70 | 65 |
| ProtXLNet | 62 | 69 | 63 |
| ProtElectra-Generator | 60 | 66 | 61 |
| ProtElectra-Discriminator | 62 | 69 | 65 |
| ProtTXL | 59 | 64 | 59 |
| ProtTXL-BFD | 60 | 65 | 60 |π Predict your sequence live on [predictprotein.org](https://predictprotein.org).
* π§¬Β Membrane-bound vs Water-soluble (Q2):
| Model | DeepLoc |
| -------------------------- | :----------------: |
| ProtT5-XL-UniRef50 | 91 |
| ProtT5-XL-BFD | 91 |
| ProtT5-XXL-UniRef50 | 89 |
| ProtT5-XXL-BFD | 90 |
| ProtBert-BFD | 89 |
| ProtBert | 89 |
| ProtAlbert | 88 |
| ProtXLNet | 87 |
| ProtElectra-Generator | 85 |
| ProtElectra-Discriminator | 86 |
| ProtTXL | 85 |
| ProtTXL-BFD | 86 |
* π§¬Β Subcellular Localization (Q10):
| Model | DeepLoc |
| -------------------------- | :----------------: |
| ProtT5-XL-UniRef50 | 81 |
| ProtT5-XL-BFD | 77 |
| ProtT5-XXL-UniRef50 | 79 |
| ProtT5-XXL-BFD | 77 |
| ProtBert-BFD | 74 |
| ProtBert | 74 |
| ProtAlbert | 74 |
| ProtXLNet | 68 |
| ProtElectra-Generator | 59 |
| ProtElectra-Discriminator | 70 |
| ProtTXL | 66 |
| ProtTXL-BFD | 65 |
## πΒ Use-cases
| Level | Type | Tool | Task | Manuscript | Webserver |
| ----- | ---- | -- | -- | -- | -- |
| Protein | Function | Light Attention | Subcellular localization | [Light attention predicts protein location from the language of life](https://doi.org/10.1093/bioadv/vbab035) | ([Web-server](https://embed.protein.properties/)) |
| Residue | Function | bindEmbed21 | Binding Residues | [Protein embeddings and deep learning predict binding residues for various ligand classes](https://www.nature.com/articles/s41598-021-03431-4) | (Coming soon) |
| Residue | Function | VESPA | Conservation & effect of Single Amino Acid Variants (SAVs) | [Embeddings from protein language models predict conservation and variant effects](https://rdcu.be/cD7q5) | (coming soon) |
| Protein | Structure | ProtTucker | Protein 3D structure similarity prediction | [Contrastive learning on protein embeddings enlightens midnight zone at lightning speed](https://www.biorxiv.org/content/10.1101/2021.11.14.468528v2) | |
| Residue | Structure | ProtT5dst | Protein 3D structure prediction | [Protein language model embeddings for fast, accurate, alignment-free protein structure prediction](https://www.biorxiv.org/content/10.1101/2021.07.31.454572v1.abstract) | |
## πΒ Comparison to other protein language models (pLMs)
While developing the [use-cases](#inaction), we compared ProtTrans models to other protein language models, for instance the [ESM](https://github.com/facebookresearch/esm) models. To focus on the effect of changing input representaitons, the following comparisons use the same architectures on top on different embedding inputs.| Task/Model | ProtBERT-BFD | ProtT5-XL-U50 | ESM-1b | ESM-1v | Metric | Reference |
| -------------------------- | :--------------: | :--------------: | :-----------: | :-----------: | :-----------: | :-----------: |
| Subcell. loc. (setDeepLoc) | 80 | 86 | 83 | - | Accuracy | [Light-attention](https://academic.oup.com/view-large/figure/321379865/vbab035f2.tif) |
| Subcell. loc. (setHard) | 58 | 65 | 62 | - | Accuracy | [Light-attention](https://academic.oup.com/view-large/figure/321379865/vbab035f2.tif) |
| Conservation (ConSurf-DB) | 0.540 | 0.596 | 0.563 | - | MCC | [ConsEmb](https://rdcu.be/cD7q5) |
| Variant effect (DMS-data) | - | 0.53 | - | 0.49 | Spearman (Mean) | [VESPA](https://rdcu.be/cD7q5) |
| Variant effect (DMS-data) | - | 0.53 | - | 0.53 | Spearman (Median) | [VESPA](https://rdcu.be/cD7q5) |
| CATH superfamily (unsup.) | 18 | 64 | 57 | - | Accuracy | [ProtTucker](https://www.biorxiv.org/content/10.1101/2021.11.14.468528v1) |
| CATH superfamily (sup.) | 39 | 76 | 70 | - | Accuracy | [ProtTucker](https://www.biorxiv.org/content/10.1101/2021.11.14.468528v1) |
| Binding residues | - | 39 | 32 | - | F1 | [bindEmbed21](https://www.nature.com/articles/s41598-021-03431-4) |Important note on ProtT5-XL-UniRef50 (dubbed ProtT5-XL-U50): all performances were measured using only embeddings extracted from the encoder-side of the underlying T5 model as described [here](https://github.com/agemagician/ProtTrans/blob/master/Embedding/PyTorch/Advanced/ProtT5-XL-UniRef50.ipynb). Also, experiments were ran in half-precision mode (model.half()), to speed-up embedding generation. No performance degradation could be observed in any of the experiments when running in half-precision.
## β€οΈΒ Community and ContributionsThe ProtTrans project is a **open source project** supported by various partner companies and research institutions. We are committed to **share all our pre-trained models and knowledge**. We are more than happy if you could help us on sharing new ptrained models, fixing bugs, proposing new feature, improving our documentation, spreading the word, or support our project.
We are happy to hear your question in our issues page [ProtTrans](https://github.com/agemagician/ProtTrans/issues)! Obviously if you have a private question or want to cooperate with us, you can always **reach out to us directly** via our [RostLab email](mailto:[email protected]?subject=[GitHub]ProtTrans)
Feel free to **file a new issue** with a respective title and description on the the [ProtTrans](https://github.com/agemagician/ProtTrans/issues) repository. If you already found a solution to your problem, **we would love to review your pull request**!.
For protein feature extraction or fine-tuninng our pre-trained models, [Pytorch](https://github.com/pytorch/pytorch) and [Transformers](https://github.com/huggingface/transformers) library from huggingface is needed. For model visualization, you need to install [BertViz](https://github.com/jessevig/bertviz) library.
* Technical University of Munich:
| Ahmed Elnaggar | Michael Heinzinger | Christian Dallago | Ghalia Rehawi | Burkhard Rost |
|:-------------------------:|:-------------------------:|:-------------------------:|:-------------------------:|:-------------------------:|
| | | | | |* Med AI Technology:
| Yu Wang |
|:-------------------------:|
| |* Google:
| Llion Jones |
|:-------------------------:|
| |* Nvidia:
| Tom Gibbs | Tamas Feher | Christoph Angerer |
|:-------------------------:|:-------------------------:|:-------------------------:|
| | | |* Seoul National University:
| Martin Steinegger |
|:-------------------------:|
| |* ORNL:
| Debsindhu Bhowmik |
|:-------------------------:|
| |Nvidia | Google | Google | ORNL | Software Campus
:-------------------------:|:-------------------------:|:-------------------------:|:-------------------------:|:-------------------------:
![](https://github.com/agemagician/ProtTrans/blob/master/images/1200px-Nvidia_image_logo.svg.png?raw=true) | ![](https://github.com/agemagician/ProtTrans/blob/master/images/google-cloud-logo.jpg?raw=true) | ![](https://github.com/agemagician/ProtTrans/blob/master/images/tfrc.png?raw=true) | ![](https://github.com/agemagician/ProtTrans/blob/master/images/Oak_Ridge_National_Laboratory_logo.svg.png?raw=true) | ![](https://github.com/agemagician/ProtTrans/blob/master/images/SOFTWARE_CAMPUS_logo_cmyk.jpg?raw=true)
## πΒ License
The ProtTrans pretrained models are released under the under terms of the [Academic Free License v3.0 License](https://choosealicense.com/licenses/afl-3.0/).
## βοΈΒ Citation
If you use this code or our pretrained models for your publication, please cite the original paper:
```
@ARTICLE
{9477085,
author={Elnaggar, Ahmed and Heinzinger, Michael and Dallago, Christian and Rehawi, Ghalia and Yu, Wang and Jones, Llion and Gibbs, Tom and Feher, Tamas and Angerer, Christoph and Steinegger, Martin and Bhowmik, Debsindhu and Rost, Burkhard},
journal={IEEE Transactions on Pattern Analysis and Machine Intelligence},
title={ProtTrans: Towards Cracking the Language of Lifes Code Through Self-Supervised Deep Learning and High Performance Computing},
year={2021},
volume={},
number={},
pages={1-1},
doi={10.1109/TPAMI.2021.3095381}}
```