YOLOv5-Seg 深度解析:与 YOLOv5 检测模型的区别

YOLOv5-Seg 深度解析:与 YOLOv5 检测模型的区别

1. 概述

YOLOv5 是一个强大的目标检测框架,而 YOLOv5-Seg 是其扩展版本,增加了实例分割功能。

YOLOv5(目标检测) vs YOLOv5-Seg(实例分割)

版本 主要任务 输出结果
YOLOv5 目标检测(Object Detection) 目标类别、边界框 (Bounding Box)
YOLOv5-Seg 目标检测 + 实例分割(Instance Segmentation) 目标类别、边界框、掩码 (Mask)

2. YOLOv5-Seg 与 YOLOv5 的结构差异

2.1 网络结构对比

  • YOLOv5-Seg 在 YOLOv5 的基础上增加了 Mask 预测头,用于输出目标的掩码。
  • YOLOv5 仅有 类别预测头边界框预测头

2.2 主要结构变化

YOLOv5-Seg 中,主要修改了 model.yaml 文件,增加了一个 segmentation 相关的输出:

  • nc: 类别数,与目标检测一致。
  • mask: 32×32 的二值化掩码。
  • proto: 原始掩码特征,用于恢复高分辨率掩码。

在代码结构上,YOLOv5-Segmodels/yolo.pyforward() 中增加了额外的分割分支。

Mask 预测头的具体结构

YOLOv5-Seg 在 detect.py 代码中增加了 segmentation 分支,其核心是 mask 预测头,计算方式如下:

  • YOLOv5 目标检测头的基础上,增加了一个 ProtoNet 网络。
  • ProtoNet 负责提取 32×32 的掩码特征。
  • mask 预测头输出 32 维的 mask embedding,并与 ProtoNet 进行点积,生成最终掩码。

models/yolo.py 代码片段中,ProtoNet 计算方式如下:

python 复制代码
class ProtoNet(nn.Module):
    def __init__(self, c1, c2, k=3):
        super().__init__()
        self.conv = nn.Conv2d(c1, c2, k, stride=1, padding=k//2)
    def forward(self, x):
        return self.conv(x)

ProtoNet 结构的作用是对特征图进行降维,使 mask 预测变得更加高效。

3. YOLOv5-Seg 输出格式解析

YOLOv5 目标检测模型中,输出格式如下:

python 复制代码
# YOLOv5 输出 (N, 6): [x1, y1, x2, y2, 置信度, 类别]

YOLOv5-Seg 额外输出了 maskproto,格式如下:

python 复制代码
# YOLOv5-Seg 输出 (N, 6+32): [x1, y1, x2, y2, 置信度, 类别, mask_1, mask_2, ..., mask_32]

其中:

  • mask_1 ~ mask_32 是目标的 32 维掩码向量,用于通过 proto 计算最终掩码。
  • proto 是一个 (32, H/4, W/4) 的张量,用于掩码解码。

4. 训练 YOLOv5-Seg

YOLOv5 训练类似,只需要指定 --task segment

bash 复制代码
python train.py --task segment --data coco128-seg.yaml --weights yolov5s-seg.pt --epochs 100

其中:

  • coco128-seg.yaml 是适用于分割任务的数据集配置。
  • yolov5s-seg.ptYOLOv5-Seg 预训练模型。

5. 推理与后处理

5.1 推理命令

bash 复制代码
python detect.py --task segment --weights yolov5s-seg.pt --source image.jpg

5.2 结果后处理

对于 YOLOv5-Seg,我们需要对 mask 进行解码:

python 复制代码
import torch
import cv2
import numpy as np

def process_mask(mask, proto, bbox, img_shape):
    """
    解析 YOLOv5-Seg 的 32×32 掩码,将其映射到原图
    """
    x1, y1, x2, y2 = map(int, bbox)  # 边界框坐标
    mask_decoded = (proto @ mask.T).sigmoid().cpu().numpy()  # 计算掩码
    mask_resized = cv2.resize(mask_decoded, (x2-x1, y2-y1))
    full_mask = np.zeros(img_shape[:2], dtype=np.uint8)
    full_mask[y1:y2, x1:x2] = (mask_resized > 0.5).astype(np.uint8)
    return full_mask

6. 总结

  • YOLOv5-SegYOLOv5 目标检测基础上,增加了掩码分支,实现了实例分割。
  • 输出增加了 mask,需要结合 proto 进行解码。
  • 训练方式与 YOLOv5 类似,推理时需要额外处理 mask
  • 适用于需要同时进行目标检测和实例分割的任务,如医学影像、自动驾驶等。

如果你对 YOLOv5-Seg 有任何问题,欢迎交流!🚀

相关推荐
workflower7 分钟前
以光量子为例,详解量子获取方式
数据仓库·人工智能·软件工程·需求分析·量子计算·软件需求
壹氿10 分钟前
Supersonic 新一代AI数据分析平台
人工智能·数据挖掘·数据分析
张较瘦_17 分钟前
[论文阅读] 人工智能 | 搜索增强LLMs的用户偏好与性能分析
论文阅读·人工智能
我不是小upper28 分钟前
SVM超详细原理总结
人工智能·机器学习·支持向量机
Yxh1813778455434 分钟前
抖去推--短视频矩阵系统源码开发
人工智能·python·矩阵
取酒鱼食--【余九】1 小时前
rl_sar实现sim2real的整体思路
人工智能·笔记·算法·rl_sar
一勺汤1 小时前
YOLO12 改进|融入 Mamba 架构:插入视觉状态空间模块 VSS Block 的硬核升级
yolo·计算机视觉·mamba·yolov12·yolo12·yolo12该机·yolo12 mamba
Jamence1 小时前
多模态大语言模型arxiv论文略读(111)
论文阅读·人工智能·语言模型·自然语言处理·论文笔记
归去_来兮2 小时前
图神经网络(GNN)模型的基本原理
大数据·人工智能·深度学习·图神经网络·gnn