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

python3GUI--基于PyQt5+DeepSort+YOLOv8智能人员入侵检测系统(详细图文介绍)

文章目录

  • 一.前言
  • 二.技术介绍
    • 1.PyQt5
    • 2.DeepSort
    • 3.卡尔曼滤波
    • 4.YOLOv8
    • 5.SQLite3
  • 三.核心功能
    • 1.登录注册
      • 1.登录
      • 2.注册
    • 2.主界面
      • 1.主界面简介
      • 2.数据输入
      • 3.参数配置
      • 4.告警配置
      • 5.操作控制台
      • 6.核心内容显示区域
      • 7.检测结果表格
      • 8.入侵人员信息表格
      • 9.日志输出区域
      • 10.系统功能总览
  • 四.总结


本系统使用DeepSort对目标进行追踪,支持ROI区域告警,日志导出、加入了登录系统,欢迎了解!
请添加图片描述
在这里插入图片描述

一.前言

本次使用PyQt5+DeepSort实现了一个智能人员入侵检测系统,系统包括多个区域支持ROI感兴趣区域标注告警,支持展示区域内标签显隐控制,自动统计全部目标以及ROI区域内目标,支持数据导出、入侵人员照片查看,动态阈值调整。

二.技术介绍

1.PyQt5

PyQt5 是一套用于创建跨平台桌面应用程序的 Python GUI 工具包,它是 Qt 应用框架的 Python 绑定。通过 PyQt5,开发者可以使用 Python 编写具有现代图形界面的应用程序,支持丰富的控件、信号与槽机制、窗口管理、事件处理等功能。它兼容主流操作系统(如 Windows、macOS 和 Linux),适用于开发各种规模的桌面软件,常与 Qt Designer 配合使用以加快开发效率。请添加图片描述

2.DeepSort

DeepSort(Deep Simple Online and Realtime Tracking)是一种基于深度学习的多目标跟踪算法,它在原始 SORT(Simple Online and Realtime Tracking)算法的基础上引入了外观特征提取器,通过结合目标的运动信息(卡尔曼滤波)和外观特征(由深度神经网络提取)来进行数据关联,从而在遮挡、目标重叠等复杂场景中实现更稳健的跟踪。DeepSort 通常与目标检测器(如 YOLO)结合使用,广泛应用于视频监控、行为识别等实际场景中。在这里插入图片描述

3.卡尔曼滤波

卡尔曼滤波(Kalman Filter)是一种基于线性系统状态空间模型的递归估计算法,广泛用于对动态系统的状态进行预测和修正。它通过结合系统的预测模型和带噪声的观测数据,在每一步动态更新状态估计,从而实现对目标位置、速度等变量的高精度跟踪。卡尔曼滤波具有计算效率高、实时性强的优点,广泛应用于导航、目标跟踪、控制系统和金融预测等领域。

在这里插入图片描述

4.YOLOv8

YOLOv8(You Only Look Once version 8)是由 Ultralytics 推出的最新一代实时目标检测模型,属于 YOLO 系列的改进版本。相比前代模型,YOLOv8 在精度、速度和灵活性上都有显著提升,支持目标检测、图像分割、姿态估计等多任务处理。它采用了更加高效的网络结构和训练策略,并提供开箱即用的 Python 接口和命令行工具,适用于边缘设备和云端部署,广泛应用于安防监控、自动驾驶、工业检测等场景。
在这里插入图片描述

5.SQLite3

SQLite3 是一个轻量级、嵌入式的关系型数据库管理系统,遵循ACID事务规范,使用文件作为数据库存储形式,具有零配置、无需服务器的特点。它被广泛应用于移动设备、桌面软件、嵌入式系统和小型网站等场景中,特别适合对资源占用要求较低、部署简便的本地数据存储需求。在 Python 中,sqlite3 模块作为标准库提供,允许开发者方便地在应用中进行数据库操作,如创建表、插入数据、执行查询等。
在这里插入图片描述

三.核心功能

1.登录注册

1.登录

软件启动后首先进入登录页面,用户需要输入正确的用户名和密码才能使用本系统的正式功能,登录页面整体采用了垂直布局,局部采用了水平布局,登录界面简约不简单,登录功能后端采用SQLite3本地文件型数据库存储用户信息,每次登录都是通过查库进行验证的,实现了流程标准化。
在这里插入图片描述

2.注册

没有账号的用户需要进行注册,注册操作流程十分简单,用户点击登录界面的注册按钮就跳转到了注册窗口,用户需要输入自定义的用户名和两次匹配的密码才能完成登录,值得一提的是,成功注册的用户软件会自动填写用户名和密码到登录界面,实现了登录流程路径的简化。
在这里插入图片描述

2.主界面

1.主界面简介

成功登陆的用户直接跳转至主界面,主界面右上角会展示当前用户的用户名,单击自己的用户名会弹出二级菜单,菜单包括两个项目:退出登录、退出系统。我们软件的主界面左上角是当前日期时间以及星期、紧挨着的是当前系统的CPU、内存占用情况,这些信息都是1秒刷新一次的。
在这里插入图片描述

2.数据输入

在这面板用户可以设置要检测的目标,我们系统是支持多源输入的,输入的数据类型可以是:图片、视频、视频流地址,另外数据输入下方是模型选择,用户可以选择适合当前系统的模型,我们系统内置了YOLOv8n.pt模型,模型位于data/models/目录下,大家可以将自己的模型放置到这个位置,系统会自动识别可以使用的模型,展示到界面上以供用户选择。

在这里插入图片描述

3.参数配置

在这个区域用户可以实时调整当前YOLO识别引擎的重叠度(IOU)以及置信度(Conf),通过动态调整这两个值用户能找到适合目标检测的值,我们内置了两个组件分别是spinBox以及slider,用户可以点击spinBox微调或者拖动slider调整对应的数值,两个组件的数值是关联的。
请添加图片描述

4.告警配置

在这个区域用户可以控制是否进行告警,系统的告警逻辑是:(前置条件:用户要设置ROI区域)-开启告警-ROI区域有人员侵入-发出语音告警消息提示,值得一提的是本系统支持动态调整告警内容,具体的操作流程是:在告警开启情况下,点击蓝色齿轮按钮,在弹出的对话框中输入告警内容,当满足告警条件时,就会使用用户指定的告警内容。
在这里插入图片描述

告警的流程图见下图:
在这里插入图片描述

5.操作控制台

这个区域是本系统的核心,用户可以在操作台直接与系统进行交互,交互的逻辑就是直接点击按钮进行操作,我们采用了不同颜色和不同类型的按钮实现了目标的功能,比如“导出数据”这个按钮,用户点击后可以选择导出到CSV、Excel、TXT类型的文件里,系统人性化的选择了桌面作为默认路径并且自动命名了目标文件,当用户成功导出后,系统还会询问用户是否打开,用户选择“是”系统就会调用默认的打开方式打开导出的数据文件。
值得一提的是,我们的操作控制台下方设置了多达8个开关按钮用于用户直接和系统交互,开关默认都是打开的,即默认显示所有画面标注内容。
请添加图片描述

6.核心内容显示区域

这里我们以检测目标视频为例,给大家演示一下具体核心显示区域的作用,我们在左侧“数据输入”选择打开视频,选择好之后系统会自动进行检测,我们在画面上画下ROI区域,然后停止检测,所有的检测结果以及计数统计信息就都展示到界面上了,在ROI区域的目标被判定为入侵人员,系统自动采用红色框来标注,否则就是一般人员,系统采用蓝框标注,每个目标都会被分配ID、系统自动标注目标类别、置信度。

在这里插入图片描述

7.检测结果表格

在这个表格中用户可以查看当前画面的所有检测结果数据,检测结果包括:目标ID、置信度、类别、是否为入侵人员以及目标的图像数据,整个表格是支持下拉的,我们采用了自定义的滚动条样式,用户可以拖动目标图像到系统导出数据。请添加图片描述

8.入侵人员信息表格

在这个表格区域展示了所有入侵人员的图像以及ID,用户可以比对目标图像以及实时画面检测结果,鼠标放上去会有个发光的效果,表示用户正在和目标进行交互。
请添加图片描述
另外用户可以点击图像在本地图像查看器中查看目标图像,当然目标图像是临时生成的,所以在tmp目录下,只有点击了图像才会生成图像文件,这样做的目的是避免磁盘重复读写,只操作用户感兴趣的数据。

9.日志输出区域

在这个区域实时展示当前的操作以及告警信息,系统采用不同的日志级别实时展示日志,具体来说是:一般信息采用蓝色、警告信息采用橘黄色、错误信息采用红色,每次产生告警信息时,都会展示具体的入侵人员数量,每次产生新的日志内容时,都会自动展示当前时间精确到秒。

请添加图片描述

10.系统功能总览

我们用一张图展示当前系统的主要核心功能
在这里插入图片描述

四.总结

本次由浅入深地和大家分享了我使用PyQt5+DeepSort+YOLOv8开发的智能人员入侵检测系统,系统相当智能并且包括多个功能区域,支持登录注册功能,欢迎大家前来了解!

在这里插入图片描述

http://www.xdnf.cn/news/12842.html

相关文章:

  • 【razor】x264 在 的intra-refresh和IDR插帧
  • Visual Studio 2022打包程序流程
  • BIO通讯
  • 【量化】策略交易 - 均线策略(Moving Average Strategy)- 代码增强版本
  • Vue作用域插槽
  • 楠溪江诗意传承:李文照笔下的山水印记
  • Linux下的进程调度机制
  • 一文看懂Spring Boot集成智谱清言 AI最佳实践
  • Spring AOP执行原理源码解析
  • 上位机知识篇---dialoutuucp组
  • Windows设置之网络路由
  • 手写RPC框架<一> SPI机制
  • 华为云之使用云服务器搭建Leanote云笔记本【玩转华为云】
  • MS8911S/8921S/8922M/8931S 是一款具有内部迟滞的高速比较器
  • spring task定时任务快速入门
  • 【LangChain4J】LangChain4J 第四弹:RAG 的多种实现方式
  • 《汇编语言》第16章 直接定址表——实验16 编写包含多个功能子程序的中断例程
  • 【时时三省】(C语言基础)局部变量和全局变量例题
  • 贝叶斯定理与医学分析(t检验场景)
  • 【量化】策略交易 - 均线策略(Moving Average Strategy)
  • 如何在Redhat Linux7.9下安装配置MySQL
  • 历史数据分析——辽港股份
  • Java高频面试之并发编程-24
  • Semantic-SAM: Segment and Recognize Anything at Any Granularity
  • 大模型如何选型?嵌入模型如何选型?
  • 【PhysUnits】17.2 配套变量结构体 Var(variable.rs)
  • 一套个人知识储备库构建方案
  • UE的AI行为树Selector和Sequence如何理解
  • 数据结构——D/串
  • comfyui 工作流中 图生视频 如何增加视频的长度到5秒