如何使用Matlab(不使用内置函数)制作简单的低通FIR滤波器?
问题示例:
Implement a FIR LPF with cut-off frequency 250Hz
可能还需要给出采样频率...
解决方案尝试或我已经知道的:
x = [...] -> input signal
A = 1; -> Since this is FIR
B = [?????]
y = filter(B, A, x) -> Output signal
Afaik,B应该包含FIR滤波器的系数。但;假设我只有截止频率,如何计算这些系数?
最佳答案
最简单的事情是“window sinc”过滤器:
fs = 44100;
cutoff = 250;
t = -256:256; % This will be a 513-tap filter
r = 2*cutoff/fs;
B = sinc(r*t).*r .* blackman(length(t))';
freqz(B);
滤波器的长度(请参见
t=...
)控制过渡带的宽度。在这种情况下,cutoff
是-6 dB点。 blackman
是流行窗口的名称。您可以查看this Wikipedia页面以获取有关窗口功能的更多信息。它们在过渡带宽和阻带抑制之间基本上具有不同的权衡。关于matlab - 如何使用Matlab制作简单的FIR滤波器?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/1738702/