Skip to main content

Reads in medical images and structures them into 3D arrays with associated ROI/POIs if they exist.

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description

MedicalImageConverter

Version 2.0 and later releases contain a structure than in previous versions.

MedicalImageConverter is a Python package for working with medical image files. Currently, it is only works with dicom files with future plans to read in .mhd, .stl, .3mf files. An image instance is created for each respective image found, a 3D numpy array is created to contain the pixel data and various variables exist for the tag information. If there is an associated RTSTRUCT file for an image then they are added to the image instance. The user need only to give the top level folder and not read in each image folder one by one. Also, the dicom files for multiple images can exist in a single folder, it will separate them using the tag information.

The module currently imports 5 different modalities and RTSTRUCT files. The accepted modalites are:

  1. CT
  2. MR
  3. US
  4. MG
  5. DX

The CT and MR modalities have been tested extensively, along with their respective ROIs. The other 3 modalities have been tested but only on a few datasets a piece. For RTSTRUCTS, only those referencing CT and MR have been tested.

The images will be converted to Feet-First-Supine (if not so already), and the image position will be updated to reflect the needed rotations.

Disclaimer: All the files will be loaded into memory so be sure you have enough RAM available. Meaning don't select a folder path that contains 10s of different patient folders because you could possibly run out of RAM. Also, this module does not distinguish between patient IDs or patient names.

Installation

Using pip:

pip install MedicalImageConverter

Example 1

The user sets a path to the folder containing the dicom files or highest level folder with subfolders containing dicom files.

import MedicalImageConverter as mic

path = r'/path/to/folder'

reader = mic.Reader(folder_path=path)
reader.read_dicoms()

Example 2

The user has more options if they are specifics requirements.

  1. file_list - if the user already has the files wanted to read in, must be in type list
  2. exclude_files - if the user wants to not read certain files
  3. only_tags - does not read in the pixel array just the tags
  4. only_modality - specify which modalities to read in, if not then all modalities will be read
  5. only_load_roi_names - will only load rois with input name

Note: if folder_path and file_list are both input, then folder_path will be used and not both.

import MedicalImageConverter as mic

file_list = ['filepath1.dcm', 'filepath2.dcm', ...]
exclude_files = ['filepath10.dcm', 'filepath11.dcm', ...]

reader = mic.Reader(file_list=file_list, exclude_files=exclude_files, only_tags=True, only_modality=['CT'],
                    only_load_roi_names=['Liver', 'Tumor'])
reader.read_dicoms()

Retrieve image and tags:

The images are stored in a list. Each image instance contains a 3D array (None if only_tags=True), all tag information and popular tags have their own respective variable.

Note: Even 2D images will contain a 3D array, along with a fake slice thickness of 1 mm.

import MedicalImageConverter as mic

path = r'/path/to/folder'

reader = mic.Reader(folder_path=path)
reader.read_dicoms()

images = reader.images

array = images[0].array
tags = images[0].tags  # list of all the tags, for 100 slice CT scan the tags list would be 0-99 each containing a dict

name = images[0].patient_name  # or tags[0].PatientName
spacing = images[0].spacing  # inplane spacing followed by slice thickness

Instance variables: base_position, date, dimensions, filepaths, frame_ref, image_matrix, mrn, orientation, origin, patient_name, plane, pois, rgb, rois, sections, series_uid, skipped_slice, sops, spacing, tags, time, unverified

Retrieve ROI/POIs:

Each image contains a roi and poi dictionary, if a RTSTRUCT file associates with an image then each ROI/POI is added to respective image dictionary.

import MedicalImageConverter as mic

path = r'/path/to/folder'

reader = mic.Reader(folder_path=path)
reader.read_dicoms()

image = reader.images[0]

roi_names = list(image.rois.keys())
roi = image.rois[roi_names[0]]
contour_position = roi.contour_position

poi_names = list(image.pois.keys())
poi = image.rois[poi_names[0]]
point_position = poi.point_position

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

medicalimageconverter-2.1.7.tar.gz (36.1 kB view details)

Uploaded Source

Built Distribution

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

MedicalImageConverter-2.1.7-py3-none-any.whl (42.9 kB view details)

Uploaded Python 3

File details

Details for the file medicalimageconverter-2.1.7.tar.gz.

File metadata

  • Download URL: medicalimageconverter-2.1.7.tar.gz
  • Upload date:
  • Size: 36.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.8.7

File hashes

Hashes for medicalimageconverter-2.1.7.tar.gz
Algorithm Hash digest
SHA256 f68bb1d906c1f3f7d037ba60210ee6f4bce04d4abfe16f2accc39d73cd86dc0a
MD5 0758d86446ccf1c205c4c3595e3d5419
BLAKE2b-256 fcbce45037393c6acca1e287fed9a40a4aaf6fdf043aefb5190e59a28d5808fe

See more details on using hashes here.

File details

Details for the file MedicalImageConverter-2.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for MedicalImageConverter-2.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 fa7533e2048e677f5e8accc49ac5b6ac5953b9c64b40b473f6bdc1b386e2049f
MD5 44d56d95767f10c2abe48d4f6b068356
BLAKE2b-256 cabf23aa412b87e547afe2228eaf9af0d16c6b8e21e44348bc51436f3714a3e0

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