This is the official implementation of Omni-Seg: A Scale-aware Dynamic Network for Pathological Image Segmentation.
IEEE TBME Paper
Omni-Seg: A Scale-aware Dynamic Network for Pathological Image Segmentation
Ruining Deng, Quan Liu, Can Cui, Tianyuan Yao, Jun Long, Zuhayr Asad, R. Michael Womick, Zheyu Zhu, Agnes B. Fogo, Shilin Zhao, Haichun Yang, Yuankai Huo.
IEEE Transactions on Biomedical Engineering
MIDL Paper
Omni-Seg: A Single Dynamic Network for Multi-label Renal Pathology Image Segmentation using Partially Labeled Data
Ruining Deng, Quan Liu, Can Cui, Zuhayr Asad, Haichun Yang, Yuankai Huo.
MIDL 2022
SPIE Paper
An Accelerated Pipeline for Multi-label Renal Pathology Image Segmentation at the Whole Slide Image Level
Haoju Leng*, Ruining Deng*, Zuhayr Asad, R. Michael Womick, Haichun Yang, Lipeng Wan, and Yuankai Huo.
SPIE 2023
+ We release an accelerated pipeline as a single Docker.
Comprehensive semantic segmentation on renal pathological images is challenging due to the heterogeneous scales of the objects. For example, on a whole slide image (WSI), the cross-sectional areas of glomeruli can be 64 times larger than that of the peritubular capillaries, making it impractical to segment both objects on the same patch, at the same scale. To handle this scaling issue, we propose the Omni-Seg network, a scale-aware dynamic neural network that achieves multi-object (six tissue types) and multi-scale (5$\times$ to 40$\times$ scale) pathological image segmentation via a single neural network.
The contribution of this paper is three-fold:
(1) a novel scale-aware controller is proposed to generalize the dynamic neural network from single-scale to multi-scale;
(2) semi-supervised consistency regularization of pseudo-labels is introduced to model the inter-scale correlation of unannotated tissue types into a single end-to-end learning paradigm;
(3) superior scale-aware generalization is evidenced by directly applying a model trained on human kidney images to mouse kidney images, without retraining.
sudo docker pull lengh2/omni_seg
You can run the following command or change the input_dir
, then you will have the final segmentation results in output_dir
. Please refer to "New data" section at DEVELOP.md for input data format requirement and data arrangement.
# you need to specify the input directory.
export input_dir=/home/input_dir
# make that directory
sudo mkdir $input_dir
# set output directory
export output_dir=$input_dir/output
#run the docker
sudo nvidia-docker run --shm-size 64G -it --rm -v $input_dir:/INPUTS/ -v $output_dir:/OUTPUTS lengh2/omni_seg
Please refer to INSTALL.md for installation instructions of the segmentation.
Pretrained model can be found here
The training data can be found here
The example dataset for the pipeline which contains a .SVS input file and three .PNG files with different magnifications generated from the .SVS file can be found here
Omni-Seg can easily be run on a single image.
Below is an example input of region image.
- The entire pipeline is at the Omni_seg_pipeline_gpu folder
- Create three empty folders named as "40X", "10X", and "5X" under Omni_seg_pipeline_gpu/svs_input folder. Put 40X, 10X and 5X PNG files of the region image into these folders correspondingly. Each folder must contain only one file when running.
- Create three empty folders in the Omni_seg_pipeline_gpu folder (before running, these three folders must be empty to remove any previous data):
- "clinical_patches" folder
- "segmentation_merge" folder
- "final_merge" folder
- Run the python scripts as following orders:
python 1024_Step1_GridPatch_overlap_padding.py
python 1024_Step1.5_MOTSDataset_2D_Patch_normal_save_csv.py
python Random_Step2_Testing_OmniSeg_label_overlap_64_padding.py --reload_path 'snapshots_2D/fold1_with_white_UNet2D_ns_normalwhole_1106/MOTS_DynConv_fold1_with_white_UNet2D_ns_normalwhole_1106_e89.pth'
python step3.py
python step4.py
- The output will be stored at "final_merge" folder.
If set up correctly, the output should look like
CircleNet can also be run on Whole Slide Images in *.svs file format.
Please download the following file:
We need to annotate and convert data into *.png file format first.
- Annotate the WSI rectangularly to remove most of the empty background. Recommend to use ImageScope and save the .xml file for annotation information.
- Convert the svs file into PNG files and saved into 40X, 10X and 5X magnifications. Please refer to Omni_seg_pipeline_gpu/svs_input/svs_to_png.py for an example to convert svs format to PNG format and resize to different magnifications.
- Create three empty folders named as "40X", "10X", and "5X" under Omni_seg_pipeline_gpu/svs_input folder. Put 40X, 10X and 5X PNG files into these folders correspondingly. Each folder must contain only one file when running.
After annotation, the inputs should be like the following image with three different magnifications
Please create three empty folders in the Omni_seg_pipeline_gpu folder (before running, these three folders must be empty to remove any previous data):
- "clinical_patches" folder
- "segmentation_merge" folder
- "final_merge" folder
To run the Omni-Seg pipeline, please go to Omni_seg_pipeline_gpu folder and run the python scipts as following orders:
python 1024_Step1_GridPatch_overlap_padding.py
python 1024_Step1.5_MOTSDataset_2D_Patch_normal_save_csv.py
python Random_Step2_Testing_OmniSeg_label_overlap_64_padding.py --reload_path 'snapshots_2D/fold1_with_white_UNet2D_ns_normalwhole_1106/MOTS_DynConv_fold1_with_white_UNet2D_ns_normalwhole_1106_e89.pth'
python step3.py
python step4.py
The output will be stored at "final_merge" folder.
If set up correctly, the output should look like
Please refer to DEVELOP.md to train Omni-Seg on a new dataset, design a new architecture based on Omni-Seg.
A Google Colab version of the Oracle pipeline can be found here. The code demonstrates the patch-wise segmentation of the Oracle pipeline.
@article{deng2023omni,
title={Omni-Seg: A Scale-Aware Dynamic Network for Renal Pathological Image Segmentation},
author={Deng, Ruining and Liu, Quan and Cui, Can and Yao, Tianyuan and Long, Jun and Asad, Zuhayr and Womick, R Michael and Zhu, Zheyu and Fogo, Agnes B and Zhao, Shilin and others},
journal={IEEE Transactions on Biomedical Engineering},
year={2023},
publisher={IEEE}
}
@inproceedings{deng2022single,
title={Single Dynamic Network for Multi-label Renal Pathology Image Segmentation},
author={Deng, Ruining and Liu, Quan and Cui, Can and Asad, Zuhayr and Huo, Yuankai and others},
booktitle={International Conference on Medical Imaging with Deep Learning},
pages={304--314},
year={2022},
organization={PMLR}
}
@inproceedings{leng2023accelerated,
title={An accelerated pipeline for multi-label renal pathology image segmentation at the whole slide image level},
author={Leng, Haoju and Deng, Ruining and Asad, Zuhayr and Womick, R Michael and Yang, Haichun and Wan, Lipeng and Huo, Yuankai},
booktitle={Medical Imaging 2023: Digital and Computational Pathology},
volume={12471},
pages={174--179},
year={2023},
organization={SPIE}
}