原文地址  http://blog.csdn.NET/daijucug/article/details/7535370

【图像算法OpenCV】几何不变矩--Hu矩

一 原理

几何矩是由Hu(Visual pattern recognition by moment invariants)在1962年提出的,具有平移、旋转和尺度不变性。 定义如下:

① (p+q)阶不变矩定义

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

③ 归一化中心矩定义

④Hu矩定义

-------------------------------------------------------------------------------------------------------------------------------

二 实现(源码)

自编函数模块

View
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矩的更多相关文章

  1. 几何不变矩--Hu矩

    [图像算法]图像特征: ---------------------------------------------------------------------------------------- ...

  2. opencv —— moments 矩的计算(空间矩/几何矩、中心距、归一化中心距、Hu矩)

    计算矩的目的 从一幅图像计算出来的矩集,不仅可以描述图像形状的全局特征,而且可以提供大量关于该图像不同的几何特征信息,如大小,位置.方向和形状等.这种描述能力广泛应用于各种图像处理.计算机视觉和机器人 ...

  3. Hu矩SVM训练及检测-----OpenCV

    关键词:Hu矩,SVM,OpenCV 在图像中进行目标物识别,涉及到特定区域内是否存在目标物,SVM可在样本量较少情况下对正负样本(图片中前景背景)做出良好区分,图片基本特征包括诸如HOG.LBP.H ...

  4. opencv计算两个轮廓之间hu矩相似程度,MatchShapes

    https://blog.csdn.net/jiake_yang/article/details/52589063 [OpenCV3.3]通过透视变换矫正变形图像 https://blog.csdn. ...

  5. opencv中的图像矩(空间矩,中心矩,归一化中心矩,Hu矩)

    严格来讲矩是概率与统计中的一个概念,是随机变量的一种数字特征.设 x 为随机变量,C为常数,则量E[(x−c)^k]称为X关于C点的k阶矩.比较重要的两种情况如下: 1.c=0,这时a_k=E(X^k ...

  6. 【OpenCV】轮廓的特征矩Moment

    opencv中的矩主要包括以下几种:空间矩,中心矩和中心归一化矩. class Moments { public: ...... // 空间矩 double m00, m10, m01, m20, m ...

  7. 【图像基础】图像不变性特征HU矩和Zernike矩

    参考 1. 图像不变性特征: 2. matlab实现: 3. HU矩和Zernike矩: 完

  8. Hu矩

    close all; clear all; I1=imread('lena.bmp'); angle=; T=[cos(angle),sin(angle),;-sin(angle),cos(angle ...

  9. 形状特征提取-Hu不变矩(转载)

    [原文部分转载]:http://blog.csdn.net/wrj19860202/archive/2011/04/16/6327094.aspx 在连续情况下,图像函数为 ,那么图像的p+q阶几何矩 ...

随机推荐

  1. struts2提交表单注意事项 (3)

    供应商模块 需求:实现供应商的列表.添加.修改.删除三个功能 注意:修改时,不允许修改供应商编号 添加时,不允许显现的添加供应商编号 删除时,进行逻辑删除(根据主键将该条数据不再显示在列表) 物理删除 ...

  2. 校验正确获取对象或者数组的属性方法(babel-plugin-idx/_.get)

    背景: 开发中经常遇到取值属性的时候,需要校验数值的有效性. 例如: 获取props对象里面的friends属性 props.user && props.user.friends &a ...

  3. 分布式hadoop 架构图

    zk:zookeeper NN:namenode DN:datanode ZF Failover Controller:简称zkfc ,是zk的客户端,只运行在主备的namenode上,主要作用是判断 ...

  4. Linux 文件查看

    链接:https://www.nowcoder.com/questionTerminal/fb39fbeec71f43a3a16edeb0bc98f4ac 来源:牛客网 /var/log/messag ...

  5. Python数据抓取(3) —抓取标题、时间及链接

    本次分享,jacky将跟大家分享如何将第一财经文章中的标题.时间以及链接抓取出来 (一)观察元素抓取位置 网页的原始码很复杂,我们必须找到特殊的元素做抽取,怎么找到特殊的元素呢?使用开发者工具检视每篇 ...

  6. javaweb和数据库的简易商城系统

    这是一个基于Javaweb和数据库的简易商城系统.为大二夏季小学期完成. 目录结构 主要功能截图为: 一.购买用户 1.首页(除此界面其余界面访问需要登录才能进入) 查看商品 添加购物车 查看购物车 ...

  7. spring事务之事务传播机制和隔离级别

    Spring事务传播行为 运用Spring事务,必须要深入理解它的传播机制,否则会遇到各种意想不到的坑,Spring定义了七种传播行为. public interface TransactionDef ...

  8. 预处理、const、static与sizeof-内联函数与宏有什么区别

    1:二者的区别如下: (1)内联函数在编译时展开,宏在预编译时展开. (2)在编译的时候,内联函数可以直接被镶嵌到目标代码中,而宏只是一个简单的文本替换. (3)内联函数可以完成诸如类型检测.语句是否 ...

  9. Spring AOP:Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException

    1 报错 Exception encountered during context initialization - cancelling refresh attempt: org.springfra ...

  10. HTTP之缓存技术

    1. 缓存简介 缓存是位于服务器和客户端的中间单元,主要根据用户代理发送过来的请求,向服务器请求相关内容后提供给用户,并保存内容副本,例如 HTML 页面.图片.文本文件或者流媒体文件.然后,当下一个 ...