人脸检测? 对Python来说太简单, 调用dlib包就可以完成

“Dlib 是一个现代化的 C ++ 工具包,包含用于创建复杂软件的机器学习算法和工具 ” 。它使您能够直接在 Python 中运行许多任务,其中一个例子就是人脸检测。

安装 dlib 并不像只做一个 “pip install dlib” 那么简单,因为要正确配置和编译 dlib ,您首先需要安装其他系统依赖项。如果你按照这里描述的步骤,它应该很容易让 dlib 启动并运行。(在本文中,我将介绍如何在 Mac 上安装 dlib ,但如果您使用的是 Ubuntu ,请务必查看相关资源部分的链接。)

你需要确定的第一件事是你已经安装和更新了 Hombrew 。如果您需要安装它,请将其粘贴到终端中:

1.      $ /usr/bin/ruby -e  "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

或者,如果您需要更新 Hombrew ,请输入以下内容:

1.      $ brew  update 

您现在可以使用 Homebrew 来安装 CMake , Boost.Python ,以及在您的系统中正确配置和编译 dlib 所需的两个依赖关系:

1.      $ brew install cmake

2.      $ brew install boost-python

最后,您需要手动下载并安装 XQuartz 。

您现在已准备好安装 dlib 。我们将通过首先为这个项目创建一个孤立的虚拟环境来做到这一点。我将使用 virtualenv ,但您可以使用任何您熟悉的虚拟环境工具,包括 Python 的 venv 模块。需要 scikit-image 库才能读取我们稍后将传递给 dlib 的图像文件,因此我们还需要 pip 安装它:

1.      $ virtualenv venv_dlib

2.      $ source venv_dlib / bin / activate

3.      $ pip install scikit-image

4.      $ pip install dlib

就是这样。有了这个,你应该有可用的 dlib 。

Dlib

Dlib 提供了不同的脸部检测算法。我将在这里使用的是基于 CNN 的人脸检测器。您可以下载预训练模型: https : //github.com/davisking/dlib-models 。由于使用此模型的计算成本很高,因此最好在 GPU 上执行以下代码。使用 CPU 也可以,但速度会更慢。

要在下面的要点中运行人脸检测代码,我建议首先在虚拟环境中再安装两个库。这些库将使与代码交互和可视化结果更容易:

1.      $ pip install matplotlib

2.      $ pip install jupyterlab

安装完库后,您需要确保:

·              下载预训练模型( http://dlib.net/files/mmod_human_face_detector.dat.bz2 )并将其存储在项目的根目录中

·              创建一个名为 ‘faces‘ 的新目录,在该目录中存储带有希望检测的脸部的 .jpg 。

有了这个,你终于准备好开始在图片中检测脸部了!您可以通过在 Jupyter Notebook 中运行以下代码来完成此操作

1.      import dlib

2.          import matplotlib.patches  as  patches

3.          import matplotlib.pyplot  as  plt

4.           from  pathlib import Path

5.           from  skimage import io

6.          %matplotlib inline

7.          #  Load  trained model

8.          cnn_face_detector = dlib.cnn_face_detection_model_v1(

9.           ‘mmod_human_face_detector.dat‘ )

10.        #  Function   to  detect  and  show faces  in  images

11.        def detect_face_dlib(img_path, ax):

12.        #  Read  image  and  run algorithm

13.        img = io.imread(img_path)

14.        dets = cnn_face_detector(img, 1)

15.        # If there were faces detected, show them

16.        if len(dets) > 0:

17.         for  d  in  dets:

18.        rect = patches.Rectangle(

19.        (d.rect. left (), d.rect. top ()),

20.        d.rect.width(),

21.        d.rect.height(),

22.        fill= False ,

23.        color= ‘b‘ ,

24.        lw= ‘2‘ )

25.        ax.add_patch(rect)

26.        ax.imshow(img)

27.        ax.set_title(str(img_path).split( ‘/‘ )[-1])

28.        # Path  to  images

29.        images = list(Path( ‘faces‘ ).glob( ‘*.jpg‘ ))

30.        # Show results

31.        fig = plt.figure(figsize=(15, 5))

32.         for  i, img  in  enumerate(images):

33.        ax = fig.add_subplot(1, len(images), i+1)

34.        detect_face_dlib(img, ax)

结果

在运行代码之后,您应该看到图像中的脸部周围出现蓝色方块,如果您问我,考虑到我们只写了几行代码,这非常棒!

python学习交流群:125240963

原文链接:http://www.linuxmysql.com/23/2018/829.htm?utm_source=tuicool&utm_medium=referral

原文地址:https://www.cnblogs.com/pythonedu/p/9014950.html

时间: 2024-10-06 09:05:14

人脸检测? 对Python来说太简单, 调用dlib包就可以完成的相关文章

OpenCV人脸检测(C++代码)

OpenCV人脸检测(C++代码)-- By wepon 这篇文章简单总结一下人脸检测的代码实现,基于OpenCV,C++版本.之所以强调C++版本是因为OpenCV有很多其他语言的接口,之前我也写过人脸检测的Python实现<Python-OpenCV人脸检测(代码)>,这篇文章则讲C++实现,其实大同小异,C++相比于Python实现代码写起来会繁琐一点,这也是语言本身决定的吧. 为了保持代码风格一致,C++实现与之前的Python实现一样,都将人脸检测.眼睛检测.框出人脸.框出眼睛.截取

图片人脸检测——Dlib版(四)

上几篇给大家讲了OpenCV的图片人脸检测,而本文给大家带来的是比OpenCV更加精准的图片人脸检测Dlib库. 点击查看往期: <图片人脸检测——OpenCV版(二)> <视频人脸检测——OpenCV版(三)> dlib与OpenCV对比 识别精准度:Dlib >= OpenCV Dlib更多的人脸识别模型,可以检测脸部68甚至更多的特征点 效果展示 人脸的68个特征点 安装dlib 下载地址:https://pypi.org/simple/dlib/ 选择适合你的版本,本

人脸检测及识别python实现系列(4)——卷积神经网络(CNN)入门

人脸检测及识别python实现系列(4)--卷积神经网络(CNN)入门 上篇博文我们准备好了2000张训练数据,接下来的几节我们将详细讲述如何利用这些数据训练我们的识别模型.前面说过,原博文给出的训练程序使用的是keras库,对我的机器来说就是tensorflow版的keras.训练程序建立了一个包含4个卷积层的神经网络(CNN),程序利用这个网络训练我的人脸识别模型,并将最终训练结果保存到硬盘上.在我们实际动手操练之前我们必须先弄明白一个问题--什么是卷积神经网络(CNN)? CNN(Conv

人脸检测及识别python实现系列(2)——识别出人脸

人脸检测及识别python实现系列(2)--识别出人脸 从实时视频流中识别出人脸区域,从原理上看,其依然属于机器学习的领域之一,本质上与谷歌利用深度学习识别出猫没有什么区别.程序通过大量的人脸图片数据进行训练,利用数学算法建立建立可靠的人脸特征模型,如此即可识别出人脸.幸运的是,这些工作OpenCV已经帮我们做了,我们只需调用对应的API函数即可,先给出代码: #-*- coding: utf-8 -*- import cv2 import sys from PIL import Image d

基于python+opencv的人脸检测+

人脸检测分为两种:一种是基于知识的,一种是基于深度学习的.深度不会学习 人脸识别属于目标检测,主要涉及两个方面: ①先对检测的物体进行概率统计,从而知道待检测对象的一些特征,建立其目标的检测模型 ②用得到的模型来匹配输入的图像,如果有匹配则则输出匹配的区域,否则什么也不做. 我们看到的图片和计算机不一样,计算机看到的是一串串数字矩阵,图片由多个像素组成,拿我们熟悉的RGB图像来说,每个像素又有红绿蓝三个通道,假如每个像素的单个通道由uint8类型字符组成,那么三通道的像素便会有24位,这是我们常

python 人脸检测 +python 二维码检测

从官网下载opencv 目录结构如图 在samples中有丰富的示例 应为我的系统中已经安装好opepncv-python,可直接运行 会得到结果: 人脸检测代码如下 #!/usr/bin/env python ''' face detection using haar cascades USAGE: facedetect.py [--cascade <cascade_fn>] [--nested-cascade <cascade_fn>] [<video_source>

OpenCV实践之路——人脸检测(C++/Python) 【转】

转自:http://blog.csdn.net/xingchenbingbuyu/article/details/51105159 版权声明:本文为博主原创文章,转载请联系作者取得授权. 本文由@星沉阁冰不语出品,转载请注明作者和出处. 文章链接:http://blog.csdn.net/xingchenbingbuyu/article/details/51105159 微博:http://weibo.com/xingchenbing  之前一直觉得人脸检测是非常麻烦的,即使是用OpenCV,麻

OpenCV实践之路——人脸检测(C++/Python)

之前一直觉得人脸检测是非常麻烦的,即使是用opencv,麻烦到我都不敢去碰.这两天仔细看了下,如果只是调用opencv自带的分类器和函数的话,简直是简单.这不,正好最近也在学习Python,索性就用C++和Python两种语言都实现一下.当然,我现在这个是最简单的版本. 步骤: 调用opencv训练好的分类器和自带的检测函数检测人脸人眼等的步骤简单直接: 1.加载分类器,当然分类器事先要放在工程目录中去.分类器本来的位置是在*\opencv\sources\data\haarcascades(h

人脸检测真的不难,50行Python代码就能实现人脸检测

Python现在非常火,语法简单而且功能强大,很多同学都想学Python!所以小的给各位看官们准备了高价值Python学习视频教程,都放在了文章结尾,欢迎前来领取! *注意:全文代码可以滑动查看 现在的人脸识别技术已经得到了非常广泛的应用,支付领域.身份验证.美颜相机里都有它的应用.用iPhone的同学们应该对下面的功能比较熟悉. iPhone的照片中有一个"人物"的功能,能够将照片里的人脸识别出来并分类,背后的原理也是人脸识别技术. 这篇文章主要介绍怎样用Python实现人脸检测.人