91午夜免费视频-91午夜视频-91午夜影院-91系列在线-91线上观看-91香蕉视频在线

你的位置:首頁 > 信息資訊 > 行業新聞

OpenCV是如何實現人臉檢測的?

來源: 2020/5/7 22:46:56??????點擊:

OpenCV中有檢測人臉的函數(該函數還可以檢測一些其他物體), 甚至還包含一些預先訓練好的物體識別文件。

所以利用這些現成的東西就可以很快做出一個人臉檢測的程序。

主要步驟為:

1.加載分類器。

用cvLoad函數讀入xml格式的文件。文件在OpenCV安裝目錄下的“data/haarcascades/”路徑下。

2.讀入待檢測圖像。讀入圖片或者視頻。

3.檢測人臉。

#include "cv.h" 

#include "highgui.h"


#include <stdio.h> 

#include <stdlib.h> 

#include <string.h> 

#include <assert.h> 

#include <math.h> 

#include <float.h> 

#include <limits.h> 

#include <time.h> 

#include <ctype.h>


#ifdef _EiC 

#define WIN32 

#endif


static CvMemStorage* storage = 0; 

static CvHaarClassifierCascade* cascade = 0;


void detect_and_draw( IplImage* image );


const char* cascade_name = 

"haarcascade_frontalface_alt.xml"; 

/*    "haarcascade_profileface.xml";*/


int main( int argc, char** argv ) 

    cascade_name = "haarcascade_frontalface_alt2.xml"; 

    cascade = (CvHaarClassifierCascade*)cvLoad( cascade_name, 0, 0, 0 ); 

  

    if( !cascade ) 

    { 

        fprintf( stderr, "ERROR: Could not load classifier cascade\n" ); 

        return -1; 

    } 

    storage = cvCreateMemStorage(0); 

    cvNamedWindow( "result", 1 ); 

     

    const char* filename = "Lena.jpg"; 

    IplImage* image = cvLoadImage( filename, 1 );


    if( image ) 

    { 

        detect_and_draw( image ); 

        cvWaitKey(0); 

        cvReleaseImage( &image );   

    }


    cvDestroyWindow("result"); 

  

    return 0; 

}



void detect_and_draw(IplImage* img ) 

    double scale=1.2; 

    static CvScalar colors[] = { 

        {{0,0,255}},{{0,128,255}},{{0,255,255}},{{0,255,0}}, 

        {{255,128,0}},{{255,255,0}},{{255,0,0}},{{255,0,255}} 

    };//Just some pretty colors to draw with


    //Image Preparation 

    // 

    IplImage* gray = cvCreateImage(cvSize(img->width,img->height),8,1); 

    IplImage* small_img=cvCreateImage(cvSize(cvRound(img->width/scale),cvRound(img->height/scale)),8,1); 

    cvCvtColor(img,gray, CV_BGR2GRAY); 

    cvResize(gray, small_img, CV_INTER_LINEAR);


    cvEqualizeHist(small_img,small_img); //直方圖均衡


    //Detect objects if any 

    // 

    cvClearMemStorage(storage); 

    double t = (double)cvGetTickCount(); 

    CvSeq* objects = cvHaarDetectObjects(small_img, 

                                                                        cascade, 

                                                                        storage, 

                                                                        1.1, 

                                                                        2, 

                                                                        0/*CV_HAAR_DO_CANNY_PRUNING*/, 

                                                                        cvSize(30,30));


    t = (double)cvGetTickCount() - t; 

    printf( "detection time = %gms\n", t/((double)cvGetTickFrequency()*1000.) );


    //Loop through found objects and draw boxes around them 

    for(int i=0;i<(objects? objects->total:0);++i) 

    { 

        CvRect* r=(CvRect*)cvGetSeqElem(objects,i); 

        cvRectangle(img, cvPoint(r->x*scale,r->y*scale), cvPoint((r->x+r->width)*scale,(r->y+r->height)*scale), colors[i%8]); 

    } 

    for( int i = 0; i < (objects? objects->total : 0); i++ ) 

    { 

        CvRect* r = (CvRect*)cvGetSeqElem( objects, i ); 

        CvPoint center; 

        int radius; 

        center.x = cvRound((r->x + r->width*0.5)*scale); 

        center.y = cvRound((r->y + r->height*0.5)*scale); 

        radius = cvRound((r->width + r->height)*0.25*scale); 

        cvCircle( img, center, radius, colors[i%8], 3, 8, 0 ); 

    }


    cvShowImage( "result", img ); 

    cvReleaseImage(&gray); 

    cvReleaseImage(&small_img); 

}

 流程說明:


       原始待檢測圖像經過resize,生成不同尺寸的圖像構建圖像金字塔作為網絡的輸入。


構建的圖像金字塔,其層數由兩個因素決定,第一個是設置的最小人臉minSize,第二個是縮放因子factor,最小人臉表示min(w,h),論文中說明最小人臉不能小于12,給出的縮放因子0.709可以根據公式計算圖像金字塔的層數


minL=org_L*(12/minsize)*factor^(n),n={0,1,2,3,...,N}


其中n就是金字塔的層數,org_L是輸入原始圖像的最小邊min(W,H),minisize是人為根據應用場景設定,在保證minL大于12的情況下,所有的n就構成金字塔的層。所以minsize的值越小,n的取值范圍就越大,計算量就相應地增加,能夠檢測到的人臉越小




主站蜘蛛池模板: 久久久久国产a免费观看rela | 九九视频精品在线 | 天天亚洲综合 | 亚洲影院色 | 久草久视频 | 亚洲国产精品一区二区久久,亚洲午夜 | 97色婷婷成人综合在线观看 | 色午夜 | 亚洲国产免费看 | 日日久视频 | 色中文字幕在线观看 | 狠狠亚洲 | 五月天六月丁香 | 午夜视频欧美 | 91桃色免费视频 | 久久久久久久久久久网站 | 国产精品国产三级国产aⅴ入口 | 在线观看免费av网站 | 国产丝袜一区二区三区 | 色国产精品 | av黄在线播放 | 91成人免费观看视频 | 伊人狠狠操 | 亚洲视频免费 | 亚洲精品成人 | 亚洲毛片一区二区三区 | 四虎海外影库www4hu | 欧美午夜理伦三级在线观看 | 国产精品久久 | 中文av日韩| 久久久精品 一区二区三区 国产99视频在线观看 | 黄色小说免费在线观看 | av大片网址 | 青青河边草免费直播 | 免费看毛片在线 | 6080yy午夜一二三区久久 | 色www免费视频 | 成人午夜免费福利 | 日韩午夜在线 | 欧美另类性 | 亚洲视频精品 | 国产成人一区二区三区影院在线 | 国产精品久久电影网 | 在线v片免费观看视频 | 视频在线观看一区 | 国产在线观看不卡 | 在线 精品 国产 | 国产中文在线观看 | 九九九热精品免费视频观看 | 成人免费观看视频大全 | 91日本在线播放 | av电影在线免费 | 亚洲国产激情 | 久久精品国产一区二区 | 色99久久| 99在线观看视频网站 | 午夜av剧场 | 日韩三级免费观看 | 亚洲婷婷伊人 | 国产玖玖精品视频 | 蜜臀久久99精品久久久无需会员 | 亚洲精品9 | 欧美 日韩 成人 | 丁香五月亚洲综合在线 | 美女网色| 国产色妞影院wwwxxx | 正在播放国产91 | 毛片网站免费在线观看 | 精品福利在线视频 | 亚洲深夜影院 | 欧美日韩在线观看视频 | 五月天中文字幕mv在线 | 久久深爱网 | 在线观看国产麻豆 | 日日日日 | 美女激情影院 | 成人黄色小说在线观看 | 天堂久久电影网 | 美女在线免费观看视频 | 天天操天天草 | av在线色| 99久久婷婷国产 | 国产精品成久久久久三级 | 国产 在线 高清 精品 | 欧美精品乱码久久久久久 | 欧美色道 | 97夜夜澡人人双人人人喊 | 久久少妇免费视频 | 视频一区二区在线 | 久久9999久久免费精品国产 | 国产一区二区三区免费视频 | 操操操av | 中文字幕有码在线播放 | 97在线免费视频观看 | 少妇性aaaaaaaaa视频 | 婷婷综合网 | 色综合久久88色综合天天 | 欧美视频日韩视频 | 婷婷综合久久 |