No project description provided
Project description
IgFold
Official repository for IgFold: Fast, accurate antibody structure prediction from deep learning on massive set of natural antibodies.
The code and pre-trained models from this work are made available for non-commercial use (including at commercial entities) under the terms of the JHU Academic Software License Agreement. For commercial inquiries, please contact jruffolo[at]jhu.edu
.
Try antibody structure prediction in Google Colab.
Updates
- Version 0.1.1
- Added AbNumber integration for structure renumbering.
- Constrained PyRosetta refinement to stay closer to model output.
Install
For easiest use, create a conda environment and install IgFold via PyPI:
$ pip install igfold
To access the latest version of the code, clone and install the repository:
$ git clone git@github.com:Graylab/IgFold.git
$ pip install IgFold
Refinement
Two refinement methods are supported for IgFold predictions. To follow the manuscript, PyRosetta should be installed following the instructions here. If PyRosetta is not installed, refinement with OpenMM will be attempted. For this option, OpenMM must be installed and configured before running IgFold as follows:
$ conda install -c conda-forge openmm pdbfixer
Renumbering
Antibody renumbering will use AbNumber by default. To install AbNumber, run the following command:
$ conda install -c bioconda abnumber
If AbNumber cannot be installed, integration with the AbNum server is provided as an alternative.
Usage
Note: The first time IgFoldRunner
is initialized, it will download the pre-trained weights. This may take a few minutes and will require a network connection.
Antibody structure prediction from sequence
Paired antibody sequences can be provided as a dictionary of sequences, where the keys are chain names and the values are the sequences.
from igfold import IgFoldRunner, init_pyrosetta
init_pyrosetta()
sequences = {
"H": "EVQLVQSGPEVKKPGTSVKVSCKASGFTFMSSAVQWVRQARGQRLEWIGWIVIGSGNTNYAQKFQERVTITRDMSTSTAYMELSSLRSEDTAVYYCAAPYCSSISCNDGFDIWGQGTMVTVS",
"L": "DVVMTQTPFSLPVSLGDQASISCRSSQSLVHSNGNTYLHWYLQKPGQSPKLLIYKVSNRFSGVPDRFSGSGSGTDFTLKISRVEAEDLGVYFCSQSTHVPYTFGGGTKLEIK"
}
pred_pdb = "my_antibody.pdb"
igfold = IgFoldRunner()
igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Antibody sequences
do_refine=True, # Refine the antibody structure with PyRosetta
do_renum=True, # Renumber predicted antibody structure (Chothia)
)
To predict a nanobody structure (or an individual heavy or light chain), simply provide one sequence:
from igfold import IgFoldRunner, init_pyrosetta
init_pyrosetta()
sequences = {
"H": "QVQLQESGGGLVQAGGSLTLSCAVSGLTFSNYAMGWFRQAPGKEREFVAAITWDGGNTYYTDSVKGRFTISRDNAKNTVFLQMNSLKPEDTAVYYCAAKLLGSSRYELALAGYDYWGQGTQVTVS"
}
pred_pdb = "my_nanobody.pdb"
igfold = IgFoldRunner()
igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Nanobody sequence
do_refine=True, # Refine the antibody structure with PyRosetta
do_renum=True, # Renumber predicted antibody structure (Chothia)
)
To predict a structure without refinement, set do_refine=False
:
from igfold import IgFoldRunner
sequences = {
"H": "QVQLQESGGGLVQAGGSLTLSCAVSGLTFSNYAMGWFRQAPGKEREFVAAITWDGGNTYYTDSVKGRFTISRDNAKNTVFLQMNSLKPEDTAVYYCAAKLLGSSRYELALAGYDYWGQGTQVTVS"
}
pred_pdb = "my_nanobody.pdb"
igfold = IgFoldRunner()
igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Nanobody sequence
do_refine=False, # Refine the antibody structure with PyRosetta
do_renum=True, # Renumber predicted antibody structure (Chothia)
)
Predicted RMSD for antibody structures
RMSD estimates are calculated per-residue and recorded in the B-factor column of the output PDB file. These values are also returned from the fold
method.
from igfold import IgFoldRunner, init_pyrosetta
init_pyrosetta()
sequences = {
"H": "EVQLVQSGPEVKKPGTSVKVSCKASGFTFMSSAVQWVRQARGQRLEWIGWIVIGSGNTNYAQKFQERVTITRDMSTSTAYMELSSLRSEDTAVYYCAAPYCSSISCNDGFDIWGQGTMVTVS",
"L": "DVVMTQTPFSLPVSLGDQASISCRSSQSLVHSNGNTYLHWYLQKPGQSPKLLIYKVSNRFSGVPDRFSGSGSGTDFTLKISRVEAEDLGVYFCSQSTHVPYTFGGGTKLEIK"
}
pred_pdb = "my_antibody.pdb"
igfold = IgFoldRunner()
out = igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Antibody sequences
do_refine=True, # Refine the antibody structure with PyRosetta
do_renum=True, # Renumber predicted antibody structure (Chothia)
)
out.prmsd # Predicted RMSD for each residue's N, CA, C, CB atoms (dim: 1, L, 4)
Antibody sequence embedding
Representations from IgFold may be useful as features for machine learning models. The embed
method can be used to surface a variety of antibody representations from the model:
from igfold import IgFoldRunner
sequences = {
"H": "EVQLVQSGPEVKKPGTSVKVSCKASGFTFMSSAVQWVRQARGQRLEWIGWIVIGSGNTNYAQKFQERVTITRDMSTSTAYMELSSLRSEDTAVYYCAAPYCSSISCNDGFDIWGQGTMVTVS",
"L": "DVVMTQTPFSLPVSLGDQASISCRSSQSLVHSNGNTYLHWYLQKPGQSPKLLIYKVSNRFSGVPDRFSGSGSGTDFTLKISRVEAEDLGVYFCSQSTHVPYTFGGGTKLEIK"
}
igfold = IgFoldRunner()
emb = igfold.embed(
sequences=sequences, # Antibody sequences
)
emb.bert_embs # Embeddings from AntiBERTy final hidden layer (dim: 1, L, 512)
emb.gt_embs # Embeddings after graph transformer layers (dim: 1, L, 64)
emb.strucutre_embs # Embeddings after template incorporation IPA (dim: 1, L, 64)
Extra options
Refinement with OpenMM can be prioritized over PyRosetta by setting use_openmm=True
.
from igfold import IgFoldRunner, init_pyrosetta
init_pyrosetta()
sequences = {
"H": "EVQLVQSGPEVKKPGTSVKVSCKASGFTFMSSAVQWVRQARGQRLEWIGWIVIGSGNTNYAQKFQERVTITRDMSTSTAYMELSSLRSEDTAVYYCAAPYCSSISCNDGFDIWGQGTMVTVS",
"L": "DVVMTQTPFSLPVSLGDQASISCRSSQSLVHSNGNTYLHWYLQKPGQSPKLLIYKVSNRFSGVPDRFSGSGSGTDFTLKISRVEAEDLGVYFCSQSTHVPYTFGGGTKLEIK"
}
pred_pdb = "my_antibody.pdb"
igfold = IgFoldRunner()
igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Antibody sequences
do_refine=True, # Refine the antibody structure with PyRosetta
use_openmm=True, # Use OpenMM for refinement
do_renum=True, # Renumber predicted antibody structure (Chothia)
)
Renumbering using the AbNum server can be prioritized over AbNumber by setting use_abnum=True
.
from igfold import IgFoldRunner, init_pyrosetta
init_pyrosetta()
sequences = {
"H": "EVQLVQSGPEVKKPGTSVKVSCKASGFTFMSSAVQWVRQARGQRLEWIGWIVIGSGNTNYAQKFQERVTITRDMSTSTAYMELSSLRSEDTAVYYCAAPYCSSISCNDGFDIWGQGTMVTVS",
"L": "DVVMTQTPFSLPVSLGDQASISCRSSQSLVHSNGNTYLHWYLQKPGQSPKLLIYKVSNRFSGVPDRFSGSGSGTDFTLKISRVEAEDLGVYFCSQSTHVPYTFGGGTKLEIK"
}
pred_pdb = "my_antibody.pdb"
igfold = IgFoldRunner()
igfold.fold(
pred_pdb, # Output PDB file
sequences=sequences, # Antibody sequences
do_refine=True, # Refine the antibody structure with PyRosetta
do_renum=True, # Renumber predicted antibody structure (Chothia)
use_abnum=True, # Send predicted structure to AbNum server for Chothia renumbering
)
Synthetic antibody structures
To demonstrate the capabilities of IgFold for large-scale prediction of antibody structures, we applied the model to two sets of natural paired antibody sequences.
The first set contains 104,994 non-redundant paired antibody sequences from the Observed Antibody Space database. These predicted structures are made available for use online.
$ wget https://data.graylab.jhu.edu/igfold_oas_paired95.tar.gz
The second set contains 1.3M unique paired antibodies from four human donors, collected by Jaffe et al.. These predicted structures are made available for use online.
$ wget https://data.graylab.jhu.edu/Jaffe2022.tar.gz
Bug reports
If you run into any problems while using IgFold, please create a Github issue with a description of the problem and the steps to reproduce it.
Citing this work
@article{ruffolo2021deciphering,
title = {Deciphering antibody affinity maturation with language models and weakly supervised learning},
author = {Ruffolo, Jeffrey A and Gray, Jeffrey J and Sulam, Jeremias},
journal = {arXiv},
year= {2021}
}
@article{ruffolo2022fast,
title = {Fast, accurate antibody structure prediction from deep learning on massive set of natural antibodies},
author = {Ruffolo, Jeffrey A and Chu, Lee-Shin and Mahajan, Sai Pooja and Gray, Jeffrey J},
journal = {bioRxiv},
year= {2022}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file igfold-0.1.5.tar.gz
.
File metadata
- Download URL: igfold-0.1.5.tar.gz
- Upload date:
- Size: 28.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fde32f64db3fda4f7d8195c625b291b5c6596946fe8e16b6bf9d1ecbe4cf8676 |
|
MD5 | 8ab1fa81f996adb31d4c9826b4655ea6 |
|
BLAKE2b-256 | a4825dec03d69bec8f7c28b85fd67486acf867d17ecb86bad5e3ec02796f3ce4 |
File details
Details for the file igfold-0.1.5-py3-none-any.whl
.
File metadata
- Download URL: igfold-0.1.5-py3-none-any.whl
- Upload date:
- Size: 32.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 99f36e0e88c1b8bdc926292474ff2a4082916789039423f8a94dddab71372508 |
|
MD5 | 4d6977bd7e3cfde195aa5172f3f70641 |
|
BLAKE2b-256 | bbb80f9a4033ed75ffb0f2758590dfc512ed02fd1ed3b0e25029c3deaf07c8fc |