Skip to content

Python Open-source package for medical images processing and radiomics features extraction.

License

Notifications You must be signed in to change notification settings

MahdiAll99/MEDimage

Repository files navigation

PyPI - Python Version TestPyPI - version Continuous Integration Documentation Status License: GPL-3 Open In Colab

Table of Contents

1. Introduction

MEDimage is an open-source Python package that can be used for processing multi-modal medical images (MRI, CT or PET) and for extracting their radiomic features. This package is meant to facilitate the processing of medical images and the subsequent computation of all types of radiomic features while maintaining the reproducibility of analyses. This package has been standardized with the IBSI norms.

MEDimage overview

2. Installation

Python installation

The MEDimage package requires Python 3.8 or more. If you don't have it installed on your machine, follow the instructions here to install it.

Package installation

You can easily install the MEDimage package from PyPI using:

pip install medimage-pkg

For more installation options (Conda, Poetry...) check out the installation documentation.

3. Generating the documentation locally

The documentation of the MEDimage package was created using Sphinx. However, you can generate and host it locally by compiling the documentation source code using :

cd docs
make clean
make html

Then open it locally using:

cd _build/html
python -m http.server

4. A simple example

import os
import pickle

import MEDimage

# Load the DataManager
dm = MEDimage.DataManager(path_dicoms=os.getcwd())

# Process the DICOM files and retrieve the MEDimage object
med_obj = dm.process_all_dicoms()[0]

# Extract ROI mask from the object
vol_obj_init, roi_obj_init = MEDimage.processing.get_roi_from_indexes(
            med_obj,
            name_roi='{ED}+{ET}+{NET}',
            box_string='full')

# Extract features from the imaging data
local_intensity = MEDimage.biomarkers.local_intensity.extract_all(
                img_obj=vol_obj_init.data,
                roi_obj=roi_obj_init.data,
                res=[1, 1, 1]
            )

# Update radiomics results class
med_obj.update_radiomics(loc_int_features=local_intensity)

# Saving radiomics results
med_obj.save_radiomics(
                scan_file_name='STS-UdS-001__T1.MRscan.npy',
                path_save=os.getcwd(),
                roi_type='GrossTumorVolume',
                roi_type_label='GTV',
            )

5. Tutorials

We have created many tutorial notebooks to assist you in learning how to use the different parts of the package. More details can be found in the documentation.

6. IBSI Standardization

The image biomarker standardization initiative (IBSI) is an independent international collaboration that aims to standardize the extraction of image biomarkers from acquired imaging. The IBSI therefore seeks to provide image biomarker nomenclature and definitions, benchmark datasets, and benchmark values to verify image processing and image biomarker calculations, as well as reporting guidelines, for high-throughput image analysis. We participate in this collaboration with our package to make sure it respects international nomenclatures and definitions. The participation was separated into two chapters:

  • IBSI Chapter 1

    The IBSI chapter 1 is dedicated to the standardization of commonly used radiomic features. It was initiated in September 2016 and reached completion in March 2020. We have created two jupyter notebooks for each phase of the chapter and made them available for the users to run the IBSI tests for themselves. The tests can also be explored in interactive Colab notebooks that are directly accessible here:

    • Phase 1: Open In Colab
    • Phase 2: Open In Colab
  • IBSI Chapter 2

    The IBSI chapter 2 was launched in June 2020 and reached completion in February 2024. It is dedicated to the standardization of commonly used imaging filters in radiomic studies. We have created two jupyter notebooks for each phase of the chapter and made them available for the users to run the IBSI tests for themselves and validate image filtering and image biomarker calculations from filter response maps. The tests can also be explored in interactive Colab notebooks that are directly accessible here:

    • Phase 1: Open In Colab
    • Phase 2: Open In Colab

    Our team at UdeS (a.k.a. Université de Sherbrooke) has already submitted the benchmarked values to the IBSI uploading website.


Miscellaneous

You can avoid the next steps (Jupyter installation and environment setup) if you installed the package using Conda or Poetry according to the documentation.


You can view and run the tests locally by installing the Jupyter Notebook application on your machine:

python -m pip install jupyter

Then add the installed medimage environment to the Jupyter Notebook kernels using:

python -m ipykernel install --user --name=medimage

Then access the IBSI tests folder using:

cd notebooks/ibsi/

Finally, launch Jupyter Notebook to navigate through the IBSI notebooks using:

jupyter notebook

7. Acknowledgement

MEDimage is an open-source package developed at the MEDomics-Udes laboratory with the collaboration of the international consortium MEDomics. We welcome any contribution and feedback. Furthermore, we wish that this package could serve the growing radiomics research community by providing a flexible as well as IBSI standardized tool to reimplement existing methods and develop new ones.

8. Authors

9. Statement

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

Copyright (C) 2024 MEDomics consortium

GPL3 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 on about the LICENSE can be found here