Modules:VMTK in 3D Slicer Tutorial: Coronary Artery Centerline Extraction

From Slicer Wiki
Jump to: navigation, search
Home < Modules:VMTK in 3D Slicer Tutorial: Coronary Artery Centerline Extraction

Return to Slicer 3.5 Documentation

Segmentation of the Right Coronary Artery using VMTK in 3D Slicer
Close-Up of the segmented Vessel
The Voronoi Diagram and the corresponding Centerline

Background

Coronary heart disease (CHD) is the leading cause of death in high-income countries and one of the main causes of death worldwide [WHO2008]. The primary cause for CHD is atherosclerosis of the coronary arteries and is called coronary artery disease (CAD). Plaque within the walls of the coronaries narrows the lumen of the affected vessels (so-called stenosis) and disturbs the regularization abilities of the vessel walls. Consequently this reduces the blood flow inside the affected vessels and constrains the supply of oxygen and nutrients to the myocardium. Beside of heart pain, symptoms of the CHD can appear as heart-rhythm-disturbances, cardiac insufficiency, angina-pectoris-attacks, cardiac infarcts or sudden cardiac deaths [HJ07, pp307].

Medical imaging is used for the diagnosis of CAD and for the quantification and grading of stenosis. The extraction of the central lumen line (centerline) of coronary arteries is helpful for visualization purposes, stenosis quantification or further processing steps (e.g. reformatting) [Schaap2009].

This tutorial shows how to use tools based on the Vascular Modeling Toolkit (VMTK) ([Antiga2008]) in 3D Slicer to segment the right coronary artery (A. coronaria dextra, RCA) in a computed tomography angiography (CTA) volume and extract the associated centerline. In particular the segmentation is performed on a CTA dataset which was obtained through the Rotterdam Coronary Artery Algorithm Evaluation Framework ([Schaap2009]).

Even if this documentation shows how to establish a work flow between three VMTK in 3D Slicer tools, each of the three documented segmentation steps can be considered as a guide for the individual module.

Human heart with Coronary Arteries

VMTK in 3D Slicer Installation

Before using VMTK in 3D Slicer a set of modules has to be installed. Since the 3D Slicer version 3.5 the modules are available as extensions and can be downloaded into an existing Slicer installation by using the extension wizard.
The cogwheel icon starts the 3D Slicer extension wizard.
  The 3D Slicer extension build system provides VMTK in 3D Slicer packages for different OS platforms. At the moment Linux 64bit and Darwin are supported.

Using the extension wizard, the VMTK in 3D Slicer modules can be installed following three steps.

  • STEP ONE: Select Find & Install and click next.
  • STEP TWO: Choose the desired modules and click Download & Install. In this tutorial we use the following extensions:
    • VmtkSlicerModule to get the VMTK libraries (see also this page for further documentation)
    • VMTKVesselEnhancement to generate a vessel enhanced image (see also this page for further documentation)
    • VMTKEasyLevelSetSegmentation to perform level-set initialization and evolution (see also this page for further documentation)
    • VMTKCenterlines to compute the centerlines (see also this page for further documentation)
  • STEP THREE: Restart 3D Slicer
After restarting 3D Slicer, the VMTK tools are available in the module selector inside the category Vascular Modeling Toolkit.
Step one: Find & Install
Step two: Selection of the modules
Step three: Restart 3D Slicer
The VMTK tools appear inside the category Vascular Modeling Toolkit

If the extension wizard does not work for you or if you want to use VMTK in 3D Slicer on unsupported OS platforms, you should give the manual installation a shot.

Segmentation

The centerline extraction using VMTK in 3D Slicer consists of a processing sequence using three different modules.

A flow-chart of the VMTK in 3D Slicer tools involved in this tutorial and their connection as a pipeline.

Due to time-consuming calculations, it is highly recommended to extract a subvolume of the region of interest prior to the segmentation process. This can be done by using Converters -> Extract Subvolume or Converters -> Extract Subvolume ROI in the 3D Slicer module selector.

The original CTA volume. (Dimensions 512x512x276, Spacing 0.37x0.37x0.4)
The extracted subvolume. (Dimensions 293x285x194)

Generating Vesselness using VMTKVesselEnhancement

VMTKVesselEnhancement
     The VMTKVesselEnhancement module provides multiscale vesselness filters in 3D Slicer. These filters detect tubular or blob-like structures of various sizes according to a defined scale. We want to use the method of Sato et al. ([Sato1998]) to enhance the right coronary artery in our extracted subvolume.
The extracted subvolume after vesselness filtering.

INSTRUCTIONS:

  • 1. Choose the VMTKVesselEnhancement module from the 3D Slicer module selector.
  • 2. Select the targeted dataset as the input volume.
  • 3. Switch between diameter specification in physical units (e.g. [mm]) or voxels.
  • 4. Specify the minimal and maximal diameters of the tubular structures to detect.
  • 5. Steps between minimal and maximal diameters defines how the various diameters inside the diameter range get distributed.
  • 6. Click Start!.
  • 7. The new vessel enhanced volume gets loaded into the 3D Slicer slice viewers.


For the detection of the RAC we use a-priori information about the shape of the vessel and set the following parameters:

  • Steps between minimal and maximal diameters: 10
  • Diameter specification in: physical units
  • Minimal Diameter: 1.0 mm
  • Maximal Diameter: 5.0 mm

The vesselness filtering takes some time. Our extracted subvolume gets processed in about 10 minutes on a Quad Core 2.6GHz Xeon machine with 6GB of RAM.

HINTS:

  • VMTKVesselEnhancement is already configured to detect tubular rather than blob-like structures. This can be modified by setting different sensitivity thresholds. The lower the threshold, the more likely is that the desired structure gets highlighted.
  • Parameter presets for certain use-cases exist and can be selected using the Existing Parameter Sets: node selector. They can be extended by editing the presets.xml MRML file inside the module directory.

Lumen Segmentation using VMTKEasyLevelSetSegmentation

VMTKEasyLevelSetSegmentation and the initialization step
VMTKEasyLevelSetSegmentation and the evolution step
     Segmentation of the vessel lumen can be performed using the VMTKEasyLevelSetSegmentation module. The level-set segmentation process consists of two steps: Fast Marching Upwind Gradient initialization ([Antiga2008], [Sethian1999]) and Geodesic Active Contours evolution ([Caselles1995]).

The initialization step involves the description of a starting model within a region of interest. In the evolution step this initial deformable model then gets inflated to match the contours of the targeted volume.

We want to initialize inside the RCA on the vessel enhanced volume from the previous step and then evolve on the original extracted subvolume.

INSTRUCTIONS:

Initialization:

  • 1. Choose the VMTKEasyLevelSetSegmentation module from the 3D Slicer module selector.
  • 2. Select the vessel enhanced volume as the input volume.
  • 3. Create a new fiducial list using the source seeds selector. This list will be automatically set to the active fiducial list in 3D Slicer.
  • 4. Place one fiducial inside the vessel or vascular tree of interest.
  • 5. Turn off Use Volume Rendering since we need polydata models for the centerline computation.
  • 6. Specify a threshold to limit the Fast Marching front propagation.
  • 7. Click Start!.

The initial segmentation is shown as an overlayed labelmap in the 3D Slicer slice viewers and a red model is shown in the 3D rendering window.

Evolution:

  • 1. Now select the original volume as the input volume.
  • 2. Configure the importance of inflation during evolution of the deformable model.
  • 3. Configure the importance of curvature during evolution of the deformable model.
  • 4. Configure the importance of attraction to the gradient ridges during evolution of the deformable model.
  • 5. Specify the number of evolution iterations.
  • 6. Click Start!

The evolved segmentation is shown as an overlayed labelmap in the 3D Slicer slice viewers and a blue model is shown in the 3D rendering window.

The RCA after initialization
The RCA after evolution
3D Slicer slice viewers showing the evolution of the RCA as a labelmap

For the segmentation of the RCA we use the following parameters:

  • Threshold: 206
  • Inflation weight: 30
  • Curvature weight: 40
  • Attraction to ridges weight: 100
  • Iterations: 10

Attraction to ridges is the most important parameter. Since our initialization is already pretty good, we only choose medium inflation and medium curvature. The Fast Marching initialization takes some time. Our extracted subvolume gets processed in about 6 minutes on a Quad Core 2.6GHz Xeon machine with 6GB of RAM.


HINTS:

  • It is also possible to specify Target seeds to stop the initialization by reaching a certain position. This speeds up the Fast Marching initialization.
  • Parameter presets for certain use-cases exist and can be selected using the Existing Parameter Sets: node selector. They can be extended by editing the presets.xml MRML file inside the module directory.

Centerline Computation using VMTKCenterlines

VMTKCenterlines
Centerline import and export functionality
     Centerlines of polydata models can be computed using the VMTKCenterlines module. Beside the actual centerline it also outputs the Voronoi diagram which describes the maximal sphere radius of every point on the centerline. The module also provides import and export functionality for centerlines defined by a cloud of points.


INSTRUCTIONS:

  • 1. Choose the VMTKCenterlines module from the 3D Slicer module selector.
  • 2. Select a polydata model as the input model.

Preparation Step:

  • 1. Click Prepare Model!.

This step closes the input model with caps and changes the color to green.

Centerlines Computation:

  • 1. Create a new fiducial list using the source seeds selector. This list will be automatically set to the active fiducial list in 3D Slicer.
  • 2. Place one fiducial inside the 3D model as a starting point for the centerline.
  • 3. Create a new fiducial list using the target seeds selector. This list will be automatically set to the active fiducial list in 3D Slicer.
  • 4. Place one fiducial inside the 3D model as the end point for the centerline.
  • 5. Click Get Centerlines!.

After computation, the centerlines and Voronoi diagram are added as 3D polydata models to the current scene and get displayed in the 3D rendering window.

Import/Export: Computed centerlines can be imported and exported as clouds of points.

  • Add description headers: adds a description of the exported fields as the first line in the export file.
  • Invert coordinates (IJK<->NIFTI): inverts X and Y coordinates during import/export.
  • Export details: add other information like the maximal inscribed sphere radius to each exported point.
  • Strip headers: strips the first line of the import file.

HINTS:

  • It is possible to specify multiple source and target seeds to generate several centerlines at once.
The green model of the RCA after the preparation step.
The RCA after centerline computation.
The computed Voronoi diagram.
Close-Up of the computation results including an imported reference segmentation.
Close-Up of the computation results without the segmented lumen.
Close-Up of the segmented vessel.

Evaluation

Main GUI
Main GUI

References

[Antiga2008] Antiga, L.; Piccinelli, M.; Botti, L.; Ene-Iordache, B.; Remuzzi, A. & Steinman, D. A. An image-based modeling framework for patient-specific computational hemodynamics. Med Biol Eng Comput, Biomedical Engineering Department, Mario Negri Institute for Pharmacological Research, Villa Camozzi, Ranica, BG, Italy. 2008, 46, 1097-1112
[Caselles1995] Caselles, V.; Kimmel, R. & Sapiro, G. Geodesic active contours. Proc. Fifth International Conference on Computer Vision, 1995, 694-699
[HJ07] Huch, R. & Jürgens, K. D. Mensch, Körper, Krankheit. Urban & Fischer Verlag, 2007
[Sato1998] Sato, Y.; Nakajima, S.; Shiraga, N.; Atsumi, H.; Yoshida, S.; Koller, T.; Gerig, G. & Kikinis, R. Three-dimensional multi-scale line filter for segmentation and visualization of curvilinear structures in medical images. Department of Radiology, Harvard Medical School and Brigham and Women's Hospital, Boston, MA 02115, USA. Med Image Anal, 1998, 6
[Schaap2009] Schaap, M.; Metz, C.; van Walsum, T.; van der Giessen, A.; Weustink, A.; Mollet, N.; Bauer, C.; Bogunović, H.; Castro, C.; Deng, X.; Dikici, E.; O'Donnell, T.; Frenay, M.; Friman, O.; Hoyos, M. H.; Kitslaar, P.; Krissian, K.; Kühnel, C.; Luengo-Oroz, M. A.; Orkisz, M.; Smedby, Ö.; Styner, M.; Szymczak, A.; Tek, H.; Wang, C.; Warfield, S. K.; Zambal, S.; Zhang, Y.; Krestin, G. P. & Niessen, W. Standardized Evaluation Methodology and Reference Database for Evaluating Coronary Artery Centerline Extraction Algorithms. Medical Image Analysis, 2009, 13/5, 701-714
[Sethian1999] Sethian, J. A. Level Set Methods and Fast Marching Methods: Evolving Interfaces in Computational Geometry, Fluid Mechanics, Computer Vision, and Materials Science (Cambridge ... on Applied and Computational Mathematics) Cambridge University Press, 1999
[WHO08] World Health Organization WHO. The top ten causes of death. Fact sheet N310, 10 2008.