A trainable PyTorch reproduction of AlphaFold 3.
For more information on the model's performance and capabilities, see our technical report (biorxiv | pdf).
You can follow our twitter or join the conversation in the discord server.
- π The preview version of constraint feature is released to branch
constraint_esm
. - πͺ The training data pipeline is released.
- β‘οΈ The MSA pipeline is released.
- πΈ Use local colabfold_search to generate protenix-compatible MSA.
pip3 install protenix
If you're interested in model training, we recommand to run with docker.
If you set up Protenix
by pip
, you can run the following command to do model inference:
# run with example.json, which contains precomputed msa dir.
protenix predict --input examples/example.json --out_dir ./output --seeds 101
# run with multiple json files, the default seed is 101.
protenix predict --input ./jsons_dir/ --out_dir ./output
# if the json do not contain precomputed msa dir,
# add --use_msa_server to search msa and then predict.
# if mutiple seeds are provided, split them by comma.
protenix predict --input examples/example_without_msa.json --out_dir ./output --seeds 101,102 --use_msa_server
Detailed information on the format of the input JSON file and the output files can be found in input and output documentation .
Alternatively you can run inference by:
Note: by default, we do not use layernorm and EvoformerAttention kernels for simple configuration, if you want to speed up inference, see setting up kernels documentation .
bash inference_demo.sh
Arguments in this scripts are explained as follows:
input_json_path
: path to a JSON file that fully describes the input.dump_dir
: path to a directory where the results of the inference will be saved.dtype
: data type used in inference. Valid options include"bf16"
and"fp32"
.use_msa
: whether to use the MSA feature, the default is true.use_esm
: whether to use the ESM feature, the default is false.
If your input is pdb or cif file, you can convert it to json file for inference.
# run with pdb/cif file, and convert it to json file for inference.
protenix tojson --input examples/7pzb.pdb --out_dir ./output
We also provide an independent MSA search function, you can do msa search from json file or fasta file.
# run msa search with json file, it will write precomputed msa dir info to a new json file.
protenix msa --input examples/example_without_msa.json --out_dir ./output
# run msa search with fasta file which only contains protein.
protenix msa --input examples/prot.fasta --out_dir ./output
If you want to run Protenix inference with PyMol
, please refer to PyMOLfold.
If you're interested in model training, see training documentation .
See the performance documentation for memory and time consumption in training and inference.
π Protenix now allows users to specify contacts, enabling the model to leverage additional inter-chain information as constraint guidance! We benchmarked our constraint feature on Posebuster and a protein-antibody interfaces subset. Protenix demonstrates powerful ability in predicting more accurate structures. If you want to have a try, checkout to branch constraint_esm
for details about the input format.
Tips: Our online service already supports the new features, so feel free to try it now! Due to the preview version, the constraint support is only applicable in the branch
constraint_esm
. If you want to run inference via the command line, please check out to this branch first.
If you use this code or the model in your research, please cite the following paper:
@article{chen2025protenix,
title={Protenix - Advancing Structure Prediction Through a Comprehensive AlphaFold3 Reproduction},
author={Chen, Xinshi and Zhang, Yuxuan and Lu, Chan and Ma, Wenzhi and Guan, Jiaqi and Gong, Chengyue and Yang, Jincai and Zhang, Hanyu and Zhang, Ke and Wu, Shenghao and Zhou, Kuangqi and Yang, Yanping and Liu, Zhenyu and Wang, Lan and Shi, Bo and Shi, Shaochen and Xiao, Wenzhi},
year={2025},
doi = {10.1101/2025.01.08.631967},
journal = {bioRxiv}
}
Implementation of the layernorm operators referred to OneFlow and FastFold. We used OpenFold for some module implementations, except the LayerNorm
.
Please check Contributing for more details. If you encounter problems using Protenix, feel free to create an issue! We also welcome pull requests from the community.
Please check Code of Conduct for more details.
If you discover a potential security issue in this project, or think you may have discovered a security issue, we ask that you notify Bytedance Security via our security center or vulnerability reporting email.
Please do not create a public GitHub issue.
The Protenix project, including code and model parameters, is made available under the Apache 2.0 License, it is free for both academic research and commercial use.
We welcome inquiries and collaboration opportunities for advanced applications of our model, such as developing new features, fine-tuning for specific use cases, and more. Please feel free to contact us at [email protected].