用汉宁窗设计线性相位低通滤波器matlab
时间: 2023-07-28 22:10:28 浏览: 168
好的,以下是用汉宁窗设计线性相位低通滤波器的 MATLAB 代码:
```matlab
% 定义滤波器参数
fc = 1000; % 截止频率
fs = 8000; % 采样频率
N = 51; % 滤波器阶数
% 计算理想低通滤波器的频率响应
H_ideal = zeros(1, N);
for n = 1:N
if (n-(N+1)/2 == 0)
H_ideal(n) = 2*pi*fc/fs;
else
H_ideal(n) = sin(2*pi*fc*(n-(N+1)/2)/fs)/(pi*(n-(N+1)/2));
end
end
% 计算汉宁窗函数
w = hann(N)';
% 将理想低通滤波器的频率响应与汉宁窗函数相乘得到实际频率响应
H = H_ideal.*w;
% 将实际频率响应应用于 FIR 滤波器系数中
b = H;
% 将滤波器系数归一化
b = b/sum(b);
% 绘制频率响应
freqz(b, 1, 1024, fs);
```
运行以上代码,将产生一个低通滤波器的频率响应图。请注意,汉宁窗是一种窗函数,用于在频域中对理想滤波器的频率响应进行加权,以减少滤波器的频域泄漏。这种技术被称为频域窗口法。
相关问题
调用MATLAB工具箱函数fir1设计线性相位低通FIRDF,要求希望逼近的理想低通滤波器通带截止频率wc = pi/3 rad,滤波器长度N = 25。分别选用矩形窗、汉宁窗、哈明窗和布莱克曼窗进行设计,绘制用每种窗函数设计的单位脉冲响应h(n)及其幅频特性曲线,代码
以下是MATLAB代码实现:
```matlab
% 理想低通滤波器通带截止频率
wc = pi/3;
% 滤波器长度
N = 25;
% 设计矩形窗滤波器
h_rect = fir1(N-1, wc/pi, 'low', rectwin(N));
freqz(h_rect);
% 设计汉宁窗滤波器
h_hamming = fir1(N-1, wc/pi, 'low', hamming(N));
freqz(h_hamming);
% 设计哈明窗滤波器
h_hanning = fir1(N-1, wc/pi, 'low', hanning(N));
freqz(h_hanning);
% 设计布莱克曼窗滤波器
h_blackman = fir1(N-1, wc/pi, 'low', blackman(N));
freqz(h_blackman);
```
其中,`fir1`函数用于设计FIR滤波器,`freqz`函数用于绘制幅频特性曲线。在`fir1`函数中,第一个参数为滤波器长度减一,第二个参数为通带截止频率除以π,第三个参数为滤波器类型(这里选择了低通滤波器),第四个参数为窗函数。
用窗函数法设计一线性相位fir低通滤波器
线性相位FIR低通滤波器可以使用窗函数法设计,步骤如下:
1. 确定滤波器的阶数N和截止频率fc。
2. 根据式子h(n)=2fc * sinc(2fc(n-N/2))计算出理想低通滤波器的单位取样响应h_i(n)。
3. 选择一个窗函数w(n),如矩形窗、汉宁窗、汉明窗等。
4. 计算出窗函数w(n)和理想低通滤波器单位取样响应h_i(n)的乘积,即h_w(n)=h_i(n)w(n)。
5. 对h_w(n)进行DFT,得到其频域表示H_w(k)。
6. 将H_w(k)乘以exp(-j*k*N/2),得到线性相位FIR低通滤波器的频域表示H(k)。
7. 对H(k)进行IDFT,得到其时域表示h(n)。
下面给出MATLAB代码实现:
```matlab
N = 31; % 滤波器阶数
fc = 0.2; % 截止频率
h_i = 2*fc*sinc(2*fc*((0:N-1)-N/2)); % 计算理想低通滤波器
w = hamming(N); % 选择汉明窗
h_w = h_i.*w'; % 计算窗函数与理想滤波器的乘积
H_w = fft(h_w); % 计算DFT
H = H_w.*exp(-1j*pi*(0:N-1)*N/2); % 计算线性相位FIR低通滤波器的频域表示
h = real(ifft(H)); % 计算时域表示
```
其中,hamming(N)表示生成长度为N的汉明窗。通过修改窗函数和截止频率,可以得到不同的线性相位FIR低通滤波器。
阅读全文