Skip to main content

Microbial Genome Prospecting (MiGenPro) combines phenotype and genomic linked data. Migenpro serves as a framework for the generation of machine learning models that predict microbial traits from genome sequences.

Project description

Coverage codequality MIT Logo

MiGenPro - Microbial Genome Processing Toolkit

MiGenPro: A flexible linked data framework for phenotype-genotype prediction of microbial traits using machine learning.

Functionalities

  • Genome annotation based on taxonomy identifiers.
  • Data formatting and cleaning for microbial genome datasets.
  • Conversion of raw query data into structured feature and phenotype matrices.
  • Advanced filtering options to remove low-frequency features or phenotypes.
  • Parallel processing support for efficient handling of large datasets.
  • Easy training and prediction with machine learning models on microbial characteristics.

workflow_overview.svg

Quickstart

Installation with pip in a special conda environment

conda create -n migenpro -c bioconda ;   
conda activate migenpro ;
pip install -i https://test.pypi.org/simple/ migenpro

Run the workflow from phenotype graph to phenotype prediction using the following command:

migenpro --df --gq --ml --annotation \
  --sapp_jar ./binaries/SAPP-2.0.jar \
  --phenotype_query_file sparql_phenotype:demo_gram.sparql \
  --phenotype_hdt_file ./data/bacdive.hdt \
  --genome_query_file sparql_genome:DomainCopyNumber.sparql \
  --abs_frequency 1 \
  --threads 20 \
  --sampling_type SMOTEN \

The --param_grids flag can be used to optimise the parameters of the machine learning models. An example json file is available at: tests/resources/param_grid.json

The individual steps:

  1. Querying phenotype graphs
  2. Annotating genomes
  3. Querying the annotated genomes
  4. Training machine learning models
  5. Predicting phenotypes with existing models
  6. Feature importance analysis
  7. Summarising the results

1. Querying phenotype graphs

migenpro --df \
    --phenotype_query_file sparql_phenotype:demo_gram.sparql \
    --phenotype_hdt_file ./output/bacdive.hdt \
    --abs_frequency 1 \
    --sapp_jar binaries/SAPP-2.0.jar \
    --output ./output/

2. Annotating genomes

Genome annotation is done by default using the workflow: https://workflowhub.eu/workflows/1170/ this can be changed using the --cwl_file flag with a workflow of your choice granted that it takes a fasta file as input. You can speed up this process with the --threads flag.

migenpro --annotation \
    --genome_query_file sparql_genome:DomainCopyNumber.sparql \
    --sapp_jar ./binaries/SAPP-2.0.jar 

3. Querying the annotated genomes

migenpro --gq \
    --genome_query_file path/to/genome_query_file.sparql \
    --sapp_jar binaries/SAPP-2.0.jar \
    --output ./output/ 

4. Training machine learning models

We will now use the default parameters for training the models. If you wish to optimise the parameters you can do this using the --param_grids flag. To modify training settings you can use the

migenpro --ml \
      --feature_matrix ./output/feature_matrix.tsv \
      --phenotype_matrix ./output/phenotype_matrix.tsv \
      --output ./output/

5. Predicting phenotypes with existing models

You can do this through the docker container or from the source code.

  1. You will need to obtain a protein domain matrix of the desired genomes you can do this using the java code.
  2. For ease of use we will use the python scripts that were made with the following command. The default output directory is "output/mloutput" if desired you can change this using the --output [output_directory_location]
migenpro --ml \
      --feature_matrix ./output/feature_matrix.tsv \
      --phenotype_matrix ./output/phenotype_matrix.tsv \
      --output ./output/

6. Feature importance analysis

migenpro --fi \
        --models path/to/models \
        --feature_matrix path/to/features.tsv \
        --phenotype_matrix path/to/phenotype.tsv \
        --output ./output/

7. Summarising the results

Wait for the script to finish and retrieve the results of your prediction from the output directory. There the predictions are given in the following format:

Genome Phenotype Prediction Confidence
GCA123 Temperature mesophilic 0.96
migenpro --summarise \
        --output ./output/

Contributing

Pull the git repo:

git pull git@gitlab.com:pig-paradigm/migenpro.git
cd migenpro

Installing the needed dependencies.

A pip requirements.txt file is located in the installation directory which you can install using the following command.

conda create -n migenpro python=3.12.5 --file installation/requirements.txt

Recreating the results from the study

The files needed to recreate our results are located on https://zenodo.org/records/16995284. Apply the steps from this tutorial namely the /data_visualisation/construct_all_graphs_from_summaries.ipynb to recreate the graphs.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

migenpro-0.1.2.tar.gz (45.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

migenpro-0.1.2-py3-none-any.whl (54.7 kB view details)

Uploaded Python 3

File details

Details for the file migenpro-0.1.2.tar.gz.

File metadata

  • Download URL: migenpro-0.1.2.tar.gz
  • Upload date:
  • Size: 45.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for migenpro-0.1.2.tar.gz
Algorithm Hash digest
SHA256 4c556f95fa8db7cdc9f589376889b22bb5049c93fd1b17bc16d712f99fa75ab5
MD5 89ed55f7e7940d02d00cedcbd6d9b04e
BLAKE2b-256 d575eda6f5f2f38b4aed6235afedde75f6276a720bc73e5942e78f52ef185ce4

See more details on using hashes here.

File details

Details for the file migenpro-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: migenpro-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 54.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for migenpro-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fed52c2d43a791d20720d405f0737ac281f55f86b14f5ec5ae2b66bcc31c7fad
MD5 1c9232f26148e5f1340d727f7e8e91b0
BLAKE2b-256 be1788e715081791dc056b6c18ef5f8b9b4e21a484bfca0c92d18a16d21bb3bd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page