MASSP stands for Membrane Association and Secondary Structure Prediction. It is a general method for predicting secondary structure, transmembrane segment and topology, and residue orientation of proteins. MASSP was compared with several classic and state-of-the-art predictors and was shown to perform equally well as the best methods in the field while being generalized to different classes of proteins. If you find MASSP useful in your work, please consider citing the MASSP paper:
- Li B, Mendenhall J, Capra JA, and Meiler J, A multi-task deep-learning method for predicting membrane associations and secondary structures of proteins, J. Proteome Res. 2021, 20, 8, 4089–4100, https://doi.org/10.1021/acs.jproteome.1c00410
MASSP depends the following external software packages to generate multiple sequence alignments (MSA) and position-specific-scoring matrices.
- HHblits
- The BioChemical Library (BCL)
It was developed and tested under the following Python/Keras/TensforFlow environment.
- Keras 2.3.1 with TensorFlow 2.0.0 as the backend.
- Python 3.7
Clone MASSP to a local directory.
git clone https://github.com/computbiolgeek/massp.git
Follow the instructions here to install and configure HHblits. We used the UniRef20 database in this work, which can be downloaded here. Then export the following environment variables for MASSP to run.
# path to sequence database
export SEQ_DB="path to local UniRef20 database"
# path to hhblits binary
export HHBLITS="path to hhblits binary"
# path to reformat.pl
export REFORMAT="path to reformat.pl"
Follow the instructions here to obtain and install the BCL locally. Then export the BCL for MASSP to run.
export BCL="path to the bcl executable"
There are many resources out there that one can follow to install TensorFlow and Keras. We found it easiest to install them with the Anaconda Python distribution.
- Get the Python 3.7 version Anaconda 2019.10 for Linux installer.
- Follow the instructions here to install it.
- Open anaconda-navigator from the comand line. Go to Environments and search for keras and tensorflow, install all the matched libraries.
Alternatively, one can create a conda environment to use Keras and TensorFlow, i.e.:
# create conda environment for deep learning/neural networks
conda create --name massp python=3.7
conda activate massp
# install GPU version if you have a GPU already configured for deep learning
conda install keras-gpu==2.3.1
conda install tensorflow-gpu==2.0.0
# otherwise install the CPU version
conda install keras==2.3.1
conda install tensorflow==2.0.0
Change to the examples/
subdirectory to run the following two examples. You do not need to have HHblits or the BCL configured to run these examples. The position-specific-scoring matrices for them have been pre-computed and provided. However, you do need to configure the Python/Keras/TensorFlow environment. In addition, lines 27-30 in massp.py
will need to be commented out.
# 2yevB
python ../massp/massp.py -q 2yevB.fasta -p 2yevB.pssm --cnn-model ../models/final_cnn_model.h5 --lstm-model ../models/final_lstm_model.h5 --tokenizer ../models/tokenizer.pickle --output-prefix 2yevB
# 4c00A
python ../massp/massp.py -q 4c00A.fasta -p 4c00A.pssm --cnn-model ../models/final_cnn_model.h5 --lstm-model ../models/final_lstm_model.h5 --tokenizer ../models/tokenizer.pickle --output-prefix 4c00A
Then run the following command to compute performance metrics.
# remove unresolved residues in the structure
python ../scripts/process_sse_prediction.py ../ciphipsi/2yevB.ciphipsi 2yevB_predicted_sse.fasta 2yevB
python ../scripts/process_sse_prediction.py ../ciphipsi/4c00A.ciphipsi 4c00A_predicted_sse.fasta 4c00A
# run SOV_refine.pl to compute performance metrics
perl ../scripts/SOV_refine.pl 2yevB_true_sse.fasta 2yevB_processed_sse.fasta
perl ../scripts/SOV_refine.pl 4c00A_true_sse.fasta 4c00A_processed_sse.fasta
- Li B, Mendenhall J, Capra JA, and Meiler J, A multi-task deep-learning method for predicting membrane associations and secondary structures of proteins, J. Proteome Res. 2021, 20, 8, 4089–4100, https://doi.org/10.1021/acs.jproteome.1c00410
- Liu, T. and Z. Wang, SOV_refine: A further refined definition of segment overlap score and its significance for protein structure similarity. Source Code Biol Med, 2018. 13: p. 1.