Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/boemer00/signet-ring-cv
This project focuses on classifying pathological images of signet ring cells from the WSI of gastrointestinal tissues.
https://github.com/boemer00/signet-ring-cv
classification computer-vision image-classification keras neural-networks pathology python recall vgg19
Last synced: about 13 hours ago
JSON representation
This project focuses on classifying pathological images of signet ring cells from the WSI of gastrointestinal tissues.
- Host: GitHub
- URL: https://github.com/boemer00/signet-ring-cv
- Owner: boemer00
- Created: 2023-12-12T09:05:18.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-26T16:03:17.000Z (4 months ago)
- Last Synced: 2024-11-22T05:14:28.723Z (2 months ago)
- Topics: classification, computer-vision, image-classification, keras, neural-networks, pathology, python, recall, vgg19
- Language: Jupyter Notebook
- Homepage:
- Size: 370 MB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Signet Ring Cell Classification Model
## Introduction
This project presents a classification algorithm of signet ring cell carcinoma in histopathological images. Ultimately, the projects addresses the significant challenge of early detection of rare but aggressive carcinomas.## Background
Signet ring cell carcinoma is a rare form of adenocarcinoma, known for its poor prognosis. So, accurate detection of these cells is key to improving patient survival rates. The project uses a unique dataset comprising both positive and negative samples to train a classification model.## Dataset Description
The dataset includes:
- **Positive Samples**: 77 images from 20 Whole Slide Images (WSIs).
- **Negative Samples**: 378 images from 79 WSIs, potentially containing other tumor cells but no signet ring cells.Each image is 2000x2000 pixels, sourced from gastric mucosa and intestine tissues, stained with hematoxylin and eosin, and scanned at X40 magnification. While the original dataset includes annotated information, this project does not require such information.
![.](docs/signet_ring_computer_vision_model.png)
## Installation
To set up the project environment:`git clone https://github.com/boemer00/signet-ring-cell-classification.git`
`cd signet-ring-cell-classification`
`pip install -r requirements.txt`
## Usage
### Training the Model
To train the model, execute the following command:
`python src/trainer.py`
This script uses the model in `src/trainer.py` and saves the trained model for future use.
### Making Predictions Using FastAPI
This project also includes a FastAPI application for deploying the trained model as a web service, which allows users to upload images and receive predictions.
#### Starting the FastAPI Server
To start the FastAPI server, run:
`uvicorn app.main:app --reload`
This command will launch the server, making the API accessible at `http://127.0.0.1:8000`. The `--reload` flag is useful during development as it automatically reloads the server when code changes are made.
#### Using the Prediction Endpoint
Once the server is running, you can make predictions by sending image files to the `/predict/` endpoint. This can be done using the Swagger UI:
1. Navigate to `http://127.0.0.1:8000/docs` in your web browser.
2. Locate the `/predict/` endpoint and use the interactive UI to upload an image file.
3. Submit the request, and the API will return the model's prediction for the uploaded image.The FastAPI application uses the `SignetRingPredictor` class from `src/predictor.py` for processing the image and generating predictions.
## Running Tests
To run tests for this project, navigate to the project directory and activate a virtual environment (recommended). Use the pytest command to execute tests. For detailed output, use `pytest -v`. If using *pytest-cov* for test coverage, view the report with `pytest --cov=src`## Model Architecture and Training
The classification model is built on the VGG19 architecture, with specific customizations for signet ring cell classification. The model includes a `SignetRingPredictor` class, which encapsulates the model's loading and prediction logic, making it seamlessly integrable with FastAPI for deployment.
- **Base Model**: VGG19 pre-trained on ImageNet, without the top layer.
- **Custom Layers**: Global Average Pooling, Dense, Dropout, and Output layers tailored for binary classification.
- **Compilation**: Compiled with the Adam optimizer, binary cross-entropy loss, and includes accuracy and recall metrics.The model's architecture and training details are elaborated in `src/trainer.py`. The `SignetRingPredictor` class, which you can use for predictions--for more details see `src/predictor.py`.
## Results and Evaluation
The evaluation of the classification model focuses on the same three metrics established in the paper:
- **Recall**: The model is designed to prioritise recall, ensuring that the rate of missed signet ring cells (false negatives). While the the minimum acceptable threshold of 20% in in the paper, this current model demonstrated a **recall rate of 75%**. Recall is crucial for medical applications where the cost of missing positive cases is high.
- **Normal Region FP (FPNormal)**: This metric measures the average number of false positives per image in normal (non-cancerous) regions. This project achieved **FPNormal = 11.0** which indicates that, on average, the model incorrectly identifies 11 regions per image as cancerous when they are, in fact, normal. In a clinical setting, a low FPNormal is preferred, as it means fewer false alarms.
- **Free-response ROC (FROC)**: The FROC curve is a plot of the true positive rate against the average number of false positives per image. This metric shows the model's ability to maintain a balance between sensitivity (*aka* recall) and the false positive rate across different thresholds. Below is a fixed levels of FPPI:
- Sensitivity at 1 FPPI: 0.45
- Sensitivity at 2 FPPI: 0.45
- Sensitivity at 4 FPPI: 0.75
- Sensitivity at 5 FPPI: 0.75Sensitivity at 5 FPPI (75%) indicates that the model's threshold to a level where it is allowed to make, on average, 5 false positive detections per image, it will correctly identify 75% of the true positive cases (actual disease presence). However, in a clinical setting, determining an acceptable FPPI level depends on various factors.
## Areas of Improvement
- The current model would benefit from a larger training set to handle a wider staining variability. While hematoxylin and eosin staining aids the detection process, different lab protocals or the age of the chemical might affect colour intensity. Therefore, future versions should include more images from different labs as well as a more stain-specific tuning.
- Creating a standard protocol on the handling of WSI for computer vision models could improve image quality due to factors like uneven lighting, artifacts, or blur. Improper handling of WSI can hinder the model's ability to accurately analyse the image.
Overall, computer vision models in histopathology would benefit from quality and consistency of improved processes.
## Citation
Da Q, Huang X, Li Z, et al. [DigestPath: a Benchmark Dataset with Challenge Review for the
Pathological Detection and Segmentation of Digestive-System](https://doi.org/10.1016/j.media.2022.102485)[J].
Medical Image Analysis, 2022: 102485.[GitHub repo for the original project](https://github.com/bupt-ai-cz/CAC-UNet-DigestPath2019/blob/main/papers/DigestPath-a-Benchmark-Dataset-with-Challenge-Review.pdf)