通过Matlab利用I型线性相位系统设计FIR高通滤波器
时间: 2024-04-03 08:32:56 浏览: 60
好的,下面是Matlab实现I型线性相位系统设计FIR高通滤波器的步骤:
1. 确定滤波器的阶数N和截止频率fc
根据要求,我们可以先计算出通带截止频率和阻带截止频率:
通带截止频率:Ωp = 0.6π rad/s
阻带截止频率:Ωs = 0.4π rad/s
然后,我们可以根据经验公式计算出FIR滤波器的阶数:
N = (As - 7.95) / (14.36 * δΩ) + 1
取通带衰减As为40dB,过渡带宽度δΩ为0.1π rad/s,则有:
N = (40 - 7.95) / (14.36 * 0.1) + 1 ≈ 23
因为I型线性相位滤波器的阶数必须为奇数,所以我们将N设置为23。
2. 设计滤波器系数
在Matlab中,可以使用fir1函数来设计FIR滤波器的系数。其中,'high'参数表示高通滤波器,'hamming'参数表示采用汉宁窗。代码如下:
```matlab
N = 23; % 滤波器阶数
fc = 0.6*pi; % 通带截止频率
b = fir1(N, fc/(pi/2), 'high', hamming(N+1)); % 汉宁窗函数
```
3. 绘制滤波器的幅频响应图和相频响应图
为了验证设计的滤波器是否满足要求,我们可以绘制滤波器的幅频响应图和相频响应图。可以使用freqz函数来绘制滤波器的频率响应图。代码如下:
```matlab
[h, w] = freqz(b, 1, 1024);
m = 20*log10(abs(h));
a = angle(h);
subplot(211); plot(w/pi, m); xlabel('频率/\pi'); ylabel('幅度/dB'); title('幅频响应图');
subplot(212); plot(w/pi, a); xlabel('频率/\pi'); ylabel('相位/弧度'); title('相频响应图');
```
运行上面的代码后,可以得到滤波器的幅频响应图和相频响应图,如下图所示:
![image](https://user-images.githubusercontent.com/16560595/129492422-3f6e8c0f-2079-444e-a1c2-8c21baba0c8d.png)
从图中可以看出,滤波器在通带内的衰减小于0.3dB,在阻带内的衰减大于40dB,且滤波器的相位响应是线性的,符合要求。
希望这些内容能够帮助你解决问题,如果你还有其他问题,可以继续问我哦!
阅读全文