用python、opencv快速实现人脸检测

Prerequisites:

python2.7、openCV3.0

代码及注释

def detectface(filename):
    files = []
    print('Using face detector %s' % FLAGS.face_detection_model)
    face_detect = FaceDetector('haarcascade_frontalface_default.xml')
    face_files, rectangles = face_detect.run(filename)
    files += face_files
    if (len(files)>0) :
        return 1
    else:
        return 0

主要是FaceDetector类的run函数实现了人脸检测,run函数会返回人脸的文件、以及矩形区域
我们把FaceDetector类的实现代码贴出来

class FaceDetector(object):

    def __init__(self, model_name, basename = 'frontal-face', tgtdir = '.'):
        self.tgtdir = tgtdir
        self.basename = basename
        self.face_cascade = cv2.CascadeClassifier(model_name)

    def run(self, image_file, min_height_dec = 20, min_width_dec = 20, min_height_thresh=50, min_width_thresh=50):
        print(image_file)
        img = cv2.imread(image_file)
        min_h = int(max(img.shape[0] / min_height_dec, min_height_thresh))
        min_w = int(max(img.shape[1] / min_width_dec, min_width_thresh))
        gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        faces = self.face_cascade.detectMultiScale(gray, 1.3, minNeighbors=5, minSize=(min_h,min_w))

        images = []
        for i, (x,y,w,h) in enumerate(faces):
            images.append(self.sub_image('%s/%s-%d.jpg' % (self.tgtdir, self.basename, i+1), img, x, y, w, h))

        print('%d faces detected' % len(images))

        for (x,y,w,h) in faces:
            self.draw_rect(img, x, y, w, h)
            # Fix in case nothing found in the image
        outfile = '%s/%s.jpg' % (self.tgtdir, self.basename)
        cv2.imwrite(outfile, img)

        return images, outfile

    def sub_image(self, name, img, x, y, w, h):
        upper_cut = [min(img.shape[0], y+h+FACE_PAD), min(img.shape[1], x+w+FACE_PAD)]
        lower_cut = [max(y-FACE_PAD, 0), max(x-FACE_PAD, 0)]
        roi_color = img[lower_cut[0]:upper_cut[0], lower_cut[1]:upper_cut[1]]
        cv2.imwrite(name, roi_color)
        return name

    def draw_rect(self, img, x, y, w, h):
        upper_cut = [min(img.shape[0], y+h+FACE_PAD), min(img.shape[1], x+w+FACE_PAD)]
        lower_cut = [max(y-FACE_PAD, 0), max(x-FACE_PAD, 0)]
        cv2.rectangle(img, (lower_cut[1],lower_cut[0]),(upper_cut[1],upper_cut[0]), (255,0,0), 2)

FaceDetector类有init初始化函数来初始化显式变量,是可变长参数
我们第一段代码中只是传了模型参数

more haarcascade_frontalface_default.xml 

打开模型配置文件,发现是一堆xml配置参数

  <stages>
    <_>
      <maxWeakCount>9</maxWeakCount>
      <stageThreshold>-5.0425500869750977e+00</stageThreshold>
      <weakClassifiers>
        <_>
          <internalNodes>
            0 -1 0 -3.1511999666690826e-02</internalNodes>
          <leafValues>
            2.0875380039215088e+00 -2.2172100543975830e+00</leafValues></_>
        <_>
          <internalNodes>
            0 -1 1 1.2396000325679779e-02</internalNodes>
          <leafValues>
            -1.8633940219879150e+00 1.3272049427032471e+00</leafValues></_>
        <_>
          <internalNodes>
            0 -1 2 2.1927999332547188e-02</internalNodes>
          <leafValues>
            -1.5105249881744385e+00 1.0625729560852051e+00</leafValues></_>
        <_>
          <internalNodes>
            0 -1 3 5.7529998011887074e-03</internalNodes>
          <leafValues>
            -8.7463897466659546e-01 1.1760339736938477e+00</leafValues></_>
        <_>
          <internalNodes>
            0 -1 4 1.5014000236988068e-02</internalNodes>
          <leafValues>
            -7.7945697307586670e-01 1.2608419656753540e+00</leafValues></_>
        <_>
          <internalNodes>

这是从openCV源码那边拷贝过来的,是别人训练好的haar分类器模型,可以看到起到主要作用的函数是
detectMultiScale
人脸检测主要用到的是CascadeClassifier这个类,以及该类下的detectMultiScale函数。

函数原型是:

void CascadeClassifier::detectMultiScale(InputArray image, vector<Rect>& objects, double scaleFactor=1.1, int minNeighbors=3, int flags=0, Size minSize=Size(), Size maxSize=Size())

总共有7个参数,分别是

第一个参数image: 要检测的图片,一般为灰度图

第二个参数objects: Rect型的容器,存放所有检测出的人脸,每个人脸是一个矩形

第三个参数scaleFactor: 缩放因子,对图片进行缩放,默认为1.1

第四个参数minNeighbors: 最小邻居数,默认为3

第五个参数flags: 兼容老版本的一个参数,在3.0版本中没用处。默认为0

第六个参数minSize: 最小尺寸,检测出的人脸最小尺寸

第七个参数maxSize: 最大尺寸,检测出的人脸最大尺寸

这里关注第六和第七个参数,由之前的代码看出

        min_h = int(max(img.shape[0] / min_height_dec, min_height_thresh))
        min_w = int(max(img.shape[1] / min_width_dec, min_width_thresh))

img.shape[0]和img.shape[1]分别是图片的高、宽,然后除以20的整数,和预设的min_height_thresh、min_width_thresh作比较后,取最大值的整数。
也就是理论上说可以最小检测到图片1/20的人脸
可以看到这里没有传递最大的值。

具体的参数配置可参考这篇csdn博友的文章http://blog.csdn.net/delltdk/article/details/9186875
(待续)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,关于Python OpenCV实例化人脸检测,可以通过以下步骤进行: 1. 安装OpenCV库 在命令行输入以下命令来安装OpenCV库: ``` pip install opencv-python ``` 2. 加载人脸检测器 在Python中,可以使用OpenCV提供的Haar级联分类器来检测人脸。您可以通过以下代码加载人脸检测器: ``` import cv2 face_cascade = cv2.CascadeClassifier('path/to/haarcascade_frontalface_default.xml') ``` 请将“path/to”替换为您下载的“haarcascade_frontalface_default.xml”的路径。 3. 加载图像并进行人脸检测Python中,您可以使用OpenCV中的“cv2.imread”函数来加载图像。使用以下代码来检测图像中的人脸: ``` img = cv2.imread('path/to/image.jpg') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5) ``` 请将“path/to”替换为您图像的路径。此代码将加载图像并将其转换为灰度图像。然后,它将使用“detectMultiScale”函数在图像中检测人脸。参数“scaleFactor”和“minNeighbors”可用于调整检测器的灵敏度和准确性。 4. 在图像中绘制人脸边界框 您可以使用以下代码在图像中绘制人脸边界框: ``` for (x, y, w, h) in faces: cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2) cv2.imshow('img', img) cv2.waitKey() ``` 这将在图像中绘制矩形框以显示检测到的人脸。然后,它将使用“imshow”函数显示图像,并等待用户按下任意键关闭窗口。 希望这可以帮助您实例化人脸检测。 ### 回答2: PythonOpenCV库是一个很强大的图像处理库,可以用来进行人脸检测。所谓实例化人脸检测,就是创建一个人脸检测器的实例,用于在图像或视频中检测人脸。 要使用PythonOpenCV库实例化人脸检测,首先需要安装OpenCV库及其相关依赖。接下来,我们可以使用以下代码进行人脸检测的实例化: ```python import cv2 # 加载人脸检测器数据 face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') # 加载图像,灰度化 image = cv2.imread('image.jpg') gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 在灰度图像中进行人脸检测 faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30)) # 遍历检测到的人脸 for (x, y, w, h) in faces: # 绘制矩形框在检测到的人脸周围 cv2.rectangle(image, (x, y), (x+w, y+h), (0, 255, 0), 3) # 展示检测结果 cv2.imshow('Faces Detected', image) cv2.waitKey(0) cv2.destroyAllWindows() ``` 上述代码中,首先我们加载了一个人脸检测器数据,该数据在OpenCV的安装目录下的`data`文件夹中可以找到。然后,加载了一张图像并将其转为灰度图像。接着,使用`detectMultiScale`函数在灰度图像中进行人脸检测,返回的是检测到的人脸的坐标和大小。最后,我们在原图像上绘制了矩形框标识出检测到的人脸,并展示了检测结果。 通过这种方法,我们可以很方便地实例化人脸检测,对图像或视频中的人脸进行实时监测和分析。 ### 回答3: Python中使用OpenCV进行人脸检测的示例代码如下: ```python import cv2 # 加载人脸检测face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') # 加载图像 img = cv2.imread('image.jpg') # 将图像转换为灰度图 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 进行人脸检测 faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30)) # 在检测到的人脸周围绘制矩形框 for (x, y, w, h) in faces: cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2) # 显示结果 cv2.imshow('Face Detection', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 首先,需要加载人脸检测器。这里使用了一个预训练的级联分类器文件 `haarcascade_frontalface_default.xml`,它包含描述人脸特征的模型。 然后,加载待检测的图像。可以使用 `cv2.imread()` 函数加载图像文件。 接着,将彩色图像转换为灰度图像,因为人脸检测通常在灰度图像上进行。 接下来,使用 `detectMultiScale()` 函数进行人脸检测。该函数将返回在图像中检测到的人脸的位置坐标。 最后,使用 `cv2.rectangle()` 函数在检测到的人脸周围绘制矩形框。对于每个检测到的人脸,使用该函数确定其左上角和右下角坐标,并指定矩形框的颜色和线宽度。 最后,使用 `cv2.imshow()` 函数显示绘制了矩形框的图像,并使用 `cv2.waitKey()` 和 `cv2.destroyAllWindows()` 函数等待用户按下任意键关闭窗口。 这就是使用PythonOpenCV实例化人脸检测的基本步骤。将以上代码保存为.py文件并运行,即可实现人脸检测功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值