Skip to main content

A comprehensive toolkit for medical image processing, including DICOM, NIfTI, and multi-format I/O utilities

Project description

MedImgKit

A comprehensive toolkit for medical image processing, providing utilities for DICOM, NIfTI, and other medical image formats with seamless multi-format I/O operations.

Features

  • DICOM Support: Read, anonymize, and manipulate DICOM files
  • NIfTI Support: Work with neuroimaging data in NIfTI format
  • Multi-format I/O: Unified interface for reading various image formats
  • Anonymization: DICOM anonymization following DICOM standards
  • Coordinate Conversion: Convert between pixel and patient coordinates
  • Multi-frame Assembly: Combine multiple DICOM files into multi-frame volumes

Installation

From PyPI

pip install medimgkit

From Source

pip install git+https://github.com/SonanceAI/medimgkit

Quick Start

DICOM Operations

import medimgkit as mik
import pydicom

# Read and normalize DICOM image
ds = pydicom.dcmread('path/to/dicom.dcm')
image_array = mik.load_image_normalized(ds)

# Anonymize DICOM
anonymized_ds = mik.anonymize_dicom(ds)

# Convert pixel coordinates to patient coordinates
patient_coords = mik.pixel_to_patient(ds, pixel_x=100, pixel_y=150)

NIfTI Operations

import nibabel as nib
import medimgkit as mik

# Load NIfTI file
nifti_data = nib.load('path/to/image.nii.gz')

# Get a specific slice
slice_image = mik.get_slice(nifti_data, slice_index=50, slice_axis=2)

# Convert world coordinates to slice index
slice_idx, axis = mik.line_to_slice_index(nifti_data, point1, point2)

Multi-format Reading

import medimgkit as mik

# Read any supported format
image_array = mik.read_array_normalized('path/to/image.dcm')
image_array = mik.read_array_normalized('path/to/image.nii.gz')
image_array = mik.read_array_normalized('path/to/image.png')

API Reference

DICOM Utils (medimgkit.dicom_utils)

Core Functions

  • load_image_normalized(dicom, index=None): Load and normalize DICOM pixel data
  • anonymize_dicom(ds, retain_codes=[], copy=False, token_mapper=None): Anonymize DICOM following standards
  • assemble_dicoms(files_path, return_as_IO=False): Combine multiple DICOMs into multi-frame
  • is_dicom(f): Check if file is a DICOM

Coordinate Conversion

  • pixel_to_patient(ds, pixel_x, pixel_y, slice_index=None): Convert pixel to patient coordinates
  • get_image_position(ds, slice_index=None): Get image position in patient coordinates
  • get_pixel_spacing(ds, slice_index): Get pixel spacing information

Anatomical Analysis

  • determine_anatomical_plane_from_dicom(ds, slice_axis, alignment_threshold=0.95): Determine anatomical plane

NIfTI Utils (medimgkit.nifti_utils)

Slice Operations

  • get_slice(data, slice_index, slice_axis): Extract 2D slice from 3D volume
  • get_slice_from_line(data, world_point1, world_point2): Get slice defined by line
  • slice_location_to_slice_index(data, slice_location, slice_axis): Convert location to index

Coordinate Conversion

  • line_to_slice_index(data, world_point1=None, world_point2=None, coplanar_vector=None): Convert line to slice
  • axis_name_to_axis_index(data, axis_name): Convert axis name to index

Utilities

  • is_nifti_file(file_path): Check if file is NIfTI format

I/O Utils (medimgkit.io_utils)

Reading Functions

  • read_array_normalized(file_path, index=None, return_metainfo=False, use_magic=False): Universal image reader
  • read_image(file_path): Read standard image formats (PNG, JPEG)
  • read_nifti(file_path, mimetype=None): Read NIfTI files
  • read_video(file_path, index=None): Read video files

Supported Formats

  • DICOM: .dcm, .dicom (and files without extension)
  • NIfTI: .nii, .nii.gz
  • Images: .png, .jpg, .jpeg
  • Video: .mp4, .avi, .mov, .mkv
  • NumPy: .npy

Development

Running Tests

pytest

License

MIT License - see LICENSE file for details.

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Submit a pull request

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

medimgkit-0.4.4.tar.gz (28.3 kB view details)

Uploaded Source

Built Distribution

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

medimgkit-0.4.4-py3-none-any.whl (26.0 kB view details)

Uploaded Python 3

File details

Details for the file medimgkit-0.4.4.tar.gz.

File metadata

  • Download URL: medimgkit-0.4.4.tar.gz
  • Upload date:
  • Size: 28.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for medimgkit-0.4.4.tar.gz
Algorithm Hash digest
SHA256 ccf51bf501dec62fe492a04b8cdc431da7f39926ace8930df83f0be24f33d86d
MD5 1ee03d21e9d219d65fad97127e3f4e03
BLAKE2b-256 e22c9da0b6532e85d4f993a72ade01f327a529bb61758740900d42c1e0f97ec0

See more details on using hashes here.

Provenance

The following attestation bundles were made for medimgkit-0.4.4.tar.gz:

Publisher: release_pypi.yaml on SonanceAI/medical-image-utils

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

File details

Details for the file medimgkit-0.4.4-py3-none-any.whl.

File metadata

  • Download URL: medimgkit-0.4.4-py3-none-any.whl
  • Upload date:
  • Size: 26.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for medimgkit-0.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 545684d18bdf8dd5525a3c1f5a88619c497910ab6386a319a0afcdc59ac1a1c2
MD5 bbe939563706a3074751b9121e5ec4bf
BLAKE2b-256 dba5730a872424ff87d2db0bae060d806d469fcdef9221854b4930d9b3443e67

See more details on using hashes here.

Provenance

The following attestation bundles were made for medimgkit-0.4.4-py3-none-any.whl:

Publisher: release_pypi.yaml on SonanceAI/medical-image-utils

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