失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > OpenCV学习:找出人脸 同时比较两张图片中的人脸相似度

OpenCV学习:找出人脸 同时比较两张图片中的人脸相似度

时间:2018-12-18 05:40:20

相关推荐

OpenCV学习:找出人脸 同时比较两张图片中的人脸相似度

终于到了有实际应用的功能了,有2张图片,里面各有一个人脸,我的目的是比较这两个人脸的相似度,这里用到了facedetect的功能,还有图像转换,图像剪切,以及直方图的比较。具体流程是:

1。分别用facedetect功能将两张图片中的人脸检测出来

2。将人脸部分的图片剪切出来,存到两张只有人脸的图片里。

3。将这两张人脸图片转换成单通道的图像

4。使用直方图比较这两张单通道的人脸图像,得出相似度。

这里对图的要求还是比较高的,光线和姿势不能有差别,脸的垂直或者左右角度偏差就会影响比较,但和两张图片的大小关系不大,本人觉得较适合于证件照的对比。

下面是代码,其中haarcascade_frontalface_alt.xml是opencv里facedetect例子用的样本。 比较的是srcImage和targetImage对应的文件.

还有下面是IplImage和Mat混用,纯当熟悉这两个类了。

[cpp]view plaincopy

</pre><div class="dp-highlighter bg_cpp"><div class="bar"><div class="tools"><strong>[cpp]</strong> <a target=_blank title="view plain" class="ViewSource" href="/nicebooks/article/details/8175002#">view plain</a><a target=_blank title="copy" class="CopyToClipboard" href="/nicebooks/article/details/8175002#">copy</a><a target=_blank title="print" class="PrintSource" href="/nicebooks/article/details/8175002#">print</a><a target=_blank title="?" class="About" href="/nicebooks/article/details/8175002#">?</a></div></div><ol class="dp-cpp"><li class="alt"><span><span></span></span></li></ol></div><pre class="cpp" style="display: none;" name="code">

[cpp]view plaincopy

#include"opencv/cv.hpp"#include"opencv2/objdetect/objdetect.hpp"#include"opencv2/highgui/highgui.hpp"#include"opencv2/imgproc/imgproc.hpp"#include<iostream>#include<stdio.h>usingnamespacestd;usingnamespacecv;StringcascadeName="D:\\OpenCV-2.4.2\\data\\haarcascades\\haarcascade_frontalface_alt.xml";IplImage*cutImage(IplImage*src,CvRectrect){cvSetImageROI(src,rect);IplImage*dst=cvCreateImage(cvSize(rect.width,rect.height),src->depth,src->nChannels);cvCopy(src,dst,0);cvResetImageROI(src);returndst;}IplImage*detect(Mat&img,CascadeClassifier&cascade,doublescale){inti=0;doublet=0;vector<Rect>faces;Matgray,smallImg(cvRound(img.rows/scale),cvRound(img.cols/scale),CV_8UC1);cvtColor(img,gray,CV_BGR2GRAY);resize(gray,smallImg,smallImg.size(),0,0,INTER_LINEAR);equalizeHist(smallImg,smallImg);t=(double)cvGetTickCount();cascade.detectMultiScale(smallImg,faces,1.3,2,CV_HAAR_SCALE_IMAGE,Size(30,30));t=(double)cvGetTickCount()-t;printf("detectiontime=%gms\n",t/((double)cvGetTickFrequency()*1000.));for(vector<Rect>::const_iteratorr=faces.begin();r!=faces.end();r++,i++){IplImage*temp=cutImage(&(IplImage(img)),cvRect(r->x,r->y,r->width,r->height));returntemp;}returnNULL;}//画直方图用intHistogramBins=256;floatHistogramRange1[2]={0,255};float*HistogramRange[1]={&HistogramRange1[0]};intCompareHist(IplImage*image1,IplImage*image2){IplImage*srcImage;IplImage*targetImage;if(image1->nChannels!=1){srcImage=cvCreateImage(cvSize(image1->width,image1->height),image1->depth,1);cvCvtColor(image1,srcImage,CV_BGR2GRAY);}else{srcImage=image1;}if(image2->nChannels!=1){targetImage=cvCreateImage(cvSize(image2->width,image2->height),srcImage->depth,1);cvCvtColor(image2,targetImage,CV_BGR2GRAY);}else{targetImage=image2;}CvHistogram*Histogram1=cvCreateHist(1,&HistogramBins,CV_HIST_ARRAY,HistogramRange);CvHistogram*Histogram2=cvCreateHist(1,&HistogramBins,CV_HIST_ARRAY,HistogramRange);cvCalcHist(&srcImage,Histogram1);cvCalcHist(&targetImage,Histogram2);cvNormalizeHist(Histogram1,1);cvNormalizeHist(Histogram2,1);//CV_COMP_CHISQR,CV_COMP_BHATTACHARYYA这两种都可以用来做直方图的比较,值越小,说明图形越相似printf("CV_COMP_CHISQR:%.4f\n",cvCompareHist(Histogram1,Histogram2,CV_COMP_CHISQR));printf("CV_COMP_BHATTACHARYYA:%.4f\n",cvCompareHist(Histogram1,Histogram2,CV_COMP_BHATTACHARYYA));//CV_COMP_CORREL,CV_COMP_INTERSECT这两种直方图的比较,值越大,说明图形越相似printf("CV_COMP_CORREL:%.4f\n",cvCompareHist(Histogram1,Histogram2,CV_COMP_CORREL));printf("CV_COMP_INTERSECT:%.4f\n",cvCompareHist(Histogram1,Histogram2,CV_COMP_INTERSECT));cvReleaseHist(&Histogram1);cvReleaseHist(&Histogram2);if(image1->nChannels!=1){cvReleaseImage(&srcImage);}if(image2->nChannels!=1){cvReleaseImage(&targetImage);}return0;}StringsrcImage="d:\\ldh1.jpg";StringtargetImage="d:\\ldh5.jpg";intmain(intargc,char*argv[]){CascadeClassifiercascade;namedWindow("image1");namedWindow("image2");if(!cascade.load(cascadeName)){return-1;}MatsrcImg,targetImg;IplImage*faceImage1;IplImage*faceImage2;srcImg=imread(srcImage);targetImg=imread(targetImage);faceImage1=detect(srcImg,cascade,1);if(faceImage1==NULL){return-1;}//cvSaveImage("d:\\face.jpg",faceImage1,0);faceImage2=detect(targetImg,cascade,1);if(faceImage2==NULL){return-1;}//cvSaveImage("d:\\face1.jpg",faceImage2,0);imshow("image1",Mat(faceImage1));imshow("image2",Mat(faceImage2));CompareHist(faceImage1,faceImage2);cvWaitKey(0);cvReleaseImage(&faceImage1);cvReleaseImage(&faceImage2);return0;}

如果觉得《OpenCV学习:找出人脸 同时比较两张图片中的人脸相似度》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。