Opencv计算一幅图像的hu矩

首先Hu矩是干嘛得呢?用hu矩来匹配图像

下面是计算hu矩的过程  概念先了解一下吧

普通矩 -----》
0阶矩(m00) :目标区域的质量
1阶矩(m01,m10) :目标区域的质心
2阶矩(m02,m20,m11) :旋转半径
3阶矩(m03,m30,m12,m21) :目标的方位和斜度,反应目标

中心矩:构造平移不变性 ---------》 
质心坐标:x = m10/m00 y = m01/m00;

归一化中心矩:构造尺度不变性 ----------》(mu02,mu20,mu11,mu03,mu30,mu12,mu21)

hu矩:构造旋转不变性 (h1,h2,。。。。,h7)

代码如下:

#include<iostream>
#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
//计算一幅图像的hu矩
int main()
{
	IplImage* src;
	src = cvCreateImage(cvSize(10,10),8,1); //这里是创建一幅图像 也可以自己加载一幅图像计算
	cvZero(src); //把所以值都赋值为0
	int xx,yy;
	for( yy = 0;yy<5;yy++){
		for( xx = 0;xx<5;xx++){
			cvSetReal2D(src,yy,xx,255); //把前5行5列的像素变为255 白色
		}
	}
	/*cvNamedWindow("1");
	cvShowImage("1",src);*/
	double m00,m10,m01; //计算0阶矩和1阶矩
	CvMoments moment;
	cvMoments(src,&moment,2);  //2: 只要比0大的数都可以 表示像素255的点都用1来表示
	m00 = cvGetSpatialMoment(&moment,0,0);
	m10 = cvGetSpatialMoment(&moment,1,0);
	m01 = cvGetSpatialMoment(&moment,0,1);
 
	double x = m10/m00;
	double y = m01/m00;
 
	CvHuMoments humoment;
	cvGetHuMoments(&moment,&humoment); //计算出hu矩的值
 
	cvWaitKey(0);
	return 0;
}


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864