Skip to main content

Conversion of medical images to MHA and TIFF.

Project description

panimg

CI PyPI Python Version from PEP 621 TOML Code style: black DOI

NOT FOR CLINICAL USE

Conversion of medical images to MHA and TIFF. Requires Python 3.10, 3.11, 3.12, 3.13 or 3.14. libvips-dev and libopenslide-dev must be installed on your system.

Under the hood we use:

  • SimpleITK
  • pydicom
  • pylibjpeg
  • Pillow
  • openslide-python
  • pyvips
  • oct-converter
  • wsidicom
  • pyisyntax

Usage

panimg takes a directory and tries to convert the containing files to MHA or TIFF. By default, it will try to convert files from subdirectories as well. To only convert files in the top level directory, set recurse_subdirectories to False. It will try several strategies for loading the contained files, and if an image is found it will output it to the output directory. It will return a structure containing information about what images were produced, what images were used to form the new images, image metadata, and any errors from any of the strategies.

NOTE: Alpha software, do not run this on directories you do not have a backup of.

from pathlib import Path
from panimg import convert

result = convert(
    input_directory=Path("/path/to/files/"),
    output_directory=Path("/where/files/will/go/"),
)

Command Line Interface

panimg is also accessible from the command line. Install the package from pip as before, then you can use:

NOTE: Alpha software, do not run this on directories you do not have a backup of.

panimg convert --input-dir /path/to/files/ --output-dir /where/files/will/go/

To access the help test you can use panimg -h.

Supported Formats

Input Output Strategy Notes
.mha .mha metaio
.mhd with .raw or .zraw .mha metaio
.dcm .mha dicom
.nii .mha nifti
.nii.gz .mha nifti
.nrrd .mha nrrd 1
.e2e .mha oct 2
.fds .mha oct 2
.fda .mha oct 2
.png .mha fallback 3
.jpeg .mha fallback 3
.tiff .tif tiff
.tif .tif tiff
.svs (Aperio) .tif tiff
.vms, .vmu, .ndpi (Hamamatsu) .tif tiff
.scn (Leica) .tif tiff
.mrxs (MIRAX) .tif tiff
.biff (Ventana) .tif tiff
.dcm (DICOM-WSI) .tif tiff
.isyntax (iSyntax) .tif tiff 4

1: Detached headers are not supported.

2: Only OCT volume(s), no fundus image(s) will be extracted.

3: 2D only, unitary dimensions

4: When isyntax is available in the python environment

Post Processors

You can also define a set of post processors that will operate on each output file. Post processors will not produce any new image entities, but rather add additional representations of an image, such as DZI or thumbnails. We provide a dzi_to_tiff post processor that is enabled by default, which will produce a DZI file if it is able to. To customise the post processors that run you can do this with

result = convert(..., post_processors=[...])

You are able to run the post processors directly with

from panimg import post_process
from panimg.models import PanImgFile

result = post_process(image_files={PanImgFile(...), ...}, post_processors=[...])

Using Strategies Directly

If you want to run a particular strategy directly which returns a generator of images for a set of files you can do this with

files = {f for f in Path("/foo/").glob("*.dcm") if f.is_file()}

try:
    for result in image_builder_dicom(files=files):
        sitk_image = result.image
        process(sitk_image)  # etc. you can also look at result.name for the name of the file,
                             # and result.consumed_files to see what files were used for this image
except UnconsumedFilesException as e:
    # e.file_errors is keyed with a Path to a file that could not be consumed,
    # with a list of all the errors found with loading it,
    # the user can then choose what to do with that information
    ...

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

panimg-0.18.1.tar.gz (56.9 kB view details)

Uploaded Source

Built Distribution

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

panimg-0.18.1-py3-none-any.whl (51.8 kB view details)

Uploaded Python 3

File details

Details for the file panimg-0.18.1.tar.gz.

File metadata

  • Download URL: panimg-0.18.1.tar.gz
  • Upload date:
  • Size: 56.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for panimg-0.18.1.tar.gz
Algorithm Hash digest
SHA256 1d23997f46a09718b092f170043dbcb4eb01d8c92231ba1c83f8f3014251811c
MD5 44b342eaf111b485528d9efac49ec26a
BLAKE2b-256 0c50265acdb0415fb3e24d54b04fe6ad12fcfe66e94440a62cbf03b16679ca14

See more details on using hashes here.

Provenance

The following attestation bundles were made for panimg-0.18.1.tar.gz:

Publisher: release.yml on DIAGNijmegen/rse-panimg

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

File details

Details for the file panimg-0.18.1-py3-none-any.whl.

File metadata

  • Download URL: panimg-0.18.1-py3-none-any.whl
  • Upload date:
  • Size: 51.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for panimg-0.18.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b60f869446d48ad8a0300dbfdc12f749e0e96dd05c7a77c2932955318d6547d5
MD5 b5736fa91537f3440629217cdaa9b73c
BLAKE2b-256 8a6ffd51f1e3ebfc4206db0c440cbe98b8647a3985c1aeb2507d2111466af3d0

See more details on using hashes here.

Provenance

The following attestation bundles were made for panimg-0.18.1-py3-none-any.whl:

Publisher: release.yml on DIAGNijmegen/rse-panimg

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