Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aican-research/dru-net
🫁 DRU-Net: Lung carcinoma Segmentation using multi-lens distortion and fusion refinement network
https://github.com/aican-research/dru-net
carcinoma convolutional-neural-networks deep-learning histopathology lung lung-cancer pathology whole-slide-image wsi
Last synced: about 2 months ago
JSON representation
🫁 DRU-Net: Lung carcinoma Segmentation using multi-lens distortion and fusion refinement network
- Host: GitHub
- URL: https://github.com/aican-research/dru-net
- Owner: AICAN-Research
- License: mit
- Created: 2024-03-12T11:58:33.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-06-26T19:45:01.000Z (7 months ago)
- Last Synced: 2024-06-27T07:35:46.225Z (7 months ago)
- Topics: carcinoma, convolutional-neural-networks, deep-learning, histopathology, lung, lung-cancer, pathology, whole-slide-image, wsi
- Language: Python
- Homepage:
- Size: 102 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
🫁 DRU-Net
Segmentation of Non-Small Cell Lung Carcinomas
[![license](https://img.shields.io/badge/MIT-License-008000)](https://github.com/AICAN-Research/DRU-Net/blob/main/LICENSE.md)
[![arXiv preprint](https://img.shields.io/badge/arXiv-preprint-D12424)](
https://doi.org/10.48550/arXiv.2406.14287)**DRU-Net** was developed by the AICAN research group.
# Introduction
This repository contains the source code related to the manuscript _"DRU-Net: Lung carcinoma segmentation using multi-lens distortion and fusion refinement network"_ which is openly available on [arXiv](https://arxiv.org/abs/2406.14287).
## A brief introduction to the DRU-Net model
The DRU-Net is an innovative artificial intelligence model designed for the segmentation of non-small cell lung carcinomas (NSCLCs) from whole slide images (WSIs). This model enhances the automated analysis of histopathological images, assisting pathologists by improving the speed and accuracy of cancer diagnosis.## DRU-Net Architecture
DRU-Net integrates two main components:
1. **Patch-Wise Classification (PWC):** Utilizes truncated, pre-trained DenseNet201 and ResNet101V2 networks to classify image patches as tumor or non-tumor. This dual-head setup captures local features effectively, improving initial classification accuracy.
2. **Refinement Network:** A lightweight U-Net architecture that refines the segmentation by considering the global context of the WSIs. This network processes the concatenated outputs of the PWC and a down-sampled WSI, enhancing the detail and accuracy of the tumor delineation.The model is trained on a proprietary dataset of annotated NSCLC WSIs, achieving a high Dice similarity coefficient of 0.91, indicating robust segmentation performance.
## Multi-lens Distortion Augmentation
To further enhance the model's robustness and accuracy, the DRU-Net employs a novel data augmentation technique called Multi-lens Distortion. This method simulates random local lens distortions (both barrel and pincushion) within the training images, introducing variability that helps the model generalize better to new, unseen data.### How It Works:
- **Random Distortions:** Multiple "lenses" are randomly placed on the training images, each distorting the image within a specific radius and strength.
- **Implementation:** The algorithm adjusts pixel positions based on the distortion parameters, creating variations in cell and tissue shapes that the model might encounter in real pathological slides.In the related research, this augmentation resulted in improving the network's performance by 3% on tasks requiring high generalization capabilities.
# Getting started
## Setup
1. Setup virtual environment and activate it:
```
python -m venv venv/
source venv/bin/activate
```2. Install dependencies:
```
pip install -r requirements.txt
```# Development
## Automatic training with whole tumor annotation (WTA)
For this approach, after creating thumbnails of your WSIs, you need to create tissue clusters for balancing the data between various tissue types. For implementation details, see [ClusteringForTissueBalancing.py](ClusteringForTissueBalancing.py).
You also need to create gradients which will be used to create a reliable tissue mask and for clustering in later codes [GenerateGradients.py](GenerateGradients.py).
Before training, we also need to create positions of the patches in WSIs. To generate related patches and their labels you can use npy files or rgb image formats and save the annotation mask. In our code, annotation masks are saved as images and are used for label extraction linked with the patch position. For implementation see [PatchPositions.ipynb](notebooks/PatchPositions.ipynb).
Finally, you can train your model using a code similar to [TrainingOnWSIPatches.ipynb](notebooks/TrainingOnWSIPatches.ipynb).
A sample data generator is used here [Generator.py](src/Generator.py).## Training using saved patches with partial selective annotation (PSA)
In this method, you need to save images from areas of interest and then train the model on those images. Sample implementation can be found here [ManyShotTransferLearning.ipynb](notebooks/ManyShotTransferLearning.ipynb).
You can also use a few-shot learning method [FewShot.py](./FewShot.py) and optimize for the number of classes using our novel optimization method using [FindOptimumNumberOfClasses.py](FindOptimumNumberOfClasses.py).## Linting
First install linting dependencies:
```
pip install isort==5.10.1 flake8==4.0.1 black==22.3.0 "black[jupyter]"
```Then run linting test by:
```
sh shell/lint.sh
```Perform automatic linting by:
```
sh shell/format.sh
```## Citation
If you found the source code or manuscript relevant in your research, please cite the following reference:
```
@misc{oskouei2024segmentation,
title={{Segmentation of Non-Small Cell Lung Carcinomas: Introducing DRU-Net and Multi-Lens Distortion}},
author={Soroush Oskouei and Marit Valla and André Pedersen and Erik Smistad and Vibeke Grotnes Dale and Maren Høibø and Sissel Gyrid Freim Wahl and Mats Dehli Haugum and Thomas Langø and Maria Paula Ramnefjell and Lars Andreas Akslen and Gabriel Kiss and Hanne Sorger},
year={2024},
eprint={2406.14287},
archivePrefix={arXiv},
doi={10.48550/arXiv.2406.14287}
}
```