1. 查找图像中出现的人脸
代码示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
#导入face_recognition模块
import face_recognition
#将jpg文件加载到numpy数组中
image = face_recognition.load_image_file(“your_file.jpg”)
#查找图片中人脸(上下左右)的位置,图像中可能有多个人脸
#face_locations的值类似[(135,536,198,474),()]
face_locations = face_recognition.face_locations(image);
# 使用cnn模型 准确率高
face_locations = face_recognition.face_locations(image, number_of_times_to_upsample = 0 , model = "cnn" )
face_locations = face_recognition.face_locations(small_frame, model = "cnn" )
|
2. 获取图像中人脸的眼睛、鼻子、嘴、下巴、眉毛的位置和轮廓
代码示例:
1
2
3
4
5
6
7
8
9
|
import face_recognition
image = face_recognition.load_image_file(“your_file.jpg”)
#查找图片中人脸的所有面部特征(眉毛,眼睛,鼻子,上下嘴唇,面部轮廓)
#face_landmarks_list是个二维数组
face_landmarks_list = face_recognition.face_landmarks(image)
|
3. 识别图像中出现的人脸
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
import face_recognition
known_image = face_recognition.load_image_file(“biden.jpg”)
unknown_imag = face_recognition.load_image_file(“unknown.jpg”)
#获取每个图像文件中每个面部的面部编码
#由于每个图像中可能有多个人脸,所以返回一个编码列表。
#但是事先知道每个图像只有一个人脸,每个图像中的第一个编码,取索引0。
biden_encoding = face_recognition.face_encodings(known_image)[ 0 ]
unknown_encoding = face_recognition.face_encodings(unknown_image)[ 0 ]
#如果图像中有多个人脸 获取图像中多个人脸编码
face_locations = face_recognition.face_locations(unknow_image)
face_encodings = face_recognition.face_encodings(unknown_image, face_locations)
#结果是true/false的数组,未知面孔known_faces阵列中的任何人相匹配的结果
#[true, false,false]
results = face_recognition.compare_faces([biden_encoding],unknown_encoding)
#结果是true/false的数组,未知面孔known_faces阵列中的任何人相匹配的结果 设定比对结果的阀值
#[true, false,false]
match = face_recognition.compare_faces(known_faces, face_encoding, tolerance = 0.50 )
|
4.两个人脸的相似度
1
2
3
4
5
6
7
|
#结果是小于1的值 例如0.5 0.7等
face_distances = face_recognition.face_distance(known_encodings, image_to_test_encoding)
设定阀值 05 或者 0.6 等
face_distances < 阀值
|
更多关于face_recognition库的介绍请查看以下链接
原文链接:https://blog.csdn.net/u010471273/article/details/80682638