前端人脸识别--两张脸类似度

本文例子主要写的是如何获取两张脸的类似度, 其他例子参考官网, 博主才疏学浅, 若是有错误, 麻烦大佬们多多指点.javascript

face-api.js 传送门: github.com/justadudewh…java

代码传送门, 安装即用, 顺手点star, 一天好心情, 例子基于face-api.js github.com/TheKiteRunn…node

本人csdn地址: blog.csdn.net/c_kite/arti…linux

1. 效果图

效果图

能够clone下个人例子代码, 比对参考图片是images文件夹下的reference.jpggit

2. 开发流程

2.1. 安装face-api.js

获取face-api.js: npm i face-api.jsgithub

若是想要在node端运行, 我做为一个windows用户遇到了n多坑, 下面贴上一些解决连接:npm

  1. node-gyp: windows用户安装办法 github.com/nodejs/node…
  2. TensorFlow.js Node.js windows故障排查 github.com/tensorflow/…
  3. 若是遇到 Downloading libtensorflow events.js:173 throw er; // Unhandled 'error' event ^ Error: connect ETIMEDOUT 172.217.160.80:443 网络问题, 须要合理的工具来解决这个问题, 代码里的libtensorflow地址: const BASE_URI = 'storage.googleapis.com/tensorflow/…'; const CPU_DARWIN = 'cpu-darwin-x86_64-1.12.0.tar.gz'; const CPU_LINUX = 'cpu-linux-x86_64-1.12.0.tar.gz'; const GPU_LINUX = 'gpu-linux-x86_64-1.12.0.tar.gz'; const CPU_WINDOWS = 'cpu-windows-x86_64-1.12.0.zip'; const GPU_WINDOWS = 'gpu-windows-x86_64-1.12.0.zip';
  4. 安装过程若是遇到"node-pre-gyp install --fallback-to-build", 那是canvas包执行的, 会下载一个文件: github.com/node-gfx/no… 长时间没反应的话估计是这个包卡主了, 须要合理上网

2.2. 加载model

安装完包以后, 须要根据你所须要的功能加载适当的model, 人脸检测一个model, 表情识别一个model, 人脸识别一个model, 若是你没有提早加载model直接使用api的话会有下面示例代码相似提示canvas

Uncaught (in promise) Error: FaceLandmark68Net - load model before inference 
// 这就意味着没有加载FaceLandmark model
复制代码

那么如何加载model呢, 以下代码windows

await faceapi.loadTinyFaceDetectorModel('model地址')
// 等价于
await faceapi.nets.tinyFaceDetector.load('model地址')
复制代码

所有的model能够在仓库找到: github.com/justadudewh… 你能够把他们放到本身的静态服务器里api

2.3. 面部检测

检测视频或者图片中所有脸

const detections = await faceapi.detectAllFaces(input)
复制代码

检测图像中具备最高置信度分数的面部

const detection = await faceapi.detectSingleFace(input)
复制代码

默认状况下,detectAllFacesdetectSingleFace使用SSD Mobilenet V1人脸检测器。您能够经过传递相应的选项对象来指定面部检测器

// 我测试的时候使用的是`TinyFaceDetector`, 所以能够
const detections = await faceapi.detectAllFaces(input, new faceapi.TinyFaceDetectorOptions())
复制代码

2.4. 检测脸部68个标记点

在面部检测以后,咱们还能够预测每一个检测到的面部的面部标志,以下所示:

const detectionsWithLandmarks = await faceapi.detectAllFaces(input).withFaceLandmarks()
// 或者
const detectionWithLandmarks = await faceapi.detectSingleFace(input).withFaceLandmarks()
复制代码

2.5. 计算脸部描述

Note: 必定要按照博文所写的顺序来调用函数

在面部检测和面部标志预测以后,能够计算每一个面部的面部描述符:

const results = await faceapi.detectAllFaces(input).withFaceLandmarks().withFaceDescriptors()
// 或者
const result = await faceapi.detectSingleFace(input).withFaceLandmarks().withFaceDescriptor()
复制代码

2.6. 计算两张脸类似度

要执行面部识别,可使用faceapi.FaceMatcher将参考面部描述符与查询面部描述符进行比较

const imgEle = document.createElement('img');
imgEle.src = '/reference.jpg'
const  reference = await faceapi.detectSingleFace(imgEle, options).withFaceLandmarks().withFaceDescriptor()

const result = await faceapi.detectSingleFace(videoEl, options).withFaceLandmarks().withFaceDescriptor()
if (result) {
    const faceMatcher = new faceapi.FaceMatcher(result)
    drawLandmarks(videoEl, $('#overlay').get(0), [result], withBoxes)

    if (reference) {
       const bestMatch = faceMatcher.findBestMatch(reference.descriptor)
       console.log(bestMatch)
     }
}
复制代码

此处主要经过脸部特征向量来计算euclidean distance(欧氏距离), 所以如预览图所示_distance越小, 说明两张脸越匹配, 这个阈值能够设置为0.4, 0.4如下为匹配成功, 以上则失败.

所以若是你有脸部特层向量, 你也能够经过这个face-api.js api来计算欧式距离

const dist = faceapi.euclideanDistance([0, 0], [0, 10])
console.log(dist) // 10
复制代码

tips: euclidean distance(欧氏距离)定义: 是一个一般采用的距离定义,它是在m维空间中两个点之间的真实距离.在二维空间中的欧氏距离就是两点之间的直线段距离. 二维空间的欧氏距离公式 d = sqrt(( x1-x2)^2 + (y1-y2)^2 )三维空间的欧氏距离公式d = sqrt( (x1-x2)^2+(y1-y2)^2+(z1-z2)^2 )

相关文章
相关标签/搜索