当前位置: 首页 > news >正文

基于深度学习的安全帽识别检测系统(python OpenCV yolov5)

收藏和点赞,您的关注是我创作的动力

文章目录

    • 概要
  • 一、研究的内容与方法
  • 二、基于深度学习的安全帽识别算法
    • 2.1 深度学习
    • 2.2 算法流程
    • 2.3 目标检测算法
    • 2.3.1 Faster R-CNN
    • 2.3.2 SSD
    • 2.3.3 YOLO v3
  • 三 实验与结果分析
    • 3.1 实验数据集
    • 3.1.1 实验数据集的构建
    • 3.1.2 数据集的分类
    • 3.1.3 增强数据集
  • 四 原型系统实现
    • 4.1 生成系统的Web页面
    • 4.2 上传检测图片
  • 五 结 论
    • 目录

概要

  
  基于深度学习算法,以PaddlePaddle深度学习框架作为实验环境,选取了开源的安全帽识别数据库和实地拍摄的安全帽佩戴照片,使用样本扩增增加了实验数据集的样本数,选取了Faster R-CNN、SSD与YOLO v3三种深度神经网络模型,构建出安全帽智能识别模型。
  在实验数据集上对三种模型分别实验,对比实验结果。结果显示,基于YOLOv3的模型具有识别精度高,识别速率快等特点,识别准确率达到了99.97%。为了验证了本文提出方法的有效性,使用Python语言开发了安全帽佩戴识别的原型系统。
  
关键词:深度学习;安全帽识别;Python;YOLO v3

一、研究的内容与方法

  本课题对基于深度学习的安全帽佩戴识别方法进行了研究,以PaddleHub深度学习框架作为实验环境,选取了开源的安全帽识别数据库和实地拍摄的安全帽佩戴照片,使用样本扩增增加了实验数据集的样本数,选取了Faster RCNN、SSD与YOLOv3三种深度神经网络模型,构建出安全帽智能识别模型。在实验数据集上对三种模型进行了对比实验。分别计算了准确率、速率与稳定性,对实验结果进行了对比分析。为了验证了本文提出方法的有效性,使用Python语言开发了安全帽佩戴识别的原型系统,用于模拟建筑工地上识别安全帽的过程。

二、基于深度学习的安全帽识别算法

2.1 深度学习

深度学习,是实现人工智能的必经之路——机械学习中的一种,是人工神经网络研究不断深入后的产物之一,它的结构特点是包含多个隐藏层感知器。深度学习中更为抽象的高层次表示特征是由多个低层次的特征组合而成,这使深度学习模型更容易发现数据特征的表示结构。由于深度学习模型的构造理念是通过模拟人脑来建立高效分析与学习的神经网络,因此深度学习具有通过模拟人脑的思考方式来解释图像、声音等数据的能力。深度学习是一种常用的模式分析方法的统称,根据研究的具体内容,主要使用三种方法:
  一是卷积神经网络,也就是基于卷积运算的神经网络系统;二是基于多层神经元的自编码神经网络,主要包括自编码与稀疏编码两类;三是深度执行网络,主要通过多层自编码神经网络进行预训练,继而与鉴别信息结合对神经网络权值进行优化。
  深度学习在通过多层处理后,能够将初始“低层”的特征表示逐渐向“高层”的特征表示转化,以达到用相对简单、基础的模型完成更为困难、复杂的学习任务。从这一角度,也可以把深度学习理解为特征学习或是表示学习
  在以往的机械学习实现实际任务时,通常依赖专家对描述样本的特征进行设计,这使得专家对样本特征设计的好坏,直接影响了实际系统的性能。而特征学习则通过机械学习技术来弥补这一缺点,这使得深度学习拜托了对专家的依赖。

2.2 算法流程

本课题的算法流程图如图1所示
在这里插入图片描述
图1 算法流程图
  首先,将开源的安全帽数据集与工地实地拍摄获取的安全帽原始图片按比例分为训练集与测试集,并对它们分别进行数据增强。然后再用数据增强后训练集对深度模型进行训练。训练完成后,用数据增强后的测试集安全帽图片对已训练的模型进行测试,最后输出识别结果。

2.3 目标检测算法

本文选用了Faster R-CNN、SSD与YOLO v3三种深度模型。Faster R-CNN模型在ILSVRV与COCO等竞赛中均获得多项第一,SSD是在Faster RCNN与YOLO v1 之后的高级的物体检测模型。与 Faster RCNN与YOLO v1相比,SSD在识别速度和性能上都得到了明显的提升。下面对三种模型分别进行介绍。

2.3.1 Faster R-CNN

Faster R-CNN在目标检测领域表现出极强的生命力,虽然Faster R-CNN是2015年建立的算法,但它现在仍然是许多的目标监测系统的基础,并且在解决拥挤或是小物体等问题上仍然具有较大的有优势,这在更新迅速的深度学习领域是十分少见的,不仅如此,Faster R-CNN的利用范围也十分广阔,例如:水果种类检测,宠物种类检测以及本文的安全帽检测等等。

2.3.2 SSD

SSD的全称为Single Shot MultiBox Detector是WeiLiu在ECCV上提出的深度模型,是一种目标检测模型。虽然SSD是在2016年提出的模型,但现在仍然是主要的目标检测算法之一,兼顾了Faster R-CNN与YOLOv1的优缺点,在速度上优于Faster R-CNN,在精度上优于YOLOv1;并且在处理小目标时对比YOLO有着结构上的优势。

2.3.3 YOLO v3

YOLO v3是在YOLOv2与YOLOv1的基础上建立的一种目标检测算法采用了残差跳连接和上采样等新架构值,YOLO v3最为突出的特点是它能够检测三种不同的尺度。YOLO是一种全卷积网络,它是通过在特征映射上使用1x1的核来产生最终的输出,而YOLOv3在此基础上完成了优化和改进,它能够在网络的三个位于不同位置的大小不同的特征图使用1x1核来进行检测。

三 实验与结果分析

3.1 实验数据集

3.1.1 实验数据集的构建

    实验的数据集包括两部分,一部分来源于一个开源的安全帽识别数据集(https://github.com/njvisionpower/Safety-Helmet-Wearing-Dataset),该数据集已经完成了图片样本的标注。另外一部分是本人在工地现场拍摄的照片,也进行了标注。
  佩戴安全帽两个集合,构成有标签的数据样本。随后再将数据集随机划分成训练集与测试集两个部分。两个部分的比例为训练集:测试集=8:2。得到的训练集和测试集的样本数量分布如图2所示。

3.1.2 数据集的分类

   首先将数据集中本人拍摄的安全帽图片样本进行了人工分类,与开源数据集样本一起,划分为佩戴安全帽与未佩戴安全帽两个集合,构成有标签的数据样本。随后再将数据集随机划分成训练集与测试集两个部分。两个部分的比例为训练集:测试集=8:2。得到的训练集和测试集的样本数量分布如图2所示。

在这里插入图片描述

3.1.3 增强数据集

   为了得到更多的训练图片,实验使用Tensorflow开发库对数据进行了增强,目的是达到扩充原始数据集的效果。Tensorflow开发库是深度学习库,它是开源的,支持所有流行语言,如Python、C++、Java、R和Go,并且它受到所有云服务(AWS、Google和Azure)的支持。Tensorflow内部包含有大量的工具,可以对模型进行设计和调试,同时也提供了基本的数据增强工具。
  本课题使用了Tensorflow库对数据集进行了旋转、变形等随机操作,得到增强后的数据集。增强后的数据集包括:佩戴安全帽图片样本总数达到3143张,未佩戴安全帽的图片样本总数达到2271张。在佩戴安全帽的图片样本中,将2514张作为训练集,将629张作为测试集;未佩戴安全帽的图片中将1816张作为训练集,将455张作为测试集。训练集和测试集的样本统计结果如表1所示。图3和图4分别为佩戴安全帽图片样本和未佩戴安全帽图片的样本示例。
表1 训练集和测试集的样本统计

在这里插入图片描述在这里插入图片描述

四 原型系统实现

   因为在实验过程中发现,YOLOv3是三个对比实验中最为突出的一个,在损失函数曲线图中的曲线收敛速度相比另外两种算法更快,而且网络波动的幅度也较小,收敛的值比较小,且准确率在三者中也是最高的一个,得到了YOLOv3在安全帽智能检测领域的适用性较高的结果。因此,本课题基于训练好的YOLOv3模型使用Python语言开发了安全帽佩戴识别的原型系统,用于模拟建筑工地上识别安全帽的过程。该系统实现为一个Web页面。

4.1 生成系统的Web页面

    通过Python程序编写生成了该系统的Web页面。在Python程序运行结束时会给出生成的页面的本地地址和端口号,一般为http://localhost:8000。在浏览器上输入该地址和端口号就可以打开系统的Web页面,进行安全帽的识别操作。下面是该Python程序的源代码。

在这里插入图片描述图8是Python程序的运行结果。输出了系统页面的地址。
在这里插入图片描述

图8 运行结果
打开地址http://localhost:8000就可以实际进行安全帽图像的智能识别操作。

4.2 上传检测图片

识别系统需要上传检测图片,相关代码如下。
在这里插入图片描述

用户只需要点击选择文件就可以打开浏览窗口对图片进行选择,如图10所示。
在这里插入图片描述

图10 选择图片
  在选择了图片之后,运行界面就会改变,便于用户对选择的图片进行确认,以及进行下一步的操作,如图11所示。
在这里插入图片描述
在这里插入图片描述

图11图片确认

五 结 论

  本课题针对企业作业和工地施工过程佩戴安全帽的自动识别问题,基于深度学习,提出了一种安全帽佩戴识别方法。该方法基于深度学习算法,以PaddlePaddle深度学习框架作为实验环境,选取了开源的安全帽识别数据库和实地拍摄的安全帽佩戴照片,使用样本扩增增加了实验数据集的样本数,选取了Faster R-CNN、SSD与YOLO v3三种深度神经网络模型,构建出安全帽智能识别模型。在实验数据集上对三种模型分别实验,对比实验结果。结果显示,基于YOLOv3的模型具有识别精度高,识别速率快等特点,识别准确率达到了99.97%。为了验证了本文提出方法的有效性,使用Python语言开发了安全帽佩戴识别的原型系统。
  在本课题的研究与实现过程中,遇到了许多困难在设计这个系统之前,例如,算法调用失败的经历就多次遇到,图像显示、参数传递出现的问题更是数不胜数,在浏览各大网站之后慢慢摸索,逐渐改善了研究,解决了问题,经过了这一系列的努力,不仅懂得了学习一项技术最重要的是能够脚踏实地,勇敢面对失败才能更加靠近成功,而且提高了自身的专业能力,赋予自己面对将来挑战的信心。由于能力和时间有限,系统仍有着诸多不足,在将来的学习工作中将不断完善。

目录

目 录
内容摘要I
AbstractII
1 绪论1
1.1 目的及意义1
1.2 国内外的发展现状1
1.3 研究的内容与方法2
2 基于深度学习的安全帽识别算法3
2.1 深度学习3
2.2 算法流程4
2.3 目标检测算法4
3 实验结果分析6
3.1 数据集6
3.2 实验环境搭建8
3.3 实验设置9
3.4 实验结果分析10
4 原型系统实现13
4.1 模块调用以及运行网址呼出13
4.2 检测图片上传14
4.3 检测结果显示15
5 结论与研究成果17
参考文献18

相关文章:

基于深度学习的安全帽识别检测系统(python OpenCV yolov5)

收藏和点赞,您的关注是我创作的动力 文章目录 概要 一、研究的内容与方法二、基于深度学习的安全帽识别算法2.1 深度学习2.2 算法流程2.3 目标检测算法2.3.1 Faster R-CNN2.3.2 SSD2.3.3 YOLO v3 三 实验与结果分析3.1 实验数据集3.1.1 实验数据集的构建3.1.2 数据…...

Spring源码分析篇一 @Autowired 是怎样完成注入的?究竟是byType还是byName亦两者皆有

1. 五种不同场景下 Autowired 的使用 第一种情况 上下文中只有一个同类型的bean 配置类 package org.example.bean;import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;Configuration public class FruitCo…...

Goby 漏洞发布|F5 BIG-IP AJP 身份认证绕过漏洞(CVE-2023-46747)

漏洞名称:F5 BIG-IP AJP 身份认证绕过漏洞(CVE-2023-46747) English Name:F5 BIG-IP AJP authentication bypass vulnerability (CVE-2023-46747) CVSS core: 10 影响资产数: 307282 漏洞描述: Cisco …...

Vue中watch侦听器用法

watch 需要侦听特定的数据源,并在单独的回调函数中执行副作用 watch第一个参数监听源 watch第二个参数回调函数cb(newVal,oldVal) watch第三个参数一个options配置项是一个对象{ immediate:true //是否立即调用一次 deep:true //是否开启…...

[算法前沿]--054-大语言模型的学习材料

大语言模型的学习材料 Other Papers If you’re interested in the field of LLM, you may find the above list of milestone papers helpful to explore its history and state-of-the-art. However, each direction of LLM offers a unique set of insights and contribut…...

DWA算法,仿真转为C用于无人机避障

DWA算法,仿真转为C用于无人机避障 链接: 机器人局部避障的动态窗口法(dynamic window approach) 链接: 机器人局部避障的动态窗口法DWA (dynamic window approach)仿真源码详细注释版 链接: 常见路径规划算法代码-Matlab (纯代码篇) …...

现阶段的主流数据库分别是哪几种?

关系型数据库 1. MySQL数据库 MySQL是最受欢迎的开源SQL数据库管理系统,它由 MySQL AB开发、发布和支持。MySQL AB是一家基于MySQL开发人员的商业公司,它是一家使用了一种成功的商业模式来结合开源价值和方法论的第二代开源公司。MySQL是MySQL AB的注册商…...

“原生感”暴涨311%,这届年轻人不再爱浓妆?丨小红书数据分析

近年来,越来越多美妆博主在社交媒体平台安利“原生感妆容”,即我们所熟知的“伪素颜妆”、“裸妆”、“白开水妆”,显然,追求“原生感”成为当代妆容主流。通过小红书数据分析工具,查看#原生感妆容 话题,近…...

基于深度学习的植物识别算法 - cnn opencv python 计算机竞赛

文章目录 0 前言1 课题背景2 具体实现3 数据收集和处理3 MobileNetV2网络4 损失函数softmax 交叉熵4.1 softmax函数4.2 交叉熵损失函数 5 优化器SGD6 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习的植物识别算法 ** …...

k8s调度约束

List-Watch Kubernetes 是通过 List-Watch的机制进行每个组件的协作,保持数据同步的,每个组件之间的设计实现了解耦。 List-Watch机制 工作机制:用户通过 kubectl请求给 APIServer 来建立一个 Pod。APIServer会将Pod相关元信息存入 etcd 中…...

面经(面试经验)第一步,从自我介绍开始说起

看到一位同学讲自己的面试步骤和过程,我心有所感,故此想整理下面试的准备工作。以便大家能顺利应对面试,通过面试... 求职应聘找工作,面试是必然的关卡,如今竞争激烈呀,想要得到自己喜欢的工作&#xff0c…...

S/4 HANA 中的 Email Template

1 如何创建Email Template? 没有特定的事务用于创建电子邮件模板,我们可以将其创建为 SE80 事务中的存储库对象,如下所示: 1,选择包(或本地对象)并右键单击。 2,选择“创建”->“更多”->“电子邮件模板” 尽管如此,对于已有的Email Template,可以使用程序…...

\r\n和\n的区别 回车/换行 在不同系统下的区别

文章目录 1 \r\n和\n的区别2 什么是 回车/换行3 \r\n和\n 故事 1 \r\n和\n的区别 \r\n和\n是两个常见的控制字符符号,它们在计算机领域中有着不同的作用和用途。 \r\n在Windows系统中被广泛使用,而\n在Unix和Linux系统中更为常见。 在Windows操作系统中…...

机械应用笔记

1. 螺纹转换头:又名金属塞头,例如M20-M16;适合于大小螺纹转换用; 2. 螺纹分英制和公制,攻丝同样也有英制和公制之分; 3. DB9头制作,M6.5的线,用M6.5的钻头扩线孔,在根…...

机房精密空调发生内部设备通信故障不一会压缩机就停止工作,怎么处理?

环境: 山特AT-DA810U 精密空调 问题描述: 机房精密空调发生内部设备通信故障不一会压缩机就停止工作,怎么处理? 回风处不显示温湿度 解决方案: 1.进入诊断模式工程师密码333333 看到压缩机关闭了,强制输出测试一下压缩机正常 2.尝试更换温湿度传感器模块网口,重启…...

手机端运维管理系统——图扑 HT for Web

随着信息技术的快速发展,网络技术的应用涉及到人们生活的方方面面。其中,手机运维管理系统可提供数字化、智能化的方式,帮助企业和组织管理监控企业的 IT 环境,提高运维效率、降低维护成本、增强安全性、提升服务质量,…...

中期科技:智慧公厕打造智能化城市设施,提升公共厕所管理与服务体验

智慧公厕是利用先进的技术和创新的解决方案来改进公厕的设施和管理。借助物联网、互联网、5G/4G通信、人工智能、大数据、云计算等新兴技术的集成,智慧公厕具备了一系列令人惊叹的应用功能。从监测公厕内部人体活动状态、人体存在状态,到空气质量情况、环…...

innovus: set_ccopt_property的基本用法

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 clock route clock route的net type分为三种,分别是root、trunk和leaf,其中root是指fanout超过routing_top_fanout_count约束的net,leaf是指…...

打造美团外卖新体验,HarmonyOS SDK持续赋能开发者共赢鸿蒙生态

从今年8月起,所有升级到HarmonyOS 4的手机用户在美团外卖下单后,可通过屏幕上的一个“小窗口”,随时追踪到“出餐、取餐、送达”等订单状态。这个能让用户实时获悉订单进度的神奇“小窗口”,就是实况窗功能。 实况窗:简…...

Realtek 5G pcie网卡 RTL8126-CG简介

总shu:PCIE 5G网卡方案“RTL8126-CG”采用QFN56封装,面积8 x 8毫米,非常小巧,提供一个RJ-45网口、两个USB 3.x接口。它走的是PCIe 3.0 x1系统通道,搭配超五类网线,可以在长达100米的距离上提供满血的5Gbps网…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了: 这一篇我们开始讲: 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下: 一、场景操作步骤 操作步…...

java 实现excel文件转pdf | 无水印 | 无限制

文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

UE5 学习系列(三)创建和移动物体

这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...

基于Uniapp开发HarmonyOS 5.0旅游应用技术实践

一、技术选型背景 1.跨平台优势 Uniapp采用Vue.js框架,支持"一次开发,多端部署",可同步生成HarmonyOS、iOS、Android等多平台应用。 2.鸿蒙特性融合 HarmonyOS 5.0的分布式能力与原子化服务,为旅游应用带来&#xf…...

微信小程序 - 手机震动

一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注&#xff1a;文档 https://developers.weixin.qq…...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念&#xff0c;其实 Fiori当中还有 V4&#xff0c;咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务)&#xff0c;代理中间件&#xff08;ui5-middleware-simpleproxy&#xff09;-CSDN博客…...

云原生玩法三问:构建自定义开发环境

云原生玩法三问&#xff1a;构建自定义开发环境 引言 临时运维一个古董项目&#xff0c;无文档&#xff0c;无环境&#xff0c;无交接人&#xff0c;俗称三无。 运行设备的环境老&#xff0c;本地环境版本高&#xff0c;ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...

论文笔记——相干体技术在裂缝预测中的应用研究

目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术&#xff1a;基于互相关的相干体技术&#xff08;Correlation&#xff09;第二代相干体技术&#xff1a;基于相似的相干体技术&#xff08;Semblance&#xff09;基于多道相似的相干体…...