用OpenCV进行年龄和性别检测的实现示例


Posted in Python onJanuary 29, 2021

本文主要介绍了用OpenCV进行年龄和性别检测的实现示例,分享给大家,具体如下:

用OpenCV进行年龄和性别检测的实现示例

在本文中,我将带您完成用 Python 进行机器学习的年龄和性别检测的任务。年龄和性别检测属于计算机视觉的范畴,因此我将在Python中使用OpenCV库。

在开始使用Python进行年龄和性别检测任务之前,我将首先带您了解该概念的含义以及如何处理年龄和性别检测问题。理解这个概念很重要,以便将来您不仅可以使用python,还可以使用任何编程语言轻松地执行年龄和性别检测任务。

年龄和性别检测简介

检测年龄和性别的任务是一个固有的难题,比许多其他计算机视觉任务更为困难。造成这种困难的主要原因在于训练这些类型的系统所需的数据。

尽管一般的对象检测任务通常可以访问成千上万甚至数百万张图像进行训练,但是带有年龄或性别标签的数据集却要小得多,通常只有几千个,或者最好是几万个。

原因是要为此类图像添加标签,我们需要访问图像中主题的个人信息。即,我们将需要他们的出生日期和性别,尤其出生日期是很难获取的信息。

因此必须解决这个问题的本质,我们正在用适应网络体系结构和算法方法来解决这些局限性。

用Python进行年龄和性别检测

按年龄和性别分类的领域已经研究了数十年。多年来,已经采取了各种方法来解决该问题,并且取得了不同程度的成功。现在,我们开始使用 Python 来检测年龄和性别。

我将把性别检测问题作为分类问题,将年龄检测问题作为回归问题。但是,使用回归准确估计年龄是困难的。甚至人类也无法通过注视一个人来准确预测年龄。但是,我们确实知道他们是30多岁还是40多岁。这也是我要使用Python进行的操作。

现在,让我们开始使用 Python 语言进行年龄和性别检测任务。首先,我将开始编写用于检测面部的代码,因为如果没有面部检测,我们将无法继续进行年龄和性别预测任务。

您可以从此处下载在年龄和性别检测任务中所需的必要的OpenCV预训练模型。现在,在您的python文件中导入OpenCV模块后,即可开始使用以下代码。

用于人脸检测的Python代码:

def getFaceBox(net, frame, conf_threshold=0.7):
    frameOpencvDnn = frame.copy()
    frameHeight = frameOpencvDnn.shape[0]
    frameWidth = frameOpencvDnn.shape[1]
    blob = cv.dnn.blobFromImage(frameOpencvDnn, 1.0, (300, 300), [104, 117, 123], True, False)
 
    net.setInput(blob)
    detections = net.forward()
    bboxes = []
    for i in range(detections.shape[2]):
        confidence = detections[0, 0, i, 2]
        if confidence > conf_threshold:
            x1 = int(detections[0, 0, i, 3] * frameWidth)
            y1 = int(detections[0, 0, i, 4] * frameHeight)
            x2 = int(detections[0, 0, i, 5] * frameWidth)
            y2 = int(detections[0, 0, i, 6] * frameHeight)
            bboxes.append([x1, y1, x2, y2])
            cv.rectangle(frameOpencvDnn, (x1, y1), (x2, y2), (0, 255, 0), int(round(frameHeight/150)), 8)
    return frameOpencvDnn, bboxes

现在,下一步是预测图像中人的性别。在这里,我将把性别网络加载到内存中,并通过网络将检测到的面部发送给性别检测任务。

性别检测的Python代码:

genderProto = "gender_deploy.prototxt"
genderModel = "gender_net.caffemodel"
ageNet = cv.dnn.readNet(ageModel, ageProto)
 
genderList = ['Male', 'Female']
 
blob = cv.dnn.blobFromImage(face, 1, (227, 227), MODEL_MEAN_VALUES, swapRB=False)
genderNet.setInput(blob)
genderPreds = genderNet.forward()
gender = genderList[genderPreds[0].argmax()]
print("Gender Output : {}".format(genderPreds))
print("Gender : {}".format(gender))

现在的下一个任务是预测图像中人的年龄。在这里,我将使用前向传递来获取输出。由于网络架构类似于性别网络,因此我们可以充分利用所有输出,以获取预期的年龄组,来完成任务以检测年龄。

用于年龄检测的Python代码:

ageProto = "age_deploy.prototxt"
ageModel = "age_net.caffemodel"
ageNet = cv.dnn.readNet(ageModel, ageProto)
 
ageList = ['(0 - 2)', '(4 - 6)', '(8 - 12)', '(15 - 20)', '(25 - 32)', '(38 - 43)', '(48 - 53)', '(60 - 100)']
 
ageNet.setInput(blob)
agePreds = ageNet.forward()
age = ageList[agePreds[0].argmax()]
print("Gender Output : {}".format(agePreds))
print("Gender : {}".format(age))

我们需要编写的最后代码是显示输出:

label = "{}, {}".format(gender, age)
cv.putText(frameFace, label, (bbox[0], bbox[1]-20), cv.FONT_HERSHEY_SIMPLEX, 0.8, (255, 0, 0), 3, cv.LINE_AA)
cv.imshow("Age Gender Demo", frameFace)

因此,从输出中可以看到,我们能够高度准确地预测性别和年龄。

用OpenCV进行年龄和性别检测的实现示例

到此这篇关于用OpenCV进行年龄和性别检测的实现示例的文章就介绍到这了,更多相关OpenCV 年龄和性别检测内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python中的defaultdict模块和namedtuple模块的简单入门指南
Apr 01 Python
Python中动态创建类实例的方法
Mar 24 Python
python 给DataFrame增加index行名和columns列名的实现方法
Jun 08 Python
PyCharm专业最新版2019.1安装步骤(含激活码)
Oct 09 Python
Python3.6安装卸载、执行命令、执行py文件的方法详解
Feb 20 Python
Python sqlalchemy时间戳及密码管理实现代码详解
Aug 01 Python
python自动化测试三部曲之request+django实现接口测试
Oct 07 Python
基于Python的身份证验证识别和数据处理详解
Nov 14 Python
Python  Asyncio模块实现的生产消费者模型的方法
Mar 01 Python
python基于opencv批量生成验证码的示例
Apr 28 Python
TensorFlow中tf.batch_matmul()的用法
Jun 02 Python
Python下opencv使用hough变换检测直线与圆
Jun 18 Python
python使用numpy中的size()函数实例用法详解
Jan 29 #Python
Python机器学习工具scikit-learn的使用笔记
Jan 28 #Python
K近邻法(KNN)相关知识总结以及如何用python实现
Jan 28 #Python
Python3中对json格式数据的分析处理
Jan 28 #Python
Python实现微信表情包炸群功能
Jan 28 #Python
Python基于opencv的简单图像轮廓形状识别(全网最简单最少代码)
Jan 28 #Python
python如何构建mock接口服务
Jan 28 #Python
You might like
Notice: Undefined index: page in E:\PHP\test.php on line 14
2010/11/02 PHP
PHP获取MAC地址的函数代码
2011/09/11 PHP
三种php连接access数据库方法
2013/11/11 PHP
PHP实现生成带背景的图形验证码功能
2016/10/03 PHP
jquery 3D球状导航的文章分类
2010/07/06 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
javascript中的Base64、UTF8编码与解码详解
2015/03/18 Javascript
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
JS实现从网页顶部掉下弹出层效果的方法
2015/08/06 Javascript
jQuery插件EasyUI校验规则 validatebox验证框
2015/11/29 Javascript
浅谈JavaScript中数组的增删改查
2016/06/20 Javascript
js前端实现多图图片上传预览的两个方法(推荐)
2016/11/18 Javascript
js判断iframe中元素是否存在的实现代码
2016/12/24 Javascript
js 原生判断内容区域是否滚动到底部的实例代码
2017/11/15 Javascript
nodejs 简单实现动态html的方法
2018/05/12 NodeJs
详解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on
2018/10/12 Javascript
[03:18]DOTA2放量测试专访820:希望玩家加入国服大家庭
2013/08/25 DOTA
[00:56]跨越时空加入战场 全新祈求者身心“失落奇艺侍祭”展示
2019/07/20 DOTA
使用rpclib进行Python网络编程时的注释问题
2015/05/06 Python
浅谈python中requests模块导入的问题
2018/05/18 Python
python3 对list中每个元素进行处理的方法
2018/06/29 Python
Python中使用遍历在列表中添加字典遇到的坑
2019/02/27 Python
Python列表的切片实例讲解
2019/08/20 Python
Python脚本如何在bilibili中查找弹幕发送者
2020/06/04 Python
Steiff台湾官网:德国金耳釦泰迪熊
2019/12/26 全球购物
培训主管的岗位职责
2013/11/23 职场文书
乡村卫生服务一体化管理实施方案
2014/03/30 职场文书
运动会广播稿150字(9篇)
2014/09/20 职场文书
后进基层党组织整改方案
2014/10/25 职场文书
贫困生助学金感谢信
2015/01/21 职场文书
投资申请报告
2015/05/19 职场文书
运动会加油稿30字
2015/07/21 职场文书
青年联谊会致辞
2015/07/31 职场文书
护士岗前培训心得体会
2016/01/08 职场文书
幼儿园2016年圣诞活动总结
2016/03/31 职场文书
深入探讨opencv图像矫正算法实战
2021/05/21 Python