| 查看: 2461 | 回复: 1 | ||
xiashaoyan新虫 (正式写手)
|
[求助]
normxcorr2函数求互相关量最大值位置的问题 已有1人参与
|
|
看了一些求基准图像和配准图像的互相关值的最大值对应的位置,我现在看到有两种方法, 第一种是使用MATLAB里面自带的normxcorr2函数,我看了mathwork网站上有一个求互相关量最大值位置的程序:(参考网址为:http://cn.mathworks.com/help/images/ref/normxcorr2.html) onion = rgb2gray(onion); peppers = rgb2gray(peppers); Perform cross-correlation and display result as surface. c = normxcorr2(onion,peppers); [ypeak, xpeak] = find(c==max(c( );yoffSet = ypeak-size(onion,1); xoffSet = xpeak-size(onion,2); 可是有一个疑问是,为什么在求出互相关量最大值位置后还要减去基准图像的尺寸呢?(也即为什么yoffSet = ypeak-size(onion,1)??xoffSet = xpeak-size(onion,2);??) 第二种方法是采用两副图像进行互相关运算,计算的程序,我找了网上的程序为: (参考网址为:http://www.mathworks.com/matlabc ... /dftregistration.m) buf1ft是基准图像,buf2ft是配准待图像 [m,n]=size(buf1ft); CC = ifft2(buf1ft.*conj(buf2ft));%先计算buf1ft与buf2ft共轭的傅立叶变换,得到互相关函数的频谱,然后求结果ifft2得到互相关函数 %% 计算互相关函数的最大值及最大值的位置 [max1,loc1] = max(CC); [max2,loc2] = max(max1); rloc=loc1(loc2); cloc=loc2; CCmax=CC(rloc,cloc); md2 = fix(m/2); nd2 = fix(n/2); if rloc > md2 row_shift = rloc - m - 1; else row_shift = rloc - 1; end if cloc > nd2 col_shift = cloc - n - 1; else col_shift = cloc - 1; end 这里我同样有一个,就是为什么求出互相关量最大值的位置后还要减去一个1或者减去1+基准图像的尺寸呢?(也即:row_shift = rloc - m - 1??或者row_shift = rloc - 1),还有为什么rloc > md2时,就得 row_shift = rloc - m - 1,其中的具体含义是什么呢? 两种方法计算最大值对应的位置,我思索了半天想,最后计算的结果表示什么意思,是表示配准时两幅图像的偏差量吗? |
» 猜你喜欢
假如你的研究生提出不合理要求
已经有8人回复
萌生出自己或许不适合搞科研的想法,现在跑or等等看?
已经有4人回复
Materials Today Chemistry审稿周期
已经有4人回复
参与限项
已经有3人回复
实验室接单子
已经有4人回复
全日制(定向)博士
已经有4人回复
对氯苯硼酸纯化
已经有3人回复
求助:我三月中下旬出站,青基依托单位怎么办?
已经有12人回复
所感
已经有4人回复
要不要辞职读博?
已经有7人回复

2楼2015-03-10 10:36:26












);
回复此楼