用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获取apk文件URL地址实例
Nov 01 Python
探究Python多进程编程下线程之间变量的共享问题
May 05 Python
Python3实现并发检验代理池地址的方法
Sep 18 Python
python将文本中的空格替换为换行的方法
Mar 19 Python
Python tkinter label 更新方法
Oct 11 Python
Python字典中的键映射多个值的方法(列表或者集合)
Oct 17 Python
Python使用sklearn库实现的各种分类算法简单应用小结
Jul 04 Python
python增加图像对比度的方法
Jul 12 Python
python 输出列表元素实例(以空格/逗号为分隔符)
Dec 25 Python
Python进程间通信multiprocess代码实例
Mar 18 Python
Python爬虫入门案例之爬取二手房源数据
Oct 16 Python
利用Python实现Picgo图床工具
Nov 23 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
php Try Catch异常测试
2009/03/01 PHP
php switch语句多个值匹配同一代码块的实现
2014/03/03 PHP
php模仿asp Application对象在线人数统计实现方法
2015/01/04 PHP
CI框架实现创建自定义类库的方法
2018/12/25 PHP
laravel 5.5 关闭token的3种实现方式
2019/10/24 PHP
jquery ajax例子返回值详解
2012/09/11 Javascript
一行代码实现纯数据json对象的深度克隆实现思路
2013/01/09 Javascript
ExtJS4 Grid改变单元格背景颜色及Column render学习
2013/02/06 Javascript
JQuery onload、ready概念介绍及使用方法
2013/04/27 Javascript
js(jQuery)获取时间的方法及常用时间类搜集
2013/10/23 Javascript
javascript获取函数名称、函数参数、对象属性名称的代码实例
2014/04/12 Javascript
禁用Tab键JS代码兼容Firefox和IE
2014/04/18 Javascript
JavaScript的9种继承实现方式归纳
2015/05/18 Javascript
JS实现统计复选框选中个数并提示确定与取消的方法
2015/07/01 Javascript
JS实现无限级网页折叠菜单(类似树形菜单)效果代码
2015/09/17 Javascript
AngularJS基础 ng-value 指令简单示例
2016/08/03 Javascript
Bootstrap按钮功能之查询按钮和重置按钮
2016/10/26 Javascript
Angularjs根据json文件动态生成路由状态的实现方法
2017/04/17 Javascript
详解angular笔记路由之angular-router
2017/09/12 Javascript
node下使用UglifyJS压缩合并JS文件的方法
2018/03/07 Javascript
JavaScript经典案例之简易计算器
2020/08/24 Javascript
使用Python下载歌词并嵌入歌曲文件中的实现代码
2015/11/13 Python
python简单实例训练(21~30)
2017/11/15 Python
在Tensorflow中实现leakyRelu操作详解(高效)
2020/06/30 Python
美国大城市最热门旅游景点门票:CityPASS
2016/12/16 全球购物
美国女性卫生用品公司:Thinx
2017/06/30 全球购物
美国在线咖啡、茶和餐厅供应商:LollicupStore
2018/05/04 全球购物
MATCHESFASHION澳大利亚/亚太地区:英国时尚奢侈品电商
2020/01/14 全球购物
Java中compareTo和compare的区别
2016/04/12 面试题
卫校毕业生自我鉴定
2013/10/31 职场文书
婚纱摄影师求职信范文
2014/04/17 职场文书
班级口号大全
2014/06/09 职场文书
秦兵马俑导游词
2015/02/02 职场文书
老干部座谈会主持词
2015/07/03 职场文书
python小程序之飘落的银杏
2021/04/17 Python
聊聊CSS粘性定位sticky案例解析
2022/06/01 HTML / CSS