利用Hu不变矩进行特征提取

#include "stdafx.h"

#include <opencv2/opencv.hpp>

#include <string>

int _tmain(int argc, _TCHAR* argv[])

{ string strImageName = "F:\\base.jpg";

IplImage *imgSrc, *imgTmp;

imgSrc = cvLoadImage(strImageName.c_str(), 2 | 4);

imgTmp = cvCreateImage(cvGetSize(imgSrc), IPL_DEPTH_8U, 1);

cvSetZero(imgTmp);

if (imgSrc->nChannels == 3)

{

cvCvtColor(imgSrc, imgTmp, CV_BGR2GRAY);

}

else

{

cvCopy(imgSrc, imgTmp);

}

CvMoments moments;

CvHuMoments humoments;

cvMoments(imgTmp, &moments, 0);

cvGetHuMoments(&moments, &humoments);

cout<<humoments.hu1<<" "<<humoments.hu2<<" "<<humoments.hu3<<" "<<humoments.hu4<<" "<<humoments.hu5<<" "<<humoments.hu6<<" "<<humoments.hu7<<endl;

cvReleaseImage(&imgSrc);

cvReleaseImage(&imgTmp);

return 0;

}

/* Spatial and central moments */

typedef struct CvMoments

{

double m00, m10, m01, m20, m11, m02, m30, m21, m12, m03; /* spatial moments */

double mu20, mu11, mu02, mu30, mu21, mu12, mu03; /* central moments */

double inv_sqrt_m00; /* m00 != 0 ? 1/sqrt(m00) : 0 */

}

CvMoments;

/* Hu invariants */

typedef struct CvHuMoments

{

double hu1, hu2, hu3, hu4, hu5, hu6, hu7; /* Hu invariants */

}

CvHuMoments;

参考文献:

1、 http://www.cnblogs.com/seacode/archive/2011/03/17/1987413.html

2、 http://download.csdn.net/download/wshsh2010/3026538

3、 http://archive.cnblogs.com/a/2110183/

4、 http://blog.csdn.net/shandianling/article/details/6456097

5、 http://blog.sina.com.cn/s/blog_73ee929c01010f45.html

6、 http://blog.csdn.net/fdl19881/article/details/6736477

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值