MIMIC: A Comprehensive Python Package for Simulating, Inferring, and Predicting Microbial Community Interactions
The study of microbial communities is vital for understanding their impact on environmental, health, and technological domains. The Modelling and Inference of MICrobiomes Project (MIMIC) introduces a Python package designed to advance the simulation, inference, and prediction of microbial community interactions and dynamics. Addressing the complex nature of microbial ecosystems, MIMIC integrates a suite of mathematical models, including previously used approaches such as Generalized Lotka- Volterra (gLV), Gaussian Processes (GP), and Vector Autoregression (VAR), plus newly developed models for integrating multiomic data, to offer a comprehensive framework for analysing microbial dynamics. By leveraging Bayesian inference and machine learning techniques, MIMIC accurately infers the dynamics of microbial communities from empirical data, facilitating a deeper understanding of their complex biological processes, unveiling possible unknown ecological interactions, and enabling the design of microbial communities. Such insights could help to advance microbial ecology research, optimizing biotechnological applications, and contributing to environmental sustainability and public health strategies. MIMIC is designed for flexibility and ease of use, aiming to support researchers and practitioners in microbial ecology and microbiome research. This software package contributes to microbial ecology research and supports ecological predictions and applications, benefiting the scientific and applied microbiology communities.
The repository is organized into the following main directories:
- AUTHORS.rst: A list of authors and contributors to the project.
- build/: Contains files generated by the build process.
- CONTRIBUTING.rst: Guidelines for contributing to the project.
- dist/: Contains distribution packages.
- docs/: Contains the project's documentation and Sphinx sources. - docs/source/notebooks/: Jupyter notebooks categorized by model type.
- examples/: Contains example scripts and notebooks demonstrating how to use the package.
- HISTORY.rst: A log of changes made in each version of the project.
- LICENSE: The license for the project.
- mimic/: The main directory for the project's source code. - data_imputation/: Data imputation-related modules. - model_infer/: Inference models. - model_simulate/: Simulation models. - utilities/: Utility scripts.
- README.rst: The main README file for the project, providing an overview and basic usage examples.
- environment.yml: The Conda environment file for macOS and Ubuntu.
- environment_windows.yml: The Conda environment file for Windows.
- requirements.in: The pip requirements input file.
- requirements.txt: The compiled list of Python dependencies.
- setup.py: The build script for the project.
- tests/: Contains unit tests for the project's code.
- .github/: Contains GitHub templates and workflows.
- Conda Package Manager: We recommend using Conda to manage the environment due to dependencies that may not be available via pip.
Clone the Repository
git clone https://github.com/ucl-cssb/MIMIC.git cd MIMIC
Create the Conda Environment
conda env create -f environment.yml
Activate the Environment
conda activate mimic_env
Install the Package
pip install -e .
Run the Code
Refer to the Usage section below for instructions on how to run the code.
Clone the Repository
git clone https://github.com/ucl-cssb/MIMIC.git cd MIMIC
Create the Conda Environment for Windows
On Windows, use the environment_windows.yml file:
conda env create -f environment_windows.yml
Activate the Environment
conda activate mimic_env
Install the Package
Install the package in editable mode:
pip install -e .
Run the Code
Refer to the Usage section below for instructions on how to run the code.
If you prefer to use pip without Conda, you can install the package and its dependencies by compiling requirements.in into requirements.txt:
# Step 1: Compile requirements.txt from requirements.in
pip install pip-tools
pip-compile requirements.in
# Step 2: Install dependencies
pip install -r requirements.txt
pip install -e .
Note: This method may not install all dependencies correctly, especially if there are packages that are only available via Conda. We recommend using the Conda installation method for full functionality.
A g++ compiler is required for the PyMC3 package.
To get started with MIMIC, you can explore a variety of detailed examples and comprehensive documentation.
- Documentation: Visit our [complete documentation](https://yourdocumentationurl.com) for detailed guides and more.
- Examples: Check out our [Examples Directory](https://github.com/ucl-cssb/MIMIC/tree/master/examples) which includes Jupyter notebooks demonstrating how to use MIMIC for different applications and scenarios.
The documentation is regularly updated with the latest information on usage, features, and examples to help you effectively utilize the MIMIC package in your research or applications.
We welcome contributions to the MIMIC project. Please refer to our Contribution Guidelines for more information.
This project is licensed under the LICENSE.
This project is based on methods proposed in this paper.
For questions or feedback, please contact us.