CaMeL-Net : Centroid-aware Metric Learning for Efficient Multi-class Cancer Classification in Pathology Images
by Jaeung Lee, Chiwon Han, Kyungeun Kim, Gi-Ho Park, and Jin Tae Kwak.
This repository is for our CMPB 2023 paper [Centroid-aware Metric Learning for Efficient Multi-class Cancer Classification in Pathology Images] (-).
CaMeL-Net is a network designed to predict cancer grades in pathological images. The network leverages centroids of different classes to compute relative distances between input images and utilizes metric learning for optimization. The centeroid-aware margin loss is employed not only for positive and negative samples but also for efficient and effective metric learning utilizing centroids from distinct classes. The proposed network predicts input pathological images with relevant class labels, i.e., cancer grades.
All the models in this project were evaluated on the following datasets:
- Colon_KBSMC (Colon TMA from Kangbuk Samsung Hospital)
- Colon_KBSMC (Colon WSI from Kangbuk Samsung Hospital)
- Gastric_KBSMC (Gastric from Kangbuk Samsung Hospital)
conda env create -file environment.yml
conda activate CameLNet
Below are the main directories in the repository:
data/
: datasets and figures used in the repoutils/
: utils that arelossfunction/
: CaM loss definitionmodel_lib/
: model definitionpretrained/
: pretrained weights that are
Below are the main executable scripts in the repository:
config.py
: configuration filedataprepare.py
: data loader filetester_CaMeLNet.py
: evalution-only scripttrainer_CaMeLNet.py
: main training script
Details of data folder
- Clone the dataset and set up the folders in the following structure:
└─ data
└─ colon
| ├─ KBSMC_colon_tma_cancer_grading_1024
| | ├─ 1010711
| | ├─ ...
| | └─ wsi_00018
| └─ KBSMC_colon_45wsis_cancer_grading_512 (Test 2)
| ├─ wsi_001
| ├─ ...
| └─ wsi_100
└─ gastric
├─ gastric_wsi
| ├─ gastric_wsi_PS1024_80_her01_step05_bright230_resize05
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_95
| ├─ gastric_wsi_PS1024_80_her01_step10_bright230_resize05
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_95
| └─ gastric_wsi_PS1024_80_her01_split.csv
└─ gastric_wsi_addition
├─ gastric_wsi_addition_PS1024_ano08_step05_bright230
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_61
├─ gastric_wsi_addition_PS1024_ano08_step05_bright230_resize05
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_61
├─ gastric_wsi_addition_PS1024_ano08_step10_bright230
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_61
├─ gastric_wsi_addition_PS1024_ano08_step10_bright230_resize05
| | ├─ gastric_0
| | ├─ ...
| | └─ gastric_61
└─ gastric_wsi_addition_PS1024_ano08_split.csv
python trainer_CaMeLNet.py [--gpu=<id>] [--data_name=<colon/gastric>] [--wandb_id=<your wandb id>] [--wandb_key=<your wandb key>]
python tester_CaMeLNet.py [--gpu=<id>] [--data_name=<colon/gastric>] [--wandb_id=<your wandb id>] [--wandb_key=<your wandb key> [--pretrained_weight=<True>]]
Model weights obtained from training CaMeL-Net here:
If any of the above checkpoints are used, please ensure to cite the corresponding paper.
If CaMeL-Net is useful for your research, please consider citing the following paper: