BioM3 / README.md
Niksa Praljak
Add section on model weight installation
d85f01b
|
raw
history blame
8.34 kB
---
license: apache-2.0
---
# BioM3: Biological Multi-Modal Model for Protein Design
## Citation
If you use this code, please cite:
```bibtex
Natural Language Prompts Guide the Design of Novel Functional Protein Sequences
bioRxiv 2024.11.11.622734
doi: https://doi.org/10.1101/2024.11.11.622734
```
[Read the paper on bioRxiv](https://www.biorxiv.org/content/10.1101/2024.11.11.622734v1)
## Software Requirements
### Required Dependencies
- Python 3.8 or later (recommend Python 3.10 to package conflicts)
- PyTorch (latest stable version)
- Huggingface
- fair-esm
- pandas
### Installation
Create and activate a conda environment and install the required packages:
```bash
conda create -p /env_path/BioM3_env python=3.10 # /env_path/ is the location that contains the conda env
conda activate /env_path/BioM3_env
git clone https://huggingface.co/niksapraljak1/BioM3 /path/
cd /path/BioM3 # /path/ is the location that contains the huggingface repo for BioM3
sh torch_requirements.sh # install torch software
pip install -r requirements.txt # install remaining packages
```
## Model Weights Installation
Before running models, change directory to `BioM3/weights` folder, follow instructions, and download pretrained weights for the desired BioM3 configuration:
```bash
cd /path/BioM3/weights
# after changing directory, follow instructions of README.md to install weights for each model component
```
Note: choose the desired BioM3 configuration/checkpoint, then install weights for each folder:
- `/path/BioM3/weights/PenCL`
- `/path/BioM3/weights/Facilitator`
- `/path/BioM3/weights/ProteoScribe`
Each folder contains a `README.md` detailing the different model weight configurations. For benchmarking, the optimal configuration is:
- `BioM3_PenCL_epoch20.bin`
- `BioM3_Facilitator_epoch20.bin`
- `BioM3_ProteoScribe_epoch20.bin`
## Stage 1: PenCL Inference
### Overview
This stage demonstrates how to perform inference using the **BioM3 PenCL model** for aligning protein sequences and text descriptions. The model computes latent embeddings for the given inputs and calculates **dot product scores** (similarities) with normalization.
### Model Weights
Before running the model, ensure you have:
- Configuration file: `stage1_config.json`
- Pre-trained weights: `BioM3_PenCL_epoch20.bin`
### Running the Model
1. Change directory to BioM3 repo:
```bash
cd /path/BioM3 # /path/ where is the location to the cloned BioM3 repo
```
2. Run inference:
```bash
python run_PenCL_inference.py \
--json_path "stage1_config.json" \
--model_path "./weights/PenCL/BioM3_PenCL_epoch20.bin" \
--output_path "test_PenCL_embeddings.pt"
```
### Example Input Data
The script demonstrates inference using two protein-text pairs from the SwissProt dataset:
**Pair 1:**
- **Protein Sequence:** MSLEQKKGADIISKILQIQNSIGKTTSPSTLKTKLSEISRKEQENARIQSKL...
- **Text Description:** PROTEIN NAME: 2' cyclic ADP-D-ribose synthase AbTIR...
**Pair 2:**
- **Protein Sequence:** MRFQVIVAAATITMITSYIPGVASQSTSDGDDLFVPVSNFDPKSIFPEIKHP...
- **Text Description:** PROTEIN NAME: Glucan endo-1,3-beta-D-glucosidase 1...
These pairs demonstrate how the model aligns protein sequences with their corresponding functional descriptions. The model will compute embeddings for both the sequences and descriptions, then calculate their similarities using dot product scores.
### Expected Output
The script provides the following outputs:
1. **Latent Embedding Shapes**
- `z_p`: Protein sequence embeddings
- `z_t`: Text description embeddings
2. **Vector Magnitudes**
- L2 norms of both embedding types
3. **Dot Product Scores**
- Similarity matrix between embeddings
4. **Normalized Probabilities**
- Protein-normalized (softmax over rows)
- Text-normalized (softmax over columns)
#### Sample Output
```plaintext
=== Inference Results ===
Shape of z_p (protein latent): torch.Size([2, 512])
Shape of z_t (text latent): torch.Size([2, 512])
Magnitudes of z_p vectors: tensor([5.3376, 4.8237])
Magnitudes of z_t vectors: tensor([29.6971, 27.6714])
=== Dot Product Scores Matrix ===
tensor([[ 7.3152, 1.8080],
[ 3.3922, 16.6157]])
=== Normalized Probabilities ===
Protein-Normalized Probabilities:
tensor([[9.8060e-01, 3.7078e-07],
[1.9398e-02, 1.0000e+00]])
Text-Normalized Probabilities:
tensor([[9.9596e-01, 4.0412e-03],
[1.8076e-06, 1.0000e+00]])
=== Homology Matrix (Dot Product of Normalized z_p) ===
tensor([[1.0000, 0.1840],
[0.1840, 1.0000]])
```
## Stage 2: Facilitator Sampling
### Overview
In this stage, the **Facilitator model** takes the text embeddings (z_t) computed in Stage 1 and generates **facilitated embeddings (z_c)**. The facilitated embeddings align more closely with protein embeddings (z_p) and reduce discrepancies, as demonstrated by **Mean Squared Error (MSE)** and **Maximum Mean Discrepancy (MMD)** metrics.
### Model Weights
Before running the model, ensure you have:
- Configuration file: `stage2_facilitator_config.json`
- Pre-trained weights: `BioM3_Facilitator_epoch20.bin`
### Running the Facilitator Model
1. Run sampling:
```bash
python run_Facilitator_sample.py \
--json_path "stage2_facilitator_config.json" \
--model_path "./weights/Facilitator/BioM3_Facilitator_epoch20.bin" \
--input_data_path "test_PenCL_embeddings.pt" \
--output_data_path "test_Facilitator_embeddings.pt"
```
Arguments:
- **json_path**: Path to the JSON configuration file
- **model_path**: Path to the pre-trained facilitator weights
- **input_data_path**: Path to the input embeddings (z_t and z_p) generated in Stage 1
- **output_data_path**: Path to save the facilitated embeddings (z_c)
### Expected Output
The script provides the following outputs:
1. **Latent Embedding Shapes**
- z_t: Text embeddings
- z_p: Protein embeddings
- z_c: Facilitated embeddings
2. **Vector Magnitudes**
- L2 norms of z_t, z_p, and z_c for a given batch
3. **Mean Squared Error (MSE)**
- MSE between facilitated embeddings (z_c) and protein embeddings (z_p)
- MSE between text embeddings (z_t) and protein embeddings (z_p)
4. **Maximum Mean Discrepancy (MMD)**
- MMD between facilitated embeddings (z_c) and protein embeddings (z_p)
- MMD between text embeddings (z_t) and protein embeddings (z_p)
### Sample Output
```plaintext
=== Facilitator Model Output ===
Shape of z_t (Text Embeddings): torch.Size([2, 512])
Shape of z_p (Protein Embeddings): torch.Size([2, 512])
Shape of z_c (Facilitated Embeddings): torch.Size([2, 512])
=== Norm (L2 Magnitude) Results for Batch Index 0 ===
Norm of z_t (Text Embedding): 29.697054
Norm of z_p (Protein Embedding): 5.337610
Norm of z_c (Facilitated Embedding): 3.244318
=== Mean Squared Error (MSE) Results ===
MSE between Facilitated Embeddings (z_c) and Protein Embeddings (z_p): 0.069909
MSE between Text Embeddings (z_t) and Protein Embeddings (z_p): 1.612812
=== Max Mean Discrepancy (MMD) Results ===
MMD between Facilitated Embeddings (z_c) and Protein Embeddings (z_p): 0.000171
MMD between Text Embeddings (z_t) and Protein Embeddings (z_p): 0.005172
```
### What the Output Means
1. **Latent Shapes**:
- Ensures that z_c has the same shape as z_p and z_t
2. **Norms**:
- z_c is closer in magnitude to z_p compared to z_t, showing that the facilitator model effectively aligns the embeddings
3. **MSE**:
- Lower MSE for z_c and z_p compared to z_t and z_p confirms that z_c approximates z_p better
4. **MMD**:
- The MMD loss shows that the **distribution** of z_c is closer to z_p than the original z_t
### Saving the Output
The facilitated embeddings are saved to the specified output_data_path for further stages.
## Stage 3: ProteoScribe
🚧 **Coming Soon** 🚧
This stage will contain scripts and models for the ProteoScribe process. Check back for:
- Configuration files
- Model weights
- Running instructions
- Output examples
## Support
For questions or issues:
- Open an issue in this repository
- Contact: [Your contact information]
---
Repository maintained by the BioM3 Team