人脸识别考勤系统

人脸识别考勤系统是一种利用生物识别技术进行自动身份验证的现代解决方案,它通过分析和比对人脸特征来进行员工的出勤记录。这种系统不仅提升了工作效率,还大大减少了人为错误和欺诈行为的可能性。

一、工作原理

人脸识别考勤系统的核心在于其生物识别算法。当员工到达或离开工作场所时,他们面对摄像头,系统捕获他们的面部图像。随后,这些图像会被转换成数字特征向量,即所谓的“人脸模板”。这一过程涉及检测面部位置、提取关键点(如眼睛、鼻子、嘴巴等)、以及分析面部轮廓和纹理特征。系统会将生成的模板与数据库中已注册的员工模板进行比较,从而实现快速准确的身份验证。

二、系统组成

  1. 硬件设备:包括高分辨率的摄像头、微处理器和存储单元。摄像头用于捕捉员工的面部图像,而微处理器则负责处理图像和执行识别算法。

  2. 软件系统

    • 图像采集模块:用于捕获清晰的人脸图像。
    • 人脸识别算法:基于深度学习的神经网络模型,用于从图像中提取特征并进行匹配。
    • 数据库管理模块:存储员工信息和对应的人脸模板。
    • 考勤记录模块:记录员工的出勤时间,自动生成考勤报告。

三、优势

  1. 高效性:人脸识别速度快,员工无需接触设备,避免了排队等待的问题。
  2. 准确性:每个人的脸部特征都是独一无二的,这使得人脸识别系统具有极高的识别精度。
  3. 安全性:防止了传统打卡方式中的“代打卡”现象,保障了考勤数据的真实性和完整性。
  4. 便捷性:员工无需携带额外的物品(如卡片),只需露脸即可完成签到。
  5. 自动化:系统能自动分析和生成考勤报表,减轻了人力资源部门的工作负担。

四、应用场景

人脸识别考勤系统广泛应用于各种规模的企业、学校、政府机构、医院等,尤其适合于人员流动大、考勤要求严格的环境。无论是大型工厂的员工进出管理,还是办公室的日常考勤,该系统都能提供可靠的解决方案。

五、未来展望

随着人工智能和计算机视觉技术的不断进步,人脸识别考勤系统的准确性和用户体验将进一步提升。未来的系统可能会集成更多智能功能,如情绪分析、健康状态监测等,为企业管理和员工关怀提供更多维度的支持。

总之,人脸识别考勤系统以其独特的技术优势,正在改变传统的考勤模式,为现代办公环境带来了更高的效率、安全性和便利性。

 部分关键代码:

# -*- coding: utf-8 -*-

"""
Module implementing MainWindow.
"""
from Ui_test_01 import Ui_MainWindow
from PyQt5.QtWidgets import QMainWindow
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.Qt import QSplashScreen, QPixmap, Qt
from PIL import Image, ImageDraw, ImageFont
import time
import face_recognition
import cv2
import json
import numpy
import urllib.request
import pygame
import os
import requests


class MainWindow(QMainWindow, Ui_MainWindow):
    """
    Class documentation goes here.
    """
    
    def __init__(self, parent=None):
        """
        Constructor
        
        @param parent reference to the parent widget
        @type QWidget
        """
        
        ## 初始化人员数据api文件
        # 接口地址JSON
        self.config = {}
        ## 语音识别token
        self.tok= '24.7c1517e22e211c10e802917cea5a3933.2592000.1537013512.282335-11506871'
        super(MainWindow, self).__init__(parent)
        self.setupUi(self)
        self.setWindowTitle("溜溜猪人脸识别系统") 
        window_pale = QtGui.QPalette() 
        # 这是软件背景图
        window_pale.setBrush(self.backgroundRole(),   QtGui.QBrush(QtGui.QPixmap("./static/llz_background.png"))) 
        self.setAutoFillBackground(True)
        self.setPalette(window_pale)
        # 存储网格布局对象,方便后期移动
        self.gridLayout_userlist_0 = self.gridLayoutWidget
        self.gridLayout_userlist_1 = self.gridLayoutWidget_2
        self.gridLayout_userlist_2 = self.gridLayoutWidget_3
        self.gridLayout_userlist_3 = self.gridLayoutWidget_4
        self.gridLayout_userlist_4 = self.gridLayoutWidget_5
        self.gridLayout_userlist_5 = self.gridLayoutWidget_6
        self.gridLayout_userlist_6 = self.gridLayoutWidget_8
        # 初始化面板资源
        self.init_resource()
        # cv2调用开启摄像头方法
        self.video_capture = cv2.VideoCapture(0)
        self.no_video = False
        # 下面是是人脸识别参数
        self.labels = []
        self.person = []
        self.face_locations = []
        self.face_encodings = []
        self.face_names = []
        self.process_this_frame = True
        # 渲染摄像头进行对比相似度时,开的时间如果过快,而调用的对比函数还未执行完毕时,
        # 为了防止增加负荷,可以设置一个onoff_face开关
        # 当开始执行时,将值调整为False,进入方法(关门),执行结束后再打开开关允许下次执行(开门)
        self.onoff_face = True
        
        # 初始化可变变量
        self.names = locals()
        # 初始化时获取用户的数据
        # self.init_api()
        self.get_userinfo_fromapifile()
       
        # 设置两次签到的间隔时间,单位:秒
        self.sign_between = 16
        
        # 设置连续识别成功多少次方可进行签到数据写入(成功签到)
        self.rectimes = 1
        # 精确度调整,默认为0.39
        self.tolerance = 0.39
        # 签到成功后头像与信息从主界面消失的时间间隔
        self.avatar_between = 3
        
        # 捕捉到的图像参数,系数,以及放大倍数
        # 缩小系数与放大倍数的乘机必须为 1
        self.facefx = self.facefy = 0.5
        self.facescale = 2
        
        
        # 初始化时显示头像的布局隐藏
        self.verticalLayoutWidget_2.hide()
        self.label_userinfo_all_bg.hide()
        # 初始化考勤系统唤醒时tips隐藏
        self.label_shadow_tips.hide()
        # 初始化签到成功时的时间点
        self.avatar_time = int(time.time())
    
        
        # 签到列表组件对象
        self.sign_obj_list = {}
        # 签到列表组件对象位置
        self.sign_list = {}
        # 已签到用户列表
        self.sign_user_list = []
        # 初始化签到数据
        for i in range(7):
            self.sign_user_list.append({"avatar":"", "name":"", "userinfo":"", "signed":"", "time": "", "date":""})
        self.avatar_list_func()
        self.save_sign_pos_info()
        ######## 计时器 ########
        # 线程的信号连接一个函数槽
        self.timer = QtCore.QTimer()
        self.timer.timeout.connect(self.face_start) 
        # 连接头像计时器槽函数
        self.avatar_timer_sign = QtCore.QTimer()
        self.avatar_timer_sign.timeout.connect(self.avatar_timer_func)
        # 签到列表计时器槽函数
        self.pos_start_m = 0
        self.avatar_timer_sign_list = QtCore.QTimer()
        self.avatar_timer_sign_list.timeout.connect(self.sign_list_mover_func)
    
        # 更新配置文件槽函数
        self.refresh_faceconfig_timer = QtCore.QTimer()
        self.refresh_faceconfig_timer.timeout.connect(self.refresh_resource)
        # self.refresh_faceconfig_timer.start(self.config['refreshconfigtime'])
        # 开始启动摄像头图像渲染函数,start中为渲染时间间隔
        # 人眼能识别的帧数是30fps/s
        # 1000ms/30fps 约等于33ms
        # 所以这里将频率设置为30ms~34ms比较合适
        # 为了达到最佳,这里设置为了30
        self.timer.start(20)
        # 设置签到成功头像通过此计时器刷新来使用头像框(头像与信息)隐藏的函数
        self.avatar_timer_sign.start(2000)
        # 初始化签到列表
        self.init_sign_list()
        # 签到人数
        # self.sign_num = 0
        # 存用户签到成功时的数据
        self.this_avatar = ""
        self.this_name = ""
        self.this_rank = ""
        self.this_time = ""
        self.this_date = ""
        # 签到状态图片

使用:

python3 face.py

目录介绍:

Project
|
+——— avatar -- 头像下载存储
|
+——— audio -- 音频文件下载
|
+——— back -- 打卡成功捕获的画面
|
|——— api -- 本地保留的接口文件
|
|——— config -- 软件接口配置:包含了1.本地更新打卡数据池的时间间隔(refreshconfigtime);2.签到接口(addsign);3.读取人脸识别配置接口(faceconfig);4.打卡用户数据池(userlist)
|
|——— face.py -- 入口文件
|
|——— video.mp4 -- 演示视频

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

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

相关文章

Vue3进度条nprogress(手机端、PC端通用)

Vue3进度条nprogress是一个用于显示页面加载进度的库。要在Vue3项目中使用nprogress,需要先安装它,然后在你的项目中引入和使用。 安装nprogress npm install nprogress --save配置nprogress 在目录src下创建nprogress文件夹,里面创建nprogr…

Python面试宝典第6题:有效的括号

题目 给定一个只包括 (、)、{、}、[、] 这些字符的字符串,判断该字符串是否有效。有效字符串需要满足以下的条件。 1、左括号必须用相同类型的右括号闭合。 2、左括号必须以正确的顺序闭合。 3、每个右括号都有一个对应的相同类型的左括号。 注意:空字符…

九浅一深Jemalloc5.3.0 -- ⑨浅*gc

目前市面上有不少分析Jemalloc老版本的博文,但5.3.0却少之又少。而且5.3.0的架构与之前的版本也有较大不同,本着“与时俱进”、“由浅入深”的宗旨,我将逐步分析Jemalloc5.3.0的实现。 另外,单讲实现代码是极其枯燥的,…

拆解COLA框架

COLA 是 Clean Object-Oriented and Layered Architecture的缩写,代表“整洁面向对象分层架构”。由阿里大佬张建飞所提出的一种基于DDD和代码整洁理论所诞生的实践理论框架,详细内容可阅读《程序员的底层思维》和相关git代码去了解 项目地址&#xff1a…

在地图上根据经纬度,画一个矩型围栏,设置每个点的经纬度

在做一个需求时有一个小点就是添加一个配送区域(5公里直径内的)矩形围栏 我做的比较简单 大家看看有没有帮助, 也是精简代码。测试效果上相对是精准的 //谷歌,根据经纬度获取以它为中心半径为5公里内的矩形的四个点经纬度getDefalutPoints (lng: number, lat: num…

lt6911UXC 国产原装 高性能HDMI2.0转MIPI DSI / CSI芯片方案 提供LT 开发资料包及在线软硬件技术支持!

1.说明 LT6911UXC是一款高性能HDMI2.0到MIPI DSI / CSI转换器,用于VR,智能电话,显示应用。 HDMI2.0输入支持高达6Gbps的数据速率,从而为4k 60Hz视频提供足够的带宽。还支持HDCP2.2进行数据解密。 对于MIPI DSI / CSI输出&#xf…

企业数据API平台:获取企业多维度信息

数据API平台是指提供一系列预先定义的接口、协议与工具,允许不同应用程序或系统之间进行数据交换和通信的平台。这些接口被称为数据API(Data Application Programming Interface),是数据管理系统或应用程序提供的一组开放式接口。…

Linux手动安装JDK1.8

1、下载要安装的jdk安装包文件 官网下载地址:https://www.oracle.com/cn/java/technologies/downloads/ 2、上传jdk安装包至要安装服务器 3、在要安装jdk位置使用命令解压安装包 安装路径: /usr/local/java 解压安装包,解压命令 tar -zxvf /install…

【博客21】缤果Qt5仿小米耳机APP布局_PC端软件(高级篇)

小米耳机 备注:此软件只是简单的实现布局和界面跳转逻辑, 并未加入小米协议相关内容,因需要鉴权方式验证,故无法进行通讯编程. 开发工具: qt-opensource-windows-x86-5.14.2 (编程语言C) Android反编译工具: apktool 小米小爱开放平台 - 语音服务平台 - 文档中…

3-1 激活函数和神经网络思想

3-1 激活函数和神经网络思想 主目录点这里

android应用的持续构建CI(四)-- 依赖环境(兼容多版本的gradle和jdk)

一、背景 android应用的构建前提是,安装好了gradle和jdk。在实际使用的过程中,不同的android应用,对gradle和jdk的版本要求不一。 于是,在jenkins服务器上,我们需要安装多种版本的gradle和jdk。 安装过jdk的小伙伴应…

Jenkins 使用 Publish over SSH进行远程访问

Publish over SSH 是 Jenkins 的一个插件,可以让你通过 SSH 将构建产物分发到远程服务器。以下是如何开启 Publish over SSH 的步骤: 一、安装 Publish over SSH 插件 在 Jenkins 中,进入 "Manage Jenkins" > "Manage Plugins"。选择 "Availab…

【spring MVC的执行流程】

SpringMVC可以说是Servlet的封装,屏蔽了Servlet的很多细节,比如Servlet再获取参数的时候需要不停地getParameter,现在只要在SpringMVC方法定义对应的JavaBean,只要属性和参数名一致,SpringMVC就可以帮我们实现将参数封装到JavaBea…

基础扫盲:js作用域及其优先级,有示例代码。

在 JavaScript 中,作用域指的是变量和函数的可访问性和可见性。 JavaScript 中的作用域有以下几种: 1. 全局作用域(Global Scope):全局作用域是指在代码中任何地方都可以访问的作用域。在全局作用域中声明的变量和函数…

DFS之连通性模型——AcWing 1112. 迷宫

DFS之连通性模型 定义 DFS(深度优先搜索,Depth-First Search)之连通性模型主要用于图论问题中判断图的连通性,即确定图中的所有节点是否可以通过边相互到达。 DFS(深度优先搜索,Depth-First Search&…

深度学习——深度学习中感受野的计算

感受野 在卷积神经网络(CNN)中,感受野(Receptive Field) 是一个非常重要的概念。它描述了网络中某一层的输出(通常是特征图上的一个像素点)所对应的输入图像上的空间范围。这个范围代表了该输出…

Jelly Merge | Template + Editor(休闲益智游戏包)

Jelly Merge是Watermelon Games开发的一款完整游戏。 这款完全可定制的益智游戏具有简单但超级有趣的游戏玩法。 您下一次成功的完美起点! 我们的优势 🧑🏻‍💻 不和谐支持 🗃️ 详细文档 🛠️易于使用的工…

C# WPF 3D 数据孪生 系列六

数字孪生应用开发 应用开发中的布局需求 Grid基本使用 WPF 3D绘图 点云 系列五-CSDN博客 WPF UI 3D 多轴 机械臂 stl 模型UI交互-CSDN博客 WPF UI 3D 基本概念 点线三角面 相机对象 材质对象与贴图 3D地球 光源 变形处理 动作交互 辅助交互插件 系列三-CSDN博客 数字孪生 介…

【堆 优先队列】23. 合并 K 个升序链表

本文涉及知识点 堆 优先队列 LeetCode23. 合并 K 个升序链表 给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 示例 1: 输入:lists [[1,4,5],[1,3,4],[2,6]] 输出&#…

本地Windows电脑 连接 Windows 服务器

Windows电脑 连接 Windows 服务器 方式1:直接搜索 在电脑的搜索栏,输入“远程桌面连接” 可以选择点击 “打开” 或者直接按 回车键 “Enter”,打开 远程桌面连接 方式2:运行框打开服务器连接 同时按:Windows徽标键…