Code implementations are developed for combining both JointVesselNet (MICCAI 2020) & VC-Net (IEEE TVCG SciVis 2020) techniques and datasets
👀Paper Link:
i: JointVesselNet: Joint Volume-Projection Convolutional Embedding Networks for 3D Cerebrovascular Segmentation MICCAI 2020
ii: VC-Net: Deep Volume-Composition Networks for Segmentation and Visualization of Highly Sparse and Noisy Image Data IEEE TVCG SciVis 2020 and ArXiv Open Access
We proposed a new visualization-guided computing paradigm to combine direct 3D volume processing and volume rendered clues for effective 3D exploration. Our end-to-end neural network enables robust extraction of 3D microvascular structure through embedding the image composition, generated by maximum intensity projection (MIP), into the 3D volumetric image learning process to enhance the overall performance.
The code is run and tested on Ubuntu 16.04 LTS with CUDA 9.0 and Python3, and you may need the following:
- Tensorflow
- Keras
- nibabel
- SimpleITK
- Nipype
- ITKTubeTK
TubeTK Dataset can be found and downloaded here. Currently it contains 109 patient cases. There are 42 cases which have the Auxillary Data folder (centerline + radius), such data indices can be found in Directory /patch_gen/id_list.txt
.
Preprocess the volume data: 1. Pick MRA modality 2. Skull striping 3. Brain mask computation
$ python data_preprocess.py
Convert the vessel label .tre file in TubeTK dataset to binary volume image:
Please refer here or here for building from source and python wrapping instructions.
The patches have bigger spatial dimensions across axial plane (128 x 128 in our experiments) and 16 along vertical axis. Extract patches randomly from MRA volume and save the required input formats for both 3D and 2D branches, go to /patch_gen
and run:
$ python patch_extraction.py --flag train
$ python patch_extraction.py --flag val
Just run the following script when you get the data ready:) The model by default is trained on multi-GPU, you can disable the multi-GPU training mode in /model/vc-net.py
before the model compilation. Or if you are using higher version of Tensorflow (like TF2.0+), you may need to modify a little bit about how the keras module is imported and use tf.distribute.MirroredStrategy() instead if you have multi-GPUs.
$ python train.py
When completing the network training, you can test the segmentation performance using the metrics upon your requirements either patchwisedly or casewisely. The performance reported in the paper are computed in terms of the entire volume image which is fed into the network with non-overlapping patches.
$ python pred.py
The result will be saved as the whole volume image in nifti format with the same affine matrix as the orginal MRA volume for better examination.
In JointVesselNet, our experiments include the 3D cerebravascular segmentation from MRA from both TubeTK MRA dataset and our collaborative clinic MRA dataset (the clinic MRA dataset is called as major-level MRAG in MICRO-MRI dataset in VC-Net). Typical qualitative results are shown below (key comparison parts are marked in circles):
In VC-Net, we extended the general 3D cerebravascular segmentation framework into more challenging and finer microstructure scenarios which include multimodality major-level arteries/ veins, as well as micro-level vessels. Different input image modalities are shown below:
TubeTK MRA (Whole Brain) | MICRO-MRI Major-Level MRAG (Midbrain) |
---|---|
MICRO-MRI Major-Level MRVG (Midbrain) | Original MICRO-MRI Micro-Level SWI (Whole Brain) |
---|---|
Qualitative results of major-level vessel segmentation in MICRO MRI dataset (key comparison parts are marked in circles):
Qualitative results of micro-level vessel segmentation in MICRO MRI dataset (key comparison parts are marked in circles):
In the error maps:
⚪ True Positive 🔴 False Positive
⚫ True Negative 🔵 False Negative
In MICRO-MRI dataset, the ground truth vessel labels were finally acquired by slice-wise refinement based on the pre-computed vessel labels by MRAGnls, MRVGavg, and SWIATRG methods, instead of labeling from scratch manually using our specifically-designed cerebrovascular labeling and visualization tool as shown below.
Three Vascular Systems | Vascularture Labeling Tool |
---|---|
If you find our work useful in your research, please cite our work 😃:
@article{wang2020vc,
title={VC-Net: Deep Volume-Composition Networks for Segmentation and Visualization of Highly Sparse and Noisy Image Data},
author={Wang, Yifan and Yan, Guoli and Zhu, Haikuan and Buch, Sagar and Wang, Ying and Haacke, Ewart Mark and Hua, Jing and Zhong, Zichun},
journal={IEEE Transactions on Visualization and Computer Graphics},
year={2020},
publisher={IEEE}
}
or
@inproceedings{wang2020jointvesselnet,
title={JointVesselNet: Joint Volume-Projection Convolutional Embedding Networks for 3D Cerebrovascular Segmentation},
author={Wang, Yifan and Yan, Guoli and Zhu, Haikuan and Buch, Sagar and Wang, Ying and Haacke, Ewart Mark and Hua, Jing and Zhong, Zichun},
booktitle={International Conference on Medical Image Computing and Computer-Assisted Intervention},
pages={106--116},
year={2020},
organization={Springer}
}