前期文章我们分享了opencv的人脸检测

人工智能-OpenCV+Python实现人脸识别

以及dlib的人脸检测与人脸识别

人工智能-Dlib+Python实现人脸识别

通过往期的分享,我们了解到人脸识别的大概过程,主要包括:

1、人脸图片的搜集(原始数据)

2、从图片中识别到人脸

3、人脸数据提取

4、人脸数据保存

5、从图片或者视频中检测到人脸

6、人脸数据提取

7、被识别的人脸与数据库中的数据一一对比,识别出人脸

人脸识别

以上人脸识别过程,存在一定的问题,当人脸原始数据比较大时,数据库中必然存在比较多的人脸数据,当进行人脸识别时,被识别的人脸与数据库中的数据对比时,必然会消耗大量的时间,对人脸实时识别的速度有较大的影响。受CNN卷积神经网络的启发,我们使用神经网络来进行人脸数据的训练,标签是人脸的名字,数据是人脸数据,使用神经网络对人脸数据进行训练,这样当数据比较大时,神经网络识别速度与正确率就越高,大大提高人脸识别的速度与正确率,这样人脸识别的过程便成为如下过程:

1、人脸图片的搜集(原始数据)

2、从图片中识别到人脸

3、人脸数据提取与保存

4、人脸数据与人脸标签的神经网络训练,保存训练模型

5、从图片或者视频中检测到人脸

6、识别到的人脸进行神经网络预测,进行人脸识别

本期介绍人脸数据的提取

1、人脸原始图片的搜集

要进行人脸识别,就要搜集用户的人脸图片,我们从网站上搜集了几个明星的照片来进行本期文章的分享

首先在目录文件下新建一个dataset文件夹,里面放置多个文件夹,每个文件夹便是一个明星的照片,文件夹名称是明星的名字,目录类似如下:

2、设置人脸检测模型与人脸提取嵌入数据模型

人脸检测模型,我们直接使用ResNet-10和SSD算法在caffe上面训练好的模型

人脸数据提取嵌入模型,使用OpenFace的openface_nn4.small2.v1.t7模型,此模型训练在pytorch上,可以直接使用opencv来进行加载

脸检测模型与人脸提取嵌入数据模型

3、初始化图片地址,初始化人脸数据数组与人脸名称标签数组

初始化人脸数据

4、遍历整个dataset目录,进行图片处理

30行提取了文件夹的名称,此名称便是后期需要保存的label值

33-35行,进行了图片的读取以及resize处理

38行计算图片的blob值

43-44行,把图片的blob值放入人脸检测神经网络进行人脸的检测

47行,当在图片中检测到 人脸时,其神经网络的len值会大于0

50行,当检测到人脸时,我们提取人脸的置信度

53行设计人脸置信度为0.5

55-59行,计算人脸在图片中的位置,并提取人脸的尺寸

61-62行,当人脸尺寸较小时 ,我们忽略此人脸信息,选择图片中人脸比较大的人脸

64行,当人脸图片尺寸符合要求时,我们计算人脸的blob值

67-68行,把人脸图片的blob值传递人脸嵌入数据神经网络

71-72行,保存人脸的label与人脸数据到数组中

5、保存人脸数据

当遍历完成后,dataset中的所有的人脸数据便保存在了事先建立的数组中

77行,新建一个字典数据,把人脸的label以及人脸数据保存到本地,方便后期进行神经网络的训练

以上5步便完成了整个人脸的数据采集,当然,若想后期人脸识别的精度较高,需要进行大量的人脸数据搜集

人脸识别系统

此部分文章是人脸识别的第一部分,人脸数据的搜集与提取,后期我们分享人脸识别系统的神经网络训练与人脸识别

微@信搜索:启示AI科技,

体验不一样的AI工具

微信搜索小程序:AI人工智能工具

pytorch实现人脸识别_一步一步带你完成深度学习与对象检测之人脸识别相关推荐

  1. 深度学习之对象检测_深度学习时代您应该阅读的12篇文章,以了解对象检测

    深度学习之对象检测 前言 (Foreword) As the second article in the "Papers You Should Read" series, we a ...

  2. opencv交通标志识别_教你从零开始做一个基于深度学习的交通标志识别系统

    教你从零开始做一个基于深度学习的交通标志识别系统 基于Yolo v3的交通标志识别系统及源码 自动驾驶之--交通标志识别 在本文章你可以学习到如何训练自己采集的数据集,生成模型,并用yolo v3算法 ...

  3. 无人驾驶汽车系统入门:深度前馈网络,深度学习的正则化,交通信号识别

    作者 | 申泽邦(Adam Shan) 兰州大学在读硕士研究生,主攻无人驾驶,深度学习:兰大未来计算研究院无人车团队骨干,在改自己的无人车,参加过很多无人车Hackathon,喜欢极限编程. 在前几十 ...

  4. 基于深度学习的目标检测技术演进:从目标检测到人脸检测

    本篇博客主要转载两篇写得好的分别介绍基于深度学习的目标检测和人脸检测的文章,最近在调研基于深度学习的人脸检测相关的文章,在网上查相关资料时,有幸看到.文末附带基于深度学习的目标检测和人脸检测相关经典文 ...

  5. 无人驾驶汽车系统入门(十一)——深度前馈网络,深度学习的正则化,交通信号识别

    无人驾驶汽车系统入门(十一)--深度前馈网络,深度学习的正则化,交通信号识别 在第九篇博客中我们介绍了神经网络,它是一种机器学习方法,基于经验风险最小化策略,凭借这神经网络的拟合任意函数的能力,我们可 ...

  6. 基于Python深度学习的文字检测识别系统

    摘要 文字是人类交流信息的重要工具,在科技和网络不断发展的今天,文本的方式或者说载体发生了很大的变化,文字不再只停留在书面,更以标识牌,横幅,广告牌等等方式出现我们的生活中,或者说,它们是一张张图片中 ...

  7. 基于深度学习的端到端人脸识别技术:全面调研

    44页,共计371篇参考文献.本文全面介绍了端到端深度学习人脸识别技术,包括人脸检测,人脸预处理和人脸表征等方向,详细介绍了最新的算法设计,评估指标,数据集,性能比较等. The Elements o ...

  8. PyTorch实现 | 车牌OCR识别,《PyTorch深度学习之目标检测》

    注:本文选自中国水利水电出版社出版<PyTorch深度学习之目标检测>一书,有改动 福利!免费寄送图书!! 公众号[机器学习与AI生成创作]后台回复:168.即可参与免费寄送图书活动,活动 ...

  9. 深度学习笔记(42) 人脸识别

    深度学习笔记(42) 人脸识别 1. 人脸识别 2. One-Shot学习 3. Similarity函数 1. 人脸识别 现在可以看到很多产品在运用人脸识别,如手机解锁.车站身份识别认证.刷脸支付等 ...

最新文章

  1. UGUI之Toggle使用
  2. [leetcode]476. 数字的补数
  3. codeforces 796A-D
  4. C++ Primer Plus学习(十二)——类继承(is-a)
  5. MySql解决办法:2004:Can't create TCP/IP socket (24)
  6. Linux命令查看电脑,linux查看文件大小命令
  7. c语言源程序要求每行只能书写一条语句,C语言试题库(含答案)
  8. vue 统计中英文字符串长度_Ant Design Vue实现区分中英文分全角/半角字符长度校验功能...
  9. js+ajax编码三级联动
  10. html5 3d场景设计,基于 HTML5 WebGL 的加油站 3D 可视化监控
  11. 至少12亿元收支差,分析运营商7大数据产品应用
  12. 手把手教你智能硬件开发(六)直流马达
  13. fcm基本原理_光谱FCM工作原理
  14. 15k运维面试题带答案分享
  15. oracle 碎片超过1000有啥危害,碎片化带来的坏处作文1000字
  16. 杭州海赢科技分享速卖通绑定欧盟责任人流程及相关FAQ
  17. 47 lvs-nat/dr
  18. django.core.serializers.base.DeserializationError: Problem installing fixture
  19. element-UI 弹出外部组件
  20. 提升20%运营效率!朗姿、海信的移动化实战分享

热门文章

  1. java登录中用户类型分类_基于用户登陆的struts2中action的分类详解
  2. 20155301《信息安全系统设计基础》第六周学习总结
  3. iOS 商城类 app 首页的实现
  4. android的m、mm、mmm编译命令
  5. 地址总线与内存大小的关系(待续…)
  6. tomcat装死原因汇总
  7. lintcode-514-栅栏染色
  8. Python循环定时服务功能(相似contrab)
  9. 前端面试题整理【转】
  10. 操作系统(1-12)