Skip to main content

Thickness calculation on binary 3D images

Project description

Compute the thickness of a solid using Anthony J. Yezzi’s method described in the article “An Eulerian PDE Approach for Computing Tissue Thickness, IEEE TRANSACTIONS ON MEDICAL IMAGING, VOL. 22, NO. 10, OCTOBER 2003”: http://dx.doi.org/10.1109/tmi.2003.817775

A C implementation by Rubén Cárdenes can be found at http://www.dtic.upf.edu/~rcardenes/Ruben_Cardenes/Software.html and helped me write this, especially the anisotropic part.

Requirements

numpy, cython, scikit-image. Tested with Debian Jessie and Fedora 24, miniconda-python 3.5.2, cython 0.24, numpy 1.11.2, scikit image 0.12.3

Installation instruction

Available on pypi: https://pypi.python.org/pypi/pyezzi . Use pip: pip install pyezzi

Alternatively, clone the repository and build cython modules with python setup.py build_ext --inplace.

Usage

from pyezzi.thickness import compute_thickness
thickness = compute_thickness(labeled_image, debug=True)

labeled_image is a 3 dimensional numpy array where the wall is labeled 2 and the interior is labeled 1.

A spacing parameter specifying the spacing between voxels along the axes can optionnaly be specified.

Check out the included jupyter notebooks in the example folder for more details.

Contributions

Feel free to submit pull requests. I know the code is nowhere near optimal as it is.

License

You’re free to use and modify the code, but please cite me and the original paper.

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

pyezzi-0.2.1.tar.gz (290.3 kB view details)

Uploaded Source

File details

Details for the file pyezzi-0.2.1.tar.gz.

File metadata

  • Download URL: pyezzi-0.2.1.tar.gz
  • Upload date:
  • Size: 290.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pyezzi-0.2.1.tar.gz
Algorithm Hash digest
SHA256 25489c9da5de86df7a0da0495110e21dcf4e7b75d2a2db610c0bd46cb9ca730e
MD5 fb6334ab100602ade86f1b0f5ff32f5a
BLAKE2b-256 23aca2b68e0a13c48afb091ca3e91923b7c5979c2aae82b691a2210106701b92

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