利用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
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值