基于YOLOv7的口罩检测

2024-06-04 17:04
文章标签 检测 口罩 yolov7

本文主要是介绍基于YOLOv7的口罩检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1. 作者介绍
  • 2. YOLOv7网络模型
    • 2.1 算法简介
    • 2.2 数据集介绍
    • 2.3 YOLO格式数据集制作
  • 3. 代码实现
    • 3.1 分割数据集
    • 3.2 修改数据配置文件
    • 3.3 修改训练代码,进行训练
    • 3.4 修改测试代码,进行测试
    • 3.5 检测结果

1. 作者介绍

曹宇欢,女,西安工程大学电子信息学院,2023级研究生
研究方向:模式识别与人工智能
电子邮件:1472644890@qq.com

张思怡,女,西安工程大学电子信息学院,2022级研究生,张宏伟人工智能课题组
研究方向:机器视觉与人工智能
电子邮件:981664791@qq.com

2. YOLOv7网络模型

2.1 算法简介

YOLOv7是一种面向对象检测算法,它利用单次神经网络前向传播实现高效检测并且通过将检测任务分解为多个子任务来完成,从而显著提高了检测的速度和精度。
注意:YOLOv7官方给出了相关论文及源码,地址如下

论文地址:https://arxiv.org/abs/2207.02696
论文代码下载地址:https://github.com/WongKinYiu/yolov7

在这里插入图片描述
上图展示了YOLOv7目标检测算法的整体网络结构。从图中可看出yolov7网络由三个部分组成:input,backbone和head,与yolov5不同的是,将neck层与head层合称为head层,实际上的功能的一样的。对各个部分的功能和yolov5相同,如backbone用于提取特征,head用于预测。

输入层主要是对输入的图片进行预处理,主要包括 Mosaic数据增强、自适应锚框计算、自适应图片缩放等操作。

主干网络主要功能是特征提取,主要包括CBS模块、ELAN模块和MP模块。CBS模块是由1个卷积层、1个归一化层和1个Silu激活函数层构成。ELAN模块由多个CBS模块构成,它通过控制最短和最长的梯度路径,使一个更深的网络同样可以有效地进行学习和收敛。MP模块的主要作用是进行下采样。

头部网络主要包括SPPCSPC模块、UP模块、ELAN-H模块和REP模块。SPP模块的作用是通过最大池化来增大感受野,提升模型精度。CSP模块的主要作用是减小计算量。它将特征分为两部分,其中一部分进行常规处理,另一部分进行SPP结构处理,最后再将两部分合并在一起。这样做可以减少计算量,而且还可以提升模型的精度。UP模块的主要作用是通过最近邻插值的方式进行上采样。ELAN-H模块与ELAN模块非常相似,不同的是ELAN-H模块选取的输出数量比ELAN模块多。REP模块在训练时将1个用于特征提取的3x3卷积、1个用于平滑特征的1x1卷积和1个无卷积操作融合在1个卷积层中,在推理时则重参数化1个3x3的卷积。

2.2 数据集介绍

在疫情期间,佩戴口罩是防止病毒传播的有效措施之一。基于YOLOv7的口罩检测可以帮助政府和公共卫生机构实时监控公共场所人员是否正确佩戴口罩,从而提高防疫措施的有效性。将口罩检测系统集成到现有的监控摄像头中,可以在公共场所(如车站、机场、商场、学校等)实时检测和提醒未佩戴口罩的人员,有助于提高公众卫生意识,减少传染病传播风险。因此,研究佩戴口罩的检测算法,具有重大的意义和广泛的应用价值。

使用网络上的工口罩检测数据集,该数据集共标注2个类别(‘mask’,‘no-mask’),下面给出该数据集下载链接:

口罩数据集百度网盘下载链接:https://pan.baidu.com/s/1Gud8jemSCdjG00TYA74WpQ
提取码:sv74

2.3 YOLO格式数据集制作

本文使用labelimg标注工具,标注了1000张左右作为训练集和验证,分了2个类别:mask,no-mask。

  1. 安装数据集制作工具
    执行如下命令进行数据集制作工具的安装:pip install labelimg
  2. 运行数据集制作工具
    在Terminal执行如下命令打开labelimg、
    在这里插入图片描述
    Labelimg界面如下:
    在这里插入图片描述
  3. 制作数据集
    点击Open Dir打开待制作的图片文件(尽量将图片放在images目录下,以便进行数据集的分割),点击左侧的模式切换,将PascalVOC切换到YOLO模式
    在这里插入图片描述
    绘制box框,并指明标签,点击Create RectBox按钮绘制矩形边框并设置标签文本(no-mask),点击save保存样本标签信息(可以将标签文件存放在labels文件夹下,以便后续进行数据集的分割)
    在这里插入图片描述

3. 代码实现

完整代码已打包到百度网盘:

链接:https://pan.baidu.com/s/1BsPmILw-Nnwn9ZT2anwQ3g
提取码:ddll

3.1 分割数据集

将数据集分割成训练集和验证集,同时可以根据RAIN_RATIO=80来调整训练集和验证集数据比例。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.2 修改数据配置文件

将coco.yaml复制到新建的mask.yaml中,该步骤主要进行修改训练集、验证集、测试集的地址以及类别和名称。
在这里插入图片描述
在这里插入图片描述
修改cfg配置文件,主要将nc:修改为自己数据集的类别数。
在这里插入图片描述
在这里插入图片描述

3.3 修改训练代码,进行训练

修改预训练模型权重(在训练时使用的权重可以在yolov7的readme文档中自行下载用来进行模型的训练)、cfg路径、数据集路径
在这里插入图片描述
修改模型输出路径
在这里插入图片描述
训练轮数,默认为300,训练时间比较久,在这里可以将其修改成100;batch-size用来调整每批处理的图片数量,如果电脑显存较小,可以将其修改为2或4。
在这里插入图片描述
修改完成即可进行模型训练,生成的best.pt即为最佳模型参数。
在这里插入图片描述

3.4 修改测试代码,进行测试

修改模型参数文件(这里使用的权重即为训练时产生的最佳的权重best.pt),数据集路径。
在这里插入图片描述

检测文件参数修改,将source里边的default值改为0也可调用自己的摄像头进行实时检测。
在这里插入图片描述

3.5 检测结果

在训练阶段,使用YOLOv7算法对数据集进行训练,总计训练了300个epochs。从下图可以看出,随着训练次数的增加,模型的训练损失和验证损失都逐渐降低,说明模型不断地学习到更加精准的特征。在训练结束后,我们使用模型在数据集的验证集上进行了评估,得到了以下结果。
在这里插入图片描述
通过分析下述曲线,可以了解到模型在不同置信度下的性能表现。
在这里插入图片描述
下图则是输入指定图片进行检测的结果,也可根据上述代码的修改调用自己的摄像头进行实时检测。
在这里插入图片描述

这篇关于基于YOLOv7的口罩检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030599

相关文章

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

[数据集][目标检测]血细胞检测数据集VOC+YOLO格式2757张4类别

数据集格式:Pascal VOC格式+YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2757 标注数量(xml文件个数):2757 标注数量(txt文件个数):2757 标注类别数:4 标注类别名称:["Platelets","RBC","WBC","sickle cell"] 每个类别标注的框数:

Temu官方宣导务必将所有的点位材料进行检测-RSL资质检测

关于饰品类产品合规问题宣导: 产品法规RSL要求 RSL测试是根据REACH法规及附录17的要求进行测试。REACH法规是欧洲一项重要的法规,其中包含许多对化学物质进行限制的规定和高度关注物质。 为了确保珠宝首饰的安全性,欧盟REACH法规规定,珠宝首饰上架各大电商平台前必须进行RSLReport(欧盟禁限用化学物质检测报告)资质认证,以确保产品不含对人体有害的化学物质。 RSL-铅,

YOLOv8/v10+DeepSORT多目标车辆跟踪(车辆检测/跟踪/车辆计数/测速/禁停区域/绘制进出线/绘制禁停区域/车道车辆统计)

01:YOLOv8 + DeepSort 车辆跟踪 该项目利用YOLOv8作为目标检测模型,DeepSort用于多目标跟踪。YOLOv8负责从视频帧中检测出车辆的位置,而DeepSort则负责关联这些检测结果,从而实现车辆的持续跟踪。这种组合使得系统能够在视频流中准确地识别并跟随特定车辆。 02:YOLOv8 + DeepSort 车辆跟踪 + 任意绘制进出线 在此基础上增加了用户

独立按键单击检测(延时消抖+定时器扫描)

目录 独立按键简介 按键抖动 模块接线 延时消抖 Key.h Key.c 定时器扫描按键代码 Key.h Key.c main.c 思考  MultiButton按键驱动 独立按键简介 ​ 轻触按键相当于一种电子开关,按下时开关接通,松开时开关断开,实现原理是通过轻触按键内部的金属弹片受力弹动来实现接通与断开。  ​ 按键抖动 由于按键内部使用的是机

基于stm32的河流检测系统-单片机毕业设计

文章目录 前言资料获取设计介绍功能介绍具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机设计精品

Android模拟器的检测

Android模拟器的检测 需求:最近有一个需求,要检测出模拟器,防止恶意刷流量刷注册。 1.基于特征属性来检测模拟器,比如IMSI,IDS,特殊文件等等。 这个方案局限性太大,貌似现在大部分模拟器默认就是修改了的,还不需要人为的去修改。 经过测试,发现如下图所示。 如果是模拟器的话,这些特殊值应该返回true,比如DeviceIDS,Build。可是居然返回了false,说明特殊值