Skip to content

Latest commit

 

History

History
77 lines (62 loc) · 3.76 KB

README.md

File metadata and controls

77 lines (62 loc) · 3.76 KB

Memory-aware curriculum federated learning for breast cancer classification

by Amelia Jiménez-Sánchez, Mickael Tardy, Miguel A. González Ballester, Diana Mateus, Gemma Piella

in Computer Methods and Programs in Biomedicine

This repository provides a PyTorch implementation of our work -> [PDF] [arXiv]

Overview

In this work, we integrate for the first time curriculum learning to improve breast cancer classification in a federated setting. We deploy a collaborative global model trained on three clinical datasets from different vendors (two private and one publicly available). In this federated setting, no imaging data is shared across institutions. For a precise diagnosis, we train our collaborative model on high-resolution mammograms. We focus on scheduling the training samples paying special attention to those that are forgotten during the intermediate updates of the global model. Our approach is combined with unsupervised domain adaptation to deal with domain shift while preserving data privacy. Our results verify the effectiveness of federated adversarial learning for the multi-site breast cancer classification. Moreover, we show that our proposed memory-aware curriculum method is beneficial to further improve classification performance.

Usage

1. Cloning the repository

$ git clone https://github.com/ameliajimenez/curriculum-federated-learning.git
$ cd curriculum-federated-learning/

To use the pretrained weights from Wu et al., download sample_image_model.p from nyukat/breast_cancer_classifier and place it under models/pretrained folder.

2. Single and Mix

It is possible to train a Mix model with more than one datasets using single.py. To do that, modify PATH and specify the directory for the datasets in train_dir.

$ python single.py

3. Federated Learning (Fed)

$ python federated.py

4. Curriculum Federated Learning (Fed-CL)

$ python federated_curriculum.py

5. Federated Adversarial Learning (Fed-Align)

$ python federated_align.py

6. Curriculum Federated Adversarial Learning (Fed-Align-CL)

$ python federated_align_curriculum.py

7. Evaluating the model

$ python test.py

8. Grad-CAM visualization

Compare the Gradient Class Activation Map (Grad-CAM) for the different federated models.

$ python test_misclassified_gradcam.py

Citation

If this work is useful for your research, please cite our paper:

@article{JIMENEZSANCHEZ2022107318,
title = {Memory-aware curriculum federated learning for breast cancer classification},
journal = {Computer Methods and Programs in Biomedicine},
pages = {107318},
year = {2022},
issn = {0169-2607},
doi = {https://doi.org/10.1016/j.cmpb.2022.107318},
url = {https://www.sciencedirect.com/science/article/pii/S016926072200699X},
author = {Amelia Jiménez-Sánchez and Mickael Tardy and Miguel A. {González Ballester} and Diana Mateus and Gemma Piella},
keywords = {Curriculum learning, Data scheduling, Data sharing, Domain adaptation, Federated learning, Malignancy classification, Mammography}
}

Acknowledgments

Repositories that were used in this work: xxlya/Fed_ABIDE, nyukat/breast_cancer_classifier and jacobgil/pytorch-grad-cam.