YOLOX的正负样本分配问题

news/2024/12/14 12:08:00/

正负样本分配策略

  • 正解
  • 举个例子

YOLOX的正负样本分配策略是目标检测中的一个重要环节,它直接影响模型的训练效果和最终的检测性能。以下是YOLOX正负样本分配策略的总结:

正解

  1. PAN的不同分支选取采样点:在特征金字塔网络(PAN)的不同层级中选取采样点,以捕获不同尺度的特征。

  2. 选取正样本候选者:从上述采样点中选取可能包含目标的区域作为正样本候选者。

  3. 选取在GT(Ground Truth,真实标签)中心点附近的采样点:进一步筛选出与真实目标中心点距离较近的采样点,这些点更有可能包含目标。

  4. 合并正样本候选者:将步骤2和步骤3的结果合并,形成最终的正样本候选者集合。

  5. 为每个正样本候选者对应的预测框:为每个正样本候选者分配一个预测框。

  6. 计算IoU(Intersection over Union)和IoULoss:计算每个真实目标框(GT)与每个候选预测框之间的IoU值,并计算IoU损失。

  7. 计算交叉熵损失:对每个真实目标框和每个候选预测框,计算分类的交叉熵损失。

  8. 求解cost matrix:结合IoU损失和交叉熵损失,构建一个成本矩阵,用于评估每个GT与候选预测框的匹配成本。

  9. 求每个GT的正样本数量:通过成本矩阵,为每个GT确定所需的正样本数量。如果成本矩阵的值向下取整后小于1,则该GT需要的正样本数量为1。

  10. 为每个GT选取正样本:根据成本矩阵,为每个GT从正样本候选者中选取对应数量的正样本。

  11. 特殊情况处理:如果有超过1个GT选择了同一个anchor point作为正样本,那么选择与该anchor point的cost值最小的GT。

通过这种策略,YOLOX能够更有效地分配正负样本,提高模型对目标的识别能力,尤其是在处理不同尺度和复杂场景时。这种策略有助于模型学习到更准确的目标定位和分类信息,从而提升目标检测的性能。

举个例子

YOLOX的正负样本分配策略就像是在玩一个“连线”游戏,我们要把图像中的小方块(采样点)和它们要识别的目标(真实目标框,GT)正确地连起来。

  1. 选点:在图像的不同层次上选一些小方块,这些方块可能会包含我们想要找的目标。

  2. 初选正样本:从这些小方块中,挑选出那些靠近目标中心的,作为可能的正样本。

  3. 合并候选:把上一步挑选出来的小方块合并,形成最终的正样本候选列表。

  4. 分配预测框:给每个正样本候选分配一个预测框,这个框是用来预测目标位置的。

  5. 计算匹配度:计算每个真实目标和预测框之间的匹配度,用IoU(重叠程度)来衡量。

  6. 计算成本:结合匹配度和分类的准确性,给每个真实目标和预测框的组合计算一个成本值。

  7. 确定正样本数量:根据成本值,确定每个真实目标需要多少个正样本。

  8. 选择正样本:为每个真实目标挑选出对应数量的正样本,这些正样本是与真实目标最匹配的预测框。

  9. 处理特殊情况:如果有多个真实目标选择了同一个预测框,那么就选择成本值最低的那个。

通过这个过程,YOLOX能够确保模型在训练时,每个目标都能与最合适的预测框匹配,从而提高目标检测的准确性。


http://www.ppmy.cn/news/1551334.html

相关文章

深入浅出 Python 网络爬虫:从零开始构建你的数据采集工具

在大数据时代,网络爬虫作为一种数据采集技术,已经成为开发者和数据分析师不可或缺的工具。Python 凭借其强大的生态和简单易用的语言特点,在爬虫领域大放异彩。本文将带你从零开始,逐步构建一个 Python 网络爬虫,解决实…

速发论文 | 基于 2D-SWinTransformer+1D-CNN-SENet并行故障诊断模型

往期精彩内容: Python-凯斯西储大学(CWRU)轴承数据解读与分类处理 Pytorch-LSTM轴承故障一维信号分类(一)-CSDN博客 Pytorch-CNN轴承故障一维信号分类(二)-CSDN博客 Pytorch-Transformer轴承故障一维信号分类(三)-CSDN博客 三十多个开源…

【k8s深入理解之 Scheme 补充-2】理解 register.go 暴露的 AddToScheme 函数

AddToScheme 函数 AddToScheme 就是为了对外暴露,方便别人调用,将当前Group组的信息注册到其 Scheme 中,以便了解该 Group 组的数据结构,用于后续处理 项目版本用途使用场景k8s.io/apiV1注册资源某一外部版本数据结构&#xff0…

【第十二课】Rust并发编程(三)

前言 这节介绍Rust并发编程之共享可变状态。共享可变状态指的是多个线程访问同一块内存上的数据,要想达到这样的效果,我们必须要了解互斥器,或者说锁,在某个时刻互斥器只允许一个线程访问。,也就意味着每次访问都需要…

【C++】IO库(三):string流

8.3 string 流 sstream 头文件定义了三个类型来支持内存 IO,这些类型可以向 string 写入数据,也可以从 string 读取数据,就像 string 是一个 IO 流一样。 istringstream 从 string 读数据;ostringstream 向 string 写入数据&…

【MATLAB源码-第226期】基于matlab的64QAM系统相位偏移估计HOS算法仿真,对比补偿前后的星座图误码率。

操作环境: MATLAB 2022a 1、算法描述 高阶统计量(HOS)频偏估计算法 高阶统计量(Higher Order Statistics, HOS)频偏估计算法是一种先进的信号处理技术,广泛应用于现代数字通信系统中,以应对和…

【小白学机器学习41】如何从正态分布的总体中去抽样? 获得指定正态分布的样本的2种方法

目录 1 目标:使用2种方法,去从正态分布的总体中去抽样,获得样本 1.1 step1: 首先,逻辑上需要先有符合正态分布的总体population 1.2 从总体中取得样本,模拟抽样的过程 2 从正态分布抽样的方法1 3 从正态分布抽样…

mac maven编译出现问题

背景 进行maven install 命令,报错: [ERROR] COMPILATION ERROR : [INFO] ------------------------------------------------------------- [ERROR] No compiler is provided in this environment. Perhaps you are running on a JRE rather than a J…