[信号与系统]FIR滤波器的几种常见窗口法计算方法

FIR滤波器的几种常见窗口法计算方法

1. 矩形窗口(Rectangular Window)

矩形窗口直接截断理想脉冲响应,无额外的平滑效果。它简单但会引入较大的旁瓣效应。

w [ n ] = 1 , 0 ≤ n ≤ N − 1 w[n] = 1, \quad 0 \le n \le N-1 w[n]=1,0≤n≤N−1

2. 汉宁窗口(Hanning Window)

汉宁窗口使用平滑的余弦函数,有效减少旁瓣效应。

w [ n ] = 0.5 ( 1 − cos ⁡ ( 2 π n N − 1 ) ) , 0 ≤ n ≤ N − 1 w[n] = 0.5 \left(1 - \cos\left(\frac{2\pi n}{N-1}\right)\right), \quad 0 \le n \le N-1 w[n]=0.5(1−cos(N−12πn)),0≤n≤N−1

3. 汉明窗口(Hamming Window)

汉明窗口是汉宁窗口的变种,进一步减少旁瓣效应,适用于大多数实际应用。

w [ n ] = 0.54 − 0.46 cos ⁡ ( 2 π n N − 1 ) , 0 ≤ n ≤ N − 1 w[n] = 0.54 - 0.46 \cos\left(\frac{2\pi n}{N-1}\right), \quad 0 \le n \le N-1 w[n]=0.54−0.46cos(N−12πn),0≤n≤N−1

4. 布莱克曼窗口(Blackman Window)

布莱克曼窗口具有更好的旁瓣抑制效果,适用于需要高频率分辨率的情况。

w [ n ] = 0.42 − 0.5 cos ⁡ ( 2 π n N − 1 ) + 0.08 cos ⁡ ( 4 π n N − 1 ) , 0 ≤ n ≤ N − 1 w[n] = 0.42 - 0.5 \cos\left(\frac{2\pi n}{N-1}\right) + 0.08 \cos\left(\frac{4\pi n}{N-1}\right), \quad 0 \le n \le N-1 w[n]=0.42−0.5cos(N−12πn)+0.08cos(N−14πn),0≤n≤N−1

5. 凯撒窗口(Kaiser Window)

凯撒窗口具有可调参数 β \beta β,通过调整 β \beta β 可以在主瓣宽度和旁瓣抑制之间进行权衡。

w [ n ] = I 0 ( π β 1 − ( 2 n N − 1 − 1 ) 2 ) I 0 ( π β ) , 0 ≤ n ≤ N − 1 w[n] = \frac{I_0\left(\pi \beta \sqrt{1 - \left(\frac{2n}{N-1} - 1\right)^2}\right)}{I_0(\pi \beta)}, \quad 0 \le n \le N-1 w[n]=I0(πβ)I0(πβ1−(N−12n−1)2 ),0≤n≤N−1

其中 I 0 I_0 I0 是零阶修正贝塞尔函数, β \beta β 为窗口的形状参数。

应用窗口函数设计FIR滤波器的步骤

  1. 定义理想脉冲响应

假设我们设计一个理想的低通滤波器,其理想的脉冲响应为:

h d [ n ] = sin ⁡ ( 2 π f c ( n − N − 1 2 ) ) π ( n − N − 1 2 ) , n ≠ N − 1 2 h_d[n] = \frac{\sin\left(2\pi f_c \left(n - \frac{N-1}{2}\right)\right)}{\pi \left(n - \frac{N-1}{2}\right)}, \quad n \neq \frac{N-1}{2} hd[n]=π(n−2N−1)sin(2πfc(n−2N−1)),n=2N−1

当 n = N − 1 2 n = \frac{N-1}{2} n=2N−1 时,

h d [ N − 1 2 ] = 2 f c h_d\left[\frac{N-1}{2}\right] = 2 f_c hd[2N−1]=2fc

  1. 选择窗口函数

选择适当的窗口函数 w [ n ] w[n] w[n]。

  1. 应用窗口函数

将窗口函数应用到理想的脉冲响应上:

h [ n ] = h d [ n ] ⋅ w [ n ] , 0 ≤ n ≤ N − 1 h[n] = h_d[n] \cdot w[n], \quad 0 \le n \le N-1 h[n]=hd[n]⋅w[n],0≤n≤N−1

示例

假设我们使用汉明窗口设计一个低通FIR滤波器:

python 复制代码
import numpy as np
import matplotlib.pyplot as plt

# 定义滤波器参数
N = 51  # 滤波器长度
fc = 0.25  # 归一化截止频率(f_c = f_c_actual / f_s)

# 理想脉冲响应
n = np.arange(N)
hd = np.sinc(2 * fc * (n - (N - 1) / 2))

# 汉明窗口
w = 0.54 - 0.46 * np.cos(2 * np.pi * n / (N - 1))

# 应用窗口函数
h = hd * w

# 频率响应
H = np.fft.fft(h, 1024)
H = np.fft.fftshift(H)  # 移动零频到中心
H_dB = 20 * np.log10(np.abs(H))

# 绘制时域和频域响应
plt.figure(figsize=(12, 6))

plt.subplot(2, 1, 1)
plt.stem(n, h, use_line_collection=True)
plt.title('时域脉冲响应')
plt.xlabel('样本点')
plt.ylabel('幅度')

plt.subplot(2, 1, 2)
f = np.linspace(-0.5, 0.5, len(H))
plt.plot(f, H_dB)
plt.title('频域响应')
plt.xlabel('归一化频率')
plt.ylabel('幅度 (dB)')
plt.grid()
plt.show()
相关推荐
怪小庄吖8 小时前
翻译:How do I reset my FPGA?
经验分享·嵌入式硬件·fpga开发·硬件架构·硬件工程·信息与通信·信号处理
network_tester1 天前
手机网络性能测试仪器介绍
网络·网络协议·tcp/ip·测试工具·信息与通信·信号处理·tcpdump
一个通信老学姐2 天前
专业138总分400+中国科学技术大学843信号与系统考研中科大电子信息通信生医先研,真题,大纲,参考书。
考研·信息与通信·信号处理
吹个泡泡(c++后端开发)4 天前
linux之进程信号(信号保存 & 信号处理)
linux·信号处理
一个通信老学姐6 天前
专业130+总分410+西安交通大学815/869原909信号与系统考研电子信息与通信工程。真题,大纲,参考书。
考研·信息与通信·信号处理
阑梦清川9 天前
信号与系统初识---信号的分类
信号与系统
ling1s10 天前
重邮+数字信号处理实验七:用 MATLAB 设计 IIR 数字滤波器
深度学习·matlab·信号处理
唔皇万睡万万睡12 天前
基于DFT与IIR-FIR滤波器的音频分析与噪声处理
算法·matlab·音频·信号处理
martian66512 天前
【人工智能语音识别】——深入详解人工智能语音信号处理:理解语音信号的特征提取与表示
人工智能·语音识别·信号处理
大模型铲屎官12 天前
PyTorch 时间序列与信号处理全解析:从预测到生成
人工智能·pytorch·python·深度学习·大模型·信号处理·时间序列