Skip to content

Official implementation of "CST-YOLO: A Novel Method for Blood Cell Detection Based on Improved YOLOv7 and CNN-Swin Transformer".

License

Notifications You must be signed in to change notification settings

SONYYA7/CST-yolov7

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Official CST-YOLO

This is the source code for the paper, "CST-YOLO: A Novel Method for Blood Cell Detection Based on Improved YOLOv7 and CNN-Swin Transformer", of which I am the first author.

Model

The model configuration (i.e., network construction) file is cst-yolo.yaml in the directory ./cfg/training/.

Recommended dependencies:

Python <= 3.8
Torch <= 1.7.1
CUDA <= 11.1

Training

The hyperparameter setting file is hyp.scratch.p5.yaml in the directory ./data/.

Single GPU training
python train.py --workers 8 --device 0 --batch-size 32 --data data/cbc.yaml --img 640 640 --cfg cfg/training/cst-yolo.yaml --weights '' --name cst-yolo --hyp data/hyp.scratch.p5.yaml
Multiple GPU training
python -m torch.distributed.launch --nproc_per_node 4 --master_port 9527 train.py --workers 8 --device 0,1,2,3 --sync-bn --batch-size 128 --data data/cbc.yaml --img 640 640 --cfg cfg/training/cst-yolo.yaml --weights '' --name rcs-yolo --hyp data/hyp.scratch.p5.yaml

Testing

python test.py --data data/cbc.yaml --img 640 --batch 32 --conf 0.001 --iou 0.65 --device 0 --weights runs/train/exp/weights/best.pt --name val

Evaluation

We trained and evaluated CST-YOLO on three blood cell detection datasets Blood Cell Count and Detection (BCCD), Complete Blood Count (CBC), and Blood Cell Detection (BCD). The 60 samples of the validation set duplicate those from the training set in the CBC dataset. Each image includes three types of blood cells: Red Blood Cells (RBCs), White Blood Cells (WBCs), and platelets.

Table 1    Number of examples in BCCD, CBC, and BCD.

Dataset Training Validation Testing Total
BCCD 205 87 72 364
CBC 300 0 60 360
BCD 255 73 36 364

Table 2.1    Performance comparison of YOLOv5x, YOLOv7 and CST-YOLO on the BCCD dataset. Results are [email protected] for each blood cell type and overall performance. The best results are shown in bold.

Model WBCs RBCs Platelets Overall
RT-DETR-R50vd 0.875
YOLOv5x 0.977 0.877 0.915 0.923
YOLOv7 0.977 0.829 0.883 0.896
CST-YOLO 0.984 0.869 0.928 0.927

Table 2.2    Performance comparison of YOLOv5x, YOLOv7 and CST-YOLO on the CBC dataset. Results are [email protected] for each blood cell type and overall performance. The best results are shown in bold.

Model WBCs RBCs Platelets Overall
RT-DETR-R50vd 0.855
YOLOv5x 0.995 0.930 0.942 0.955
YOLOv7 0.995 0.917 0.912 0.941
CST-YOLO 0.995 0.947 0.927 0.956

Table 2.3    Performance comparison of YOLOv5x, YOLOv7 and CST-YOLO on the BCD dataset. Results are [email protected] for each blood cell type and overall performance. The best results are shown in bold.

Model WBCs RBCs Platelets Overall
RT-DETR-R50vd 0.784
YOLOv5x 0.820 0.857 0.975 0.884
YOLOv7 0.874 0.785 0.974 0.878
CST-YOLO 0.899 0.857 0.978 0.911

Ablation Study

The tables below show the effect on the performance of the proposed modules for the three blood cell datasets.

Table 3.1    Abation study of the proposed modules. Results are [email protected] on the BCCD dataset. The best results are shown in bold.

Method WBCs RBCs Platelets Overall
w/o CST 0.849 0.841 0.900 0.894
w/o W-ELAN 0.866 0.860 0.987 0.904
w/o MCS 0.762 1.000 0.987 0.910
w/o MaxPool 0.856 0.806 0.901 0.899

Table 3.2    Abation study of the proposed modules. Results are [email protected] on the CBC dataset. The best results are shown in bold.

Method WBCs RBCs Platelets Overall
w/o CST 0.999 0.944 0.923 0.955
w/o W-ELAN 0.995 0.954 0.910 0.953
w/o MCS 0.998 0.954 0.868 0.940
w/o MaxPool 0.999 0.920 0.938 0.952

Table 3.3    Abation study of the proposed modules. Results are [email protected] on the BCD dataset. The best results are shown in bold.

Method WBCs RBCs Platelets Overall
w/o CST 0.975 0.860 0.869 0.901
w/o W-ELAN 0.980 0.851 0.924 0.918
w/o MCS 0.973 0.878 0.857 0.903
w/o MaxPool 0.975 0.827 0.849 0.884

Generalizability Study

Table 4 compares the performance between the original YOLOv7 and CST-YOLO on the TinyPerson dataset in different domain from medical images for external validation. The experimental results demonstrate the generalizability effectivenss of CST-YOLO in small object detection on both medical (i.e., blood cell) and natural (i.e., tiny person) images.

Table 4    Performance comparison of YOLOv7 and CST-YOLO for all classes of the TinyPerson dataset. The best results are shown in bold.

Model Precision Recall mAP50 mAP50:95
YOLOv7 0.530 0.361 0.335 0.111
CST-YOLO 0.565 0.358 0.344 0.111

Visual Illustrations for Model Explanation

Some heat maps are generated by Grad-CAM from the BCCD dataset. Examples of heat maps and failure cases are shown in Fig. 1 and Fig. 2, respectively.

BloodImage_00261 Platelets WBCs RBCs

(a) BloodImage_00261.jpg                  (b) Platelets                              (c) WBCs                                (d) RBCs
Fig. 1 Example of Grad-CAM heat maps. Input the original blood cell image (a) BloodImage_00261.jpg to be detected and generated heat maps. The three heat maps with gradient-weighted class activation mapping respectively emphasize the objects in different classes: (b) Platelets, (c) WBCs, and (d) RBCs in the blood cell image, and de-emphasize the other two classes. Overall, we have a much more precise region of emphasis that locates the different types of blood cell. We know that the model classifies this input image due to its intrinsic features, not a general region in the image.

Below is one example of failure cases because there aren't any Grad-CAM heatmaps solely generated for platelets. The model ability of dim object detection need be enhanced for future improvements.

BloodImage_00340 WBCs RBCs

(a) BloodImage_00340.jpg                  (b) WBCs                                (c) RBCs
Fig. 2 Example of failure cases. The heat maps of (b) WBCs, and (c) RBCs are generated through inputting the original blood cell image (a) BloodImage_00340.jpg.

Suggested Citation

Our manuscript has been uploaded on arXiv. Please cite our paper if you use code from this repository:

Plain Text

  • IEEE Style
    M. Kang, C.-M. Ting, F. F. Ting, and R. C.-W. Phan, "Cst-yolo: A novel method for blood cell detection based on improved yolov7 and cnn-swin transformer," arXiv:2306.14590 [cs.CV], Jun. 2023.

  • Nature Style
    Kang, M., Ting, C.-M., Ting, F. F. & Phan, R. C.-W. CST-YOLO: a novel method for blood cell detection based on improved YOLOv7 and CNN-swin transformer. Preprint at https://arxiv.org/abs/2306.14590 (2023).

  • Springer Style
    Kang, M., Ting, C.-M., Ting, F. F., Phan, R.C.-W.: CST-YOLO: a novel method for blood cell detection based on improved YOLOv7 and CNN-swin transformer. arXiv preprint arXiv:2306.14590 (2023)

License

CST-YOLO is released under the GNU General Public License v3.0. Please see the LICENSE file for more information.

Copyright Notice

Many utility codes of our project base on the codes of YOLOv7 and Swin Transformer repositories.

About

Official implementation of "CST-YOLO: A Novel Method for Blood Cell Detection Based on Improved YOLOv7 and CNN-Swin Transformer".

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.4%
  • Other 0.6%