A non-official simple PyTorch implementation of ET-Net
The difference between this implementation and the paper is that, this implementation uses 128 x 128 patches to train the network and make predictions, and then use sliding window to merge predictions. This is because:
i. when I try to use 512 x 512 cropped patch with batch size = 16, my GPU will be out of memory (because neither code nor detailed network setting has been released by the authors, this setting might be different from what the authors use)
ii. model prediction (segmentation) will be more robust if sliding window technique is applied
-
Change the contents of
utils/get_dataset.py
to your directories -
Run
utils/get_edges.py
to get edges of labels in your dataset -
Run
utils/get_pretrained_weight_address.py
to get pretrained weights for ResNet50 (E-Blocks) -
Change settings in
args.py
, including dataset chosen to train, batch size, etc. -
Run
train.py
to train ET-Net on some dataset -
Run
visualize.py
to observe input, label, prediction, and edge prediction -
Run
calculate_metrics.py
to get metrics (AUC, accuracy, mIoU) on validate dataset -
Run
test.py
to predict segmentation results using ET-Net
metric | DRIVE | CHASE-DB1 | MC | LUNA |
---|---|---|---|---|
AUC | 96.25 | 96.49 | ??? | ??? |
Acc. | 95.35 | 97.07 | ??? | ??? |
mIoU | 68.14 | 61.19 | ??? | ??? |
Implement more datasets and get results from these datasets