1. 开发环境

OS:        ubuntu16.04
tensorflow版本:1.12.0
python版本:    3.6.7

2. 下载源码到本地

facenet官方github: https://github.com/davidsandberg/facenet.git

git clone https://github.com/davidsandberg/facenet.git

在requirements.txt文件看到要安装相关的依赖库,自己用pip指令安装一下就好了

tensorflow==1.7
scipy
scikit-learn
opencv-python
h5py
matplotlib
Pillow
requests
psutil

3. 下载LFW数据集

LFW 是评估人脸识别算法效果的公开测试数据集,共有13233张图片,属于 5749 个不同人,其中图片的大小为250×250。

下载地址:http://vis-www.cs.umass.edu/lfw/

下载步骤:->Menu->Download->All images as gzipped tar file

facenet/data/下新建lfw_data文件夹,把下载的压缩包放在 facenet/data/lfw_data 目录下,然后进行解压。

  • 对LFW图片预处理

lfw的图片原图尺寸为 250*250,我们要修改图片尺寸,使其大小符合预训练模型的输入尺寸,即160*160。在src/align/align_dataset_mtcnn.py文件里,采用MTCNN人脸检测算法对人脸进行检测,进一步人脸对齐,然后再把人脸图片尺寸修改为160×160的尺寸,保存到facenet/data/lfw_data/lfw_160目录下。想了解更多关于MTCNN人脸检测算法,已经有不少写得不错的博客,比如:https://blog.csdn.net/qq_14845119/article/details/52680940 ,解释的很详细。

facenet/src/align/align_dataset_mtcnn.py文件拷贝到facenet/src路径下,然后执行图片转换:

cp -i src/align/align_dataset_mtcnn.py src/
python src/align_dataset_mtcnn.py data/lfw_data/lfw data/lfw_data/lfw_160 --image_size 160 --margin 32 --random_order --gpu_memory_fraction 0.25

打印如下表示成功。

4. 下载Google预训练的网络模型

下载地址 https://github.com/davidsandberg/facenet ,这两个模型都是基于Inception ResNet V1 网络架构下进行识别的。同时看到有两个基于不同的dataset预训练好的模型,这里我下载的是VGGFace2数据集的模型。

在facenet目录下新建models文件夹,并把下载的模型放到models目录下,然后解压。

5. 预训练模型准确率测试

使用预训练模型进行测试:

python src/validate_on_lfw.py data/lfw_data/lfw_160/ models/20180402-114759/

由于我使用的tf版本的原因,我使用的是 tf1.12版本的, 作者的预训练模型是在tf 1.7版本训练的,所以在导入graph时会出错。出现如下错误:

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow/python/training/input.py:734: add_queue_runner (from tensorflow.python.training.queue_runner_impl) is deprecated and will be removed in a future version.
Instructions for updating:
To construct input pipelines, use the `tf.data` module.
Model directory: models/20180402-114759/
Metagraph file: model-20180402-114759.meta
Checkpoint file: model-20180402-114759.ckpt-275
2019-02-28 19:54:02.009422: W tensorflow/core/graph/graph_constructor.cc:1265] Importing a graph with a lower producer version 24 into an existing graph with producer version 27. Shape inference will have run different parts of the graph with different producer versions.
Traceback (most recent call last):
  File "src/validate_on_lfw.py", line 164, in <module>
    main(parse_arguments(sys.argv[1:]))
  File "src/validate_on_lfw.py", line 73, in main
    facenet.load_model(args.model, input_map=input_map)
  File "/home/liguiyuan/study/deep_learning/project/facenet/src/facenet.py", line 381, in load_model
    saver = tf.train.import_meta_graph(os.path.join(model_exp, meta_file), input_map=input_map)
  File "/usr/local/lib/python3.6/dist-packages/tensorflow/python/training/saver.py", line 1674, in import_meta_graph
    meta_graph_or_file, clear_devices, import_scope, **kwargs)[0]
......
KeyError: "The name 'decode_image/cond_jpeg/is_png' refers to an Operation not in the graph."

解决方法:

1.把Tensorflow换为1.7版本的;

2.在facenet.py代码中找到create_input_pipeline 再添加一行语句 with tf.name_scope("tempscope"): 就可以完美解决(貌似Tensorflow 1.10及以上版本才修复这个bug)。

改好之后, 再重新执行python代码。准确率达到了 0.98500+-0.00658,打印如下:

6. 比较两张图片的欧氏距离

这里使用欧氏距离用来衡量两张人脸的相似程度,用来判别这两张图片是否为同一个人。两张人脸图片越相似,空间距离越小;差别越大,则空间距离越大。

执行以下命令:

python src/compare.py models/20180402-114759/20180402-114759.pb data/images/Anthony_Hopkins_0001.jpg data/images/Anthony_Hopkins_0002.jpg --gpu_memory_fraction 0.25

下篇文章:facenet 人脸识别库的搭建和使用方法(二)


参考:

http://www.cnblogs.com/gmhappy/p/9472388.html

facenet 人脸识别源码的使用方法(一)相关推荐

  1. 人脸检测颜值软件_AI人脸颜值测颜版下载-百度ai测试颜值人脸识别源码下载v1.0 免费版-西西软件下载...

    百度ai测试颜值人脸识别源码这是由官方百度AI精心打造出来的,这款软件将人脸识别氛围V2和V3两个接口,而且用户使用可以参考相应的文档权限来选择接口类型,让广大用户学习到百度AI人脸识别测颜值相关知识 ...

  2. Android园区部队人脸识别源码门禁项目讲解

    Android园区部队人脸识别源码门禁项目讲解 这边搞人脸识别相关项目有一段时间,今天抽时间讲述一个经典的人脸识别项目:部队人脸识别门禁系统. 大家都知道部队对人员管理安全要求是相当高的,很多保密的技 ...

  3. python 人脸识别源码

    Python是一种流行的编程语言,可以用于许多任务,包括人脸识别.以下是使用Python进行人脸识别的基本步骤: 安装必要的库:为了进行人脸识别,您需要安装OpenCV(用于图像处理),dlib(用于 ...

  4. python人脸识别源码_Python 抖音机器人,让你找到漂亮小姐姐

    本项目作者沉迷于抖音无法自拔,常常花好几个小时在抖音漂亮小姐姐身上. 本着高效.直接地找到漂亮小姐姐的核心思想,我用 Python + ADB 做了一个 Python 抖音机器人 Douyin-Bot ...

  5. android 虹软 例子,虹软离线人脸识别源码Android版本

    [实例简介] 虹软离线识别Android 源码,下载即可运行,包含aar包,不需要越墙下载,可运行 [实例截图] [核心代码] ArcFaceDemo ├── ArcFaceDemo-master │ ...

  6. java实现人脸识别源码【含测试效果图】——ServiceImpl层(UserServiceImpl)

    /** * @Title: BaseServiceImpl.java * @Package org.service.impl * @Description: TODO该方法的主要作用: * @auth ...

  7. java实现人脸识别源码【含测试效果图】——Service层(IUserService)

    /** * @Title: BaseService.java * @Package org.service * @Description: TODO该方法的主要作用: * @author A18ccm ...

  8. java实现人脸识别源码【含测试效果图】——DaoImpl层(UserDaoImpl)

    /** * @Title: UserDaoImpl.java * @Package org.dao.impl * @Description: TODO该方法的主要作用: * @author A18cc ...

  9. java实现人脸识别源码【含测试效果图】——DaoImpl层(BaseDaoUtilImpl)

    /*** */ package org.dao.impl;import java.sql.ResultSet; import java.sql.SQLException; import java.ut ...

最新文章

  1. 数组对称_对称性应用在物理中的几个小例子
  2. 启动模式 和 任务栈
  3. html中dir标签的作用是什么意思,htmldir标签是干啥的?dir标签的具体定义和属性介绍...
  4. python mysql操作_Python的MySQL操作
  5. 孩子学计算机最佳年龄,孩子学编程最佳年龄是几岁
  6. 全排列的递归与非递归形式
  7. 吴恩达深度学习 —— 3.11 随机初始化
  8. proto3与proto2的区别
  9. Axure RP 9(附授权码+安装教程)
  10. 修复移动硬盘坏道计算机睡眠了,硬盘坏道屏蔽工具DiskGenius,教您如何修复硬盘坏道...
  11. 实现跨word文档的格式刷,两个word间格式刷
  12. python的合法命名,以下不是Python语言合法命名的是:A、MyGod5B、5MyGodC、_...
  13. “文件大小”和“占用空间”的区别
  14. 华为擎云 W510 鲲鹏 920 24 核工作站使用体验
  15. //数据结构:先序、中序、后序遍历二叉树。输入数据:abd##eg###c#f#h##
  16. 灾备系统与备用服务器区别,服务器灾备方案是什么
  17. C语言编写简易图书管理系统
  18. Mac根目录下无法创建文件夹
  19. xlsx文件打不开损坏要如何恢复呢?
  20. Missing Tag Identification in COTS RFID Systems: Bridging the Gap between Theory and Practice 翻译

热门文章

  1. Im4java接口调用ImageMagick图片处理服务简单demo学习
  2. 学校信息化分享-中小学怎样快速完成教学资源库的建设
  3. PostGreSQL设置主键自增
  4. JS实现炫酷雪花飘落效果
  5. 三菱电梯部分原理图,软件工具及资料
  6. 关于Excel在VB里的应用(来自微软)
  7. 环保数采仪 数据主动上报
  8. 单源最短路之Dijkstra算法代码模板
  9. 双翌视觉对位系统图像处理方法说明—边缘匹配
  10. Qt 使用QMediaPlayer播放音乐无声音