算法---FaceNet在Tf下的实战篇
FaceNet---Tensorflow下的下的实战篇
@WP20190225
===============目录===============
一、FaceNet算法简介
二、FaceNet配置与使用
2.1 安装环境的确定
2.2 下载文件:FaceNet源码 + LFW数据集 + 模型
2.3 环境配置
2.4 测试自己的数据
三、遇到的问题与解决方式
3.1 安装requirements.txt里要求的依赖项时报错
3.2 非法指令 (核心已转储)
3.3 找不到路径
3.4 模型版本太旧
===============正文===============
一、FaceNet算法简介
FaceNet算法,是谷歌开发的人脸检测算法,发表于 CVPR 2015,利用相同人脸在不同角度等姿态的照片下有高内聚性,不同人脸有低耦合性,提出使用 cnn + triplet mining 方法,在 LFW 数据集上准确度达到 99.63%,在 youtube 人脸数据集上准确度 95.12%,比以往准确度提升了将近 30%。【引用】
FaceNet算法原理,这里不做介绍。
二、FaceNet使用环境
2.1 安装环境的确定
Ubuntu 18.04 + Tensorflow 1.5.0 + Python 2.7 + OpenCV 3.2.0
说明:之前已经安装过Python + OpenCV,长时间不用Ubuntu系统忘记装的什么版本了,通过命令查看已安装的版本。要知道自己电脑的opencv 版本,因为版本不同,调用的头文件就不同。
(1)查看Python版本: $ python
(2)查看Tensorflow 版本: $ import tensorflow as tf
$ tf.__version__
(3)查看OpenCV版本: $ pkg-config --modversion opencv
2.2 下载文件:FaceNet源码+模型
(1)FaceNet在github源码地址为: https://github.com/davidsandberg/facenet/tree/master
FaceNet库源码下载链接:https://codeload.github.com/davidsandberg/facenet/zip/master
(2)LFW数据集: http://vis-www.cs.umass.edu/lfw/#resources
网址打开后下载Download the database: All images as gzipped tar file
(3)FaceNet库模型下载链接:
FaceNet预训练的模型,官网给出是在谷歌连接上,可能不方便下载,自己想招。下面备注一下,个人在网络资源上找的下载链接。
- 20170512-110547模型下载地址:https://pan.baidu.com/s/1nvBX233 密码:s0sb
- 20180402-114759模型下载地址:https://drive.google.com/open?id=1EXPBSXwTaqrSC0OhUdXNmKSh9qJUQ55-
如果不能翻墙,可以通过下面的链接下载:https://download.csdn.net/download/rookie_wei/10609076
说明:20170512-110547模型,后面使用时出现了模型版本太旧,所以又下载了20180402-114759模型。
2.3 环境配置
(1)FaceNet源码的解压与配置依赖项
前提是已经配置好python、opencv环境,然后解压FaceNet源码。这里尝试了两种方式:一是,计算机根目录下使用python,直接在根目录下解压FaceNet源码;二是,计算机下安装了conda虚拟机,在ananconda下使用python,在ananconda目录下解压FaceNet源码。两者配置FaceNet方式相同,只是在配置好后,使用方式稍微有点区别。
接下来,仅仅细说在ananconda下的配置过程。
1>解压FaceNet源码到路径/home/wp/anaconda2/test_py2/facenet-py2。【文件夹facenet-py2是FaceNet源码的解压文件。】
2>利用pip安装运行代码所需引入工具包
提示:因为后面安装调试的时候,发现了本人的ubuntu18.04系统不支持tf1.7、tf1.10版本的问题,这里直接将requirements.txt里要求的tensorflow==1.7改成tensorflow==1.5.0后再往下进行。
进入facenet源码文件夹,安装依赖项:
$ cd /home/wp/anaconda2
$ source activate test_py2 【激活虚拟环境,开始使用,里面之前安装过tf1.5】
$ cd test_py2
$ cd facenet-py2 【进入FaceNet源码解压文件:文件夹facenet-py2是中】
$ pip install -r requirements.txt
$ source deactivate 【最后,不使用了,记得关闭。即,退出虚拟环境。】
【利用pip安装运行代码所需的依赖项,如果使用的是python3,则用pip3 install -r requirements.txt。稍微等待一会儿,不报错,安装完后基本可以使用facenet了。报错,解决一下就可以了。】
3>设置环境变量
为了正常执行FaceNet,还要设置好环境变量,也就是,PYTHONPATH实际指向你的facenet存储位置中的src目录。这里提供两种方式:一是,每次重启电脑,都需要设置一下的;二是,不需每次重启电脑,永久生效。
方式一,终端下直接执行命令:
$ export PYTHONPATH=$PATH:/home/wp/anaconda2/test_py2/facenet-py2/src
或者 $ export PYTHONPATH=/home/wp/anaconda2/test_py2/facenet-py2/src
为了避免每次开机都执行,将其写到~/.bashrc文件中。可以采用方式二:
首先:$ sudo gedit ~/.bashrc
接着,添加内容并保存:
$ export PYTHONPATH=$PATH:/home/wp/anaconda2/test_py2/facenet-py2/src
最后,每次修改.bashrc后,使用:$ source ~/.bashrc,使修改立即生效
注:后面的地址是facenet目录+ /src
2.4 测试自己的数据
Step1,准备工作:
(1)将下载的LFW数据集解压到data文件下,重命名lfw_160,新建lfw:/home/wp/anaconda2/test_py2/facenet-py2/data/lfw/lfw_160 。
(2)将下载的20180402-114759模型放在如下文件夹下:
/home/wp/anaconda2/test_py2/facenet-py2/models/20180402-114759。
注,20180402-114759文件夹下含有4个文件。
(3)将自己找的几张图片(如10.jpg、11.jpg、20.jpg),放在如下文件夹下:/home/wp/anaconda2/test_py2/facenet-py2/data/images
Step2,继续:
$ cd /home/wp/anaconda2
$ source activate test_py2
$ cd test_py2
$ cd facenet-py2
Step3,测试自己的数据:
$ python src/compare.py models/20180402-114759 data/images/10.jpg data/images/11.jpg data/images/20.jpg
Step4,观察结果后,根据需要退出虚拟环境:
$ source deactivate
三、遇到的问题与解决方式
3.1 安装requirements.txt里要求的依赖项时报错
(1)执行pip install -r requirements.txt ,报错:
Could not find a version that satisfies the requirement PyHamcrest>=1.9.0 (from Twisted>=13.1.0->scrapy) (from versions: )
No matching distribution found for PyHamcrest>=1.9.0 (from Twisted>=13.1.0->scrapy)
大致意思是没有安装PyHamcrest吧,还规定了版本,因为怕直接pip安装版本会不对,就直接下载对应版本的包,本地安装了。
【解决】在这里下载PyHamcrest->1.9.0版本的包到本地,然后进入目录,
$ pip install ./PyHamcrest-1.9.0-py2.py3-none-any.whl
【或者pip3 install ./PyHamcrest-1.9.0-py2.py3-none-any.whl】
然后重新输入:$ pip install -r requirements.txt
(2)执行pip install -r requirements.txt ,报错:
grin 1.2.1 requires argparse>=1.1, which is not installed.
https://blog.csdn.net/picturelife/article/details/81022265
【解决】那就再安装一下:$ pip install argparse
3.2 非法指令 (核心已转储)
这个经过不停的调试,安装了不同版本的tf,发现是ubuntu系统和tf版本的匹配问题,注意这里两者是否匹配。亲测,个人的ubuntu18.04支持tf1.5, 不支持tf1.7和tf1.10,其他版本的还没有试过。
【解决】安装匹配的版本:如ubuntu18.04支持tf1.5。
3.3 找不到路径
运行$ python src/compare.py models/20170512-110547 data/images/01.jpg data/images/02.jpg,提示找不到路径、参数太多等问题。
usage: compare.py [-h] [--image_size IMAGE_SIZE] [--margin MARGIN]
[--gpu_memory_fraction GPU_MEMORY_FRACTION]
model image_files [image_files ...]
问题1:compare.py: error: too few arguments
。。。。
File "/home/wp/anaconda2/test_py2/facenet-py2/src/facenet.py", line 388, in get_model_filenames
raise ValueError('No meta file found in the model directory (%s)' % model_dir)
问题2:ValueError: No meta file found in the model directory (models/20180402-114759)
【解决】经过不断调试发现是,执行命令中使用中英文空格参杂,使用了中文空格导致的。保持英文输入,空格大小一致即可。
3.4 模型版本太旧
报错:cannot convert a tensor of type int32 to an input of type int64.
【解决】20170512-110547模型版本太旧,下载了20180402-114759模型。
算法---FaceNet在Tf下的实战篇的更多相关文章
- 手牵手,使用uni-app从零开发一款视频小程序 (系列下 开发实战篇)
系列文章 手牵手,使用uni-app从零开发一款视频小程序 (系列上 准备工作篇) 手牵手,使用uni-app从零开发一款视频小程序 (系列下 开发实战篇) 扫码体验,先睹为快 可以扫描下微信小程序的 ...
- KNN 算法-实战篇-如何识别手写数字
公号:码农充电站pro 主页:https://codeshellme.github.io 上篇文章介绍了KNN 算法的原理,今天来介绍如何使用KNN 算法识别手写数字? 1,手写数字数据集 手写数字数 ...
- SVM 支持向量机算法-实战篇
公号:码农充电站pro 主页:https://codeshellme.github.io 上一篇介绍了 SVM 的原理和一些基本概念,本篇来介绍如何用 SVM 处理实际问题. 1,SVM 的实现 SV ...
- Android为TV端助力 转载:Android绘图Canvas十八般武器之Shader详解及实战篇(下)
LinearGradient 线性渐变渲染器 LinearGradient中文翻译过来就是线性渐变的意思.线性渐变通俗来讲就是给起点设置一个颜色值如#faf84d,终点设置一个颜色值如#CC423C, ...
- caffe框架下目标检测——faster-rcnn实战篇操作
原有模型 1.下载fasrer-rcnn源代码并安装 git clone --recursive https://github.com/rbgirshick/py-faster-rcnn.git 1) ...
- 【微信小程序】转载:微信小程序实战篇-下拉刷新与加载更多
下拉刷新 实现下拉刷新目前能想到的有两种方式 1. 调用系统的API,系统有提供下拉刷新的API接口 当然,你可以直接在全局变量app.json的window里面配置上面这个属性,这样整个项目都允许下 ...
- Redis实战篇
Redis实战篇 1 Redis 客户端 1.1 客户端通信 原理 客户端和服务器通过 TCP 连接来进行数据交互, 服务器默认的端口号为 6379 . 客户端和服务器发送的命令或数据一律以 \r\n ...
- SAS数据挖掘实战篇【五】
SAS数据挖掘实战篇[五] SAS--预测模型 6.1 测模型介绍 预测型(Prediction)是指由历史的和当前的数据产生的并能推测未来数据趋势的知识.这类知识可以被认为是以时 间为关键属性的关联 ...
- SAS数据挖掘实战篇【四】
SAS数据挖掘实战篇[四] 今天主要是介绍一下SAS的聚类案例,希望大家都动手做一遍,很多问题只有在亲自动手的过程中才会有发现有收获有心得. 1 聚类分析介绍 1.1 基本概念 聚类就是一种寻找数据之 ...
随机推荐
- webdriervAPI(获取验证信息)
from selenium import webdriver driver = webdriver.Chorme() driver.get("http://www.baidu.co ...
- Fabric 查看zookeeper和kafka
进入kafka容器: sudo docker exec -it kafka bash cd opt/kafka 查看Kafka自动创建的topic bin/kafka-tipiccs.sh --lis ...
- Map对象,Set对象使用(2)
今天重点见一下Set Set 在我印象里它主要就是去重,Set 是一个值的集合,这个集合中所有的值仅出现一次 Set 属性size:和Map的size一样,返回成员的总数 Set的方法: Set.pr ...
- Java High Level REST Client 之 创建索引
1. 创建索引请求 CreateIndexRequest request = new CreateIndexRequest("twitter"); 2.设置 2.1 分别设置 2. ...
- SQL SERVER创建表
创建表 create table table_name ( column_name_1 data_type, column_name_2 data_type NOT NULL, column_name ...
- mysql中比较实用的几个函数
1.曾有这样的需求: 可以使用如下函数: 语法:FIND_IN_SET(str,strlist). 定义: 1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间 ...
- 后台返回数据为map集合,前端js处理方法
当后台返回的数据不是json而是map集合的时候,前端js中处理就将其看作是一个数组,例如后台返回的代码入下: Map<String, String> result = new HashM ...
- PID程序实现
传统PID(位置式PID控制)调节: 这种算法的缺点是,由于全量输出,每次输出均与过去的状态有关,计算时要对 e(k) 进行累加,计算机运算工作量大.而且,因为计算机输出的 u(k) 对应的是执行机构 ...
- 护卫神等IIS设置Thinkphp框架的public目录为根目录的解决办法
最近碰到一个棘手的问题,在使用护卫神或者主机宝等IIS环境配置PHP的时候,不能把public设置为网站根目录(因为Thinkphp的安全要求:要将public设置为对外公开目录),这个问题无法搜索到 ...
- Mysql数据库的优化(本文摘自于网络,文章末端有原文链接)
对于一个以数据为中心的应用,数据库的好坏直接影响到程序的性能,因此数据库性能至关重要.一 般来说,要保证数据库的效率,要做好以下四个方面的工作: ① 数据库设计 ② sql语句优化 ③ 数据库参数配置 ...