cvMatchShapes匹配

本文通过实例演示如何使用OpenCV中的cvMatchShapes函数来比较两张图片的形状相似度。介绍了从加载图片到灰度转换、边缘检测、轮廓查找直至形状匹配的完整流程,并提供了源代码。

cvMatchShapes匹配

 

 函数 cvMatchShapes 比较两个形状。 三个实现方法全部使用 Hu .
Hu
矩具有平移、伸缩和旋转不变形.

匹配中,对比两种方法:1、先进行canny边缘检测 将得到的边缘信息作为输入 再用cvMatchShapes 
2
、先进行角点检测 将得到的角点信息作为输入再用cvMatchShapes  

边缘检测应该会更准确一些

# include "cv.h"
# include "highgui.h"
# include <iostream>
using namespace std;

int main()

   IplImage *mode = cvLoadImage("D:\\picture\\jz.jpg", 1);
   IplImage *test = cvLoadImage("D:\\picture\\stuff.jpg", 1);
   IplImage* bw_mode = cvCreateImage(cvGetSize(mode),mode->depth,1);
   IplImage* bw_test = cvCreateImage(cvGetSize(test),mode->depth,1);
   IplImage* canny_mode = cvCreateImage(cvGetSize(mode),mode->depth,1);
   IplImage* canny_test = cvCreateImage(cvGetSize(test),mode->depth,1);

   CvMemStorage *mode_mems=cvCreateMemStorage();
   CvSeq *mode_seqs;
   CvMemStorage *test_mems=cvCreateMemStorage();
   CvSeq *test_seqs;

   cvCvtColor(mode,bw_mode,CV_RGB2GRAY);
   cvCvtColor(test,bw_test,CV_RGB2GRAY);

   //model contours
   cvCanny(bw_mode,canny_mode,50,60);
   cvFindContours( canny_mode, mode_mems,
                  &mode_seqs,sizeof(CvContour),CV_RETR_TREE);

   //test contours
   cvCanny(bw_test,canny_test,50,60);
   cvFindContours( canny_test, test_mems,
                  &test_seqs,sizeof(CvContour),CV_RETR_TREE);

   double matching=cvMatchShapes( test_seqs, mode_seqs, 3);
   cout << matching << endl;
   
   system("pause");
   //
释放内存
}

 

也可以直接用灰度图进行匹配。
返回值越靠近0,说明两张图像相似度越高。
你用的是不是两张完全一样的图片啊。
不妨贴一下。

 

cvMatchShapes

Venus » 2009-07-23 22:26

int cvMatchShapes_test()
{
IplImage *mode = cvLoadImage("D:\\lena.jpg", 1);
IplImage *test = cvLoadImage("D:\\test3.bmp", 1);
IplImage* bw_mode = cvCreateImage(cvGetSize(mode),mode->depth,1);
IplImage* bw_test = cvCreateImage(cvGetSize(test),mode->depth,1);
IplImage* canny_mode = cvCreateImage(cvGetSize(mode),mode->depth,1);
IplImage* canny_test = cvCreateImage(cvGetSize(test),mode->depth,1);

CvMemStorage *mode_mems=cvCreateMemStorage();
CvSeq *mode_seqs;
CvMemStorage *test_mems=cvCreateMemStorage();
CvSeq *test_seqs;

cvCvtColor(mode,bw_mode,CV_RGB2GRAY);
cvCvtColor(test,bw_test,CV_RGB2GRAY);

//model contours
//cvCanny(bw_mode,canny_mode,50,60);
cvFindContours( bw_mode, mode_mems,
&mode_seqs,sizeof(CvContour),CV_RETR_TREE);

//test contours
//cvCanny(bw_test,canny_test,50,60);
cvFindContours( bw_test, test_mems,
&test_seqs,sizeof(CvContour),CV_RETR_TREE);

double matching=cvMatchShapes( test_seqs, mode_seqs, 3);
printf("%f",matching);

cvReleaseImage( &mode ); //ÊÍ·ÅͼÏñ
cvReleaseImage( &test );
cvReleaseImage( &bw_mode ); //ÊÍ·ÅͼÏñ
cvReleaseImage( &bw_test );
cvReleaseImage( &canny_mode ); //ÊÍ·ÅͼÏñ
cvReleaseImage( &canny_test );
//ÊÍ·ÅÄÚ´æ
return 1;

 

从别人博客里看的,忘记地址了。尊重博主的原创,在这里先谢谢那个博主,再次强调,是引用别人的哦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值