Structure-guided RNA foundation model.
Project description
A fully open structure-guided RNA foundation model for robust structural and functional inference
Heqin Zhu
·
Ruifeng Li
·
Feng Zhang
·
Fenghe Tang
Tong Ye
·
Xin Li
·
Yunjie Gu
·
Peng Xiong*
·
S. Kevin Zhou*
Submitted
Overview
Abstract
RNA language models have achieved strong performance across diverse downstream tasks by leveraging large-scale sequence data. However, RNA function is fundamentally shaped by its hierarchical structure, making the integration of structural information into pretraining essential. Existing methods often depend on noisy structural annotations or introduce task-specific biases, limiting model generalizability. Here, we introduce structRFM, a structure-guided RNA foundation model that is pretrained by implicitly incorporating large-scale base pairing interactions and sequence data via a dynamic masking ratio to balance nucleotide-level and structure-level masking. structRFM learns joint knowledge of sequential and structural data, producing versatile representations-including classification-level, sequence-level, and pairwise matrix features-that support broad downstream adaptations. structRFM ranks top models in zero-shot homology classification across fifteen biological language models, and sets new benchmarks for secondary structure prediction, achieving F1 scores of 0.873 on ArchiveII and 0.641 on bpRNA-TS0 dataset. structRFM further enables robust and reliable tertiary structure prediction, with consistent improvements in both 3D accuracy and extracted 2D structures. In functional tasks such as internal ribosome entry site identification, structRFM achieves a 49% performance gain. These results demonstrate the effectiveness of structure-guided pretraining and highlight a promising direction for developing multi-modal RNA language models in computational biology.
Key Achievements
- Zero-shot homology classification: Top-ranked among 15 biological language models.
- Secondary structure prediction: Sets new state-of-the-art performances.
- Tertiary structure prediction: Derived method Zfold improves RNA Puzzles accuracy by 19% over AlphaFold3.
- Functional inference: Boosts F1 score by 49% on IRES identification.
Installation
Requirements
- python3.8+
- anaconda
Instructions
- Clone this repo.
git clone https://github.com/heqin-zhu/structRFM.git
cd structRFM
- Create and activate conda environment.
conda env create -f structRFM_environment.yaml
conda activate structRFM
- Download and decompress pretrained structRFM (305 MB).
wget https://github.com/heqin-zhu/structRFM/releases/latest/download/structRFM_checkpoint.tar.gz
tar -xzf structRFM_checkpoint.tar.gz
- Set environment varible
structRFM_checkpoint.
export structRFM_checkpoint=PATH_TO_CHECKPOINT # modify ~/.bashrc for permanent setting
Usage
Extract RNA sequence features
import os
from structRFM.infer import structRFM_infer
from_pretrained = os.getenv('structRFM_checkpoint')
model_paras = dict(max_length=514, dim=768, layer=12, num_attention_heads=12)
model = structRFM_infer(from_pretrained=from_pretrained, **model_paras)
seq = 'AGUACGUAGUA'
print('seq len:', len(seq))
feat_dic = model.extract_feature(seq)
for k, v in feat_dic.items():
print(k, v.shape)
'''
seq len: 11
cls_feat torch.Size([768])
seq_feat torch.Size([11, 768])
mat_feat torch.Size([11, 11])
'''
Build structRFM for finetuning
import os
from structRFM.model import get_structRFM
from structRFM.data import preprocess_and_load_dataset, get_mlm_tokenizer
from_pretrained = os.getenv('structRFM_checkpoint')
tokenizer = get_mlm_tokenizer(max_length=514)
model = get_structRFM(dim=768, layer=12, num_attention_heads=12, from_pretrained=from_pretrained, pretrained_length=None, max_length=514, tokenizer=tokenizer)
Pretraining
Download sequence-structure dataset
The pretrianing sequence-structure dataset is constructed using RNAcentral and BPfold. We filter sequences with a length limited to 512, resulting about 21 millions sequence-structure paired data. It can be downloaded at Zenodo (4.5 GB).
Run pretraining
- Modify variables
USER_DIRandPROGRAM_DIRinscripts/run.sh, - Specify
DATA_PATHandrun_namein the following command,
Then run:
bash scripts/run.sh --batch_size 96 --epoch 100 --lr 0.0001 --tag mlm --mlm_structure --max_length 514 --model_scale base --data_path DATA_PATH --run_name structRFM_512
For more information, run python3 main.py -h.
Downstream Tasks
Download all data (3.7 GB) and checkpoints (2.2 GB) from Zenodo, and then place them into corresponding folder of each task.
- Zero-shot inference
- Structure prediction
- Function prediction
Acknowledgement
We appreciate the following open-source projects for their valuable contributions:
LICENSE
Citation
If you find our work helpful, please cite our paper:
@article {structRFM,
author = {Zhu, Heqin and Li, Ruifeng and Zhang, Feng and Tang, Fenghe and Ye, Tong and Li, Xin and Gu, Yujie and Xiong, Peng and Zhou, S Kevin},
title = {A fully-open structure-guided RNA foundation model for robust structural and functional inference},
elocation-id = {2025.08.06.668731},
year = {2025},
doi = {10.1101/2025.08.06.668731},
publisher = {Cold Spring Harbor Laboratory},
URL = {https://www.biorxiv.org/content/early/2025/08/07/2025.08.06.668731},
journal = {bioRxiv}
}
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file structrfm-0.0.8.tar.gz.
File metadata
- Download URL: structrfm-0.0.8.tar.gz
- Upload date:
- Size: 24.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
16b4e4262b97b5c5f0202676987907663a58e18345250a92ca642bda3e53eff5
|
|
| MD5 |
8a7832cceff1422967d217768e9c07bb
|
|
| BLAKE2b-256 |
572f004181effd952a9e49c9bc0c72dcd8761b260ae6bd96a3c464e888f25704
|
Provenance
The following attestation bundles were made for structrfm-0.0.8.tar.gz:
Publisher:
publish.yml on heqin-zhu/structRFM
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
structrfm-0.0.8.tar.gz -
Subject digest:
16b4e4262b97b5c5f0202676987907663a58e18345250a92ca642bda3e53eff5 - Sigstore transparency entry: 830680882
- Sigstore integration time:
-
Permalink:
heqin-zhu/structRFM@35c5f416e0f8395c459ae65c691200a2ddff3eb3 -
Branch / Tag:
refs/tags/v0.0.8 - Owner: https://github.com/heqin-zhu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@35c5f416e0f8395c459ae65c691200a2ddff3eb3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file structrfm-0.0.8-py3-none-any.whl.
File metadata
- Download URL: structrfm-0.0.8-py3-none-any.whl
- Upload date:
- Size: 24.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec624409a3949164cf9397f3fdc0ed475710aad8c54862e0ff67b967c4df700b
|
|
| MD5 |
a81a9a840ccface99437b386a30504c3
|
|
| BLAKE2b-256 |
95e12ca54623a1f992ca3c8de7ae824bbb0e40065fbe869a6e38898a9839cbf5
|
Provenance
The following attestation bundles were made for structrfm-0.0.8-py3-none-any.whl:
Publisher:
publish.yml on heqin-zhu/structRFM
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
structrfm-0.0.8-py3-none-any.whl -
Subject digest:
ec624409a3949164cf9397f3fdc0ed475710aad8c54862e0ff67b967c4df700b - Sigstore transparency entry: 830680918
- Sigstore integration time:
-
Permalink:
heqin-zhu/structRFM@35c5f416e0f8395c459ae65c691200a2ddff3eb3 -
Branch / Tag:
refs/tags/v0.0.8 - Owner: https://github.com/heqin-zhu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@35c5f416e0f8395c459ae65c691200a2ddff3eb3 -
Trigger Event:
push
-
Statement type: