To run training, you will need to download a a few pre-processed datasets. Note that you will need ~250G of storage for all the data. If instead you want to re-run the preprocessing pipeline or processed your own raw data for training, please see the instructions at the bottom of this page.
- The pre-processed RCSB (i.e PDB) structures:
wget https://boltz1.s3.us-east-2.amazonaws.com/rcsb_processed_targets.tar
tar -xf rcsb_processed_targets.tar
rm rcsb_processed_targets.tar
- The pre-processed RCSB (i.e PDB) MSA's:
wget https://boltz1.s3.us-east-2.amazonaws.com/rcsb_processed_msa.tar
tar -xf rcsb_processed_msa.tar
rm rcsb_processed_msa.tar
- The pre-processed OpenFold structures:
wget https://boltz1.s3.us-east-2.amazonaws.com/openfold_processed_targets.tar
tar -xf openfold_processed_targets.tar
rm openfold_processed_targets.tar
- The pre-processed OpenFold MSA's:
wget https://boltz1.s3.us-east-2.amazonaws.com/openfold_processed_msa.tar
tar -xf openfold_processed_msa.tar
rm openfold_processed_msa.tar
- The pre-computed symmetry files for ligands:
wget https://boltz1.s3.us-east-2.amazonaws.com/symmetry.pkl
The training script requires a configuration file to run. This file specifies the paths to the data, the output directory, and other parameters of the data, model and training process.
We provide under scripts/train/configs
a template configuration file analogous to the one we used for training the structure model (structure.yaml
) and the confidence model (confidence.yaml
).
The following are the main parameters that you should modify in the configuration file to get the structure model to train:
trainer:
devices: 1
output: SET_PATH_HERE # Path to the output directory
resume: PATH_TO_CHECKPOINT_FILE # Path to a checkpoint file to resume training from if any null otherwise
data:
datasets:
- _target_: boltz.data.module.training.DatasetConfig
target_dir: PATH_TO_TARGETS_DIR # Path to the directory containing the processed structure files
msa_dir: PATH_TO_MSA_DIR # Path to the directory containing the processed MSA files
symmetries: PATH_TO_SYMMETRY_FILE # Path to the file containing molecule the symmetry information
max_tokens: 512 # Maximum number of tokens in the input sequence
max_atoms: 4608 # Maximum number of atoms in the input structure
max_tokens
and max_atoms
are the maximum number of tokens and atoms in the crop. Depending on the size of the GPUs you are using (as well as the training speed desired), you may want to adjust these values. Other recommended values are 256 and 2304, or 384 and 3456 respectively.
Here is an example of how to set multiple dataset sources like the PDB and OpenFold distillation dataset that we used to train the structure model:
datasets:
- _target_: foldeverything.task.train.data.DatasetConfig
target_dir: PATH_TO_PDB_TARGETS_DIR
msa_dir: PATH_TO_PDB_MSA_DIR
prob: 0.5
sampler:
_target_: boltz.data.sample.cluster.ClusterSampler
cropper:
_target_: boltz.data.crop.boltz.BoltzCropper
min_neighborhood: 0
max_neighborhood: 40
split: ./scripts/train/assets/validation_ids.txt
- _target_: foldeverything.task.train.data.DatasetConfig
target_dir: PATH_TO_DISTILLATION_TARGETS_DIR
msa_dir: PATH_TO_DISTILLATION_MSA_DIR
prob: 0.5
sampler:
_target_: boltz.data.sample.cluster.ClusterSampler
cropper:
_target_: boltz.data.crop.boltz.BoltzCropper
min_neighborhood: 0
max_neighborhood: 40
Before running the full training, we recommend using the debug flag. This turns off DDP (sets single device) and sets num_workers
to 0 so everything is in a single process, as well as disabling wandb:
python scripts/train/train.py scripts/train/configs/structure.yaml debug=1
Once that seems to run okay, you can kill it and launch the training run:
python scripts/train/train.py scripts/train/configs/structure.yaml
We also provide a different configuration file to train the confidence model:
python scripts/train/train.py scripts/train/configs/confidence.yaml
We have already pre-processed the training data for the PDB and the OpenFold self-distillation set. However, if you'd like to replicate the processing pipeline or processed your own data for training, you can follow the instructions below.
cd scripts/process
Install the few extra requirements required for processing:
pip install -r requirements.txt
You must also install two external libraries: mmseqs
and redis
. Instructions for installation are below:
mmseqs
: https://github.com/soedinglab/mmseqs2?tab=readme-ov-file#installationredis
: https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/
We have already done this for you, the relevant file is here:
wget https://boltz1.s3.us-east-2.amazonaws.com/ccd.pkl
Unless you wish to do it again yourself, you can skip to the next step! If you do want to recreate the file, you can do so with the following commands:
wget https://files.wwpdb.org/pub/pdb/data/monomers/components.cif
python ccd.py --components components.cif --outdir ./ccd
Note: runs in parallel by default with as many threads as cpu cores on your machine, can be changed with
--num_processes
First, you must create a fasta file containing all the polymer sequences present in your data. You can use any header format you want for the sequences, it will not be used.
For the PDB, this can already be downloaded here:
wget https://files.rcsb.org/pub/pdb/derived_data/pdb_seqres.txt.gz
gunzip -d pdb_seqres.txt.gz
Note: for the OpenFold data, since the sequences were chosen for diversity, we do not apply any clustering.
When this is done, you can run the clustering script, which assigns proteins to 40% similarity clusters and rna/dna to a cluster for each unique sequence. For ligands, each CCD code is also assigned to its own cluster.
python cluster.py --ccd ccd.pkl --sequences pdb_seqres.txt --mmseqs PATH_TO_MMSEQS_EXECUTABLE --outdir ./clustering
Note: you must install mmseqs (see: https://github.com/soedinglab/mmseqs2?tab=readme-ov-file#installation)
We have already computed MSA's for all sequences in the PDB at the time of training using the ColabFold colab_search
tool. You can setup your own local colabfold using instructions provided here: https://github.com/YoshitakaMo/localcolabfold
The raw MSA's for the PDB can be found here:
wget https://boltz1.s3.us-east-2.amazonaws.com/rcsb_raw_msa.tar
tar -xf rcsb_raw_msa.tar
rm rcsb_raw_msa.tar
Note: this file is 130G large, and will take another 130G to extract before you can delete the original tar archive, we make sure you have enough storage on your machine.
You can also download the raw OpenFold MSA's here:
wget https://boltz1.s3.us-east-2.amazonaws.com/openfold_raw_msa.tar
tar -xf openfold_raw_msa.tar
rm openfold_raw_msa.tar
Note: this file is 88G large, and will take another 88G to extract before you can delete the original tar archive, we make sure you have enough storage on your machine.
If you wish to use your own MSA's, just ensure that their file name is the hash of the query sequence, according to the following function:
import hashlib
def hash_sequence(seq: str) -> str:
"""Hash a sequence."""
return hashlib.sha256(seq.encode()).hexdigest()
During MSA processing, among other things, we annotate sequences using their taxonomy ID, which is important for MSA pairing during training. This happens only on MSA sequences with headers that start with the following:
>UniRef100_UNIREFID
...
This format is the way that MSA's are provided by colabfold. If you use a different MSA pipeline, make sure your Uniref MSA's follow the above format.
Next you should download our provided taxonomy database and place it in the current folder:
wget https://boltz1.s3.us-east-2.amazonaws.com/taxonomy.rdb
You can now process the raw MSAs. First launch a redis server. We use redis to share the large taxonomy dictionary across workers, so MSA processing can happen in parallel without blowing up the RAM usage.
redis-server --dbfilename taxonomy.rdb --redis-port 7777
Please wait a few minutes for the DB to initialize. It will print Ready to accept connections
when ready.
Note: You must have redis installed (see: https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/)
In a separate shell, run the MSA processing script:
python msa.py --msadir YOUR_MSA_DIR --outdir YOUR_OUTPUT_DIR --redis-port 7777
Important: the script looks for
.a3m
or.a3m.gz
files in the directory, make sure to match this extension and file format.
Finally, we're ready to process structural data. Here we provide two different scripts for the PDB and for the OpenFold data. In general, we recommend using the rcsb.py
script for your own data, which is expected in mmcif
format.
You can download the full RCSB using the instructions here: https://www.rcsb.org/docs/programmatic-access/file-download-services
wget https://boltz1.s3.us-east-2.amazonaws.com/ccd.rdb
redis-server --dbfilename ccd.rdb --redis-port 7777
Note: You must have redis installed (see: https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/)
In a separate shell, run the processing script, make sure to use the clustering/clustering.json
file you previously created.
python rcsb.py --datadir PATH_TO_MMCIF_DIR --cluster clustering/clustering.json --outdir YOUR_OUTPUT_DIR --use-assembly --max-file-size 7000000 --redis-port 7777
Important: the script looks for
.cif
orcif.gz
files in the directory, make sure to match this extension and file format.
We skip a few of the very large files, you can modify this using the
--max-file-size
flag, or by removing it.
You're ready to start training the model on your data, make sure to modify the config to assign the paths you created in the previous two steps. If you have any questions, don't hesitate to open an issue or reach out on our community slack channel.