Yolo系列 Yolo v4简介

目录

简介

YOLOv4的特点

1、数据增强:马赛克数据增强(Mosaic Data Augmentation)

2、 防止过拟合的方法DropBlock

3、标签平滑(Label Smoothing)

4、损失函数 :GIOU损失、DIOU损失、CIOU损失

(1)、GIOU损失

(2)、DIOU损失

(3)、CIOU损失

​编辑

5、非极大值抑制:DIOU-NMS、Soft-NMS

(1)、DIOU-NMS

(2)、Soft-NMS

6、网络结构

(1)、spp-net网络

(2)、CSP-net网络

(3)、注意力机制

(4)、PAN网络

(5)、激活函数:Mish

7、整体网络结构

总结


简介

YOLOv4(You Only Look Once, Version 4)是一种先进的实时目标检测算法,由Alexey Bochkovskiy、Chien-Yao Wang和Hong-Yuan Mark Liao于2020年提出。作为YOLO系列算法的第四个版本,YOLOv4在继承了前代版本高效性的基础上,通过一系列优化和改进,实现了更高的检测精度和速度。

与YOLO前几个系列相比YOLOv4更换了作者,但整体思考没有变并且吸收了当时主流的框架优点。

YOLOv4的特点

1、数据增强:马赛克数据增强(Mosaic Data Augmentation)

YOLOv4引入了Mosaic数据增强技术,这种技术可以在训练过程中随机组合四个图像的一部分,以生成一个新的训练图像。这有助于模型学习更多的背景信息和上下文关系,提高鲁棒性。

在介绍几种数据增强的方法,YOLOv4就是在此基础上得到的启发。

(1)、Mixup[48]:将两张图片按照比例进行叠加

(2)、Cutout[3]:对图片进行区域裁剪

(3)、CutMix:把两张图片按比例拼接

(4)、Random Erase::用随机值或训练集的平均像素值替换图像的区域

(5)、Hide and Seek:根据概率设置随机隐藏一些补丁

(6)、Self-adversarial-training(SAT):通过引入噪声点来增加训练难度

       

2、 防止过拟合的方法DropBlock

DropBlock是谷歌在2018年提出的一种用于卷积神经网络(CNN)的正则化方法。这是一种用于解决过拟合问题的技术,在训练神经网络时非常有用。过拟合问题是指在训练集上表现很好,但在测试集上表现不佳的问题。 相比于传统的Dropout技术,DropBlock不是随机屏蔽掉一部分特征(注意是对特征图进行屏蔽),而是随机屏蔽掉多个部分连续的区域。这种方法有助于减少神经网络中的冗余连接,从而提高模型的泛化能力。

3、标签平滑(Label Smoothing)

标签平滑是一种正则化技术,用于改善模型的泛化能力,尤其是在分类任务中。 

**在传统的分类任务中,模型的训练目标是使预测概率尽可能接近真实标签的概率,即对于二分类任务,正确标签的预测概率应该是1,而错误标签的预测概率应该是0。
**然而,在YOLOv4中,标签平滑技术会将这个目标进行微调,将正确类别的标签值从1调整为一个较小的值(例如0.95),而将错误类别的标签值从0调整为一个正的较小值(例如0.05)。
**这样做的原因是,如果一个模型对自己的预测过于自信(即预测概率接近1或0),它可能无法很好地泛化到新的、未见过的数据。标签平滑通过让模型对自己的预测不那么确定,来促进模型学习更加鲁棒的特征,从而在遇到新的数据时能够作出更加可靠的预测。


4、损失函数 :GIOU损失、DIOU损失、CIOU损失

这些损失函数是对传统的IoU(Intersection over Union)损失函数的改进。IoU只计算预测框和真实框之间的交集与预测框的比值,这在某些情况下并不能很好地指导模型学习,例如当预测框和真实框不相交时,IoU损失为0,这就没有梯度更新,模型无法从这些错误中学习。

(1)、GIOU损失

GIOU引入了最小封闭形状C(C可以把A、B包含在内),在不重叠情况下能让预测框尽可能朝着真实框前进。

 

但是当预选框与真实框重叠时会出现GIOU损失值不变的情况 

(2)、DIOU损失

DIOU在GIOU的基础上加入了两个框中心点之间的距离信息,这有助于模型更快地收敛到正确的位置。其中分子计算预测框与真实框的中心点欧式距离d分母是能覆盖预测框与真实框的最小BOX的对角线长度c,直接优化距离,速度更快,并解决GIOU问题。

(3)、CIOU损失

损失函数必须考虑三个几何因素:重叠面积,中心点距离,长宽比其中α可以当做权重参数。 

5、非极大值抑制:DIOU-NMS、Soft-NMS

(1)、DIOU-NMS

DIOU-NMS和原始的NMS不同,DIoU-NMS不仅考虑了IoU的值,还考虑了两个Box中心点之间的距离,使用了新的公式决定一个Box是否被删除。

 其中M表示高置信度候选框,Bi就是遍历各个框跟置信度高的重合情况

(2)、Soft-NMS

传统的NMS存在一定的问题:如果一个物体在另一个物体重叠区域出现,即当两个目标框接近时,分数更低的框就会因为与之重叠面积过大而被删掉,从而导致对该物体的检测失败并降低了算法的平均检测,Soft-NMS就可以有效的解决此问题。

 

将当前检测框得分乘以一个权重函数,该函数会衰减与最高得分检测框M有重叠的相邻检测框的分数,越是与M框高度重叠的检测框,其得分衰减越严重,为此选择高斯函数为权重函数,从而修改其删除检测框的规则。(δ通常取0.3)。

6、网络结构

参考网络

(1)、spp-net网络

SPP Net的第一个贡献就是在最后一个卷积层后,接入了金字塔池化层,保证传到下一层全连接层的输入固定。在普通的CNN机构中,输入图像的尺寸往往是固定的(比如224*224像素),输出则是一个固定维数的向量。SPP Net在普通的CNN结构中加入了ROI池化层(ROI Pooling),使得网络的输入图像可以是任意尺寸的,输出则不变,同样是一个固定维数的向量 

(2)、CSP-net网络

它可以增强CNN的学习能力,并且在轻量化的同时保持准确性。

做法:

1、每一个block按照特征图的channel维度拆分为2部分。

2、一份正常执行残差网络,另一份直接concat到block的输出

CSPNet主要是为了解决三个问题: 增强CNN的学习能力;降低内存成本;以及减少计算瓶颈。 它通过将梯度的变化从头到尾地集成到特征图中,从而减少了计算量的同时保证了准确率。在特征金字塔生成过程中采用跨通道池来压缩特征映射,可以减少内存使用。 同时,CSPNet方法可以减少模型计算量和提高运行速度,还能和多种网络结构结合在一起。 

(3)、注意力机制

CBAM(Convolutional Block Attention Module)是一种针对深度神经网络的注意力机制模块,用于提高模型在分类、检测和分割等任务中的表现。它结合了通道注意力和空间注意力,几乎可以嵌入任何CNN网络中,在稍微增加一点计算量和参数量的情况下,可以大大增强模型性能。

yolo v4使用的是其中的SAM(Spatial Attention Module),也就是空间注意力机制,会注重于特征图上某个空间。

 

 

(4)、PAN网络

PAN网络是在FPN网络上进行改进得来的

FPN(Feature Pyramid Networks)是一种用于目标检测和语义分割的深度学习模型,它能够有效地处理不同尺度的目标。 FPN使用图像金字塔的思想,通过对原始图像进行多尺度处理,构造出一个类似真实金字塔的特征金字塔。在特征金字塔的每一层,FPN都会提取出不同的特征,并进行相应的预测。这样,对于不同尺度的目标,FPN可以在不同的特征层上进行预测,从而获得更好的检测效果。

PAN又引入了自底向上的路径,使得底层信息更容易传到顶部

 

(5)、激活函数:Mish

yolo v4使用了Mish激活函数

7、整体网络结构

残差块(Residual Block)的主体部分。在一个残差块中,输入首先通过一个卷积层进行变换,然后将结果加到原始输入上。这种结构允许网络学习残差函数,即输入和输出之间的差异,而不是直接学习输出。这可以使网络更好地关注输入和输出之间的微小差异,提高了特征提取的能力。

总结

YOLOv4相比于YOLOv3,不仅在速度和精度上取得了更好的平衡,而且在网络架构、激活函数、数据增强和优化策略等方面进行了全面的升级,使其成为实时目标检测任务中的一个非常有竞争力的算法。此外,YOLOv4也广泛应用于各种实际场景,如行人安全行为检测、监控、自动驾驶等领域。

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/58862.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言的数组地址 数组的遍历与练习

1.int main(void) { int a[5] { 10,20,30,40,50 };//数组间的元素地址相连的 int* p; printf("%d\n", &a[0]); printf("%d\n", &a[1]); printf("%d\n", &a[2]); printf("%d\n", &a[3]); …

Python实现SSA智能麻雀搜索算法优化XGBoost-MLP回归模型项目实战

说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后关注获取。 1.项目背景 随着大数据技术的迅猛发展,机器学习模型在各行各业的应用越来越广泛。特别是在回归任务…

nginx 设置多个代理服务器(nginx多代理)

修改配置文件 nginx.conf 修改前的内容,如下: worker_processes 1;events {worker_connections 1024; }http {include mime.types;default_type application/octet-stream;sendfile on;keepalive_timeout 65;server {listen 80…

如何找到网上爆款内容,快速复制扩大品牌声量

社媒内容爆款复制是现代营销中的一个重要策略,它对于提升品牌声量、曝光度和知名度具有显著效果。 首先什么是爆款? 爆款内容指的是在社交媒体或其他在线平台上迅速获得大量关注、分享和讨论的内容。 准确、及时找到这部分品牌相关的爆款内容&#xf…

2024年10月文章一览

2024年10月编程人总共更新了21篇文章: 1.2024年9月文章一览 2.《Programming from the Ground Up》阅读笔记:p147-p180 3.《Programming from the Ground Up》阅读笔记:p181-p216 4.《Programming from the Ground Up》阅读笔记&#xff…

Git连接码云-保姆级教学(连接Gitee失败的解决)

Git介绍 码云连接 一、Git介绍 二、Git的工作机制 下载链接:Git - 下载软件包 三、使用步骤 创建一个wss的文件夹,作为‘工作空间’ 四、连接码云账号 五、连接Gitee失败的解决方法 一、Git介绍 Git是一个免费的、开源的分布式版本控制…

KINGBASE部署

环境:x86_64 系统:centos7.9 数据库–版本:KingbaseES_V008R006C008B0014_Lin64_install 授权文件–版本:V008R006-license-企业版-90天 一 前置要求 1.1. 硬件环境要求 KingbaseES支持通用X86_64、龙芯、飞腾、鲲鹏等国产C…

Java并发常见面试题总结(下)

Map(重要) HashMap 和 Hashtable 的区别 线程是否安全: HashMap 是非线程安全的,Hashtable 是线程安全的,因为 Hashtable 内部的方法基本都经过synchronized 修饰。(如果你要保证线程安全的话就使用 ConcurrentHashMa…

Java - 免费图文识别_Java_免费_图片转文字_文字识别_spring ai_spring ai alibaba

本文主要是介绍借助阿里云免费的大模型额度来做高质量的图转文识别,图片转文字,或者文字识别都可以使用,比传统的OCR模式要直接和高效很多 。 本文使用的技术是spring ai qwen vl 。 Qwen vl有 100万Token 免费额度,可以用来免费…

基于边缘计算的智能门禁系统架构设计分析

案例 阅读以下关于 Web 系统架构设计的叙述,回答问题1至问题3。 【说明】 某公司拟开发一套基于边缘计算的智能门禁系统,用于如园区、新零售、工业现场等存在来访被访业务的场景。来访者在来访前,可以通过线上提前预约的方式将自己的个人信息…

基于SpringBoot+Vue的购物商城系统【前后端分离】

基于SpringBootVue的购物商城系统设计与实现 摘要 随着互联网技术的不断发展,线上购物已经成为人们日常生活中不可或缺的一部分。本博客将详细介绍一个基于Spring Boot和Vue的购物商城系统的设计与实现。该系统包含了商品展示、购物车管理、订单处理、用户管理等模块…

标签之文字排版,图片,链接,音视频(HTML) 基础版

目录 标签之文字排版,图片,链接,音视频知识点: 练习题一: 效果: 练习题二: 效果: 标签之文字排版,图片,链接,音视频知识点: 超文本:链接 标记:标签<> 双标签 单标签 <br>//换行 <hr>//水平线 向后tab 向前shifttab html注释<!----> css /**/ …

后端:Spring、Spring Boot-实例化Bean依赖注入(DI)

文章目录 1. 实例化Bean2. 使用FactoryBean3. 依赖注入(DI)3.1 AutoWired 属性注入(查找顺序&#xff1a;先类型&#xff0c;后名字)3.2 AutoWired 在构造函数&参数上的使用3.3 Inject和Resource 进行依赖注入3.4 Value 进行注入 1. 实例化Bean 默认使用无参构造函数&…

深度|谁在为OpenAI和Anthropic的AI编程竞赛提供“军火”?已赚得盆满钵满

图片来源&#xff1a;Unsplash AI 开发者之所以一致认为编程的重要性&#xff0c;是有原因的&#xff1a;大型语言模型编程能力越强&#xff0c;它回答与软件无关的其他类型问题的能力也越强。 去年秋天&#xff0c;几位 Google 人工智能领导者与初创公司 CEO Jonathan Siddh…

H3C OSPF配置

OSPF配置实验 实验拓扑图 实验需求 1.配置IP地址 2.分区域配置OSPF&#xff0c;实现全网互通 3.为了路由结构稳定&#xff0c;要求路由器使用环回口作为Router-id&#xff0c;ABR的环回口宣告进骨干区域 实验配置 1.配置IP地址 R1&#xff1a; <H3C>system-view …

再探“构造函数”

文章目录 一. 初始化列表1.1 实现1.2 何时必须使用初始化列表2.3 尽量使用初始化列表 二. 类型转换2.1 内置类型 转换 类类型2.2 explicit&#xff1a;不转换2.3 构造函数多参数2.4 使用隐式转换 2.5 自定义---转换为--->自定义类型 三. 静态成员变量概念在main函数调用私有…

每日OJ题_牛客_体操队形_dfs+枚举_C++_Java

目录 牛客_体操队形_dfs枚举 题目解析 C代码 Java代码 牛客_体操队形_dfs枚举 体操队形 (nowcoder.com) 描述&#xff1a; dd作为体操队队长&#xff0c;在给队员们排队形&#xff0c;体操队形为一个单独的纵列&#xff0c;体操队有n个同学&#xff0c;标号为1∼…

【Linux内核大揭秘】程序地址空间

文章目录 什么是程序地址空间地址空间的组成虚拟内存技术 如何理解程序地址空间页表页表的细节关于堆区 在Linux中如何查看各个分段的信息总结 什么是程序地址空间 程序地址空间是一个程序在执行期间可以访问的内存范围。它由操作系统为每个进程分配&#xff0c;以确保进程之间…

【论文阅读】Associative Alignment for Few-shot Image Classification

用于小样本图像分类的关联对齐 引用&#xff1a;Afrasiyabi A, Lalonde J F, Gagn C. Associative alignment for few-shot image classification[C]//Computer Vision–ECCV 2020: 16th European Conference, Glasgow, UK, August 23–28, 2020, Proceedings, Part V 16. Spri…