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

news2025/7/26 20:02:50

文章目录

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


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

基于PyQt5+DeepSort+YOLOv8智能人员入侵检测系统

一.前言

本次使用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 模块作为标准库提供,允许开发者方便地在应用中进行数据库操作,如创建表、插入数据、执行查询等。
在这里插入图片描述

6.多线程

PyQt5 的多线程通常通过 QThread 类实现,它允许在 GUI 程序中运行耗时的操作而不阻塞主线程(即界面线程),从而保持界面响应。使用 PyQt5 的多线程方法通常有两种方式:继承 QThread 或使用 QRunnable 搭配 QThreadPool。推荐方式是将耗时任务写在一个独立的工作对象中,并通过 moveToThread() 将其移到子线程中运行,同时使用信号(pyqtSignal)与主线程通信。这种方式更加安全、结构清晰,适合复杂项目的线程管理。在这里插入图片描述

7.入侵人员检测

入侵人员检测是指通过监控系统(如视频监控、红外传感器、雷达等)对特定区域进行实时监测,自动识别和判断是否有未经授权的人员进入。该技术广泛应用于安防领域,利用图像识别、行为分析等算法,在检测到异常入侵行为时,及时发出警报或联动安保措施,提高区域安全性和响应效率。在这里插入图片描述

8.ROI区域

ROI(Region of Interest,感兴趣区域)是指在图像或视频中指定的特定区域,用于重点处理或分析。在图像处理和计算机视觉中,ROI 可以帮助算法聚焦于关键部分,提高处理效率和准确性。例如,在人脸识别中,ROI 可能仅为图像中的人脸区域,从而避免对背景进行无用计算。通过设定 ROI,可以节省计算资源,提升系统性能。

在这里插入图片描述

三.核心功能

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.coloradmin.cn/o/2406191.html

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

相关文章

5. TypeScript 类型缩小

在 TypeScript 中,类型缩小(Narrowing)是指根据特定条件将变量的类型细化为更具体的过程。它帮助开发者编写更精确、更准确的代码,确保变量在运行时只以符合其类型的方式进行处理。 一、instanceof 缩小类型 TypeScript 中的 in…

【QT】qtdesigner中将控件提升为自定义控件后,css设置样式不生效(已解决,图文详情)

目录 0.背景 1.解决思路 2.详细代码 0.背景 实际项目中遇到的问题,描述如下: 我在qtdesigner用界面拖了一个QTableView控件,object name为【tableView_electrode】,然后【提升为】了自定义的类【Steer_Electrode_Table】&…

【Docker 02】Docker 安装

🌈 一、各版本的平台支持情况 ⭐ 1. Server 版本 Server 版本的 Docker 就只有个命令行,没有界面。 Platformx86_64 / amd64arm64 / aarch64arm(32 - bit)s390xCentOs√√Debian√√√Fedora√√Raspbian√RHEL√SLES√Ubuntu√√√√Binaries√√√ …

论文笔记:Large Language Models for Next Point-of-Interest Recommendation

SIGIR 2024 1 intro 传统的基于数值的POI推荐方法在处理上下文信息时存在两个主要限制 需要将异构的LBSN数据转换为数字,这可能导致上下文信息的固有含义丢失仅依赖于统计和人为设计来理解上下文信息,缺乏对上下文信息提供的语义概念的理解 ——>使用…

LeetCode 2894.分类求和并作差

目录 题目: 题目描述: 题目链接: 思路: 思路一详解(遍历 判断): 思路二详解(数学规律/公式): 代码: Java思路一(遍历 判断&a…

CCF 开源发展委员会 “开源高校行“ 暨红山开源 + OpenAtom openKylin 高校行活动在西安四所高校成功举办

点击蓝字 关注我们 CCF Opensource Development Committee CCF开源高校行 暨红山开源 openKylin 高校行 西安站 5 月 26 日至 28 日,CCF 开源发展委员会 "开源高校行" 暨红山开源 OpenAtom openKylin 高校行活动在西安四所高校(西安交通大学…

RabbitMQ work模型

Work 模型是 RabbitMQ 最基础的消息处理模式,核心思想是 ​​多个消费者竞争消费同一个队列中的消息​​,适用于任务分发和负载均衡场景。同一个消息只会被一个消费者处理。 当一个消息队列绑定了多个消费者,每个消息消费的个数都是平摊的&a…

基于微信小程序的作业管理系统源码数据库文档

作业管理系统 摘 要 随着社会的发展,社会的方方面面都在利用信息化时代的优势。互联网的优势和普及使得各种系统的开发成为必需。 本文以实际运用为开发背景,运用软件工程原理和开发方法,它主要是采用java语言技术和微信小程序来完成对系统的…

CSS(2)

文章目录 Emmet语法快速生成HTML结构语法 Snipaste快速生成CSS样式语法快速格式化代码 快捷键(VScode)CSS 的复合选择器什么是复合选择器交集选择器后代选择器(重要)子选择器(重要)并集选择器(重要)**链接伪类选择器**focus伪类选…

【RabbitMQ】- Channel和Delivery Tag机制

在 RabbitMQ 的消费者代码中,Channel 和 tag 参数的存在是为了实现消息确认机制(Acknowledgment)和精细化的消息控制。 Channel 参数 作用 Channel 是 AMQP 协议的核心操作接口,通过它可以直接与 RabbitMQ 交互: 手…

NLP学习路线图(三十四): 命名实体识别(NER)

一、命名实体识别(NER)是什么? 命名实体识别(Named Entity Recognition, NER)是自然语言处理中的一项关键序列标注任务。其核心目标是从非结构化的文本中自动识别出特定类别的名词性短语,并将其归类到预定义的类别中。 核心目标:找到文本中提到的命名实体,并分类。 典…

【HTML】HTML 与 CSS 基础教程

作为 Java 工程师,掌握 HTML 和 CSS 也是需要的,它能让你高效与前端团队协作、调试页面元素,甚至独立完成简单页面开发。本文将用最简洁的方式带你掌握核心概念。 一、HTML,网页骨架搭建 核心概念:HTML通过标签定义内…

Windows开机自动启动中间件

WinSW(Windows Service Wrapper 是一个开源的 Windows 服务包装器,它可以帮助你将应用程序打包成系统服务,并实现开机自启动的功能。 一、下载 WinSW 下载 WinSW-x64.exe v2.12.0 (⬇️ 更多版本下载) 和 sample-minimal.xml 二、配置 WinS…

【图片转AR场景】Tripo + Blender + Kivicube 实现图片转 AR 建模

总览 1.将 2D 图片转为立体建模 2. 3. 一、将 2D 图片转为立体建模 1.工具介绍 Tripo 网站 2.找图片 找的图片必须是看起来能够让 AI 有能力识别和推理的,因为现在的AI虽然可以补全但是能力还没有像人的想象力那么丰富。 比如上面这张图片,看起来虽…

LSTM-XGBoost多变量时序预测(Matlab完整源码和数据)

LSTM-XGBoost多变量时序预测(Matlab完整源码和数据) 目录 LSTM-XGBoost多变量时序预测(Matlab完整源码和数据)效果一览基本介绍程序设计参考资料 效果一览 基本介绍 普通的多变量时序已经用腻了,审稿人也看烦了&#…

C#学习12——预处理

一、预处理指令: 解释:是在编译前由预处理器执行的命令,用于控制编译过程。这些命令以 # 开头,每行只能有一个预处理指令,且不能包含在方法或类中。 个人理解:就是游戏里面的备战阶段(不同对局…

Razor编程中@Helper的用法大全

文章目录 第一章:Helper基础概念1.1 Helper的定义与作用1.2 Helper的基本语法结构1.3 Helper与HtmlHelper的区别 第二章:基础Helper用法2.1 无参数Helper2.2 带简单参数的Helper2.3 带默认值的参数2.4 使用模型作为参数 第三章:高级Helper用法…

鸿蒙APP测试实战:从HDC命令到专项测试

普通APP的测试与鸿蒙APP的测试有一些共同的特征,但是也有一些区别,其中共同特征是,它们都可以通过cmd的命令提示符工具来进行app的性能测试。 其中区别主要是,对于稳定性测试的命令的区别,性能指标获取方式的命令的区…

HarmonyOS-ArkUI 自定义弹窗

自定义弹窗 自定义弹窗是界面开发中最为常用的一种弹窗写法。在自定义弹窗中, 布局样式完全由您决定,非常灵活。通常会被封装成工具类,以使得APP中所有弹窗具备相同的设计风格。 自定义弹窗具备的能力有 打开弹窗自定义布局,以…

[electron]预脚本不显示内联script

script-src self 是 Content Security Policy (CSP) 中的一个指令,它的作用是限制加载和执行 JavaScript 脚本的来源。 具体来说: self 表示 当前源。也就是说,只有来自当前网站或者当前页面所在域名的 JavaScript 脚本才被允许执行。"…