如何使用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/

10-10 08:17