我想通过在 MATLAB 中应用汉明滤波器来消除一维信号中的吉布斯伪影。
我所拥有的是k1
频域中的信号。我可以通过应用 DFT 来获得时域信号k1
:
s1 = ifft(ifftshift(k1));
该信号具有吉布斯伪影。现在,我想通过 (A) 将 Hamming 滤波器乘以k1
频域和 (B) 将 Hamming 滤波器的 IFFT 与s1
空间域中的卷积来删除它。我期望这两个输出相同:
% (A) Multiplying Hamming filter to `k1`
n = size(k1,2);
wk = hamming(n,'symmetric')';
k2 = wk.*k1;
s2 = ifft(ifftshift(k2));
% (B) Convolving IFFT of Hamming filter with `s1`
wx = ifft(ifftshift(wk));
s3 = conv(s1,wx,'same');
(A), 的结果s2
似乎是正确的,因为信号看起来很模糊并且吉布斯伪影消失了。然而,(B), 的结果s3
完全不同且不正确。(B) 中缺少什么?(如果需要,请从此链接下载 k1.mat 。)