从壹开始解读Yolov11【源码研读系列】——Data.Augment.py:数据增强模块第四部分——Format标签格式标准化操作

**【前情回顾】**在上一篇文章中介绍了augment.py数据增强文件中一个重要的类------LetterBox图片形状大小统一化,这是不管训练还是预测都必须进行的图片操作。

LetterBox类文章地址:https://blog.csdn.net/qq_58718853/article/details/143233094

【实验代码】 所有实验代码上传至Gitee仓库。(会根据博文进度实时更新):

Gitee链接:https://gitee.com/machine-bai-xue/yolo-source-code-analysis

如果链接失效,访问404拒绝,可以直接在Gitee码云主页搜索------"机器白学",所有项目中的YOLO源码实验就是本系列所有实验代码。

【本节预告】 本文继续augment.py类部分的解读记录,下面要介绍的Format 类,其跟LetterBox类一样十分重要,尤其是在训练时,作用是将图片的标签信息标准化为统一格式,方便后续数据集加载器构建需要。

一、augment.Format类:输入标签格式统一化

1.Format类功能概述

Format 类用于标准化图像的标签信息,以便用于目标检测、实例分割和姿态估计任务。该类将图像和实例的注释转换为统一的格式,以便后续的 collate_fn(批处理函数)在 PyTorch 的 DataLoader 中使用。

其整体结构如下图所示,包含初始化该类一共定义了四个方法。其中**call**主要功能是将图像的标签格式化,以适用目标检测任务,此方法是重点对象,关键功能实现部分;_format_img主要是将图像从numpy数组转为pytorch张量;_format_segments是将语义分割的多边形分割信息转为位图掩码(mask)。

2.init:类参数初始化

首先看此类的初始化参数含义,归纳在下面表格。

|---------------------|----------------------------------------------------------|
| bbox_format | 输入字符串(str)。边界框的格式(如'xyxy'表示左上右下两点坐标;'xywh'表示左上点坐标加上框的宽高) |
| normalize | 输入bool值。是否将边界框的坐标取值归一化至区间【0,1】 |
| return_mask | 输入bool值。是否返回实例分割的掩码(语义分割任务) |
| return_keypoint | 输入bool值。是否返回关键点(姿态评估任务) |
| return_obb | 输入bool值。是否返回定向边界框OBB |

**OBB(Oriented Bounding Box,定向边界框)**是一种与传统的平行轴对齐边界框(Axis-Aligned Bounding Box,AABB)不同的边界框。

传统 的AABB边界框通常是矩形,与图像边界平行,其表示方式通常为左上角坐标加上宽度和高度(x, y, w, h),不考虑物体的旋转方向

OBB边界框 可以随物体的方向进行旋转,通常用来更准确地表示具有明显方向 的物体。OBB的表示方式一般为中心点坐标、宽度、高度、以及旋转角度 (或直接提供四个角点坐标)。这种方式特别适合那些在图像中倾斜、旋转的目标物体。OBB 的优势在于能够更好地适应物体的真实形状和方向,提高检测精度,尤其在目标密集且形状复杂的场景中。

|------------------|---------------------------|
| mask_ratio | 输入整数int值。掩码下采样比例。(语义分割任务) |
| mask_overlap | 输入bool值。掩码是否可以重叠(语义分割任务) |
| batch_idx | 输入bool值。是否保留批次索引 |
| bgr | 输入float浮点数。返回BGR图像的概率 |

3.call:标准化标签与图片数据

此方法并不复杂,该函数接受一个包含图像和标签数据的字典 labels,输出格式化后的字典。

下面暂时屏蔽掉语义分割(return_mask)、姿态评估(return_keypoint)、旋转定向框(return_obb)处的处理代码,专注于检测模型主要的处理逻辑。

下图注释了相关代码的作用和含义。

4.具体数据实验

所有实验代码已上传至Gitee仓库 data/augment/Format.py 下。

首先实验一下默认参数进行格式化操作后的labels输出。

可以看到图片、类别、边界框都转为了PyTorch数据格式。且边界框是归一化后的数据。

继续将归一化功能屏蔽,打印查看此时的边界框信息,已经是坐标绝对值形式的了。

至此,data文件中的augment.py文件中的一些基本类介绍完毕,还有一些针对语义分割、图像分类、姿态评估的增强操作将在以后编写相关任务时记录。

下一篇文章新开一个py文件------解读data文件下的base.py文件,其中定义了一个可灵活调整的数据加载类。

下一篇文章快速链接:从壹开始解读Yolov11【源码研读系列】------Data.Base.py.BaseDataset:可灵活改写的数据集加载处理基类-CSDN博客

相关推荐
向哆哆2 天前
高精度织物缺陷检测数据集(适用YOLO系列/1000+标注)(已标注+划分/可直接训练)
yolo·目标检测
前网易架构师-高司机2 天前
带标注的驾驶员安全带识别数据集,识别率99.5%,可识别有无系安全带,支持yolo,coco json,pascal voc xml格式
xml·yolo·数据集·交通·安全带
向哆哆2 天前
粉尘环境分类检测千张图数据集(适用YOLO系列)(已标注+划分/可直接训练)
yolo·分类·数据挖掘
琅琊榜首20203 天前
移动端AI挂机新范式:YOLOv8+NCNN实现无Root视觉自动化
人工智能·yolo·自动化
智驱力人工智能3 天前
地铁隧道轨道障碍物实时检测方案 守护城市地下动脉的工程实践 轨道障碍物检测 高铁站区轨道障碍物AI预警 铁路轨道异物识别系统价格
人工智能·算法·yolo·目标检测·计算机视觉·边缘计算
智驱力人工智能3 天前
机场鸟类活动智能监测 守护航空安全的精准工程实践 飞鸟检测 机场鸟击预防AI预警系统方案 机场停机坪鸟类干扰实时监测机场航站楼鸟击预警
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
前端摸鱼匠3 天前
YOLOv8使用 Ultralytics 内置功能简化格式转换:介绍如何使用 yolo mode=data 等相关功能或辅助工具来加速和简化数据格式的准备工作
人工智能·yolo·目标检测·机器学习·目标跟踪·视觉检测
hans汉斯3 天前
《数据挖掘》期刊推介&征稿指南
图像处理·人工智能·算法·yolo·数据挖掘·超分辨率重建·汉斯出版社
卓越软件开发3 天前
毕设全栈开发一条龙:Java/SpringBoot/Vue/ 小程序 / Python / 安卓 / AI 图像识别 人脸检测 车牌识别 YOLO
开发语言·spring boot·python·yolo·小程序·毕业设计·课程设计
向哆哆4 天前
单车/共享单车目标检测数据集(适用YOLO系列)(已标注+划分/可直接训练)
人工智能·yolo·目标检测