Skip to content

Latest commit

 

History

History
102 lines (63 loc) · 4.45 KB

README.md

File metadata and controls

102 lines (63 loc) · 4.45 KB

PredFull

Visit http://predfull.com/ to try online prediction

This work was published on Analytical Chemistry: Full-Spectrum Prediction of Peptides Tandem Mass Spectra using Deep Neural Network

Kaiyuan Liu, Sujun Li, Lei Wang, Yuzhen Ye, Haixu Tang

The first model for predicting complete tandem mass spectra from peptides sequences, using a deep CNN neural network trained on over 2 million experimental spectra.

Free for academic uses.

Update History

  • 2022.05.19: Support input peptide of any length
  • 2021.05.18: Support predicting peptides with oxidized methionine.
  • 2021.01.01: Update example results.
  • 2020.08.22: Fixed performance issues.
  • 2020.05.25: Support predicting non-tryptic peptides.
  • 2019.09.01: First version.

Method

Based on the structure of the residual convolutional networks. Current precision (bin size): 0.1 Th.

model

How to use

Expect clone this project, you should download pm.h5 from google drive and place it into this folder.

Important Notes

  • The only modification (PTM) supported is oxidation on Methionine, otherwise only UNMODIFIED peptides are allowed. To indicate an oxidized methionine, use the format "M(O)".
  • This model assumes a FIXED carbamidomethyl on C
  • The length of input peptides are NOT limited, however, would expect poor performance with peptides longer than 30
  • The prediction will NOT output peaks with M/z > 2000
  • Predicted peaks that are weaker than STRONGEST_PEAK / 1000 are regarded as noises thus will be omitted from the final output.

Required Packages

Recommend to install dependency via Anaconda

  • Python >= 3.7
  • Tensorflow >= 2.3.0
  • Pandas >= 0.20
  • pyteomics
  • lxml

The Tensorflow has to be 2.30 or newer! A compatibility bug in Tensorflow made version before 2.3.0 can't load the model correctly. We'll release a new model once the Tensorflow team solve this.

Input format

The required input format is TSV, with the following columns:

Peptide Charge Type NCE
AAAAAAAAAVSR 2 HCD 25
AAGAAESEEDFLR 2 HCD 25
AAPAPTASSTININTSTSK 2 HCD 25
AAPAPM(O)NTSTSK 2 HCD 25

Apparently, 'Peptide' and 'Charge' columns mean what it says. The 'Type' must be HCD or ETD (in uppercase). NCE means normalized collision energy, set to 25 as default. Note that in the above examples the last peptide has an oxidized methionine, and it's the only modification supported now. Check example.tsv for examples.

Usage

Simply run:

python predfull.py --input example.tsv --model pm.h5 --output example_prediction.mgf

The output file is in MGF format

  • --input: the input file
  • --output: the output path
  • --model: the pretrained model

Prediction Examples

Note that intensities are shown by square rooted values

example 1

example 2

Performance Evaluation

We provide sample data on google drive and codes for you to evaluate the prediction performance. The hcd_testingset.mgf file on google drive contains ground truth spectra (randomly sampled from NIST Human Synthetic Peptide Spectral Library) that corresponding to items in example.tsv, while the example_prediction.mgf file contains pre-run predictions.

To evaluate the similarity, first download groud truth reference file hcd_testingset.mgf from google drive, then run:

python compare_performance.py --real hcd_testingset.mgf --pred example_prediction.mgf

  • --real: the ground truth file
  • --pred: the prediction file

You should get around ~0.789 average similarities using these two pre-given MGF files.

Make sure that items in example.tsv and hcd_testingset.mgf are of the same order! Don't permute items or add/delete items unless you will align them by yourself.

How to build & train the model

For those who are interested in reproducing this model, here we provide train_model.py of example codes to build and train the model.