人脸实践篇 | 基于Caffe的年龄&性别识别






640?wx_fmt=png

人脸检测及对应属性的识别是现在比较流行的一个技术之一。今天我们“计算机视觉战队”就和大家说说该技术的一些详细细节。

640?wx_fmt=png

640?wx_fmt=png

640?wx_fmt=gif

随着社会的发展,快速有效的自动身份验证在安防领域变的越来越迫切。

由于生物特性是人的内在属性,具有很强的自身稳定性和个体差异性,是身份验证的最理想依据。利用人脸属性进行身份验证又是最自然最直接的手段,相比其它人类生物特性,它具有直接、方便的特点,更容易被用户所接受且不易察觉。

近几年也是有很多相关的Paper及技术得到了实现,如:

  • 2015年的一篇文章就简单得到了实现,只要你懂得Alexnet,实现这篇文献的算法,会比较容易。最后的实验结果,Gender accuracy 在86.8%,Age预测精准的值准确率在50.7%,预测年龄段准确率在 84.7%,使用的数据集是Adience;

  • 基于传统方法也有,比如基于LBP,亮度、形状直方图的多尺度特征融合的性别识别,在性别识别中融入信息论概念,对PCA、LDA等经典识别算法进行简化,在简化过程中根据信息熵、互信息量等指标提出一套特征选择理论。最后结果,Gender accuracy基于像素增强为87.85%,基于shape features可以达到91.59%,基于LBP纹理特征也可以到达93.46%,利用三种特征可以得到95.33%,都是在常用的FERET数据集中。

  • 基于形状特征和深度神经网络的现实人脸性别分类,先对人脸进行对齐操作,用深度网络的方法进行分类,在LFW数据库的非正向人脸样本部分做实验,识别率可达到89.3%。

性别识别


性别识别是利用计算机视觉来辨别图像中的人脸性别属性。多年来,人脸性别因为实际场景的需求,如在身份认证、人机接口、视频检索以及机器人视觉中的潜在应用而备受关注。

性别识别是一个复杂的大规模二分类问题,分类器将数据录入并划分男女性别。目前性别识别方法主要有:基于特征脸的性别识别算法(等传统方法)及基于深度学习方法。

640?wx_fmt=gif

基于特征脸的性别识别算法 

基于特征脸的性别识别算法主要是使用PCA。在计算过程中通过消除数据中的相关性,将高维图像降低到低维空间,而训练集中的样本则被映射成低维空间中的一点。当需要判断测试图片性别时,就需要先将测试图片映射到低维空间中,然后计算离测试图片最近样本点是哪一个,将最近样本点的性别赋值给测试图片即可。

640?wx_fmt=png

640?wx_fmt=other

下面我们主要讲深度学习方法,那我们开始吧!

年龄及性别识别


import os
import numpy as np
import matplotlib.pyplot as plt
import sys
import caffe
%matplotlib inline  

caffe_root = './caffe/'
sys.path.insert(0, caffe_root + 'python')
plt.rcParams['figure.figsize'] = (10, 10)
plt.rcParams['image.interpolation'] = 'nearest'
plt.rcParams['image.cmap'] = 'gray'

然后我们读取均值文件:

mean_filename='./mean_file/mean.binaryproto'
proto_data = open(mean_filename, "rb").read()
temp = caffe.io.caffe_pb2.BlobProto.FromString(proto_data)
mean  = caffe.io.blobproto_to_array(temp)[0]

读取之前训练好的模型文件:

age_net_pretrained='./models/age_net.caffemodel'
age_net_model_file='./deploy_age.prototxt'
age_net = caffe.Classifier(age_net_model_file, age_net_pretrained,mean=mean,channel_swap=(2,1,0),raw_scale=255,image_dims=(256, 256))

读取Label文件:

age_list=['(0, 2)','(4, 6)','(8, 12)','(15, 20)','(25, 32)','(38, 43)','(48, 53)','(60, 100)']
gender_list=['Male','Female']

读取预测图像及预测结果:

example_image = './example_image.jpg'
input_image = caffe.io.load_image(example_image)
_=plt.imshow(input_image)

640?wx_fmt=png

prediction = age_net.predict([input_image])  
print('predicted age:', age_list[prediction[0].argmax()])

640?wx_fmt=png

prediction = gender_net.predict([input_image])
print('predicted gender:', gender_list[prediction[0].argmax()])

640?wx_fmt=png

特征可视化

做这个的原因,是想通过学习特征过程,其重点学习的特征到底是什么样子的,好让我们有一个空间想象力。

COV1第一层卷积滤波器学习特征的可视化结果,该层主要学习颜色、纹理、边缘等特征,属于较低层特征。

640?wx_fmt=png

COV1第一层卷积后的可视化结果:

640?wx_fmt=png

END

今天主要以简单的操作为主,详细的框架介绍及训练和情感属性识别,我们会在“计算机视觉协会知识星球给同学们详细解释。之后,我们“计算机视觉战队公众号平台也会详细和大家一起学习,分享相关的知识推送。

如果想加入我们“计算机视觉战队”,请扫二维码加入学习群。计算机视觉战队主要涉及机器学习、深度学习等领域,由来自于各校的硕博研究生组成的团队,主要致力于人脸检测、人脸识别,多目标检测、目标跟踪、图像分割等研究方向。

640?wx_fmt=jpeg

640?wx_fmt=png

640?wx_fmt=gif
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

计算机视觉研究院

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值