【图像算法OpenCV】几何不变矩--Hu矩
原文地址 http://blog.csdn.NET/daijucug/article/details/7535370
一 原理
几何矩是由Hu(Visual pattern recognition by moment invariants)在1962年提出的,具有平移、旋转和尺度不变性。 定义如下:
① (p+q)阶不变矩定义:

② 对于数字图像,离散化,定义为:

③ 归一化中心矩定义:

④Hu矩定义


-------------------------------------------------------------------------------------------------------------------------------
二 实现(源码)
Code
1 //#################################################################################//
2 double M[7] = {0}; //HU不变矩
3 bool HuMoment(IplImage* img)
4 {
5 int bmpWidth = img->width;
6 int bmpHeight = img->height;
7 int bmpStep = img->widthStep;
8 int bmpChannels = img->nChannels;
9 uchar*pBmpBuf = (uchar*)img->imageData;
10
11 double m00=0,m11=0,m20=0,m02=0,m30=0,m03=0,m12=0,m21=0; //中心矩
12 double x0=0,y0=0; //计算中心距时所使用的临时变量(x-x')
13 double u20=0,u02=0,u11=0,u30=0,u03=0,u12=0,u21=0;//规范化后的中心矩
14 //double M[7]; //HU不变矩
15 double t1=0,t2=0,t3=0,t4=0,t5=0;//临时变量,
16 //double Center_x=0,Center_y=0;//重心
17 int Center_x=0,Center_y=0;//重心
18 int i,j; //循环变量
19
20 // 获得图像的区域重心(普通矩)
21 double s10=0,s01=0,s00=0; //0阶矩和1阶矩
22 for(j=0;j<bmpHeight;j++)//y
23 {
24 for(i=0;i<bmpWidth;i++)//x
25 {
26 s10+=i*pBmpBuf[j*bmpStep+i];
27 s01+=j*pBmpBuf[j*bmpStep+i];
28 s00+=pBmpBuf[j*bmpStep+i];
29 }
30 }
31 Center_x=(int)(s10/s00+0.5);
32 Center_y=(int)(s01/s00+0.5);
33
34 // 计算二阶、三阶矩(中心矩)
35 m00=s00;
36 for(j=0;j<bmpHeight;j++)
37 {
38 for(i=0;i<bmpWidth;i++)//x
39 {
40 x0=(i-Center_x);
41 y0=(j-Center_y);
42 m11+=x0*y0*pBmpBuf[j*bmpStep+i];
43 m20+=x0*x0*pBmpBuf[j*bmpStep+i];
44 m02+=y0*y0*pBmpBuf[j*bmpStep+i];
45 m03+=y0*y0*y0*pBmpBuf[j*bmpStep+i];
46 m30+=x0*x0*x0*pBmpBuf[j*bmpStep+i];
47 m12+=x0*y0*y0*pBmpBuf[j*bmpStep+i];
48 m21+=x0*x0*y0*pBmpBuf[j*bmpStep+i];
49 }
50 }
51
52 // 计算规范化后的中心矩: mij/pow(m00,((i+j+2)/2)
53 u20=m20/pow(m00,2);
54 u02=m02/pow(m00,2);
55 u11=m11/pow(m00,2);
56 u30=m30/pow(m00,2.5);
57 u03=m03/pow(m00,2.5);
58 u12=m12/pow(m00,2.5);
59 u21=m21/pow(m00,2.5);
60
61 // 计算中间变量
62 t1=(u20-u02);
63 t2=(u30-3*u12);
64 t3=(3*u21-u03);
65 t4=(u30+u12);
66 t5=(u21+u03);
67
68 // 计算不变矩
69 M[0]=u20+u02;
70 M[1]=t1*t1+4*u11*u11;
71 M[2]=t2*t2+t3*t3;
72 M[3]=t4*t4+t5*t5;
73 M[4]=t2*t4*(t4*t4-3*t5*t5)+t3*t5*(3*t4*t4-t5*t5);
74 M[5]=t1*(t4*t4-t5*t5)+4*u11*t4*t5;
75 M[6]=t3*t4*(t4*t4-3*t5*t5)-t2*t5*(3*t4*t4-t5*t5);
76
77 returntrue;
78 }
②调用OpenCV方法
1 // 利用OpenCV函数求7个Hu矩
2 CvMoments moments;
3 CvHuMoments hu;
4 cvMoments(bkImgEdge,&moments,0);
5 cvGetHuMoments(&moments, &hu);
6 cout<<hu.hu1<<"/"<<hu.hu2<<"/"<<hu.hu3<<"/"<<hu.hu4<<"/"<<hu.hu5<<"/"<<hu.hu6<<"/"<<hu.hu7<<"/"<<"/"<<endl;
7 cvMoments(testImgEdge,&moments,0);
8 cvGetHuMoments(&moments, &hu);
9 cout<<hu.hu1<<"/"<<hu.hu2<<"/"<<hu.hu3<<"/"<<hu.hu4<<"/"<<hu.hu5<<"/"<<hu.hu6<<"/"<<hu.hu7<<"/"<<"/"<<endl;
-------------------------------------------------------------------------------------------------------------------------------
三 相似性准则
①法一
// 计算相似度1
double dbR =0; //相似度
double dSigmaST =0;
double dSigmaS =0;
double dSigmaT =0;
double temp =0;
{for(int i=0;i<8;i++)
{
temp = fabs(Sa[i]*Ta[i]);
dSigmaST+=temp;
dSigmaS+=pow(Sa[i],2);
dSigmaT+=pow(Ta[i],2);
}}
dbR = dSigmaST/(sqrt(dSigmaS)*sqrt(dSigmaT));
②法二
1 // 计算相似度2
2 double dbR2 =0; //相似度
3 double temp2 =0;
4 double temp3 =0;
5 {for(int i=0;i<7;i++)
6 {
7 temp2 += fabs(Sa[i]-Ta[i]);
8 temp3 += fabs(Sa[i]+Ta[i]);
9 }}
10 dbR2 =1- (temp2*1.0)/(temp3);
【图像算法OpenCV】几何不变矩--Hu矩的更多相关文章
- 几何不变矩--Hu矩
[图像算法]图像特征: ---------------------------------------------------------------------------------------- ...
- opencv —— moments 矩的计算(空间矩/几何矩、中心距、归一化中心距、Hu矩)
计算矩的目的 从一幅图像计算出来的矩集,不仅可以描述图像形状的全局特征,而且可以提供大量关于该图像不同的几何特征信息,如大小,位置.方向和形状等.这种描述能力广泛应用于各种图像处理.计算机视觉和机器人 ...
- Hu矩SVM训练及检测-----OpenCV
关键词:Hu矩,SVM,OpenCV 在图像中进行目标物识别,涉及到特定区域内是否存在目标物,SVM可在样本量较少情况下对正负样本(图片中前景背景)做出良好区分,图片基本特征包括诸如HOG.LBP.H ...
- opencv计算两个轮廓之间hu矩相似程度,MatchShapes
https://blog.csdn.net/jiake_yang/article/details/52589063 [OpenCV3.3]通过透视变换矫正变形图像 https://blog.csdn. ...
- opencv中的图像矩(空间矩,中心矩,归一化中心矩,Hu矩)
严格来讲矩是概率与统计中的一个概念,是随机变量的一种数字特征.设 x 为随机变量,C为常数,则量E[(x−c)^k]称为X关于C点的k阶矩.比较重要的两种情况如下: 1.c=0,这时a_k=E(X^k ...
- 【OpenCV】轮廓的特征矩Moment
opencv中的矩主要包括以下几种:空间矩,中心矩和中心归一化矩. class Moments { public: ...... // 空间矩 double m00, m10, m01, m20, m ...
- 【图像基础】图像不变性特征HU矩和Zernike矩
参考 1. 图像不变性特征: 2. matlab实现: 3. HU矩和Zernike矩: 完
- Hu矩
close all; clear all; I1=imread('lena.bmp'); angle=; T=[cos(angle),sin(angle),;-sin(angle),cos(angle ...
- 形状特征提取-Hu不变矩(转载)
[原文部分转载]:http://blog.csdn.net/wrj19860202/archive/2011/04/16/6327094.aspx 在连续情况下,图像函数为 ,那么图像的p+q阶几何矩 ...
随机推荐
- python一些方便excel行操作的函数(一)
import collections class headhandler(): def __init__(self,mylist): self.mystorage={} self.mylist = m ...
- Java8-Stream-No.08
import java.util.Arrays; import java.util.stream.IntStream; import java.util.stream.Stream; public c ...
- [暂停维护]基于8211lib库对s57电子海图的解析和存储
此篇博文停止维护,欢迎移步最新地址(含源代码),https://www.yanlongwang.net/USV/ENC-analysis-store.md/, 查看最新文章. 电子海图是为适用航海需要 ...
- Lighting Techinology of the Last Of Us (2013 SIGGRAPH)
Lighting Techinology of the Last Of Us(2013 SIGGRAPH) or "Old Lightmaps - New Tricks" 原作:M ...
- 2018-2019 ICPC, NEERC J. Streets and Avenues in Berhattan(DP)
题目链接:https://codeforc.es/contest/1070/problem/J 题意:给出一个长度为 k 的字符串,选出 n 个和 m 个不同位置的字符构成两个字符串,使得两个字符串相 ...
- Idea使用Lombok简化实体类代码
引入相应的maven包 <dependency> <groupId>org.projectlombok</groupId> <artifactId>lo ...
- yii框架学习(获取插入后的id)
插入单条数据, 获取插入数据的id. $model->attributes['id']; new model 添加数据的时候, 需要注意, 如果是想要循环添加多条数据的情况, new mode ...
- bbs--文章后台
bbs--文章后台 需求分析 在个人文章后台中 1 有添加文章的接口 展示文章标题输入框 文本编辑框 标签 分类 选择框 提交 2 编辑文章的接口 页面与添加文章相同,就是把该文章的内容展示到文本编辑 ...
- tensorboard 远程服务器本地浏览器无法显示
在用xshell等ssh工具远程连接服务器时,我们常常在服务器上运行tensorflow代码,而且模型tf.summary保存文件在服务器上,这是直接采用tensorboard会有一些小问题.直接用t ...
- html页面之间相互传值
常见的在页面登录过后会获得一个token值然后页面跳转时传给下一个页面 sessionStorage.setItem("token",result.token);//传输token ...