Skip to main content

Utilities for 3D Slicer

Project description

Python package Upload Python Package PyPI version

slicerio

Python utilities for 3D Slicer interoperability.

The package contains utility functions for reading and writing segmentation files and convenience functions for using 3D Slicer via its web API. More functions will be added in the future.

Installation

Using pip:

pip install slicerio

Examples

Read segmentation and show some information about segments

import slicerio
import json

segmentation_info = slicerio.read_segmentation_info("Segmentation.seg.nrrd")

number_of_segments = len(segmentation_info["segments"])
print(f"Number of segments: {number_of_segments}")

segment_names = slicerio.segment_names(segmentation_info)
print(f"Segment names: {', '.join(segment_names)}")

segment0 = slicerio.segment_from_name(segmentation_info, segment_names[0])
print("First segment info:\n" + json.dumps(segment0, sort_keys=False, indent=4))

Extract selected segments with chosen label values

import slicerio
import nrrd

input_filename = "path/to/Segmentation.seg.nrrd"
output_filename = "path/to/SegmentationExtracted.seg.nrrd"
segment_names_to_labels = [("ribs", 10), ("right lung", 12), ("left lung", 6)]

voxels, header = nrrd.read(input_filename)
extracted_voxels, extracted_header = slicerio.extract_segments(voxels, header, segmentation_info, segment_names_to_labels)
nrrd.write(output_filename, extracted_voxels, extracted_header)

View files in 3D Slicer

It is useful to load several files in a single Slicer instance, because then there is no need to wait for multiple application startups and multiple data sets can be compared in one environment. This can be achieved by activating 3D Slicer's Web Server module, which provides a web API to control the application.

For example, an image file can be loaded with the command below. The command starts a new Slicer application instance with the web API enabled.

import slicerio
import os
slicerio.view_file("path/to/SomeImage.nrrd", slicer_executable=f"{os.environ["LOCALAPPDATA"]}/NA-MIC/Slicer 5.2.0/Slicer.exe")

A segmentation file can be loaded in the same Slicer instance:

import slicerio
slicerio.view_file("path/to/Segmentation.seg.nrrd", "SegmentationFile")

Supported file types:

  • image files (nrrd, nii.gz, ...): VolumeFile
  • segmentation file (.seg.nrrd, nrrd, nii.gz, ...): SegmentationFile
  • model file (.stl, .ply, .vtk, .vtp, .vtu, ...): ModelFile
  • markup file (.mrj.json): MarkupsFile
  • transform file (.tfm, .h5, .txt): TransformFile
  • spreadsheet file (.csv, .tsv): TableFile
  • text file (.txt, .json, ...): TextFile
  • sequence file (.mrb, .seq.nrrd): SequenceFile
  • Slicer scene file (.mrml, .mrb): SceneFile

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

slicerio-0.1.5.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

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

slicerio-0.1.5-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file slicerio-0.1.5.tar.gz.

File metadata

  • Download URL: slicerio-0.1.5.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.3.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.4

File hashes

Hashes for slicerio-0.1.5.tar.gz
Algorithm Hash digest
SHA256 18d3fa1d94f4847549d6208fd1b10d4124505fc8c7d6691e29ec3d517fa97deb
MD5 442a02818d991f91c079a1091f418632
BLAKE2b-256 c0808c43dd33833274783e8c4b3c57a3d083a127c8e6d9b956e15624154ae5f8

See more details on using hashes here.

File details

Details for the file slicerio-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: slicerio-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.3.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.4

File hashes

Hashes for slicerio-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 a19c6f7138d29291b4856b201dad1ffb3472afa038cc4c7e0fe6d924acec675f
MD5 0947b954c8e89fcd89b12f431ec38dbd
BLAKE2b-256 3392ba537f4da5995d6c70fa3087d41ef192edfda5f37abaed7ce9638b49278e

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