毕业设计:python人脸表情识别系统 情绪识别系统 深度学习 神经网络CNN算法

185 篇文章 35 订阅
179 篇文章 6 订阅

[毕业设计]2023-2024年最新最全计算机专业毕设选题推荐汇总

2023年 - 2024年 最新计算机毕业设计 本科 选题大全 汇总

1、项目介绍

技术栈:
Python语言、人脸表情识别系统、情绪识别系统、深度学习、神经网络、CNN算法、PyQt5、tensorflow、FER数据集、CNN的主流框架之mini_XCEPTION。
识别分类:
生气、厌恶、恐惧、快乐、伤心、惊讶、中性(7种)

2、项目界面

(1)图片识别检测1

在这里插入图片描述

(2)图片识别检测2

在这里插入图片描述

(3)视频检测
在这里插入图片描述

(4)摄像头检测识别

在这里插入图片描述

3、项目说明

首先运用 Adaboos 算法对人 脸面部表情图像进行粗略的裁剪,再利用梯度积分投影和双阈值二值化对人脸面部表情图像中的人眼进行定位从而实现对人脸面部图像的精确裁剪;对于裁剪好的图像又对其进行了基于双线性插值的尺度归一化处理和基于均衡化算法的灰度归一化处理,得到最终的统一尺寸和统一灰度的人脸面部表情图像。

综合考虑的神经元的特征、学习规则和网络的拓扑结构三个方面构建了一个用于对人脸面部表情进行识别和分类的卷积神经网络构架。卷积层采用固定权值的 Gabor 小波直接构造,全连接层采用支持向量机算法进行构造,并运用匹配生长规则 对卷积神经网络的层次结构进行确定,利用反向传播算法对整个卷积神经网进行参 数训练。最终得到经过实验确定的适用于人脸面部表情识别与分类的卷积神经网络 结构。针对 Gabor 小波的位数灾难问题,运用 Fisher 线性判别法改进的主成分分析 法对其进行了降维处理,有效地解决了人脸面部图像维数过多和识别时间较长的问 题。 对改进的主成分分析法结合支持向量机算法与卷积神经网络算法分别进行了人 脸面部表情识别的实验,并与传统的人脸面部表情识别结构进行了比较,验证了卷 积神经网络在人脸面部表情识别的准确性和有效性;另外,对人脸面部表情识别分 类系统进行了设计,并设计了应用于人机交互的 GUI 图形用户界面

4、核心代码


# -*- coding: utf-8 -*-
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWidgets import QFileDialog
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QMovie
from real_time_video_me import Emotion_Rec
from os import getcwd
import numpy as np
import cv2
import time
from base64 import b64decode
from os import remove
from slice_png import img as bgImg
from EmotionRecongnition_UI import Ui_MainWindow
import image1_rc


class Emotion_MainWindow(Ui_MainWindow):
    def __init__(self, MainWindow):
        self.path = getcwd()
        self.timer_camera = QtCore.QTimer()  # 定时器
        self.timer_video = QtCore.QTimer()  # 定时器

        self.setupUi(MainWindow)
        self.retranslateUi(MainWindow)
        self.slot_init()  # 槽函数设置

        # 设置界面动画
        gif = QMovie(':/newPrefix/icons/scan.gif')
        self.label_face.setMovie(gif)
        gif.start()

        self.cap = cv2.VideoCapture()  # 屏幕画面对象
        self.cap2 = cv2.VideoCapture()
        self.CAM_NUM = 0  # 摄像头标号
        self.model_path = None  # 模型路径
        # self.__flag_work = 0

    def slot_init(self):  # 定义槽函数
        self.toolButton_camera.clicked.connect(self.button_open_camera_click)
        self.toolButton_model.clicked.connect(self.choose_model)
        self.toolButton_video.clicked.connect(self.button_open_video_click)

        self.timer_camera.timeout.connect(self.show_camera)
        self.timer_video.timeout.connect(self.show_video)
        self.toolButton_file.clicked.connect(self.choose_pic)

    def button_open_camera_click(self):
        # 界面处理
        self.timer_camera.stop()
        self.timer_video.stop()
        self.cap.release()
        self.cap2.release()
        self.label_face.clear()
        self.label_result.setText('None')
        self.label_time.setText('0 s')
        self.textEdit_camera.setText('实时摄像已关闭')
        self.textEdit_video.setText("视频未选中")
        self.label_outputResult.clear()
        self.label_outputResult.setStyleSheet("border-image: url(:/newPrefix/icons/ini.png);")

        if self.timer_camera.isActive() == False:  # 检查定时状态
            flag = self.cap.open(self.CAM_NUM)  # 检查相机状态
            if flag == False:  # 相机打开失败提示
                msg = QtWidgets.QMessageBox.warning(self.centralwidget, u"Warning",
                                                    u"请检测相机与电脑是否连接正确! ",
                                                    buttons=QtWidgets.QMessageBox.Ok,
                                                    defaultButton=QtWidgets.QMessageBox.Ok)

            else:
                # 准备运行识别程序
                self.textEdit_pic.setText('文件未选中')
                QtWidgets.QApplication.processEvents()
                self.textEdit_camera.setText('实时摄像已开启')
                self.label_face.setText('正在启动识别系统...\n\nleading')
                # 新建对象
                self.emotion_model = Emotion_Rec(self.model_path)
                QtWidgets.QApplication.processEvents()
                # 打开定时器
                self.timer_camera.start(30)
        else:
            # 定时器未开启,界面回复初始状态
            self.timer_camera.stop()
            self.timer_video.stop()
            self.cap.release()
            self.cap2.release()
            self.label_face.clear()
            self.textEdit_camera.setText('实时摄像已关闭')
            self.textEdit_pic.setText('文件未选中')
            self.textEdit_video.setText('文件未选中')
            gif = QMovie(':/newPrefix/icons/scan.gif')
            self.label_face.setMovie(gif)
            gif.start()
            self.label_outputResult.clear()
            self.label_outputResult.setStyleSheet("border-image: url(:/newPrefix/icons/ini.png);")

            self.label_result.setText('None')
            self.label_time.setText('0 s')

    def button_open_video_click(self):
        # 界面处理
        self.timer_camera.stop()
        self.timer_video.stop()
        self.cap.release()
        self.cap2.release()
        self.label_face.clear()
        self.label_result.setText('None')
        self.label_time.setText('0 s')
        self.textEdit_camera.setText('实时摄像已关闭')
        self.textEdit_video.setText("视频未选中")
        self.label_outputResult.clear()
        self.label_outputResult.setStyleSheet("border-image: url(:/newPrefix/icons/ini.png);")

        if self.timer_video.isActive() == False:  # 检查定时状态
            # 使用文件选择对话框选择图片
            fileName_choose, filetype = QFileDialog.getOpenFileName(
                self.centralwidget, "选取图片文件",
                self.path,  # 起始路径
                "视频(*.mp4;)")  # 文件类型
            self.path = fileName_choose  # 保存路径
            if fileName_choose != '':
                self.textEdit_video.setText(fileName_choose + '文件已选中')
                # 新建对象
                self.cap2 = cv2.VideoCapture(self.path)
                self.emotion_model = Emotion_Rec(self.model_path)
                # 打开定时器
                self.label_face.setText('正在启动识别系统...\n\nleading')
                self.timer_video.start(30)
                QtWidgets.QApplication.processEvents()
            else:
                # 准备运行识别程序
                self.textEdit_pic.setText('文件未选中')
                self.textEdit_video.setText('文件未选中')
                QtWidgets.QApplication.processEvents()
                self.textEdit_camera.setText('实时摄像已关闭')

        else:
            # 定时器未开启,界面回复初始状态
            self.timer_camera.stop()
            self.timer_video.stop()
            self.cap.release()
            self.cap2.release()
            self.label_face.clear()
            self.textEdit_camera.setText('实时摄像已关闭')
            self.textEdit_pic.setText('文件未选中')
            self.textEdit_video.setText('文件未选中')
            gif = QMovie(':/newPrefix/icons/scan.gif')
            self.label_face.setMovie(gif)
            gif.start()
            self.label_outputResult.clear()
            self.label_outputResult.setStyleSheet("border-image: url(:/newPrefix/icons/ini.png);")

            self.label_result.setText('None')
            self.label_time.setText('0 s')

  

    def choose_model(self):
        # 选择训练好的模型文件
        self.timer_camera.stop()
        self.timer_video.stop()
        self.cap.release()
        self.cap2.release()
        self.label_face.clear()
        self.label_result.setText('None')
        self.label_time.setText('0 s')
        self.textEdit_camera.setText('实时摄像已关闭')
        self.textEdit_video.setText('文件未选中')
        self.textEdit_pic.setText('文件未选中')
        self.label_outputResult.clear()
        self.label_outputResult.setStyleSheet("border-image: url(:/newPrefix/icons/ini.png);")

        # 调用文件选择对话框
        fileName_choose, filetype = QFileDialog.getOpenFileName(self.centralwidget,
                                                                "选取图片文件", getcwd(),  # 起始路径
                                                                "Model File (*.hdf5)")  # 文件类型
        # 显示提示信息
        if fileName_choose != '':
            self.model_path = fileName_choose
            self.textEdit_model.setText(fileName_choose + ' 已选中')
        else:
            self.textEdit_model.setText('使用默认模型')

        # 恢复界面
        gif = QMovie(':/newPrefix/icons/scan.gif')
        self.label_face.setMovie(gif)
        gif.start()



源码获取:

🍅由于篇幅限制,获取完整文章或源码、代做项目的,查看主页【专栏名称】或者【用户名】或者顶部的【选题链接】就可以找到我获取项目源码学习啦~🍅

大家点赞、收藏、关注、评论啦 !

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 实时人脸表情识别是一种基于人工智能和计算机视觉的技术,结合Python编程语言进行毕业设计的主题。该项目旨在实现对人脸表情的实时识别和分类,通过分析和判断人脸表情的变化,进而实现情感识别和情感分析。 首先,为了实现实时人脸表情识别,我们需要采集一组包含不同表情的人脸图像数据集。此数据集可以通过网络资源、开源数据集或自己采集得到。接下来,我们使用Python中的图像处理库OpenCV来获取实时视频流,并使用面部检测算法定位和提取视频流中的人脸。 然后,我们需要使用深度学习方法来训练一个人脸表情分类器。可以使用所采集到的人脸图像数据集,使用Python中的深度学习框架如TensorFlow或PyTorch来构建一个卷积神经网络CNN)模型。该模型将接受人脸图像作为输入,经过多个卷积层和池化层进行特征提取,并使用全连接层进行分类预测。 在训练好的模型基础上,我们可以将其应用于实时人脸表情识别。通过将每一帧的人脸图像传入该模型,可以获取到实时的人脸表情分类结果。可以根据分类结果,判断人脸表情是开心、生气、惊讶等不同的情绪。 最后,为了更好地展示实时人脸表情识别的效果,我们可以将识别结果通过图像或视频的方式展示出来,比如将分类结果添加在人脸图像上方,或者在视频中不同表情时变换特定符号或贴图。 总结来说,实时人脸表情识别毕业设计将采用Python编程语言,结合图像处理库和深度学习框架,通过建立和训练卷积神经网络模型,实现对实时人脸表情的识别和分类,并将识别结果进行展示。该项目对于理解和实践人工智能、计算机视觉和深度学习等相关领域的知识具有重要意义。 ### 回答2: 实时人脸表情识别是一种使用计算机视觉技术来检测和识别人脸表情的方法。而使用Python语言进行实时人脸表情识别毕业设计,可以通过以下步骤来完成: 1. 数据集准备:首先需要准备一个包含多种表情的人脸图像数据集。可以使用公开的人脸表情数据集,如FER2013、CK+等,或者自己构建数据集。 2. 数据预处理:对数据集进行预处理,包括将图像进行裁剪和缩放,使其符合模型输入的要求。还可以使用数据增强技术来扩充数据集,以提高模型的泛化能力。 3. 特征提取:利用深度学习模型,如卷积神经网络CNN),来提取人脸图像的特征。可以使用已经预训练好的CNN模型,如VGGNet、ResNet等,也可以根据具体需求自己搭建模型。 4. 模型训练:使用提取到的特征作为输入,利用训练集进行模型的训练。可以使用Python深度学习库,如Tensorflow、Keras等,来搭建和训练模型。在训练过程中,可以使用交叉验证等技术来评估模型的性能。 5. 模型验证:使用测试集对训练好的模型进行验证,评估其在实时人脸表情识别任务上的性能。可以计算模型的准确率、召回率等评价指标,或者通过混淆矩阵来分析不同表情类别的识别结果。 6. 实时表情识别:将训练好的模型应用到实时视频流中,进行人脸表情的实时识别。可以使用Python的图像处理和视频处理库来实现这一步骤,如OpenCV、Dlib等。通过实时检测人脸区域,并对每个人脸区域进行表情分类。 7. 界面设计和优化:将实时人脸表情识别算法与用户界面结合,可以使用Python的GUI库,如Tkinter等,设计一个友好的界面,使用户可以方便地进行实时人脸表情的测试和观察。 通过以上步骤的实现,我们可以完成一个基于Python的实时人脸表情识别系统。该系统可以用于情感分析、人机交互等领域,具有一定的实际应用价值。 ### 回答3: 实时人脸表情识别是一种通过使用Python编程语言开发的技术,用于实时检测和识别人脸表情。它可以分析人脸上的特征,并根据这些特征识别出人脸表情的种类,例如开心、悲伤、惊讶等。 实时人脸表情识别毕业设计主要包括以下几个步骤: 1. 数据集准备:首先,需要准备一份包含人脸表情样本的数据集。可以通过收集照片、视频或者使用现有的数据集来构建。 2. 数据预处理:对数据进行预处理是非常重要的一步。可以使用Python图像处理库如OpenCV对图像进行裁剪、缩放和灰度化等处理,以提升后续的算法准确度。 3. 特征提取:接下来,使用Python中常用的机器学习库,如Scikit-learn或Tensorflow等,进行特征提取。可以使用基于人脸的特征提取算法,例如局部二值模式(Local Binary Patterns,LBP)或主成分分析(Principal Component Analysis,PCA),来提取人脸表情的特征。 4. 训练模型:使用已经提取的特征,建立分类器模型。可以使用各种机器学习算法,例如支持向量机(Support Vector Machine,SVM)或卷积神经网络(Convolutional Neural Network,CNN),对数据集进行训练,以使模型能够准确地识别人脸表情。 5. 实时检测和识别:最后,使用摄像头采集实时视频流,并对每一帧图像进行处理和分析,以实现人脸表情的实时检测和识别。可以使用Python库如Dlib或OpenCV中的人脸检测器和分类器,对视频流中的人脸进行定位和分类。 总结来说,实时人脸表情识别毕业设计将通过预处理、特征提取、模型训练和实时检测等步骤,利用Python编程语言实现对人脸表情的实时检测和识别。这项技术可以应用于许多领域,例如情感分析、人机交互等,具有广泛的应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值