这是世界上最简单的人脸识别库了。你能够经过Python引用或者命令行的形式使用它,来管理和识别人脸。 该软件包使用dlib中最早进的人脸识别深度学习算法,使得识别准确率在《Labled Faces in the world》测试基准下达到了99.38%。 它同时提供了一个叫face_recognition的命令行工具,以便你能够用命令行对一个文件夹中的图片进行识别操做。html
找到图片中全部的人脸:python
import face_recognition image=face_recognition.load_image_file("your_file.jpg") face_locations=face_recognition.face_locations(image)
得到图片中人类眼睛、鼻子、嘴、下巴的位置和轮廓:git
import face_recognition image = face_recognition.load_image_file("your_file.jpg") face_landmarks_list = face_recognition.face_landmarks(image)
找到脸部特征有不少超级有用的应用场景,固然你也能够把它用在最显而易见的功能上:美颜功能 就像美图秀秀那样:github
识别图片中的人是谁web
import face_recognition known_image=face_recognition.load_image_file("biden.jpg") unknown_image=face_recognition.load_image_file("unknown.jpg") biden_encoding=face_recognition.face_encodings(known_image)[0 ]unknown_encoding=face_recognition.face_encodings(unknown_image)[0] results=face_recognition.compare_faces([biden_encoding],unknown_encoding)
你甚至能够用这个软件包作人脸的实时识别:算法
这里有一个实时识别的例子docker
首先,确保你安装了dlib,以及该软件的Python绑定接口。若是没有的话,看这篇安装说明:缓存
而后,使用pip3
(Python 2的pip2
)从pypi安装此模块:cookie
pip3 install face_recognition
若是你安装遇到问题,能够试试这个安装好了的虚拟机网络
虽然Windows不是官方支持的,可是有热心网友写出了一个Windows上的使用指南,请看这里:
若是你已经安装了face_recognition,那么你的系统中已经有了一个名为face_recognition的命令,你可使用它对图片进行识别,或者对一个文件夹中的全部图片进行识别。 首先你须要提供一个文件夹,里面是全部你但愿系统认识的人的图片。其中每一个人一张图片,图片以人的名字命名:
接下来,你须要准备另外一个文件夹,里面是你要识别的图片:
而后你就能够运行face_recognition命令了,把刚刚准备的两个文件夹做为参数传入,命令就会返回须要识别的图片中都出现了谁:
$ face_recognition ./pictures_of_people_i_know/ ./unknown_pictures/ /unknown_pictures/unknown.jpg,Barack Obama /face_recognition_test/unknown_pictures/unknown.jpg,unknown_person
输出中,识别到的每张脸都单独占一行,输出格式为<图片名称>,<人名>。 unknown_person 是一个与你的文件夹的已知人图像不匹配的人物。
若是你正在为同一我的得到多个比较,那可能就是这样您的照片中的人看起来很是类似,容差值较低须要使脸部比较更严格。 你能够用--tolerance
参数来作到这一点。默认容差值为0.6,较低的数字使脸部比较更严格:
$ face_recognition --tolerance 0.54 ./pictures_of_people_i_know/ ./unknown_pictures/ /unknown_pictures/unknown.jpg,Barack Obama /face_recognition_test/unknown_pictures/unknown.jpg,unknown_person
若是要按顺序查看每次计算出的面距要调整公差设置,可使用:--show-distancetrue
$ face_recognition --show-distance true ./pictures_of_people_i_know/ ./unknown_pictures/ /unknown_pictures/unknown.jpg,Barack Obama,0.378542298956785 /face_recognition_test/unknown_pictures/unknown.jpg,unknown_person,None
若是你只想知道每张照片中的人的名字,但不要关心文件名,你能够这样作:
$ face_recognition ./pictures_of_people_i_know/ ./unknown_pictures/ | cut -d ',' -f2 Barack Obama unknown_person
若是您有多个CPU内核的电脑,则能够并行完成脸部识别。例如,若是您的系统有4个CPU内核,您能够经过使用在相同的时间量内全部的CPU内核并行处理约4倍的图像。 若是您使用的是Python 3.4或更新版本,请传入参数:--cpus <number_of_cpu_cores_to_use> parameter
:
$ face_recognition --cpus 4 ./pictures_of_people_i_know/ ./unknown_pictures/
您还能够传入使用系统中的全部CPU内核。--cpus-1
你能够经过导入face_recognition模块来使用它,使用方式超级简单,文档在这里API文件:
import face_recognition image = face_recognition.load_image_file("my_picture.jpg") face_locations = face_recognition.face_locations(image) # face_locations is now an array listing the co-ordinates of each face!
看看这个例子本身实践一下,试试看。
你还能够自定义替换人类识别的深度学习模型。
注意:想得到比较好的性能的话,你可能须要GPU加速(使用英伟达的CUDA库)。因此编译的时候你也须要开启dlib的GPU加速选项。
import face_recognition image = face_recognition.load_image_file("my_picture.jpg") face_locations = face_recognition.face_locations(image, model="cnn") # face_locations is now an array listing the co-ordinates of each face!
你也能够经过这个例子实践一下,试试看。
若是你有不少图片和GPU,你也能够并行快速识别,看这篇文章。
import face_recognition image = face_recognition.load_image_file("my_picture.jpg") face_landmarks_list = face_recognition.face_landmarks(image) # face_landmarks_list is now an array with the locations of each facial feature in each face. # face_landmarks_list[0]['left_eye'] would be the location and outline of the first person's left eye.
试试这个例子,试试看。
import face_recognition picture_of_me = face_recognition.load_image_file("me.jpg") my_face_encoding = face_recognition.face_encodings(picture_of_me)[0] # my_face_encoding now contains a universal 'encoding' of my facial features that can be compared to any other picture of a face! unknown_picture = face_recognition.load_image_file("unknown.jpg") unknown_face_encoding = face_recognition.face_encodings(unknown_picture)[0] # Now we can see the two face encodings are of the same person with `compare_faces`! results = face_recognition.compare_faces([my_face_encoding], unknown_face_encoding) if results[0] == True: print("It's a picture of me!") else: print("It's not a picture of me!")
这里是一个例子,试试看。
全部的例子都在这里。
若是你想了解脸部位置和识别如何工做,而不是取决于黑匣子库,请阅读个人文章。
因为face_recognition
取决于使用dlib
C ++编写的内容,将其用于云端托管服务商,如Heroku或AWS 部署应用程序可能很棘手。 为了使事情更容易,这个repo中有一个Dockerfile示例,显示如何在Docker容器中运行一个构建的应用程序face_recognition
。所以,您应该能够部署支持Docker图像的任何服务。
问题:使用face_recognition或运行示例时出现 Illegal instruction(coredumped)
解决方案:dlib
使用SSE4或AVX进行编译,但您的CPU太旧,不支持。 您须要更改dlib
代码后从新编译这里概述代码更改。
问题:运行摄像头示例时出现RuntimeError: Unsupported image type, must be 8bit gray or RGB image.
解决方案:您的网络摄像机可能未正确使用OpenCV设置。在这里寻找更多帮助。 问题:运行pip2 install face_recognition
时出现MemoryError
解决方案:face_recognition_models文件对于可用的缓存内存来讲太大了。尝试使用如下方法pip2 --no-cache-dir install face_recognition
来尽可能避免这个问题。
问题:AttributeError: 'module' object has no attribute 'face_recognition_model_v1'
解决方案:dlib
您安装的版本太旧了。您须要19.7或更新版本。升级dlib
。
问题:AttributeError: 'Module' object has no attribute 'cnn_face_detection_model_v1'
解决方案:dlib
您安装的版本太旧了。您须要19.7或更新版本。升级dlib
。
问题:TypeError: imread() got an unexpected keyword argument 'mode'
解决方案:scipy
您安装的版本太旧了。您须要版本0.17或更新版本。升级scipy
。