Skip to main content

Python Open-source package for ensuring robust and reliable ML models deployments

Project description

MED3pa: Predictive Performance Precision Analysis in Medicine

Table of Contents

Overview

Overview

The MED3pa package is specifically designed to address critical challenges in deploying machine learning models, with a particular focus on the robustness and reliability of models under real-world conditions. It provides comprehensive tools for evaluating model stability and performance in the face of prediction uncertainty and disadvantaged data profiles associated with degraded model performance. This work is developed alongside the associated methodological article, published in the Journal of the American Medical Informatics Association (JAMIA): https://doi.org/10.1093/jamia/ocag034

Key Functionalities

  • Model Confidence Estimation: Through the MED3pa subpackage, the package measures the predictive confidence at both individual and group (profile) levels. This helps in understanding the reliability of model predictions and in making informed decisions based on model outputs.

  • Identification of disadvantaged Profiles: MED3pa analyzes data profiles for whom the BaseModel consistently leads to poor model performance. This capability allows developers to refine training datasets or retrain models to handle these edge cases effectively.

Subpackages

Overview

The package is structured into four distinct subpackages:

  • datasets: Stores and manages the dataset.
  • models: Handles ML models operations.
  • med3pa: Evaluates the model’s performance & extracts disadvantaged profiles.

This modularity allows users to easily integrate and utilize specific functionalities tailored to their needs without dealing with unnecessary complexities.

Getting Started with the Package

To get started with MED3pa, follow the installation instructions and usage examples provided in the documentation.

Installation

pip install MED3pa

A simple exemple

We have created a simple example of using the MED3pa package. See the full example here

from MED3pa.datasets import DatasetsManager
from MED3pa.med3pa import Med3paExperiment
from MED3pa.models import BaseModelManager
from MED3pa.visualization.mdr_visualization import visualize_mdr
from MED3pa.visualization.profiles_visualization import visualize_tree

...

# Initialize the DatasetsManager
datasets = DatasetsManager()
datasets.set_from_data(dataset_type="testing",
                       observations=x_evaluation.to_numpy(),
                       true_labels=y_evaluation,
                       column_labels=x_evaluation.columns)
# Initialize the BaseModelManager
base_model_manager = BaseModelManager(model=clf)

# Execute the MED3PA experiment
results = Med3paExperiment.run(
    datasets_manager=datasets,
    base_model_manager=base_model_manager,
    **med3pa_params
)

# Save the results to a specified directory
results.save(file_path='results/oym')

# Visualize results
visualize_mdr(result=results, filename='results/oym/mdr')
visualize_tree(result=results, filename='results/oym/profiles')

Acknowledgement

MED3pa is an open-source package developed at the MEDomicsLab laboratory. We welcome any contribution and feedback.

Authors

Statement

This package is part of https://www.medomics.ai/, a package providing research utility tools for developing precision medicine applications.

Copyright (C) 2024 MEDomics consortium

GPLV3 LICENSE SYNOPSIS

Here's what the license entails:

1. Anyone can copy, modify and distribute this software.
2. You have to include the license and copyright notice with each and every distribution.
3. You can use this software privately.
4. You can use this software for commercial purposes.
5. If you dare build your business solely from this code, you risk open-sourcing the whole code base.
6. If you modify it, you have to indicate changes made to the code.
7. Any modifications of this code base MUST be distributed with the same license, GPLv3.
8. This software is provided without warranty.
9. The software author or license can not be held liable for any damages inflicted by the software.

More information about the LICENSE can be found here

Supported Python Versions

The MED3pa package is developed and tested with Python 3.12.3.

Additionally, it is compatible with the following Python versions:

  • Python 3.11.x
  • Python 3.10.x
  • Python 3.9.x

While the package may work with other versions of Python, these are the versions we officially support and recommend.

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

med3pa-1.0.2.tar.gz (315.1 kB view details)

Uploaded Source

Built Distribution

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

med3pa-1.0.2-py3-none-any.whl (95.8 kB view details)

Uploaded Python 3

File details

Details for the file med3pa-1.0.2.tar.gz.

File metadata

  • Download URL: med3pa-1.0.2.tar.gz
  • Upload date:
  • Size: 315.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for med3pa-1.0.2.tar.gz
Algorithm Hash digest
SHA256 02f454b93097a4666a2941f5f2cde51dc4b74fb19d2f9f5160bb2a40e57a088f
MD5 0483e38462ccae8ad5692f10733ec21e
BLAKE2b-256 80bf30aa98f11d213361aca0e531a53b35a670e07bae9c9c2ce933162c232d7b

See more details on using hashes here.

Provenance

The following attestation bundles were made for med3pa-1.0.2.tar.gz:

Publisher: publish.yml on MEDomicsLab/MED3pa

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file med3pa-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: med3pa-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 95.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for med3pa-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 17d94b022f7ae82fd83dc23b013868edf326451e9b0c662b811858f7520173c2
MD5 e8ded1b18a41f3f84c30e412be40effd
BLAKE2b-256 ecd4bbb077c504435190d46c6622633dcfd8ec910c4dee4b0c7393233bca91c8

See more details on using hashes here.

Provenance

The following attestation bundles were made for med3pa-1.0.2-py3-none-any.whl:

Publisher: publish.yml on MEDomicsLab/MED3pa

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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