python 实现表情识别


Posted in Python onNovember 21, 2020

表情识别

表情识别支持7种表情类型,生气、厌恶、恐惧、开心、难过、惊喜、平静等。

实现思路

使用OpenCV识别图片中的脸,在使用keras进行表情识别。

效果预览

python 实现表情识别

实现代码

与《性别识别》相似,本文表情识别也是使用keras实现的,和性别识别相同,型数据使用的是oarriaga/face_classification的,代码如下:

#coding=utf-8
#表情识别

import cv2
from keras.models import load_model
import numpy as np
import chineseText
import datetime

startTime = datetime.datetime.now()
emotion_classifier = load_model(
  'classifier/emotion_models/simple_CNN.530-0.65.hdf5')
endTime = datetime.datetime.now()
print(endTime - startTime)

emotion_labels = {
  0: '生气',
  1: '厌恶',
  2: '恐惧',
  3: '开心',
  4: '难过',
  5: '惊喜',
  6: '平静'
}

img = cv2.imread("img/emotion/emotion.png")
face_classifier = cv2.CascadeClassifier(
  "C:\Python36\Lib\site-packages\opencv-master\data\haarcascades\haarcascade_frontalface_default.xml"
)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
faces = face_classifier.detectMultiScale(
  gray, scaleFactor=1.2, minNeighbors=3, minSize=(40, 40))
color = (255, 0, 0)

for (x, y, w, h) in faces:
  gray_face = gray[(y):(y + h), (x):(x + w)]
  gray_face = cv2.resize(gray_face, (48, 48))
  gray_face = gray_face / 255.0
  gray_face = np.expand_dims(gray_face, 0)
  gray_face = np.expand_dims(gray_face, -1)
  emotion_label_arg = np.argmax(emotion_classifier.predict(gray_face))
  emotion = emotion_labels[emotion_label_arg]
  cv2.rectangle(img, (x + 10, y + 10), (x + h - 10, y + w - 10),
         (255, 255, 255), 2)
  img = chineseText.cv2ImgAddText(img, emotion, x + h * 0.3, y, color, 20)

cv2.imshow("Image", img)
cv2.waitKey(0)
cv2.destroyAllWindows()

以上就是python 实现表情识别的详细内容,更多关于python 表情识别的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python实现上传样本到virustotal并查询扫描信息的方法
Oct 05 Python
Python中的__new__与__init__魔术方法理解笔记
Nov 08 Python
Python读写ini文件的方法
May 28 Python
win8下python3.4安装和环境配置图文教程
Jul 31 Python
Python找出微信上删除你好友的人脚本写法
Nov 01 Python
Python判断对象是否相等及eq函数的讲解
Feb 25 Python
Python帮你微信头像任意添加装饰别再@微信官方了
Sep 25 Python
Pytorch使用MNIST数据集实现CGAN和生成指定的数字方式
Jan 10 Python
使用pytorch搭建AlexNet操作(微调预训练模型及手动搭建)
Jan 18 Python
[原创]赚疯了!转手立赚800+?大佬的python「抢茅台脚本」使用教程
Jan 12 Python
matplotlib画混淆矩阵与正确率曲线的实例代码
Jun 01 Python
从np.random.normal()到正态分布的拟合操作
Jun 02 Python
python 实现性别识别
Nov 21 #Python
python遍历路径破解表单的示例
Nov 21 #Python
Python如何批量生成和调用变量
Nov 21 #Python
在终端启动Python时报错的解决方案
Nov 20 #Python
python 批量下载bilibili视频的gui程序
Nov 20 #Python
Python ellipsis 的用法详解
Nov 20 #Python
python 动态渲染 mysql 配置文件的示例
Nov 20 #Python
You might like
第七节--类的静态成员
2006/11/16 PHP
PHP得到某段时间区间的时间戳 php定时任务
2012/04/12 PHP
深入file_get_contents函数抓取内容失败的原因分析
2013/06/25 PHP
使用PHP如何实现高效安全的ftp服务器(二)
2015/12/30 PHP
实例讲解PHP验证邮箱是否合格
2019/01/28 PHP
JQuery打造PHP的AJAX表单提交实例
2009/11/03 Javascript
jQuery autocomplate 自扩展插件、自动完成示例代码
2011/03/28 Javascript
Javascript通过overflow控制列表闭合与展开的方法
2015/05/15 Javascript
js实现Select列表内容自动滚动效果代码
2015/08/20 Javascript
jQuery下拉美化搜索表单效果代码分享
2015/08/25 Javascript
jquery按回车键实现表单提交的简单实例
2016/05/25 Javascript
JS实用的带停顿的逐行文本循环滚动效果实例
2016/11/23 Javascript
JS实现字符串转驼峰格式的方法
2016/12/16 Javascript
Javascript自定义事件详解
2017/01/13 Javascript
angular中使用Socket.io实例代码
2017/06/03 Javascript
Easyui和zTree两种方式分别实现树形下拉框
2017/08/04 Javascript
百度地图去掉marker覆盖物或者去掉maker的label文字方法
2018/01/26 Javascript
vue-cli中的babel配置文件.babelrc实例详解
2018/02/22 Javascript
Electron autoUpdater实现Windows安装包自动更新的方法
2018/12/24 Javascript
每天学点Vue源码之vm.$mount挂载函数
2019/03/11 Javascript
jquery+php后台实现省市区联动功能示例
2019/05/23 jQuery
js中let能否完全替代IIFE
2019/06/15 Javascript
Openlayers实现图形绘制
2020/09/28 Javascript
原生JavaScript实现拖动校验功能
2020/09/29 Javascript
Python 变量类型及命名规则介绍
2013/06/08 Python
利用python如何处理百万条数据(适用java新手)
2018/06/06 Python
python多线程并发让两个LED同时亮的方法
2019/02/18 Python
python mqtt 客户端的实现代码实例
2019/09/25 Python
python psutil监控进程实例
2019/12/17 Python
Python 音频生成器的实现示例
2019/12/24 Python
Python定义一个函数的方法
2020/06/15 Python
使用phonegap进行本地存储的实现方法
2017/03/31 HTML / CSS
一般党员对照检查材料
2014/09/24 职场文书
县人大领导班子四风对照检查材料思想汇报
2014/10/09 职场文书
群众路线四风对照检查材料
2014/11/04 职场文书
宿舍卫生管理制度
2015/08/05 职场文书