【深度学习】基于Python Qt的口罩检测与报警系统

文章目录

  • yolov7训练
  • 系统集成
  • 数据库报警记录查看
  • qt页面跳转方式
  • qt 的数据库某表查看页面如何写
  • q742971636

yolov7训练

yolov7:https://github.com/WongKinYiu/yolov7
人脸口罩数据集:链接:https://pan.baidu.com/s/1bnxJPnoRNwUfVzLxKjIvkQ?pwd=c0yc

300轮训练趋于稳定:

   276/299     34.3G    0.0257  0.007348   0.00204   0.03509      1466       416    0.9493    0.8662    0.9207    0.6118   0.06233   0.01659    0.0317
   277/299     34.3G   0.02548  0.007208  0.002046   0.03473      1397       416    0.9512    0.8673    0.9206    0.6138   0.06227    0.0166   0.03165
   278/299     34.3G   0.02532  0.007306  0.001777    0.0344      1487       416    0.9605    0.8608    0.9207    0.6124   0.06215   0.01658   0.03148
   279/299     34.3G   0.02536  0.007267   0.00177    0.0344      1447       416    0.9605    0.8605     0.921    0.6127   0.06217   0.01652   0.03169
   280/299     34.3G   0.02569  0.007402  0.001857   0.03495      1581       416    0.9475    0.8719    0.9223    0.6111   0.06234   0.01662   0.03161
   281/299     34.3G   0.02528  0.007174  0.001653   0.03411      1525       416    0.9539    0.8662    0.9215    0.6138   0.06228   0.01673   0.03155
   282/299     34.3G   0.02548  0.007163  0.001838   0.03448      1497       416    0.9445    0.8734     0.922    0.6131   0.06231   0.01659     0.032
   283/299     34.3G   0.02502   0.00728  0.001912   0.03421      1581       416    0.9623    0.8628    0.9217    0.6129   0.06229   0.01658   0.03189
   284/299     34.3G    0.0256   0.00737  0.001769   0.03474      1443       416     0.953      0.87    0.9205    0.6125    0.0622   0.01653   0.03176
   285/299     34.3G   0.02513   0.00714  0.001742   0.03401      1407       416    0.9554    0.8657    0.9196    0.6116    0.0622   0.01652   0.03188
   286/299     34.3G   0.02545  0.007449  0.001775   0.03468      1489       416      0.96    0.8633    0.9201    0.6109    0.0622   0.01662   0.03191
   287/299     34.3G   0.02528  0.007087   0.00196   0.03433      1576       416    0.9434    0.8748    0.9204    0.6096   0.06215    0.0166   0.03185
   288/299     34.3G   0.02556  0.007509   0.00175   0.03481      1435       416     0.944    0.8723    0.9187    0.6102   0.06218   0.01653    0.0319
   289/299     34.3G   0.02504  0.007301  0.001822   0.03416      1432       416    0.9412    0.8713    0.9192    0.6112   0.06223    0.0165   0.03185
   290/299     34.3G    0.0254  0.007088  0.001781   0.03427      1531       416    0.9587      0.86    0.9185     0.611   0.06227   0.01651   0.03189
   291/299     34.3G   0.02507  0.007189  0.001821   0.03408      1431       416    0.9585    0.8635    0.9199     0.612   0.06223   0.01658   0.03172
   292/299     34.3G   0.02508   0.00739  0.001682   0.03415      1519       416    0.9615    0.8644      0.92    0.6137   0.06216   0.01661   0.03165
   293/299     34.3G   0.02538   0.00718  0.001836   0.03439      1348       416    0.9599    0.8617    0.9186    0.6131   0.06213   0.01657   0.03178
   294/299     34.3G   0.02553  0.007235  0.002009   0.03477      1330       416      0.95    0.8668    0.9186    0.6109   0.06213   0.01662   0.03183
   295/299     34.3G   0.02568  0.007386   0.00182   0.03489      1599       416    0.9563    0.8642    0.9201    0.6123   0.06213   0.01664   0.03188
   296/299     34.3G   0.02541  0.007049  0.001726   0.03419      1528       416    0.9507    0.8662    0.9194    0.6127   0.06217   0.01665   0.03198
   297/299     34.3G    0.0251  0.007234  0.001805   0.03414      1395       416    0.9429    0.8727     0.919    0.6114   0.06224   0.01664   0.03192
   298/299     34.3G   0.02508  0.006955  0.001866    0.0339      1465       416    0.9458    0.8713    0.9197    0.6121   0.06223   0.01662   0.03193
   299/299     34.3G   0.02551  0.007269  0.001724    0.0345      1555       416    0.9528    0.8664    0.9199    0.6123    0.0622   0.01658   0.03203

准确率曲线:
在这里插入图片描述
召回率曲线:
在这里插入图片描述

系统集成

Qt界面:
在这里插入图片描述
播放过程中,没戴口罩的人脸红色框,戴口罩的白色框。

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

数据库报警记录查看

sqlite数据库,可以查看报警信息,右键可以删除某条记录。
在这里插入图片描述

qt页面跳转方式

sqllite用着很便利,无需安装数据库服务。
qt中从主窗口跳转到别的窗口再回来的方法:
要在DatabaseViewer页面退出后返回到主页面,你需要进行以下操作:
1、在MainWindow类中,创建一个方法来显示DatabaseViewer页面。在这个方法中,实例化DatabaseViewer类,并将其显示为一个对话框或窗口。

from PyQt5.QtWidgets import QDialog

class MainWindow(QWidget):
    # ...

    def show_database_viewer(self):
        # 调用并显示DatabaseViewer页面
        self.database_viewer = DatabaseViewer()
        self.database_viewer.show()

2、在主页面的初始化方法中,连接history_btn按钮的点击事件到

def __init__(self):
    super().__init__()
    # ...
    self.history_btn.clicked.connect(self.show_database_viewer)
    # ...

3、在DatabaseViewer类中,添加一个属性来保存主页面的引用。

class DatabaseViewer(QMainWindow):
    def __init__(self, main_window):
        super().__init__()
        self.main_window = main_window
        # ...

4、在主页面的show_database_viewer方法中,将主页面的引用传递给DatabaseViewer类的实例。

def show_database_viewer(self):
    # 调用并显示DatabaseViewer页面
    self.database_viewer = DatabaseViewer(self)
    self.database_viewer.show()

5、在DatabaseViewer类中,重写关闭事件的方法closeEvent。在关闭事件中,调用父类的关闭事件方法,并显示主页面。

class DatabaseViewer(QMainWindow):
    # ...
    
    def closeEvent(self, event):
        # 调用父类的关闭事件方法
        super().closeEvent(event)
        
        # 显示主页面
        self.main_window.show()

这样,当你在主页面点击"查看记录"按钮时,会调用show_database_viewer方法,显示DatabaseViewer页面。当你在DatabaseViewer页面关闭窗口时,会触发关闭事件,显示主页面。这样就可以在两个页面之间进行切换了。

qt 的数据库某表查看页面如何写

以下是参考:

import os
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView, QMenu, QAction, QMessageBox, QDesktopWidget, \
    QHeaderView
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QStandardItemModel, QStandardItem
import sqlite3


class DatabaseViewer(QMainWindow):
    def __init__(self, main_window):
        super().__init__()
        self.main_window = main_window

        # 设置主窗口的大小为屏幕宽高的一半
        screen_geometry = QDesktopWidget().screenGeometry()
        width = screen_geometry.width() // 2
        height = screen_geometry.height() // 2
        self.resize(width, height)

        # 连接到数据库文件
        self.conn = sqlite3.connect('database.db')
        self.cursor = self.conn.cursor()

        self.table_view = QTableView(self)
        self.setCentralWidget(self.table_view)

        # 创建数据模型
        self.model = QStandardItemModel()
        self.model.setColumnCount(3)
        self.model.setHorizontalHeaderLabels(['ID', '时间戳', '图片路径'])
        self.table_view.setModel(self.model)

        # 设置表格属性
        self.table_view.setEditTriggers(QTableView.NoEditTriggers)
        self.table_view.setSelectionBehavior(QTableView.SelectRows)
        self.table_view.setSelectionMode(QTableView.SingleSelection)
        self.table_view.setContextMenuPolicy(Qt.CustomContextMenu)
        self.table_view.customContextMenuRequested.connect(self.show_context_menu)

        # 设置最后一列填充剩余空间
        self.table_view.horizontalHeader().setStretchLastSection(True)

        # 设置第二列宽度为自定义宽度
        self.table_view.horizontalHeader().setSectionResizeMode(1, QHeaderView.ResizeToContents)

        # 查询数据并显示
        self.query_data()

    def query_data(self):
        # 查询数据
        self.cursor.execute("SELECT * FROM warning_table")
        rows = self.cursor.fetchall()

        # 清空数据模型
        self.model.removeRows(0, self.model.rowCount())

        # 添加数据到数据模型
        for row_data in rows:
            row = [QStandardItem(str(data)) for data in row_data]
            self.model.appendRow(row)

    def show_context_menu(self, position):
        # 右键菜单
        menu = QMenu(self.table_view)
        delete_action = QAction("删除", self.table_view)
        delete_action.triggered.connect(self.delete_row)
        menu.addAction(delete_action)

        # 显示右键菜单
        menu.exec_(self.table_view.viewport().mapToGlobal(position))

    def delete_row(self):
        # 获取选中的行
        selected_row = self.table_view.selectedIndexes()
        if selected_row:
            row = selected_row[0].row()
            item_id = self.model.item(row, 0)
            id_value = int(item_id.text())

            # 拿出数据库里的此id的一行数据,有id、时间戳、图片路径,删除图片路径
            self.cursor.execute("SELECT * FROM warning_table WHERE id = ?", (id_value,))
            rows = self.cursor.fetchall()
            for row_data in rows:
                os.remove(row_data[2])

            # 删除数据
            self.cursor.execute("DELETE FROM warning_table WHERE id = ?", (id_value,))
            self.conn.commit()

            # 从数据模型中移除该行
            self.model.removeRow(row)

            QMessageBox.information(self, "提示", "删除成功")
        else:
            QMessageBox.warning(self, "警告", "请先选择要删除的行")

    def closeEvent(self, event):
        # 调用父类的关闭事件方法
        super().closeEvent(event)

        # 显示主页面
        self.main_window.show()

q742971636

采用416*416的一个输入,使得对小脸检测效果不是很好。训练数据也是重点,肯定是需求更多的训练数据让模型更加稳定。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《OrangeS一个操作系统的实现》中printf无法打印数字问题

【问题现象】 《OrangeS一个操作系统的实现》 第9章 a目录下的代码编译运行后,所有printf打印数字的地方都有问题,如下图: HD size 始终为 0MB。 【问题分析】 通过断点,发现printf第61行: int printf(const char *…

优化|数学软件是如何求解线性方程Ax=b ?

编者按 对于大家来说,我们从学会多项式开始就得和求解矩阵方程打交道。大学之前靠手算,到了大学阶段我们学会了使用科学计算软件,然后只需要输入简单的一行指令 x A \ b x A \backslash b xA\b,就可以轻轻松松求解方程组 A x …

移动端开发

1. 视口 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width, in…

MySQL---SQL优化上(explain分析执行计划、查看SQL的执行效率、定位低效率SQL)

1. 查看SQL的执行效率 MySQL 客户端连接成功后&#xff0c;通过 show [session|global] status 命令可以查看服务器状态信息。通 过查看状态信息可以查看对当前数据库的主要操作类型。 --下面的命令显示了当前 session 中所有统计参数的值 show session status like Com____…

oracle表空间、用户、表的关系和创建

目录 一、表空间 二、用户 &#xff08;1&#xff09;Oracle和mysql、sqlserver的区别 &#xff08;2&#xff09;创建用户 &#xff08;3&#xff09;给用户授权 三、表 &#xff08;1&#xff09;创建表 &#xff08;2&#xff09;用图像化软件添加表约束 1.主键约束…

【java】leetcode 二叉树展开为链表

二叉树展开为链表 leetcode114 .二叉树展开为链表解题思路二叉树专题&#xff1a; leetcode114 .二叉树展开为链表 114 leetcode 链接。可以打开测试 给你二叉树的根结点 root &#xff0c;请你将它展开为一个单链表&#xff1a; 展开后的单链表应该同样使用 TreeNode &#x…

茶润童心 以茶明礼

中国是茶的故乡&#xff0c;也是茶文化的发源地&#xff0c;茶文化也是中国文化的一部分。5月27日下午&#xff0c;8位武汉公益小天使来到中茶恩施硒茶全国运营中心开展少儿茶艺活动。 开场的自我介绍&#xff0c;公益小天使逐个进行自我介绍&#xff0c;喊着“好名字”互相加…

HMM实现中文分词

引言 在隐马尔可夫模型中介绍了HMM的理论部分&#xff0c;为了巩固理论知识&#xff0c;本文基于HMM实现中文分词。具体来说&#xff0c;通过HMM实现基于字级别的分词算法。 HMM 这里简单说明一下&#xff0c;更详细的请参考隐马尔可夫模型。 这里输入序列为 X 1 : N X_{1:N…

基于springboot注解的shiro 授权及角色认证

目录 授权 后端接口服务注解 授权验证-没有角色无法访问 授权验证-获取角色进行验证 授权验证-获取权限进行验证 授权验证-异常处理 授权 用户登录后&#xff0c;需要验证是否具有指定角色指定权限。Shiro也提供了方便的工具进行判 断。 这个工具就是Realm的doGetAuthor…

1.矢量引入

目录 一.什么是矢量 1.1 定义 1.2 公理与体系 1.3 矢量几何化 二.矢量间的相互作用 1.点积 2.点积应用 3.叉积 4. 叉积应用 三.矢量除法 1.单用叉积无法唯一定义矢量除法 2.矢量除法 四.复杂相互作用 1.混合积 2.双叉积 3.Laplace公式 五.泛函的广义矢量理论…

hive任务reduce步骤卡在99%原因及解决

我们在写sql的时候经常发现读取数据不多&#xff0c;但是代码运行时间异常长的情况&#xff0c;这通常是发生了数据倾斜现象。数据倾斜现象本质上是因为数据中的key分布不均匀&#xff0c;大量的数据集中到了一台或者几台机器上计算&#xff0c;这些数据的计算速度远远低于平均…

NVM-Nodejs多版本管理工具

NVM:&#x1f50e;:下载点我 下载含有 setup.exe的 下载完成之后修改一下settings.txt 文件&#xff0c;在原有的基础上直接加入这些配置 root: D:\nvm path: D:\nvm\nodejs node_mirror: https://npm.taobao.org/mirrors/node/ npm_mirror: https://npm.taobao.org/mirrors…

旅游有哪些好玩的地方? 今天用python分析适合年轻人的旅游攻略

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 “旅”是旅行&#xff0c;外出&#xff0c;即为了实现某一目的而在空间上从甲地到乙地的行进过程&#xff1b; “游”是外出游览、观光、娱乐&#xff0c;即为达到这些目的所作的旅行。 二者合起来即旅游。所以&#…

JavaScript 基础 DOM (四)

正则表达式正则表达式 正则基本使用 定义规则 const reg /表达式/其中/ /是正则表达式字面量正则表达式也是对象 使用正则 test()方法 用来查看正则表达式与指定的字符串是否匹配 如果正则表达式与指定的字符串匹配 &#xff0c;返回true&#xff0c;否则false reg.test(…

【算法】【算法杂谈】旋转数组的二分法查找

目录 前言问题介绍解决方案代码编写java语言版本c语言版本c语言版本 思考感悟写在最后 前言 当前所有算法都使用测试用例运行过&#xff0c;但是不保证100%的测试用例&#xff0c;如果存在问题务必联系批评指正~ 在此感谢左大神让我对算法有了新的感悟认识&#xff01; 问题介…

1722_PolySpace Bug Finder的几种启动方式

全部学习汇总&#xff1a; GreyZhang/g_matlab: MATLAB once used to be my daily tool. After many years when I go back and read my old learning notes I felt maybe I still need it in the future. So, start this repo to keep some of my old learning notes servral …

pinia

一、pinia是什么&#xff1f; &#x1f69c;&#x1f69c;&#x1f69c;Pinia是最接近西班牙语中的菠萝的词&#xff1b;背景&#xff1a;大概2019年&#xff0c;是作为一个实验为Vue重新设计状态管理&#xff0c;让它用起来像组合式API。从那时到现在&#xff0c;最初的设计原…

Vulkan Tutorial 5 顶点缓冲区

目录 16 顶点缓冲区 顶点着色器 顶点数据 管道顶点输入 17 顶点缓冲区创建 缓冲区创建 内存要求 内存分配 填充顶点缓冲区 18 暂存缓冲区 传输队列 使用暂存缓冲区 19 索引缓冲区 索引缓冲区创建 使用索引缓冲区 16 顶点缓冲区 我们将用内存中的顶点缓冲区替换…

5。STM32裸机开发(4)

嵌入式软件开发学习过程记录&#xff0c;本部分结合本人的学习经验撰写&#xff0c;系统描述各类基础例程的程序撰写逻辑。构建裸机开发的思维&#xff0c;为RTOS做铺垫&#xff08;本部分基于库函数版实现&#xff09;&#xff0c;如有不足之处&#xff0c;敬请批评指正。 &…

拥抱 Spring 全新 OAuth 解决方案

以下全文 Spring Authorization Server 简称为: SAS 背景 Spring 团队正式宣布 Spring Security OAuth 停止维护&#xff0c;该项目将不会再进行任何的迭代 目前 Spring 生态中的 OAuth2 授权服务器是 Spring Authorization Server 已经可以正式生产使用 作为 SpringBoot 3.0…