A package to simplify visualizing DICOM data, including images and segmentations (RTSTRUCT and SEG) via Jupyter/Python.
Project description
Summary
This is a simplistic DICOM viewer for images and related segmentations (RTSTRUCT and SEG). It was developed as a quick and dirty solution for performing spot checks on data downloaded from The Cancer Imaging Archive (TCIA) using tcia_utils. It was later separated into a stand-alone simpleDicomViewer PyPI package as many users of tcia_utils are not concerned with interactively viewing images and this capability introduced a lot of additional dependencies. There are many other more advanced viewers out there (e.g. 3D Slicer or itkWidgets) that you should try if your data fails with this tool.
Installation
Installation is performed using pip install simpleDicomViewer.
Jupyter Widget Installation
The interactive viewer is built using ipywidgets. After installing the python package, you may also need to enable the corresponding extension for your Jupyter environment.
For classic Jupyter Notebook:
jupyter nbextension enable --py widgetsnbextension
For JupyterLab:
jupyter labextension install @jupyter-widgets/jupyterlab-manager
After running the appropriate command, restart your Jupyter server to ensure the changes take effect. If you are using a hosted Jupyter environment like Google Colab, this step is typically not necessary as the extensions are pre-configured.
For more detailed instructions, please refer to the ipywidgets installation guide.
Usage
For viewing images, specify the path to a directory containing images from a single DICOM series. For annotations/segmentations, the path should point to the specific SEG or RTSTRUCT DICOM file name (not directory) that you're trying to visualize.
from simpleDicomViewer import dicomViewer
viewDicom(imagePath, segmentationPath)
Functional examples using TCIA data can be found in TCIA_Segmentations.ipynb.
Troubleshooting
If you encounter an "Error displaying widget: model not found" message or a warning that the @jupyter-widgets/jupyterlab-manager extension is outdated, it likely means there is a version mismatch between the ipywidgets Python package and the JupyterLab extension. This can often be resolved by running the following commands:
# Upgrade the ipywidgets package in your environment
pip install --upgrade ipywidgets
# Clean and rebuild the JupyterLab assets
jupyter lab clean
jupyter lab build
Remember to run these commands in the correct Python environment where you have JupyterLab and your kernel installed, and restart the JupyterLab server afterwards.
Acknowledgements
Thanks to Adam Li who introduced the original functionality in v1.x to display the segmentation overlays.
Citations:
This repository includes sample data from The Cancer Imaging Archive in the "data" folder which you can use for testing its features.
- Zhao, B., Schwartz, L. H., Kris, M. G., & Riely, G. J. (2015). Coffee-break lung CT collection with scan images reconstructed at multiple imaging parameters (Version 3) [Dataset]. The Cancer Imaging Archive. https://doi.org/10.7937/k9/tcia.2015.u1x8a5nr
- Wee, L., Aerts, H., Kalendralis, P., & Dekker, A. (2020). RIDER Lung CT Segmentation Labels from: Decoding tumour phenotype by noninvasive imaging using a quantitative radiomics approach [Data set]. The Cancer Imaging Archive. https://doi.org/10.7937/tcia.2020.jit9grk8
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file simpledicomviewer-2.0.4.tar.gz.
File metadata
- Download URL: simpledicomviewer-2.0.4.tar.gz
- Upload date:
- Size: 70.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b8a9a79b519d5e2f3d2e72c8857d18cb9699db1ae0db1ea7914d6011e88e00c2
|
|
| MD5 |
18d00c29c844cec00316db6bc1a9aa41
|
|
| BLAKE2b-256 |
0c21811f7954f54bbe44c263ad67568652d7687cb8ba57e6043f49ad43f6cbc7
|
File details
Details for the file simpledicomviewer-2.0.4-py3-none-any.whl.
File metadata
- Download URL: simpledicomviewer-2.0.4-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f61b274f82b3719b9c129288b6cdfde383d9fe1af9f5522ef906a02d093ab73
|
|
| MD5 |
2b8c486de198b2f8b0830f35bbb88833
|
|
| BLAKE2b-256 |
6da2e1b69f5b1dd7e4af021ce3d00f0867ee0d7f486fb3b4808b6b951c970ce5
|