Skip to content

Latest commit

 

History

History
52 lines (47 loc) · 8.32 KB

File metadata and controls

52 lines (47 loc) · 8.32 KB

Predicting gut microbial behavior in human diseases via community metabolic modeling and machine learning

This repository contains the code and data to reproduce the results presented in the paper: Chaimaa Tarzi, Guido Zampieri, Suraj Verma, Stefano Campanaro, Neil Sullivan, Claudio Angione, "Predicting gut microbial behavior in human diseases via community metabolic modeling and machine learning".

This project focuses on developing a pipeline involving pairwise genome-scale metabolic modeling, statistical analysis, and machine learning to predict patient-specific disease states. Initially, genome-scale metabolic models are constructed and curated using CarveMe and ModelPolisher, followed by pairwise reconstruction to analyze species interactions within microbial communities.

The interactions are evaluated under defined metabolic conditions, classifying them into positive (e.g., mutualism) or negative (e.g., competition) based on growth rate impacts. The data is further analyzed using R, where patient-level features are visualized through UMAP and statistical tests, highlighting significant differences in exchange reactions.

A comprehensive machine learning framework is then employed, leveraging multiple classifiers including SVC, Random Forest, and Gradient Boosting to predict disease states. SHAP values are used to interpret the model, providing insights into feature importance and the underlying biological interactions. The ensemble model, combining the strengths of individual classifiers, enhances prediction accuracy and robustness.

Overview

The Predicting Patient-specific Disease States project is structured into five main parts:
  • Genome-scale metabolic model construction: a Jupyter Notebook that guides users through the process of building and refining GEMs.

  • Pairwise reconstruction and analysis: a pipeline for analyzing interactions between different metabolic models.

  • Growth rate calculation: a method to evaluate the growth rates of microbial species under defined conditions.

  • R analysis: statistical analysis and visualization of patient-level features using R.

  • Machine learning: this part involves applying machine learning techniques to analyze patient data and predict disease states. By utilizing various classifiers and SHAP values, we can interpret model predictions and identify key features influencing patient outcomes. Additionally, ensemble modeling techniques are employed to enhance prediction accuracy, leveraging the strengths of multiple classifiers for more robust results.

1. Genome-Scale Metabolic Model Construction

To get started, ensure you have the necessary input sequence files prepared and saved in the designated folders. CarveMe serves as an automated reconstruction tool that generates a simulation-ready metabolic model based on MAG sequence data.

Begin by executing the command line in Tutorial GEM reconstruction.ipynb script, which will create the initial draft GEM. Following this, the use of the MEMOTE test suite is important to run a series of standardized tests that assess various aspects of the model, generating a report that highlights its strengths and areas for improvement.

This automated testing process facilitates tracking incremental changes and ensures that the model meets community standards. Then to enhance and improve the quality of the model through improved annotation and curation.

Note: Ensure that all prerequisite software and dependencies for CarveMe, MEMOTE, and ModelPolisher are installed prior to running the scripts.

2. Pairwise Reconstruction and Analysis

In this step, users will place all polished genome-scale metabolic models in the single_model folder. The main script main.py will be used to run the pairwise modeling analysis. Steps to Create Pairwise Models involves the widget 4 Metabolic models of 2-species communities created using COBRA Tools for the Python computational framework (COBRApy). This allows for the integration of metabolic models to analyze interactions within microbial communities.

Under defined metabolic conditions in the data folder, the growth rates of each species are estimated both in isolation and in the presence of another species within the community in widget 5. This analysis helps to understand how species interact metabolically, and then the flux of each community exchange reaction is stored in the '_rawExRxns.csv'.

The interactions occurring between pairs of species under the metabolic conditions defined in widget 5 are predicted. In widget 6 the interactions can be classified as; positive interactions: commensalism and mutualism, where at least one species benefits and no species suffers. Negative Interactions: parasitism, amensalism, and competition, where at least one species suffers. Neutralism: No interactions between the species. Interactions are determined based on their effect on the predicted growth rates compared to growth in isolation. An effect greater than 10% indicates an interaction, with the direction classified as negative or positive based on whether the species grows slower or faster in the community.

4. R Analysis

This section details the R analysis performed to visualize and analyze patient-level features. Run R Code 'Aggregated_Patient_level_analysis.R' in the R folder to aggregate the pairwise model to the patient-level feature. Following this, UMAP and violin plots are performed on a community level and patient level. The exchange reactions are read from the _rawExRxns.csv file, and UMAP is used to visualize the data. It is also presented in the manuscript and illustrated in Figures 3 and 4.

In the next step statistical analysis of flux rates is performed the analysis includes pairwise t-tests to compare flux rates across different labels 'Community_reaction_enrichment.R'.

5. Machine learning

To prepare the data for machine learning analysis, we begin by organizing the samples into distinct categories. The 'community_model_extract.ipynb' script is utilized to label the samples accordingly. Healthy samples are assigned the label "Healthy," while COVID samples are labeled "COVID." This is achieved by concatenating the two datasets into a single DataFrame, combined_samples. This step ensures that any columns with missing values are removed, resulting in a cleaner dataset for analysis. Next, we run the DataPreprocessing.py script, which includes a function extract_interaction_type(cohort, label). This function processes each sample in the cohort, reading the data from CSV files and calculating the interaction types and mean flux values.

After preprocessing the data, we proceed to implement machine-learning models to predict patient-specific disease states in the folder 'ML model'. The first step involves training multiple classifiers and interpreting their results using SHAP values to understand feature importance. In the 6ML_classifier.py script, we train several models, including Support Vector Classifier (SVC), K-Nearest Neighbors (KNN), Gradient Boosting (GB), Decision Tree, Random Forest, and Gradient Boosting classifiers. The SHAP values are calculated to interpret the model predictions. This code calculates the SHAP values for each model, visualizes the distribution of SHAP values for the top features, and categorizes them based on their importance.

In the next step, run the Ensemble_model.py script to implement an ensemble model to improve prediction accuracy. The ensemble model combines the predictions of multiple classifiers using a voting mechanism. The following code snippet defines the ensemble model using SVC, KNN, and gradient-boosting classifiers.

Plots

Main plots and biological interpretation plots are plotted in R in the R folder.

Project Structure

Note: Ensure all pip dependencies are installed as listed in requirements.txt