SlicerRVXLiverSegmentation
SlicerRVXLiverSegmentation copied to clipboard
3D Slicer plugin for Liver Anatomy Annotation by R-Vessel-X
RVesselX Slicer Liver Anatomy Annotation Plugin
data:image/s3,"s3://crabby-images/11b40/11b40d115c1e46e639d0b4b0fc2315d376c9901a" alt=""
Table of contents
- Introduction
-
Using the Plugin
- Video tutorials
- Installing the plugin
- Plugin Overview
- Sample Data
- Data import and visualization
-
Liver segmentation
- Manual Liver segmentation
- AI Liver segmentation
-
Portal veins segmentation
- Constructing the portal tree
- Extracting and segmenting the portal tree
- Editing the portal tree
- Splitting the portal tree
-
IVC veins segmentation
- Constructing the IVC tree
- Extracting and segmenting the IVC tree
- Editing the IVC tree
- Tumor segmentation
- Exporting the results
-
Changelog
- 1.1.0 (2023/07/12)
-
Developers
- Manually installing the plugin
- Testing
- Contributing
Introduction
data:image/s3,"s3://crabby-images/0271f/0271f4f1c2ccf06bc1b801f26e517e8dc164bb9b" alt=""
The RVesselX slicer plugin is a plugin for Slicer3D which aims at easing the segmentation of liver, liver vessels and liver tumor from DICOM data for annotation purposes. The exported segmentations will then be used in research.
The plugin provides a systematic annotation workflow and tools to allow for fast segmentation. The plugin is separated in the following tabs :
- Liver segmentation : Segmentation editor configured for liver segmentation
- Portal veins segmentation: VMTK extension used for portal vein segmentation
- Inferior cava vein segmentation : VMTK extension used for IVC vein segmentation
- Tumor segmentation : Segmentation editor configure for tumor segmentation
At the end of the workflow, the annotated data can be saved to a given output directory.
For more information on the R-Vessel-X project, please visit :
https://anr.fr/Projet-ANR-18-CE45-0018
Using the Plugin
Video tutorials
The following videos outline the different steps to install and use the plugin. For more detailed explanations, please refer to each section.
- Installing the extension
- MRI Liver segmentation
- AI CT Liver segmentation
- Portal veins segmentation
- IVC veins segmentation
- Exporting the results
Installing the plugin
The plugin can be installed in Slicer3D using the extension manager. It can be found using the search bar by typing "RVesselX".
When first installing the plugin the following extensions will be installed as well :
- SegmentEditorExtraEffects
- SlicerVMTK
- MarkupsToModel
- PyTorch
data:image/s3,"s3://crabby-images/312ac/312ac69e302f11342ee803de9fc404e41f9ec680" alt=""
After installing the extension, Slicer will have to be restarted for the module to be accessible.
After Slicer has been restarted, the module can be found using the module finder under the name "RVX Liver Segmentation"
.
It can also be found by navigating the module list and clicking on Segmentation>RVX Liver Segmentation
module.
data:image/s3,"s3://crabby-images/54b35/54b350b554c6bc4a07894dfcef8f79dec3431e07" alt=""
After the module is first installed, additional Python libraries will have to be installed.
The libraries will be installed automatically by clicking on the Download Dependencies and restart
button.
The library will be downloaded from Python pip
and installed automatically.
data:image/s3,"s3://crabby-images/76d21/76d21285248524cd5f0e302a96667c7af131156f" alt=""
Plugin Overview
The plugin is built upon the following tabs : Data, Liver, Portal Veins, Portal Veins Edit, IVC Veins, IVC Veins Edit, Tumors. Navigation between tabs is done either using the arrow buttons at the top of the plugin or by directly clicking on the tabs.
Each tab is oriented towards one part of the segmentation workflow but can work independently of the other tabs.
- The Liver tab allows to segment the full liver volume
- The Portal Veins and Portal Edit tabs allow to segment the portal veins of the liver
- The ICV Veins and IVC Veins Edit tabs allow to segment the Inferior Cavae Veins of the liver
- The tumors tab allows to segment any tumor present in the liver volume. As this tab is the last of the workflow, it also allows to export the results of the previous tabs.
Sample Data
To test the plugin, the 3D_IRCAD_B_5_Liver
data can be loaded from the Sample Data module. To properly load the data
in the plugin, it is advised to first open the plugin and afterwards to navigate to the Sample module and to load the
data.
This data is extracted from the 3D-IRCADb (3D Image Reconstruction for Comparison of Algorithm Database) database. The content of 3D-IRCADb is subject to a CC Attribution-Non commercial-No Derivative Works 3.0 licence.
For more information on the IRCAD Database please visit : https://www.ircad.fr/research/3dircadb/
Data import and visualization
The Data Tab
is used to open the patient data. Loading can be done using the Load DICOM
and the Load Data
buttons.
The input volume needs to be selected using the Volume
combo box.
The Data Tab
aggregates the functionalities of the load Data
and load DICOM
buttons as well as the Volume
and Volume Rendering
modules for volume display customization.
data:image/s3,"s3://crabby-images/de261/de2613b9b1126f32dbc1417c24547472a7b06061" alt=""
To start working on the segmentation :
- Click one of
Load DICOM
orLoad Data
and select the data you want to work on. - Once the volume is loaded in the 2D and 3D view, you can click on the
Liver
tab to proceed with the liver segmentation.
Liver segmentation
The Liver Tab
is used to segment the liver volume. Two segments are created by default, the Liver In
and Liver Out
segments.
The Segment CT/MRI Liver
segmentation effect is also available for fast segmentation of the liver for CT and MRI data.
This segmentation effect is built upon MONAI and PyTorch to provide ML accelerated segmentation for CT and MRI data.
Manual Liver segmentation
To manually segmenting the liver can be done using the following process:
- Select the
Liver In
segment and start painting in the liver. To improve the painting speed, you can choose a 3D brush. - Select the
Liver Out
segment and paint outside the liver. - Select the
Grow from seeds
and click on the initialize button - Iterate on the
In
andOut
segments until the grow from seeds is satisfying - Apply the
Grow from seeds
segmentation - Use the
Scissors
tool to remove any undesired volumes - Use the
Margin
tool by growing and shrinking back the volume to improve the outside shape of the volume - Use the
Smoothing
tool to smooth out the volume
data:image/s3,"s3://crabby-images/bfe6d/bfe6de8113393a30e5685e464a27a49fcccb9d18" alt=""
data:image/s3,"s3://crabby-images/00b63/00b63973f712053ee54c7ed1493b34f7cdf9ac1e" alt=""
AI Liver segmentation
AI segmentation of the liver can be done using the following process:
- Select the
Liver In
segment - Select the
Segment CT/MRI Liver
tool - Select the volume Modality
- (optional) Specify the Liver's Region of Interest
- Select the volumes ROI in the
ROI
combo box - Toggle the visibility of the ROI
- Shrink the ROI until it roughly encompasses the volume's liver
- Select the volumes ROI in the
- Click on apply
- Correct the segmented liver if necessary using the
Scissors
,Margin
andSmoothing
tools.
data:image/s3,"s3://crabby-images/4afa7/4afa79efc302a0d861beb5a87599199692f8dfd9" alt=""
data:image/s3,"s3://crabby-images/c8fab/c8fab4ba9837ff70c4f1abdbbf4c95e86708846a" alt=""
Portal veins segmentation
The portal veins segmentation is split into two tabs.
The Portal Veins
tab is used to initialize the segmentation of the vessels using a vessel intersection tree. First the
vessel tree needs to be constructed by selecting the vessels branching nodes in the views. To place the nodes, click in
the tree on the intersection to be placed. Then click in the 2D or 3D view to place the markup node.
The tree is constructed in a depth first manner. First the root of the tree should be selected, then each intersection should be selected until the end of the vessel is reached.
Hovering over an item of the tree will display an image indicating the position of the node in the tree.
Clicking on the Show Current Node Placement Help
will display the image of the position of the current node being
placed.
Edition of the nodes position is done using the Unlock Node Position
button. This mode is enabled while the button is
checked. It can be disabled by pressing the Escape
keyboard key.
The nodes can be deleted in the left panel by either clicking the delete icon
or by pressing the delete
keyboard
key.
Intermediary nodes can be placed to improve the vessel extraction by clicking on the Insert before
button in the tree.
Once every node has been placed, the vessels can be extracted from the constructed tree using the
Extract Vessels from node tree
button. The parameters of the vesselness can be edited to refine the extraction of the
vessels.
After the portal vessels have been extracted, the segmentation can be refined using the Portal Veins Edit
tab. This
tab uses the segmentation editor and allows for refining the overall portal vein segmentation using the segment editor
tools.
After the portal vein volume has been edited, click on the Proceed to vessel splitting
button. This button will
extract the center line for each portion of the portal vessels and will create one empty segment per vessel branch. The
scissors tool will be selected automatically and will allow for splitting the overall portal vein volume into its
sub-branches.
Constructing the portal tree
data:image/s3,"s3://crabby-images/608bd/608bd3d9ec78db59b39c6f3dbdc88b1992c8e4cf" alt=""
- To start the segmentation, click on the
PortalVeinRoot
element in theBranch Node Name
tree - Once the portal vein is in
*Placing*
mode, click in the 2D view at the root of the portal vein - Proceed with placing the other nodes at the intersection of the branches of the portal vein
- To obtain help on the position of a node, hover on the node in the tree to display the node positioning help
- If a node needs to be displaced, click on the node in the tree and unlock its position to displace the point in the 2D view.
- Nodes which cannot be placed due to the patient's condition or to the quality of the acquisition can be removed by clicking on the bin icon next to the point.
- Once all the points in the tree are placed, click on the
Extract Vessels from node tree
to proceed with the extraction
data:image/s3,"s3://crabby-images/801c0/801c0148cc7a4208d5fa4937e6656af2c33f94aa" alt=""
data:image/s3,"s3://crabby-images/95980/959801454a89c3a317e2f99ce15ca9f79604d6d3" alt=""
Extracting and segmenting the portal tree
The vessel tree segmentation is based on the following operations :
- A region of interest is selected around the defined tree nodes to improve the processing time
- A Hessian filter is applied on the region of interest to improve the contrast of vessel like structures in the ROI
- A level set segmentation is applied on the Hessian enhanced volume using the branch extremities as seed points
To proceed with the segmentation :
- After clicking on the
Extract Vessels from node tree
, the segmented tree is displayed in the 2D and 3D view - The segmentation can be modified by changing the parameters of the segmentation, by displacing the control points or
by adding additional control points in between branch extremities
- To update the vessel segmentation, click on the
Extract Vessels from node tree
. - To modify the Hessian parameters, unfold the
Vesselness Filter Options
. Two options are available for the Hessian filtering : VMTK's vesselness filter and Sato's Hessian Filter. - To visualize the Hessian filter's results click on the
Show vesselness volume
checkbox - To Switch between VTMK and Sato's vesselness filter, toggle the
Use VTMK Vesselness
option - For more information on Hessian filters, please refer to Vesselness filters: A survey with benchmarks applied to liver imaging
- To update the vessel segmentation, click on the
data:image/s3,"s3://crabby-images/02494/02494df611b776968ce1b971128cf0dad66558a6" alt=""
data:image/s3,"s3://crabby-images/8a75f/8a75f50632dc0e774590f4255ea829f30877a9b5" alt=""
Editing the portal tree
- Once the extracted vessel tree is satisfying, click on the
Portal Veins Edit
tab to proceed with editing the vessel tree. - This step allows to clean up the whole segmentation using the segment editor's tools.
- When the segmentation is satisfying, click on the
Proceed to vessel splitting
button to split the different branches
data:image/s3,"s3://crabby-images/16b43/16b43fa86c22d830a5e0798d633bccfe4e1c0928" alt=""
Splitting the portal tree
- After clicking on the
Proceed to vessel splitting
button, one segment per branch node is created - The
Scissors
tool is preconfigured and allows to select the segmentation in the 3D view and add the selected area to the selected segment - Click on each node successively and add the segment's volume using the
Scissors
tool - You can hide the segments once the split is done to allow for better visibility in the 3D view
- After every segment has been split, the portal vein segmentation is done
data:image/s3,"s3://crabby-images/36b65/36b65f076b47f2d3fd57f4b6082c5a56abb612dd" alt=""
data:image/s3,"s3://crabby-images/bb828/bb828b34201a522532a80e5936f15229d8c7c4b6" alt=""
IVC veins segmentation
The IVC vein segmentation principle is identical as the portal vein segmentation but for the IVC veins. For more information on each step, please refer to Portal veins segmentation
Constructing the IVC tree
data:image/s3,"s3://crabby-images/608bd/608bd3d9ec78db59b39c6f3dbdc88b1992c8e4cf" alt=""
data:image/s3,"s3://crabby-images/afdfa/afdfac9c1ee4bbb17c30ee01f172c21deddb7608" alt=""
Extracting and segmenting the IVC tree
data:image/s3,"s3://crabby-images/37af0/37af0c24e735c1f3cfe6412b2bd87440f36911c3" alt=""
Editing the IVC tree
data:image/s3,"s3://crabby-images/df3bb/df3bb98ade539a3b582dd7b6f191b587d5e1f514" alt=""
data:image/s3,"s3://crabby-images/27ceb/27ceb390856aadcbf2db8322bec479685f44579a" alt=""
Tumor segmentation
The Tumor
tab allows for annotating the portions of the liver which present any tumors. It uses the segment editor
configured with two segments.
data:image/s3,"s3://crabby-images/16983/169838bb4b7c35bb1b041af2ab6a761bd5b00098" alt=""
Exporting the results
To export the annotation results, navigate to the last tab (the Tumor
tab) and click on
the Export all segmented volumes
button. A dialog will open querying the location where the results need to be saved.
The following results will be saved :
- Liver label map and model
- Portal vein label map, model and center-lines
- Portal vein tree intersection positions (fiducial CSV, adjacent matrix and DGtal compatible format)
- IVC vein label map, model and center-lines
- IVC vein tree intersection positions (fiducial CSV, adjacent matrix and DGtal compatible format)
- Tumor label map
- Slicer scene as .MRB
data:image/s3,"s3://crabby-images/5860e/5860e8fdc28a29d34c0157d7e0d9ac8640c520a8" alt=""
data:image/s3,"s3://crabby-images/da1d8/da1d83c78fe66888ebedb088db1d2759a4a901ac" alt=""
Changelog
1.1.0 (2023/07/12)
- Add MRI AI Liver segmentation support
- Reduce CUDA insufficient memory error by managing sliding window inference devices
- Fix deprecated code and warnings for Slicer 5.2+
- Fix MacOS vessel extraction conversion errors
Developers
Manually installing the plugin
The plugin depends on the VMTK and the extra segmentation editor effects extensions. Extensions can be installed in Slicer3D using the extension manager.
Once VMTK was installed, the plugin can be installed by going to : Edit > Application Settings > Modules > Additional module paths
The RVXLiverSegmentation and RVXLiverSegmentationEffect directories need to be added to the path list.
When first loading the plugin, a button will be displayed to download the required Python packages. After the download, the application will be restarted and the plugin will be ready for usage and development.
Testing
To verify the plugin install, the unit tests of the plugin can be run by enabling Slicer developer mode. To enable the developer mode go to : Edit > Application Settings > Developer
Then tick the Enable developer mode
check box. The application may need to be restarted for this modification to be
taken into account.
To run the unit tests, open the RVesselX plugin, expand the Reload & Test
menu and click on the Reload and Test
button.
To visualize the test results, open the Python console by going to : View > Python Interactor
The number and the result of the tests will be displayed in the console. Should any of the test fail, please don't hesitate to open an issue or contact us through the Slicer forum.
Contributing
This project welcomes contributions. If you want more information about how you can contribute, please refer to the CONTRIBUTING.md file.