Skip to content

BioinfoMachineLearning/PSBench

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

PSBench

Description

A large-scale benchmark for developing and evaluating methods for estimating protein complex structural model accuracy (EMA). It includes five components: (I) datasets for training and evaluating EMA methods; (II) scripts to evaluate the prediction results of EMA methods on the datasets; (III) scripts to reproduce the benchmark results of the baseline EMA methods in PSBench; (IV) scripts to label new benchmark datasets; and (V) baseline EMA methods which users can compare their EMA methods with. PSBench Pipeline, Methods and Metrics

Data Repository at Harvard Dataverse

The datasets in PSBench can be downloaded from the Harvard Dataverse repository here: https://dataverse.harvard.edu/dataset.xhtml?persistentId=doi:10.7910/DVN/75SZ1U

DOI : https://doi.org/10.7910/DVN/75SZ1U

Colab tutorial

A Google Colab tutorial is provided to facilitate the evaluation of EMA methods, reproduce the main results table from the manuscript, and generate comparative performance plots:

Open in Colab

Webserver for third-party model upload

For third party model uploads and future references, a webserver is provided at :

Visit PSBench Web Server

PSBench Installation (tested on Linux systems)

Clone the repository

git clone https://github.com/BioinfoMachineLearning/PSBench.git
cd PSBench/ 

Setup the environment

#create the PSBench environment
conda create -n PSBench python=3.10.12

# activate PSBench
conda activate PSBench

#install the required packages
pip install -r scripts/requirements.txt

Setup and test OpenStructure

# install OpenStructure
docker pull registry.scicore.unibas.ch/schwede/openstructure:latest

# test OpenStructure installation 
docker run -it registry.scicore.unibas.ch/schwede/openstructure:latest --version

I. Datasets for training and testing EMA methods

PSBench consists of the following 5 complementary large datasets for training and testing EMA methods, which can be downloaded from the Harvard Dataverse repository above:

  1. CASP15_inhouse_dataset
  2. CASP15_community_dataset
  3. CASP16_inhouse_dataset
  4. CASP16_community_dataset
  5. Multimer_7_2024_8_2025_dataset

In addition, CASP15_inhouse_TOP5_dataset (a subset of CASP15_inhouse_dataset) and CASP16_inhouse_TOP5_dataset (a subset of CASP16_inhouse_dataset) are also included into the PSBench. The two subsets were used to train and test GATE (a graph transformer EMA method) respectively. Users may train and test their machine learning methods on the same subsets and compare the results with GATE.

Users can put the downloaded datasets anywhere or in the installation directory of PSBench (recommended for easy management).

The dataset directory structure

After the datasets are downloaded from Harvard Dataverse and unzipped, the structure of the four main datasets should be:

๐Ÿ“ PSBench/
โ”œโ”€โ”€ ๐Ÿ“ CASP15_inhouse_dataset/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“„ CASP15_inhouse_dataset_summary.tab
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ AlphaFold_Features/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ Fasta/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ Predicted_Models/
โ”‚   โ””โ”€โ”€ ๐Ÿ“ Quality_Scores/
โ”œโ”€โ”€ ๐Ÿ“ CASP15_inhouse_TOP5_dataset/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“„ CASP15_inhouse_TOP5_dataset_summary.tab
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ AlphaFold_Features/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ Fasta/
โ”‚   โ””โ”€โ”€ ๐Ÿ“ Quality_Scores/
โ”œโ”€โ”€ ๐Ÿ“ CASP15_community_dataset/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“„ CASP15_community_dataset_summary.tab
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ Fasta/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ Predicted_Models/
โ”‚   โ””โ”€โ”€ ๐Ÿ“ Quality_Scores/
โ”œโ”€โ”€ ๐Ÿ“ CASP16_inhouse_dataset/
โ”œโ”€โ”€ ๐Ÿ“ CASP16_inhouse_TOP5_dataset/
โ”œโ”€โ”€ ๐Ÿ“ CASP16_community_dataset/
โ”œโ”€โ”€ ๐Ÿ“ Multimer_7_2024_8_2025_dataset/
โ””โ”€โ”€ ๐Ÿ“„ README.md

In the folder of each dataset, a summary file provides an overview of the dataset, the "Fasta" sub-folder contains the sequences of the protein complex targets in the FASTA format; the "Predicted_Models" sub-folder contains the predicted structural models in the PDB format; the "Quality_Scores" sub-folder contains the labels (quality scores) of the structural models. CASP15_inhouse_dataset and CASP16_inhouse_dataset have an additional sub-folder "AlphaFold_Features" containing AlphaFold-based features for the structural models.

Note: The two subsets (CASP15_inhouse_TOP5_dataset and CASP16_inhouse_TOP5_dataset) do not include the Predicted_Models directories to minimize redundancy. The structural models in the two subsets are already available in the "Predicted_Models" sub-folder in their respective full datasets (CASP15_inhouse_dataset and CASP16_inhouse_dataset).

Quality scores (labels)

For each structural model in the datasets, we provide the following 10 unique quality scores as labels:

Category Quality scores
Global Quality Scores tmscore (4 variants), rmsd
Local Quality Scores lddt
Interface Quality Scores ics, ics_precision, ics_recall, ips, qs_global, qs_best, dockq_wave

Additional features

For CASP15_inhouse_dataset and CASP16_inhouse_dataset, as well as their subsets (i.e., CASP15_inhouse_TOP5_dataset and CASP16_inhouse_TOP5_dataset), the following additional features are provided for each model:

Feature Description
model_type Indicates model type (AlphaFold2-multimer or AlphaFold3)
afm_confidence_score AlphaFold2-multimer confidence score
af3_ranking_score AlphaFold3 ranking score
iptm Interface predicted Template Modeling score
num_inter_pae Number of inter-chain predicted aligned errors (<5 ร…)
mpDockQ/pDockQ Predicted multimer DockQ score

For detailed explanations of each quality score and feature, please refer to Quality_Scores_Definitions

In each figures below, there are three pieces of information: (a) Model count. Number of models per target in the dataset. (b) Score Distribution. Box plots of each of six representative quality scores of the models for each target. (c) Example. Three representative models (worst, average, best) in terms of sum of the six representative quality scores for a target. Each model with two chains colored in blue and red is superimposed with the true structure in gray.

i. CASP15_inhouse_dataset

CASP15_inhouse_dataset consists of a total of 7,885 models generated by MULTICOM3 during the 2022 CASP15 competition. Example target in Figure (c): H1143. CASP15_inhouse_dataset

CASP15_inhouse_TOP5_dataset is a subset curated for GATE-AFM from the CASP15_inhouse_dataset, consisting of the top 5 models per predictor. Each predictor varies in its use of input multiple sequence alignments (MSAs), structural templates, and AlphaFold configuration parameters to generate structural models using the AlphaFold.

ii. CASP15_community_dataset

CASP15_community_dataset consists of a total of 10,942 models generated by all the participating groups during the 2022 CASP15 competition. Example target in Figure (c): H1135. CASP15_community_dataset

iii. CASP16_inhouse_dataset

CASP16_inhouse_dataset consists of a total of 1,009,050 models generated by MULTICOM4 during the 2024 CASP16 competition. Example target in Figure (c): T1235o. CASP16_inhouse_dataset

CASP16_inhouse_TOP5_dataset is a subset curated for GATE-AFM from the CASP16_inhouse_dataset, consisting of the top 5 models per predictor. Each predictor varies in its use of input multiple sequence alignments (MSAs), structural templates, and AlphaFold configuration parameters to generate structural models using the AlphaFold program.

iv. CASP16_community_dataset

CASP16_community_dataset consists of a total of 12,904 models generated by all the participating groups during the 2024 CASP16 competition. Example target in Figure (c): H1244. CASP16_community_dataset

v. Multimer_7_2024_8_2025_dataset

Multimer_7_2024_8_2025_dataset consists of a total of 400,400 AlphaFold3-generated models for 2,002 non-redundant multimeric protein entries deposited in the RCSB PDB between July 2024 and August 2025.

II. Script to evaluate EMA methods on a benchmark dataset

This script (evaluate_QA.py) is used to evaluate and compare how well different EMA methods perform. It calculates how closely the quality scores predicted by each EMA method for the structural models in a dataset match the true quality scores in terms of four metrics, including Pearson correlation, Spearman correlation, top-1 ranking loss, and AUROC.

Command:

python scripts/evaluate_QA.py \
  --input_dir $INPUT_DIR \ 
  --native_dir $NATIVE_DIR \ 
  --true_score_field $TRUE_SCORE_FIELD

Arguments:

Argument Description
--input_dir Input directory with model quality prediction files that include predicted quality scores by one or more EMA methods for each model. The predicted quaity scores will be evaluated against the true scores.
--native_dir Directory containing the true model quality scores (labels) of structural models for each target. The true model quality scores are available in each of the benchmark datasets (CASP15_community_dataset, CASP15_inhouse_dataset, CASP16_inhouse_dataset, CASP16_community_dataset) downloaded from the Harvard Dataverse repository.
--true_score_field Name of the column in the true score file that contains the true quality score to be evaluated against. Default is tmscore_usalign
--ema_method (Optional) The name of the EMA method column in the prediction file that you want to evaluate. If not provided, the script will evaluate the model quality prediction scores of all the EMA methods
--outfile (Optional) The name of the CSV file where the evaluation results will be saved. Default is evaluation_results.csv

Example:

Run the command below in the installation directory of PSBench:

python scripts/evaluate_QA.py \
  --input_dir ./Predictions/CASP16_inhouse_TOP5_dataset/ \
  --native_dir ./true_scores \
  --true_score_field tmscore_usalign_aligned

Format of model quality prediction files

Each prediction file should be a CSV file in the following format:

  • The first row is a header row, including the column names (e.g., model, EMA method 1, EMA method 2, ...).
  • The first column starting from the second row should be the names of structural models (e.g., model1, model2).
  • The remaining columns should be predicted quality scores for the models from one or more EMA methods (e.g., EMA method 1, EMA method 2).
model,EMA1,EMA2,...
model1,0.85,0.79, ...
model2,0.67,0.71, ...

Example of a model quality prediction file (./Predictions/CASP16_inhouse_TOP5_dataset/H1202.csv):

model,PSS,DProQA,VoroIF-GNN-score,VoroIF-GNN-pCAD-score,VoroMQA-dark,GCPNet-EMA,GATE-AFM,AFM-Confidence
deepmsa2_14_ranked_2.pdb,0.9545535989717224,0.02895,0.0,0.0,0.0,0.7771772742271423,0.5923953714036315,0.8254922444800168
afsample_v2_ranked_2.pdb,0.8873916966580978,0.0066,0.0,0.0,0.0,0.7705466747283936,0.575105558750621,0.8153403780624796
def_mul_tmsearch_ranked_0.pdb,0.9609340102827764,0.02353,0.0,0.0,0.0,0.7641939520835876,0.5981529354257233,0.8133504286051549
deepmsa2_1_ranked_4.pdb,0.96272264781491,0.02055,0.0,0.0,0.0,0.7685595154762268,0.5959772306691834,0.8178802534659162
deepmsa2_1_ranked_2.pdb,0.9606568380462726,0.02318,0.0,0.0,0.0,0.7671180963516235,0.5983494717414063,0.8183128442689481
afsample_v2_r21_not_ranked_1.pdb,0.9234104884318768,0.0192,0.0,0.0,0.0,0.7699458599090576,0.5879402631363266,0.8204161898081545
deepmsa2_0_ranked_3.pdb,0.9607991259640104,0.02123,0.0,0.0,0.0,0.7682469487190247,0.5953465198918304,0.8183400300533047
afsample_v1_r21_not_ranked_1.pdb,0.9156177377892032,0.02246,0.0,0.0,0.0,0.7822033762931824,0.5772502685580536,0.8226690041151985
folds_iter_esm_1_ranked_1.pdb,0.9471744215938304,0.01475,0.0,0.0,0.0,0.7621756196022034,0.5904867273330673,0.8215535911325099
deepmsa2_15_ranked_3.pdb,0.956274524421594,0.02606,0.0,0.0,0.0,0.7756944894790649,0.5937158219111754,0.8243908296207267

Output:

The script generates a CSV file summarizing the evaluation results. Each row corresponds to a different target (e.g., a protein complex), and for each EMA method, the following metrics are reported:

  • *_pearson: How strongly the predicted scores correlate with the true scores (Pearson correlation).
  • *_spearman: A rank-based version of correlation (Spearman correlation).
  • *_loss: The difference between the quality score of the truely best model of a target and that of the top-ranked model selected by the predicted quality scores.
  • *_auroc: AUROC from ROC analysis, measuring how well the EMA method distinguishes high-quality models (top 25%) from others.

Example of an output file:

target,PSS_pearson,PSS_spearman,PSS_loss,PSS_auroc,DProQA_pearson,DProQA_spearman,DProQA_loss,DProQA_auroc,VoroIF-GNN-score_pearson,VoroIF-GNN-score_spearman,VoroIF-GNN-score_loss,VoroIF-GNN-score_auroc,VoroIF-GNN-pCAD-score_pearson,VoroIF-GNN-pCAD-score_spearman,VoroIF-GNN-pCAD-score_loss,VoroIF-GNN-pCAD-score_auroc,VoroMQA-dark_pearson,VoroMQA-dark_spearman,VoroMQA-dark_loss,VoroMQA-dark_auroc,GCPNet-EMA_pearson,GCPNet-EMA_spearman,GCPNet-EMA_loss,GCPNet-EMA_auroc,GATE-AFM_pearson,GATE-AFM_spearman,GATE-AFM_loss,GATE-AFM_auroc,AFM-Confidence_pearson,AFM-Confidence_spearman,AFM-Confidence_loss,AFM-Confidence_auroc
H1202,0.0648102729743337,0.1695381876334342,0.028000000000000025,0.5,0.11790990707180772,-0.13413140758032455,0.0050000000000000044,0.5,-0.020603323167442494,-0.031220710744368295,0.016000000000000014,0.5095527954681397,-0.028282504057759977,-0.03428508620550331,0.016000000000000014,0.509130572464023,-0.028878249628187847,-0.034223373004110276,0.05900000000000005,0.5091129798388515,0.11945280299656955,0.04279138121740533,0.040000000000000036,0.5,-0.02194819533685046,0.10417440398523113,0.025000000000000022,0.5,-0.003912594407666805,-0.040927588302773835,0.040000000000000036,0.5

III. Reproducing the evaluation results of GATE and other baseline EMA methods in PSBench

Blind Prediction Results of Estimating the Accuracy of CASP16 In-house Models

Note: Replace $DATADIR with the path where the CASP16_inhouse_TOP5_dataset is stored.

Evaluation in terms of TM-score

python scripts/evaluate_QA.py --input_dir ./Predictions/CASP16_inhouse_TOP5_dataset/ --native_dir $DATADIR/Quality_Scores/ --true_score_field tmscore_usalign_aligned

Evaluation in terms of DockQ score

python scripts/evaluate_QA.py --input_dir ./Predictions/CASP16_inhouse_TOP5_dataset/ --native_dir $DATADIR/Quality_Scores/ --true_score_field dockq_wave

Blind Prediction Results in CASP16 EMA Competition

Note: Replace $DATADIR with the path where the CASP16_community_dataset is stored.

python scripts/evaluate_QA.py --input_dir ./Predictions/CASP16_community_dataset/ --native_dir $DATADIR/Quality_Scores/ --true_score_field tmscore_mmalign

IV. Scripts to generate labels for a new benchmark dataset

Users can use the tools in PSBench to create their own benchmark dataset. Following are the prerequisites to generate the labels for a new benchmark dataset:

Required Input Data

  • Predicted protein complex structures (structural models)
  • Native (true) structures
  • Protein sequence files in FASTA format

Tools (downloaded or installed in the PSBench installation section)

  • OpenStructure
  • USalign
  • Clustalw

Generate True Quality Scores (Labels) for Predicted Structural Models

Run the generate_quality_scores.sh pipeline using the command below

sh generate_quality_scores.sh \
  --fasta_dir $FASTA_DIR \
  --predicted_dir $PREDICTED_DIR \
  --native_dir $NATIVE_DIR \
  --outdir $OUTDIR \
  --usalign $USALIGN \
  --clustalw $CLUSTALW \
  --targets $TARGETS

Required Arguments:

Argument Description
--fasta_dir Path to the directory containing protein sequence files in FASTA format (named as <target>.fasta)
--predicted_dir Path to the base directory containing predicted models (subdirectory per target)
--native_dir Path to the directory containing native protein structure files in PDB format (named as <target>.pdb)
--outdir Path to the base output directory for results
--usalign Path to the USalign program (e.g., tools/USalign)
--clustalw Path to the ClustalW program (e.g., tools/clustalw1.83/clustalw)
--targets Space-separated list of target names to process (e.g., H1204 H1213)

For each target (e.g. H1204), ensure the following:

  • Sequence file in FASTA format: /path/to/PSBench/Fasta/H1204.fasta
  • Predicted structural models: /path/to/PSBench/predicted_models/H1204/*.pdb
  • Native (true) structure in the PDB format: /path/to/PSBench/native_models/H1204.pdb

Example:

cd scripts/
sh generate_quality_scores.sh \
  --fasta_dir /path/to/PSBench/Fasta/ \
  --predicted_dir /path/to/PSBench/predicted_models/ \
  --native_dir /path/to/PSBench/native_models/ \
  --outdir /path/to/PSBench/output/ \
  --usalign /path/to/PSBench/scripts/tools/USalign \
  --clustalw /path/to/PSBench/scripts/tools/clustalw1.83/clustalw \
  --targets H1204 H1213

Output:

Output folder will have subdirectories for each target (eg. /path/to/PSBench/output/ will have H1204/ H1213/). Each target subdirectory will have the following:

  • filtered_pdbs/ : directory where aligned and filtered structural models and native structures are saved
  • H1204_quality_scores.csv : CSV containing the true quality scores for each model of the target
  • results/ : directory where outputs of OpenStructure and USalign runs are saved
  • temp/ : temporary working directory for structure alignment and filtering process

Preprocessing, edge cases and solutions

  1. Preprocessing:

    • Native structures are converted from CIF to PDB when needed
    • Native PDB structures are reindexed to match full-length protein sequences
    • Non-protein components (e.g., ligands, metal ions) are excluded.
    • Insertion codes in residue indices are replaced with monotonic numbering

    (See scripts/preprocessing for scripts)

  2. Alignment & Quality Score Computation:

    • Structures are aligned based on sequence identity.
    • Scores like RMSD, lDDT are computed with no additional preprocessing.
    • TM-scores are calculated using few approaches:
      • tmscore_mmalign (CASP16-style parameters)
      • tmscore_usalign (CASP15-style parameters)
      • Residue reindexing is applied for tmscore_usalign_aligned to ensure correct residue-residue correspondence
  3. Edge Cases:

    • Some models from CASP community datasets may fail due to format inconsistencies or non-monotonic residue numbering (e.g., H1272TS191_1 from the CASP16_community_dataset)
    • OpenStructure refuses to align chains that have less than six valid residues
  4. Fallbacks & Exclusions:

    • If OpenStructure fails but US-align succeeds, the model is retained and the TM-score from US-align is reported
    • For example, in the Multimer_7_2024_8_2025_dataset, some targets like 9DYY, 9KAP, and 9O7J fail in OpenStructure due to having fewer than six valid residues. The USalign-based TM-scores are still included
    • Models that fail in both frameworks are excluded. Such failures are rare (less than 0.002% out of more than 1.4 million processed models)

Optional : Generate AlphaFold features when available

Run the generate_af_features.sh pipeline

Required Arguments:
Argument Description
--fasta_dir Directory containing sequence files of protein targets in FASTA format (e.g., /path/to/fasta)
--pdb_dir Directory containing predicted structural model subfolders (e.g., /path/to/pdbs)
--pkl_dir Directory containing AlphaFold pickle (.pkl) subfolders (e.g., /path/to/pkls)
--outdir Directory where output CSV files will be saved (e.g., /path/to/outdir)
--targets List of target names (e.g., H1204 H1213)

For each target (e.g. H1204), ensure the following:

  • FASTA file: /path/to/PSBench/Fasta/H1204.fasta
  • Predicted models: /path/to/PSBench/predicted_models/H1204/*.pdb
  • Pickle files: /path/to/PSBench/predicted_models_pickles/H1204/*.pkl

Example:

cd scripts/
sh generate_af_features.sh \
  --fasta_dir /path/to/PSBench/Fasta/ \
  --predicted_dir /path/to/PSBench/predicted_models/ \
  --pkl_dir /path/to/PSBench/predicted_models_pickles/ \
  --outdir /path/to/PSBench/output/ \
  --targets H1204 H1213

Output:

Output folder will have target_af_features.csv for each target (eg. H1204_af_features.csv).

V. Baseline EMA methods for comparison with a new EMA method

Here are several publicly available baseline EMA methods which users can comapre their methods with:

It is worth noting that CASP15_inhouse_dataset and CASP16_inhouse_dataset contain AlphaFold2-Multimer self-estimated confidence scores for the structural models in the two datasets. They can also serve as a baseline to be compared with new EMA methods.

Acknowledgements

PSBench builds upon the source code and data from the following projects:

Reference

@inproceedings{neupane2025psbench,
  title     = {PSBench: a Large-Scale Benchmark for Estimating the Accuracy of Protein Complex Structural Models},
  author    = {Neupane, Pawan and Liu, Jian and Cheng, Jianlin},
  booktitle = {The Thirty-Ninth Annual Conference on Neural Information Processing Systems (NeurIPS)},
  year      = {2025},
  note      = {to appear}
}

About

A large and comprehensive benchmark for estimating the accuracy of protein complex structural models

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •