CVPR读书笔记[5]:Gabor特征提取之Gabor核的实现
朱金华 jinhua1982@gmail.com 2014.08.09
本文參考http://blog.csdn.net/njzhujinhua/article/details/38460861的描写叙述基于opencv实现Gabor核.
本文是Gabor特征提取三部分之二:
[1]CVPR读书笔记[4]:Gabor特征提取之Gabor核
http://blog.csdn.net/njzhujinhua/article/details/38460861
[2] CVPR读书笔记[5]:Gabor特征提取之Gabor核的实现
http://blog.csdn.net/njzhujinhua/article/details/38610281
[3] CVPR读书笔记[6]:Gabor特征提取
http://blog.csdn.net/njzhujinhua/article/details/38614697
ZGabor类声明, 该类仅仅具备Kernel的计算, 详细使用在各faborfeature相关算法中实现.
#define GABOR_SCALE_NUM 5
#define GABOR_ANGLE_NUM 8 class ZGabor
{
public:
//默认參数及指定參数的初始化
bool InitGabor();
bool InitGabor(Size ksize, double kmax, double f, double sigma); //存放kernel的实部,虚部及幅值矩阵, 直接使用, 暂未封装
Mat m_gaborReKernel[GABOR_SCALE_NUM][GABOR_ANGLE_NUM];
Mat m_gaborImgKernel[GABOR_SCALE_NUM][GABOR_ANGLE_NUM];
Mat m_gaborMagKernel[GABOR_SCALE_NUM][GABOR_ANGLE_NUM]; void test(); protected:
bool InitKernel();
bool GetKernel(Size ksize, int scaleIdx, int angleIdx, Mat &realKernel, Mat&imgKernel);
Mat GetKernelMagnitude(const Mat &rekernel, const Mat&imgkernel); double m_kmax;
double m_f;
double m_sigma;
int m_scaleNum;
int m_angleNum;
Size m_ksize;
private: };
实现部分
#include "zgabor.h" /*
Zhu.Jinhua
jinhua1982@gmail.com 20140809
http://blog.csdn.net/njzhujinhua/article/details/38460861
说明:參数初始化,使用默认參数
*/
bool ZGabor::InitGabor()
{
m_kmax = CV_PI/2;
m_f = sqrt(double(2));
m_sigma = 2*CV_PI;
m_scaleNum = GABOR_SCALE_NUM;
m_angleNum = GABOR_ANGLE_NUM;
m_ksize = Size(19,19); InitKernel();
return true;
}
/*
Zhu.Jinhua
jinhua1982@gmail.com 20140809
说明:參数初始化,使用指定參数
*/
bool ZGabor::InitGabor(Size ksize, double kmax, double f, double sigma)
{
m_kmax = kmax;
m_f = f;
m_sigma = sigma;
m_scaleNum = GABOR_SCALE_NUM;
m_angleNum = GABOR_ANGLE_NUM;
m_ksize = ksize; InitKernel();
return true;
}
/*
Zhu.Jinhua
jinhua1982@gmail.com 20140809
说明:<span style="color:green;">Gabor</span><span style="color:green;">核的生成</span>
*/
bool ZGabor::InitKernel()
{
for (int scaleIdx=0;scaleIdx < GABOR_SCALE_NUM; scaleIdx++)
{
for (int angleIdx = 0;angleIdx < GABOR_ANGLE_NUM; angleIdx++)
{
GetKernel(m_ksize, scaleIdx, angleIdx, m_gaborReKernel[scaleIdx][angleIdx], m_gaborImgKernel[scaleIdx][angleIdx]);
m_gaborMagKernel[scaleIdx][angleIdx] = GetKernelMagnitude(m_gaborReKernel[scaleIdx][angleIdx], m_gaborImgKernel[scaleIdx][angleIdx]);
}
} return true;
} /*
Zhu.Jinhua
jinhua1982@gmail.com 20140809
Get kernel magnitude by re and img part.
return magnitude Mat
*/
Mat ZGabor::GetKernelMagnitude(const Mat &rekernel, const Mat&imgkernel)
{
CV_Assert(rekernel.size() == imgkernel.size());
CV_Assert(rekernel.type() == imgkernel.type());
Mat mag;
magnitude(rekernel,imgkernel, mag); //test
/*Mat tmp;
normalize(rekernel,tmp,0,255,CV_MINMAX,CV_8U);
imshow("mag", tmp);
waitKey();
*/ return mag;
} /*
Zhu.Jinhua
jinhua1982@gmail.com 20140809
Real Part:
G(k,x,y,θ)=k^2/σ^2*exp(-(k^2 (x^2+y^2 ))/(2σ^2 ))*(cos(k(xcosθ+ysinθ))-exp(-σ^2/2))
Imag Part:
G(k,x,y,θ)=k^2/σ^2*exp(-(k^2 (x^2+y^2 ))/(2σ^2 ))*(sin(k(xcosθ+ysinθ)))
In:ksize --kernel size
scaleIdx --Scale index
andeIdx --angle index
Out:
realKernel --real part of kernel
imgKernel --imagine part of kernel
*/
bool ZGabor::GetKernel(Size ksize, int scaleIdx, int angleIdx, Mat &realKernel, Mat&imgKernel)
{
int xmin=0,xmax=0;
int ymin=0,ymax=0; //we suppose kernel width equal height.
assert(ksize.width == ksize.height); xmax=ksize.width/2;
ymax=ksize.height/2;
xmin=-xmax;
ymin=-ymax; //reset out para mat size
realKernel.create(xmax-xmin+1,ymax-ymin+1,CV_32FC1);
imgKernel.create(xmax-xmin+1,ymax-ymin+1,CV_32FC1);
double k=m_kmax/pow(m_f,scaleIdx); double scaleFactor=k*k/m_sigma/m_sigma; //k^2/σ^2
double DC=exp(-m_sigma*m_sigma/2); //direct current
double theta=CV_PI*angleIdx/m_angleNum;
double costheta=cos(theta), sintheta=sin(theta); float *ptr_re = NULL;
float *ptr_img = NULL;; for (int y=ymin;y<=ymax;y++)
{
ptr_re=realKernel.ptr<float>(y-ymin);
ptr_img = imgKernel.ptr<float>(y-ymin);
for (int x=xmin;x<=xmax;x++)
{
double xcys=x*costheta+y*sintheta; //xcosθ+ysinθ
double pub=scaleFactor*exp(-scaleFactor/2*(x*x+y*y));//k^2/σ^2*exp(-(k^2 (x^2+y^2 ))/(2σ^2 ))
double re_minus_dc=cos(k*xcys)-DC;//(cos(k(xcosθ+ysinθ))-exp(-σ^2/2))
double img=sin(k*xcys);//(sin(k(xcosθ+ysinθ))) ptr_re[x-xmin]=pub*re_minus_dc;
ptr_img[x-xmin]=pub*img;
//cout<<"y="<<y-ymin<<" x="<<x-xmin<<" = "<<ptr_re[x-xmin]<<endl;
}
} return true;
}
測试代码
void ZGabor::test()
{
Mat reKernel;
Mat imgKernel;
Mat mag;
Mat displayMatCol,displayMat, line;
//InitGabor();//CV_PI/2,1.4*(1.0+i/10.0),CV_PI*2);
for (int i=0;i<8;i++)
{
displayMatCol.release(); for (int j=0;j<5;j++)
{
normalize(m_gaborReKernel[j][i],reKernel,0,255,CV_MINMAX,CV_8U); line=Mat::ones(3,reKernel.cols,reKernel.type())*255;
displayMatCol.push_back(reKernel);
displayMatCol.push_back(line);
}
displayMatCol=displayMatCol.t();
line=Mat::ones(2,displayMatCol.cols,displayMatCol.type())*255;
displayMat.push_back(displayMatCol);
displayMat.push_back(line);
} displayMat=displayMat.t();
imwrite("gabor5x8.jpg",displayMat);
imshow("Gabor Kernel",displayMat);
waitKey(0);
}
得到的实部的图示(图中ksize=100)
用法
ZGabor m_gabor
m_gabor.InitGabor();
m_gabor.test();
用于滤波的话直接使用m_gabor.m_gaborReKernel[i][j]作为核
CVPR读书笔记[5]:Gabor特征提取之Gabor核的实现的更多相关文章
- 2019 ICCV、CVPR、ICLR之视频预测读书笔记
2019 ICCV.CVPR.ICLR之视频预测读书笔记 作者 | 文永亮 学校 | 哈尔滨工业大学(深圳) 研究方向 | 视频预测.时空序列预测 ICCV 2019 CVP github地址:htt ...
- 【读书笔记与思考】《python数据分析与挖掘实战》-张良均
[读书笔记与思考]<python数据分析与挖掘实战>-张良均 最近看一些机器学习相关书籍,主要是为了拓宽视野.在阅读这本书前最吸引我的地方是实战篇,我通读全书后给我印象最深的还是实战篇.基 ...
- Gabor变换、Gabor滤波器
D.Gabor 1946年提出 窗口Fourier变换,为了由信号的Fourier变换提取局部信息,引入了时间局部化的窗函数. 由于窗口Fourier变换只依赖于部分时间的信号,所以,现在窗口Four ...
- 读书笔记汇总 - SQL必知必会(第4版)
本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...
- 读书笔记--SQL必知必会18--视图
读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...
- 《C#本质论》读书笔记(18)多线程处理
.NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...
- C#温故知新:《C#图解教程》读书笔记系列
一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...
- C#刨根究底:《你必须知道的.NET》读书笔记系列
一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...
- Web高级征程:《大型网站技术架构》读书笔记系列
一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...
随机推荐
- HTML5 Canvas 概述
本文中,我们将探索如何使用HTML5的Canvas API.Canvas API很酷,我们可以通过它来动态创建生成和展示图形,图表,图像以及动画.本文将使用渲染API(rendering API)的基 ...
- iOS扫描二维码(系统方法)
步骤如下: 1.导入AVFoundation框架,引入<AVFoundation/AVFoundation.h> 2.设置一个用于显示扫描的view 3.实例化AVCaptureSessi ...
- centos 6.X 安装输入法
1.打开终端 su 输入 密码 yum install "@Chinese Support" 2.接下来是启用中文输入法的操作 系统 ->首选项 ->输入法 3.在弹出 ...
- TalkingData Cocos2dx集成指南【最新】
续:最近终于腾出时间把TalkingData的Cocos版本好好折腾一下了,总感觉之前的各个版本在集成上都很蹩脚.给广大开发者带了很多困扰...“游戏正着急上线呢,哪还有时间去仔细看TalkingDa ...
- ajax+XMLHttpRequest里的FormData实现图片异步上传
发这篇博客的时候我是自己在研究这个XMLHttpRequest请求,在别人的博客上面知道XMLHttpRequest新加了一个FormData的东西,好像现在APP请求后台也有用这种方式的吧. 别的不 ...
- javascript mvc 简单例子
<!DOCTYPE html> <html> <head> </head> <body> <input type="text ...
- 一起学习iOS开发专用词汇,每天记3个,助你变大牛-b
大家做开发最大的问题是什么?英语的问题应该困扰很多的同学的地方,我们提倡科学学习开发中的常用词汇.我们不要求大家有特别好的听.说.写,只要能够记住,能够认识这些常用词汇你以后的开发也将游刃有余.我们的 ...
- jQuery的live绑定事件在mobile safari(iphone / ipad / ipod)上失效的解决方案
jQuery的live绑定为什么会在mobile safari上失效呢?其实可以追溯到jQuery里live的实现方式.live的实现方式实际上是通过事件委托机制来实现的,也就是说是通过诸如冒泡的方式 ...
- h.264 Mode Decision
Mode Decision(模式选择)决定一个宏块以何种类型进行分割.宏块的分割类型有以下几种: //P_Skip and B_Skip means that nothing need to be e ...
- "Failed to fetch URL https://dl-ssl.google.com/android/repository/addons_list.xml,reason: Connection
"Failed to fetch URL https://dl-ssl.google.com/android/repository/addons_list.xml,reason: Conne ...