是一个结合了最新技术进展(State-of-the-Art, SOTA)的实时实例分割项目,基于著名的YOLOv5目标检测架构,并对其进行扩展以实现对图像中每个对象实例的精确像素级分割。以下是该项目的中文介绍:
YOLOv5: YOLOv5 是 You Only Look Once (YOLO) 系列目标检测模型的第五代版本,以其高效、准确和易于部署的特点而广受关注。YOLOv5 架构采用了深度学习方法,尤其是卷积神经网络(CNN),用于在单次前向传播过程中直接预测图像中的边界框(bounding boxes)和对应的类别概率。其设计旨在实现高检测速度与良好检测精度之间的平衡,适用于实时应用场合。
SOTA 实时 Instance Segmentation: 在传统的 YOLOv5 目标检测基础上,该项目进一步引入了实例分割能力,旨在同时提供每个对象实例的精细分割掩模(mask)。这意味着除了定位和识别图像中的对象外,模型还能精确地标记出每个实例的像素级轮廓,使得背景与各个对象之间有清晰的区分。这种能力在许多应用场景中至关重要,如自动驾驶、医疗影像分析、视频编辑、机器人导航等,需要对场景理解达到更精细的程度。
实时性: “Realtime” 表示该项目特别注重模型推理速度,确保能够在处理连续图像流或视频时达到接近即时或与帧率同步的响应速度,这对于需要实时交互或决策的应用场景至关重要。这意味着模型的设计、优化以及硬件加速策略均聚焦于在保证一定分割精度的前提下,尽可能减少推理所需的时间。
技术特点与优化: 项目可能采用了多种先进技术来提升实例分割性能和实时性,可能包括但不限于:
-
轻量级网络结构:使用高效的网络模块和层次结构,如跨阶段局部特征融合、注意力机制等,降低计算复杂度,同时保持良好的特征提取能力。
-
模型压缩与量化:通过知识蒸馏、权重剪枝、低秩分解、模型量化等手段减小模型尺寸,加速推理过程。
-
硬件适配:针对特定硬件(如GPU、CPU、专用加速器)进行模型优化,利用张量核心、矢量化运算等硬件特性提高计算效率。
-
动态调整:可能具备动态调整模型复杂度的能力,根据输入图像的内容或应用场景的需求,在精度与速度间灵活切换。
-
先进的分割策略:借鉴或创新现有的实例分割方法,如Mask R-CNN、YOLACT等的某些关键组件,结合YOLOv5的特性进行适应性改造,以提升分割质量。
-
集成高效的后处理:简化或优化后处理步骤,如非极大值抑制(NMS)、掩模生成等,以减少额外的计算开销。
应用与贡献: 项目的成功实施,意味着在保持实时处理能力的同时,实现了对各类复杂场景中多个对象实例的精准分割,为诸如智能监控、增强现实、工业自动化、无人机导航等领域提供了强大的视觉感知工具。它不仅推动了实例分割技术在实际应用中的普及,也为后续研究者提供了高性能实时实例分割模型的开发范例和实践经验。
使用示例
YOLOv5 分割训练支持自动下载带参数的 COCO128-seg 分割数据集,并手动下载带有 和 的 COCO-segments 数据集。--data coco128-seg.yaml
bash data/scripts/get_coco.sh --train --val --segments
python train.py --data coco.yaml
# Single-GPU
python segment/train.py --model yolov5s-seg.pt --data coco128-seg.yaml --epochs 5 --img 640# Multi-GPU DDP
python -m torch.distributed.run --nproc_per_node 4 --master_port 1 segment/train.py --model yolov5s-seg.pt --data coco128-seg.yaml --epochs 5 --img 640 --device 0,1,2,3
验证 ImageNet-1k 数据集上的 YOLOv5m-seg 准确性:
bash data/scripts/get_coco.sh --val --segments # download COCO val segments split (780MB, 5000 images)
python segment/val.py --weights yolov5s-seg.pt --data coco.yaml --img 640 # validate
预测
使用预训练的 YOLOv5m-seg 预测bus.jpg:
python segment/predict.py --weights yolov5m-seg.pt --data data/images/bus.jpg
model = torch.hub.load('ultralytics/yolov5', 'custom', 'yolov5m-seg.pt') # load from PyTorch Hub (WARNING: inference not yet supported)
将 YOLOv5s-seg 模型导出到 ONNX 和 TensorRT:
python export.py --weights yolov5s-seg.pt --include onnx engine --img 640 --device 0