Functional Prediction of Proteins - CAFA5 Challenge
This capstone project investigates Machine Learning techniques to enhance the accuracy of functional prrediction of proteins. Proteins are responsible for many activities in our tissues, organs, and bodies and they also play a central role in the structure and function of cells. Proteins are large molecules composed of 20 types of building-blocks known as amino acids. This amino-acid sequence determines the 3D structure and conformational dynamics of the protein, and that, in turn, determines its biological function. Due to ongoing genome sequencing projects, we are inundated with large amounts of genomic sequence data from thousands of species, which informs us of the amino-acid sequence data of proteins for which these genes code. The accurate assignment of biological function to the protein is key to understanding life at the molecular level. The Gene Ontology (GO) is a concept hierarchy that describes the biological function of genes and gene products at different levels of abstraction (Ashburner et al., 2000). It is a good model to describe the multi-faceted nature of protein function.
I have used Neural networks(base line as provided in CAFA challenge), multi output logistic regression to assess the function of the proteins.
Since this is a multilable problem, neural networks was a no-brainer choice. However, I was interested in comparing the classi ML models too, which is where MultiOutput Logistic Regreession comes along. While no hyper paramter tuning was employed for NNs, Grid Search was done to estimate the best hyper parameters for Logistic Regression.
Functional Prediction of Proteins.
https://www.kaggle.com/competitions/cafa-5-protein-function-prediction/data
Exploratory Data Analysis:
- Reporting the distribution of labels.
- To understand which GO terms are most frequently occuring.
- Obtaining protein embeddings to meaningfully use the sequence data in classification. Biopython library was used in loading sequences and protein embeddings created by Sergei Fironov using the Rost Lab's T5 protein language model was utilized.
- To subsample the GO terms to assign such that models do not run too long - Subssampling of labels was done per 'aspect' term such that the distribution of the aspect was maintained in the terms to the best possible extent
Classification Methods Used:
- Neural Networks
- MultiOutput Logistic Regression
- MultiOutput Ridge Classifier
- MultiOutput Random Forest Classifier
Grid search and hyperparameter tuning was done on the first 1000 - 2000 samples. The best model identified was then trained on the complete training set. This was done after I observed that grid searching on such a large dataset was taking more than a day on laptop.
Number of Unique Protein IDs: 142246 Number of GO terms shared by the proteins: 31466 Number of Aspects or Functional Classes being Represented: 3 Each protein is represented by many GO terms, in turn having multiple aspects to its functionality
Among the GO Terms, the following aspects of the proteins are distributed as shown in the pie-chart
Based on the ratio of the aspects, the most frequent GO terms in each category were chosen such that we down sample the labels to be predicted while maintaining the distribution of the aspect to the closest possible extent.
In the Kaggle Challenge, the baseline model was that of Neural Networks which acheived 98% accuracy.
Logistic Regression Classifier:
GO:0001850 always seems to have high false negative rate. At some point it will become necessary to diagnose why a certain label always gets misclassified more number of times than others.
Classifier | Accuracy | Precision | Recall | F1 Score |
---|---|---|---|---|
Neural Nets | 98 | |||
Logistics Regression | 83.22 | 0.64 | 0.44 | 0.47 |
Ridge Regression Classifier | 83.14 | 0.66 | 0.42 | 0.44 |
Random Forest Classifier | 81.28 | 0.52 | 0.26 | 0.24 |
Overall Neural Nets definitelly appears to model and predict the data better than machine learning models. However, it must be noted that, it took a lot longer to train machine learning models. This was a bottle neck in grid searching and tuning the hyper paramters. Among the three classifiers, if I were to have resource and re-train an ML model, I would choose Logistic Regression.
The real meaning would be if we can identify the function of the protein in terms of its weights in Biological Process, Cellular Process and Molecular Function. Having that information wil give us a lot more usable information of the protein.