Skip to content

Latest commit

 

History

History
232 lines (159 loc) · 6.62 KB

README.md

File metadata and controls

232 lines (159 loc) · 6.62 KB

YOLOv5: Detecting Blood Cells

Overview

This project demonstrates how to train and deploy a YOLOv5 model for detecting and classifying blood cells, including white blood cells (WBC), red blood cells (RBC), and platelets. The workflow leverages a publicly available dataset and Google Colab for training, testing, and evaluating the model.

the direct colab link to thenotebook is here :

The project resources including the Dataset can be accessed via the following public drive :

Or preferably this repository:

Resources:

  • Notebook: Proejct_YoloV5_detecting_blood_cells.ipynb
  • Model Weights: best.pt
  • Test Video: video.mp4
  • Test Output: output.mp4
  • Execution Recording: yolo.mp4

Dataset Information

The dataset comprises 364 images, annotated across three classes. Originally sourced from open repositories (cosmicad and akshaylambda), it has been processed further using Roboflow.

Dataset Summary:

  • Number of Images: 364
  • Number of Labels: 4888
  • Classes:
    • WBC (White Blood Cells)
    • RBC (Red Blood Cells)
    • Platelets

Visual Insights

  • Dataset Health Check: BCCD health

  • Example Image: Blood Cell Example


Step-by-Step Workflow

Step 1: Setting Up the Environment

First, we verify if a GPU is available for training, mount Google Drive to access the dataset, and ensure all resources are accessible.

# Import necessary libraries and check for GPU
import torch
from google.colab import drive

device = "cuda" if torch.cuda.is_available() else "cpu"
print(f"Using device: {device}")

# Mount Google Drive
drive.mount('/content/drive')
print("Drive mounted. Your dataset is accessible at /content/drive/MyDrive/BloodCellDetection")

Step 2: Cloning YOLOv5 and Installing Dependencies

Next, clone the YOLOv5 repository from GitHub and install the required dependencies.

!git clone https://github.com/ultralytics/yolov5.git
%cd yolov5
!pip install -r requirements.txt -q

Step 3: Previewing the Dataset

We explore the dataset structure by listing files from the train, validation, and test directories. This ensures the dataset is correctly set up.

!ls "/content/drive/MyDrive/BloodCellDetection"
!ls "/content/drive/MyDrive/BloodCellDetection/train/images" | head -n 5
!ls "/content/drive/MyDrive/BloodCellDetection/valid/images" | head -n 5
!ls "/content/drive/MyDrive/BloodCellDetection/test/images" | head -n 5

Step 4: Preparing the Configuration File

The data.yaml file specifies dataset paths, the number of classes, and class names. Create the following configuration file:

train: /content/drive/MyDrive/BloodCellDetection/train/images
val: /content/drive/MyDrive/BloodCellDetection/valid/images

# Number of classes
nc: 3

# Class names
names: ["Platelets", "RBC", "WBC"]

Step 5: Training the YOLOv5 Model

Using the blood cell dataset, train YOLOv5 with the following command. Adjust the hyperparameters like epochs and batch size as needed.

!python train.py \
  --data /content/drive/MyDrive/BloodCellDetection/data.yaml \
  --cfg yolov5s.yaml \
  --weights yolov5s.pt \
  --epochs 50 \
  --batch 16 \
  --img 640 \
  --name blood_cell_exp \
  --cache

Step 6: Visualizing Training Results

Once training is complete, YOLOv5 generates results like loss curves, precision, and recall over epochs. Display the training results:

from IPython.display import Image, display

results_png = "/content/yolov5/runs/train/blood_cell_exp/results.png"
if os.path.exists(results_png):
    display(Image(filename=results_png, width=800))
else:
    print("Training results not found.")

Step 7: Evaluating the Model

Validate the trained model on the validation dataset to evaluate its performance. Metrics like precision, recall, and mAP are generated.

!python val.py \
    --weights runs/train/blood_cell_exp/weights/best.pt \
    --data /content/drive/MyDrive/BloodCellDetection/data.yaml \
    --img 640 \
    --conf 0.001 \
    --iou 0.65 \
    --task val

Step 8: Running Inference on Images

Use the YOLOv5 detection script to test the model on new images. The annotated results will be saved in the specified directory.

!python detect.py \
  --weights runs/train/blood_cell_exp/weights/best.pt \
  --source "/content/drive/MyDrive/BloodCellDetection/test/images" \
  --img 640 \
  --conf 0.25 \
  --name blood_cell_test

Step 9: Testing the Model on a Video

Finally, apply the model to detect blood cells in a video. The output will be an annotated video.

import cv2
from models.common import DetectMultiBackend
from utils.general import non_max_suppression
from utils.plots import Annotator, colors
import torch

video_path = '/content/video.mp4'
out_path = 'output.mp4'
weights_path = '/content/yolov5/best.pt'

cap = cv2.VideoCapture(video_path)
out = cv2.VideoWriter(out_path, cv2.VideoWriter_fourcc(*'mp4v'), 30, (640, 480))
model = DetectMultiBackend(weights_path)

while cap.isOpened():
    ret, frame = cap.read()
    if not ret:
        break

    results = model(frame)
    detections = non_max_suppression(results)
    
    for det in detections:
        Annotator(frame).box_label(box, f"{cls} {conf:.2f}", color=colors(cls, True))
    out.write(frame)

cap.release()
out.release()
print("Output video saved as output.mp4")

Results

Test Outputs

  • Test Images: Annotated detection results can be found in the runs/detect/blood_cell_test folder.
  • Test Video Output: The processed video is saved as output.mp4.

Performance Insights

The training and validation metrics indicate high precision, recall, and F1 scores, demonstrating the model’s ability to accurately detect and classify blood cells.


Conclusion

This project provides a complete workflow for training and deploying YOLOv5 for blood cell detection. With its high accuracy and fast inference, YOLOv5 is a powerful tool for medical imaging tasks. Explore the provided resources to replicate or extend this project for your own datasets!