函数detectMultiScale

Posted c&z

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数detectMultiScale相关的知识,希望对你有一定的参考价值。

功能:检测图片中所有的人脸,并用vector保存每个人脸的坐标,大小(由矩形表示)

函数原型:void detectMultiScale(  

     const Mat& image,   

    CV_OUT vector<Rect>& objects,   

    double scaleFactor = 1.1,

    int minNeighbors = 3,   

    int flags = 0,  

    Size minSize = Size(), 

    Size maxSize = Size() );  

image:待检测图片,一般为灰度图像,加快检测速度

objects:被检测物体的矩形框向量组

scaleFactor:表示在前后两次相继的扫描中,搜索窗口的比例系数。默认为1.1即每次搜索窗口依次扩大10%

minNeighbors:表示构成检测目标的相邻矩形的最小个数(默认为3个)。
              如果组成检测目标的小矩形的个数和小于 min_neighbors - 1 都会被排除。
              如果min_neighbors 为 0, 则函数不做任何操作就返回所有的被检候选矩形框,
              这种设定值一般用在用户自定义对检测结果的组合程序上

flags:要么使用默认值,要么使用CV_HAAR_DO_CANNY_PRUNING,如果设置为

          CV_HAAR_DO_CANNY_PRUNING,那么函数将会使用Canny边缘检测来排除边缘过多或过少的区域,

          因此这些区域通常不会是人脸所在区域

minSize和maxSize用来限制得到的目标区域的范围

以上是关于函数detectMultiScale的主要内容,如果未能解决你的问题,请参考以下文章

OpenCV人脸识别--detectMultiScale函数

detectMultiScale 读取冲突的一个解决方法

opencv detectMultiScale()

Cuda CascadeClassifier detectMultiScale 输出不可读

opencv:foundWeights 在虚拟 void detectMultiScale(..) 中是啥意思

OpenCV中detectMultiScale的参数使用Python