【OpenCV】92 对象检测—HAAR特征介绍

92 对象检测—HAAR特征介绍

代码

import cv2 as cv

capture = cv.VideoCapture('../images/sample.mp4')
face_detector = cv.CascadeClassifier(cv.data.haarcascades + "haarcascade_frontalface_alt.xml")
smile_detector = cv.CascadeClassifier(cv.data.haarcascades + "haarcascade_smile.xml")
while True:
    ret, image = capture.read()
    if ret is True:
        cv.imshow("frame", image)
        faces = face_detector.detectMultiScale(image, scaleFactor=1.05, minNeighbors=3,
                                          minSize=(30, 30), maxSize=(300, 300))
        for x, y, width, height in faces:
            cv.rectangle(image, (x, y), (x+width, y+height), (0, 0, 255), 2, cv.LINE_8, 0)
        roi = image[y:y+height,x:x+width]
        smiles = smile_detector.detectMultiScale(roi, scaleFactor=1.7, minNeighbors=3,
                                               minSize=(15, 15), maxSize=(100, 100))
        for sx, sy, sw, sh in smiles:
            cv.rectangle(roi, (sx, sy), (sx + sw, sy + sh), (0, 255, 0), 1)

        cv.imshow("faces", image)
        c = cv.waitKey(50)
        if c == 27:
            break
    else:
        break

cv.destroyAllWindows()

实验结果

在这里插入图片描述

解释

HAAR小波基函数,因为其满足对称性,对人脸这种生物对称性良好的对象特别适合用来做检测器,常见的Haar特征分为三类:
边缘特征、
线性特征、
中心特征和对角线特征,
不同特征可以进行多种组合,生成更加复杂的级联特征,特征模板内有白色和黑色两种矩形,并定义该模板的特征值为白色矩形像素和减去黑色矩形像素和,Haar特征值反映了图像的对比度与梯度变化。
OpenCV中HAAR特征计算是积分图技术,这个我们在前面也分享过啦,所以可以非常快速高效的开窗检测, HAAR级联检测器具备有如下特性:

  • 高类间变异性
  • 低类内变异性
  • 局部强度差
  • 不同尺度
  • 计算效率高

所有内容均来源于贾志刚老师的知识星球——OpenCV研习社,本文为个人整理学习,已获得贾老师授权,有兴趣、有能力的可以加入贾老师的知识星球进行深入学习。
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCV,Haar特征分类器和级联分类器是实现人脸检测的关键。下面是它们的实现过程: 1. Haar特征分类器的实现过程: Haar特征是一种可以用于对象检测特征,它可以用来检测出图像的各种形状,如边缘、线段、矩形等。在人脸检测,我们需要用到的是Haar-like特征,它是由一些不同形状的矩形区域组成的,每个矩形区域的像素值之和作为该区域的特征值。 具体实现过程是:首先,将人脸和非人脸的样本集进行训练,从而得到一个弱分类器。然后,将得到的弱分类器组合成多个级联分类器。在每一级分类器,都有多个Haar-like特征,这些特征用来对图像进行分类。最终,将级联分类器应用于图像,通过多次扫描和分类,可以得到图像所有的人脸区域。 2. 级联分类器的实现过程: 级联分类器是一种多级分类器,每一级都有自己的分类器,用来对输入图像进行分类。在人脸检测,级联分类器通常由多个弱分类器组成,每个弱分类器都是由多个Haar特征组合而成的。在每一级分类器,都有一个阈值,如果当前区域的特征值大于该阈值,就会被认为是人脸区域,否则就会被排除。级联分类器可以通过不断的训练来提高检测的准确率。 具体实现过程是:首先,选择一些正样本和负样本,用来训练级联分类器。然后,根据正样本和负样本集,得到第一个弱分类器,该分类器的阈值是根据样本集特征值计算得到的。接着,将得到的弱分类器应用于测试图像,如果当前区域符合人脸的特征,就会被认为是人脸区域,否则就会被排除。最后,根据每个区域的分类结果,得到下一个弱分类器的训练集,然后重复上述过程,直到得到多个弱分类器组成的级联分类器。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值