- About the project
- Dataset
- Data preparation and feature matrices
- Machine Learning Models
- Results of the best ML model
- Python virtual environment and installation of required libraries
- How to run this app as a web service in a local server?
- How to run this app as a web service in the cloud?
- Structure of the repository
- Contact
Antimicrobial peptides (AMPs) are small bioactive drugs, commonly with fewer than 50 amino acids, which have appeared as promising compounds to control infectious disease caused by multi-drug resistant bacteria or superbugs. These superbugs are not treatable with the available drugs because of the development of some mechanisms to avoid the action of these compounds, which is known as antimicrobial resistance (AMR). According to the World Health Organization, AMR is one of the top ten global public health threats facing humanity in this century, so it is important to search for AMPs that combat these superbugs and prevent AMR.
However, the search for AMPs to combat superbugs by experimental methods is unfeasible because of the huge number of these compounds. So, it is required to explore other methods for handling this problem, and machine learning models could be great candidates for this task. Thus, in this project, I created some machine learning binary classifiers to predict the activity of antimicrobial peptides.
For this work, I took as a reference the notebook and video from Dataprofessor about this topic. Also, the datasets, some ideas, and references to compare the performance of the best model were obtained from this article.
The dataset for this project consists of text files (in FASTA format) with sequences of active and non-active AMPs. The active AMPs were obtained by experimental assays, while the non-active peptides were derived from computational methods. The following table summarizes the dataset partitions and the number of instances in each one.
Dataset partition | Size | AMPs | non-AMPs |
---|---|---|---|
Training | 19548 | 9781 | 9767 |
Test | 4656 | 2095 | 2561 |
External | 13888 | 3117 | 10771 |
AMPs can have more than one activity, including antibacterial, antifungal, antiparasitic, antiviral, among others. Training and Test partitions have active AMPs with a single activity, while the external partition has AMPs with more than one activity and it represents a real scenario of virtual screening with much more non-active AMPs than the active ones. You can find more details about these datasets in this article.
Also, I chose these benchmark datasets to compare the performance metrics of our best models with the results of other methods reported in this article.
The feature matrices to train machine learning models were obtained by calculating some molecular features from the amino acid sequences of AMPs. These features were obtained with the Pfeature Python library.
For this work, I calculated ten features that require only input and output files as parameters. These features are summarized in the table below.
Feature class | Description | Python Function |
---|---|---|
AAC | Amino acid composition | aac_wp |
ABC | Atom and bond composition | atc_wp, btc_wp |
PCP | Physico-chemical properties | pcp_wp |
RRI | Repetitive Residue Information | rri_wp |
DDR | Distance distribution of residues | ddr_wp |
SEP | Shannon entropy | sep_wp |
SER | Shannon entropy of residue level | ser_wp |
SPC | Shannon entropy of physicochemical property | spc_wp |
CTC | Conjoint Triad Calculation | ctc_wp |
CTD | Composition enhanced transition distribution | ctd_wp |
To know the details of these features and the entire Python library, you can read the Pfeature Manual.
Also, I used the CD-HIT software to remove the redundant sequences of the AMPs.
You can find the code for this part in the Feature matrices preparation section of this jupyter notebook.
First, I tested more than 30 ML binary classifiers using the LazyPredict Python library. I chose the best models according to some performance metrics such as accuracy, ROC AUC, precision, recall, F1 score, and Matthews Correlation Coefficient (MCC). Then, I fine-tuned the hyperparameters of the best models using sklearn's class GridSearchCV. Finally, considering the results of hyperparameter tuning and performance metrics, I obtained the best ML model to predict AMPs activity.
You can find the code for this part in the Machine learning models section of this jupyter notebook.
The best model was ExtraTreesClassifier with max_depth
of 50 and n_estimators
of 200 as hyperparameters (the others were set as default), and Amino acid Composition
(aac_wp) as feature matrix.
The performance metrics of this model on test and external datasets are presented below.
Performance metric | Test dataset | External dataset |
---|---|---|
ROC AUC | 0.90 | 0.90 |
Accuracy | 0.90 | 0.92 |
Precision | 0.94 | 0.79 |
Recall | 0.85 | 0.86 |
F1score | 0.89 | 0.82 |
MCC | 0.81 | 0.77 |
According to the evaluation results of our best model on test and external datasets, it is performing quite well. This article evaluated many the state of the art ML models for predicting AMPs using the same test and external datasets, and surprisingly the performance metrics of our model are very close to the results of the best ML models reported on this study.
You can find the code for this part in the Machine learning models section of this jupyter notebook, or in this Python script.
I used Pipenv to create a Python virtual environment, which allows the management of python libraries and their dependencies. Each Pipenv virtual environment has a Pipfile
with the names and versions of packages installed in the virtual environment, and a Pipfile.lock
, a JSON file that contains versions of packages, and dependencies required for each package.
To create a Python virtual environment with libraries and dependencies required for this project, you should clone this GitHub repository, open a terminal, move to the folder containing this repository, and run the following commands:
# Install pipenv
$ pip install pipenv
# Create the Python virtual environment
$ pipenv install
# Activate the Python virtual environment
$ pipenv shell
You can find a detailed guide on how to use pipenv here.
However, if you use the Dockerfile of this project, you do not need to run these commands because Docker installs all Operative System and Python requirements, as is explained in the next section.
Docker allows to create containers, which are isolated environments with specific system requirements such as OS, libraries, programs, dependencies, among others. You can follow instructions of the official documentation to install this program, depending on your OS and other details.
The specifications of the docker container are stated in the Dockerfile
, including the base image, instructions for installing libraries, files we need to copy from the host machine, and other instructions.
Once you have installed Docker, move to the folder containing this repository, open a terminal, and run the following commands:
# Build a docker image with specifications for this project stated in the Dockerfile
$ (sudo) docker build -t betalactamase-drug-discovery .
# Run the docker image
$ (sudo) docker run -it --rm -p 9696:9696 betalactamase-drug-discovery
The screen-shot below shows how your terminal should look like after running the docker image:
Then, you should open another terminal and run the predict-test.py
python script, and you will obtain a prediction if the AMP defined with the sequence
variable of the script will be active or non-active. The following screen-shot shows the expected result:
If you want to make predictions on other AMPs, replace the sequence
variable of the predict-test.py
python script with the corresponding sequence.
I used Heroku for hosting the web service in the cloud. For doing the deployment into the cloud, I followed a tutorial provided by one of the members of the Machine Learning Zoomcamp, which has details and code required to deploy a web service to the cloud with Heroku.
If you want to try this option, you can replace the url
variable of the predict-test.py
python script with this link: https://amps-prediction.herokuapp.com/predict, as is shown in the following screen-shot:
Then, you need to run the predict-test.py
python script in a terminal as in the last section, and you should obtain the same output without running the docker container locally.
The main files and directories of this repository are:
File/Folder | Description |
---|---|
EDA_Binary_classifiers_AMPs_activity.ipynb | Jupyter notebook with EDA, feature matrices preparation, machine learning models, performance metrics of all models, and evaluation of the best model |
train.py | Python script to train the best classifier |
predict.py | Python script to make predictions with the best classifier using a Flask's web service |
predict-test.py | Python script to send a request to the Flask's web service to make a prediction |
ExtraTreesClassifier_maxdepth50_nestimators200.zip | Compressed file of the best classifier |
Dockerfile | Docker file with specifications of the docker container |
Pipfile | File with names and versions of packages installed in the virtual environment |
Pipfile.lock | Json file that contains versions of packages, and dependencies required for each package |
Data/ | Original dataset, features matrices for training machine learning models obtained with Pfeature, and csv files with Amino acid composition feature matrix for training, test, and external datasets |
Output/ | Folder to save performance metrics and results of machine learning models |
Img/ | Folder to save images |
If you have comments or suggestions about this project, you can open an issue in this repository, or email me at sebasar1245@gamil.com.