解释代码%FIR滤波器窗函数设计法 N=21;a=(N-1)/2;Wc=pi/4; n=[0:1:(N-1)]; m=n-a+eps; hd=sin(Wc*m)./(pi*m); %矩形窗 [H1,W]=freqz(hd,1); figure(1); subplot(211);stem(n,hd); xlabel('n');ylabel('hr(n)'); title('实际脉冲响应'); subplot(212); plot(W/pi,20*log10(abs(H1)/max(H1))); xlabel('频率');ylabel('幅频响应'); title('加矩形窗时的频谱图'); %汉宁窗 W_han=(hanning(N))';h2=hd.*W_han; [H2,W]=freqz(h2,1); figure(2); subplot (211);stem(n,h2); xlabel('n');ylabel('hhn(n)'); title('汉宁窗实际脉冲响应'); subplot(212); plot (W/pi,20*log10(abs(H2)/max(H2))); xlabel('频率');ylabel('幅频响应'); title('加汉宁窗时的频谱图'); %汉明窗 W_han=(hamming(N))';h3=hd.*W_han; [H3,W]=freqz (h3,1); figure(3);subplot (211); stem(n,h3);xlabel('n');ylabel('hhm(n)'); title('汉明窗实际脉冲响应'); subplot(212); plot (W/pi,20*log10(abs(H3)/max (H3))); xlabel('频率');ylabel('幅频响应'); title('加汉明窗时的频谱图'); %加Blackman窗 W_bla=(blackman(N))';h4=hd.*W_bla; [H4,W]=freqz(h4,1); figure(4); subplot(211);stem(n,h4); xlabel('n');ylabel('hbl(n)'); title('Blackman窗实际脉冲响应'); subplot (212); plot(W/pi,20*log10(abs(H4)/max (H4))); xlabel('频率');ylabel('幅频响应'); title('加Blackman窗时的频谱图');
时间: 2024-04-05 16:29:32 浏览: 17
这是一个用于设计FIR滤波器的窗函数法。代码中给出了不同种类的窗函数(矩形窗、汉宁窗、汉明窗、Blackman窗)和对应的滤波器实际脉冲响应以及加窗后的频谱图。其中,N表示滤波器的阶数,Wc表示滤波器的截止频率,n表示滤波器的时域序列,hd表示矩形窗下的理想滤波器脉冲响应,h2、h3、h4分别为加汉宁窗、汉明窗、Blackman窗后的滤波器脉冲响应。频谱图中,横坐标为频率(单位为π),纵坐标为幅度响应(单位为dB)。
相关问题
对以下代码进行分析;% 例1,设计一个带通滤波器,其参数为:ws1=0.2*pi;wp1=0.35*pi; wp2=0.65*pi;ws2=0.8*pi;Ap=-3dB, As=-75dB; % 根据阻带要求选择布莱克曼窗。 clear;clc; ws1=0.2*pi; wp1=0.35*pi; wp2=0.65*pi; ws2=0.8*pi; Ap=-3; As=-75; wd=min((wp1-ws1),(ws2-wp2)); wc1=(ws1+wp1)/2; wc2=(ws2+wp2)/2; % 计算窗口长度 N=ceil(11*pi/wd); % 计算窗口 w_bla=(blackman(N+1))'; hd=ideal_lp(wc2,N+1)-ideal_lp(wc1,N+1);%低通 h=hd.*w_bla; % 采用窗函数设计法完成低通滤波器的设计,参数为: wp1=0.35*pi; wp=0.35*pi;ws=0.8*pi;Ap=-3dB, As=-45dB; % 阻带要求是As % 采用窗函数设计法完成低通滤波器的设计 % 采用汉明窗以及ideal_lp函数 % 参数为:wp1=0.35pi; wp=0.35pi; ws=0.8*pi; Ap=-3dB, As=-45dB clear;clc; % 参数设置 wp1 = 0.35*pi; % 通带截止频率1 wp = 0.35*pi; % 通带截止频率2 ws = 0.8*pi; % 阻带截止频率 Ap = 3; % 通带最大衰减 As = 45; % 阻带最小衰减 % 计算滤波器阶数和截止频率 delta_w = ws - wp; delta_p = (10^(Ap/20)-1)/(10^(Ap/20)+1); delta_s = 10^(-As/20); A = -20*log10(min(delta_p,delta_s)); n = ceil((A-8)/(2.285*delta_w/pi)); wc = (wp+ws)/2; % 汉宁窗窗函数设计法 h = fir1(n, wc/pi, hann(n+1)); % 绘制滤波器幅频特性曲线 [H, W] = freqz(h, 1, 1024); figure; plot(W/pi, 20*log10(abs(H)));title('低通滤波器幅频特性曲线');xlabel('频率/\pi');ylabel('幅值/dB'); fvtool(h, 1); clear;clc; % 定义参数 ws = 0.2*pi; % 通带截止频率 wp = 0.35*pi; % 阻带截止频率 Ap = 3; % 通带最大衰减量 As = 50; % 阻带最小衰减量 % 计算数字滤波器阶数和截止频率 [N, wn] = buttord(wp/pi, ws/pi, Ap, As); % 设计数字滤波器b和a分别是分子和分母多项式的系数 [b, a] = butter(N, wn, 'high'); % 绘制滤波器频率响应曲线 freqz(b, a); fvtool(b, a);
此代码实现了两个滤波器的设计,一个是带通滤波器,一个是高通滤波器。
对于带通滤波器,先根据阻带要求选择布莱克曼窗,然后计算窗口长度。接着利用ideal_lp函数得到低通滤波器的理想频率响应,再用窗函数乘上,得到带通滤波器的频率响应。
对于高通滤波器,采用汉宁窗窗函数设计法,先计算滤波器阶数和截止频率,然后用fir1函数得到滤波器系数,最后绘制滤波器的频率响应曲线。
同时,在每个滤波器的设计中,都有对应的参数设置和计算过程,最后用fvtool函数绘制滤波器的幅频特性曲线。
凯泽窗函数法设计FIR数字带通滤波器,设计指标为:wp1=0.35pi,wp2=0.65pi,ws1=0.2pi,ws2=0.8pi,Rp=1db,Rs=60db,matlab代码中文
以下是使用凯泽窗函数法设计FIR数字带通滤波器的Matlab代码:
```matlab
% 定义滤波器的参数
wp1 = 0.35*pi;
wp2 = 0.65*pi;
ws1 = 0.2*pi;
ws2 = 0.8*pi;
Rp = 1;
Rs = 60;
% 计算通带和阻带的边界频率
wp = [wp1, wp2];
ws = [ws1, ws2];
% 计算通带和阻带的宽度
wp_width = wp2 - wp1;
ws_width = ws2 - ws1;
% 计算通带和阻带的中心频率
wc1 = sqrt(wp1*wp2);
wc2 = sqrt(ws1*ws2);
% 计算滤波器的阶数和截止频率
delta_p = 10^(-Rp/20) - 1;
delta_s = 10^(-Rs/20);
A = -20*log10(delta_s);
if A > 50
N = ceil((A - 7.95)/(14.36*ws_width/pi));
else
N = ceil(3.3/ws_width);
end
if rem(N, 2) == 0
N = N + 1;
end
M = (N-1)/2;
wc = (wc1 + wc2)/2;
% 计算凯泽窗函数的参数
beta = 0.1102*(A - 8.7);
if A > 50
alpha = (A - 7.95)/14.36/ws_width;
else
alpha = 0.25*(A - 21)^0.5/pi/ws_width;
end
% 生成凯泽窗函数
n = -M:M;
w = kaiser(N, beta);
% 计算理想的频率响应
Hd = zeros(1, length(n));
for i = 1:length(n)
if n(i) == 0
Hd(i) = wc/pi;
else
Hd(i) = (sin(wc*n(i))/pi/n(i))*(cos(alpha*pi*n(i))/((1 - (n(i)/M)^2)^0.5));
end
end
% 根据窗函数和理想的频率响应计算实际的频率响应
H = Hd.*w';
% 使用fir1函数生成滤波器系数
b = fir1(N-1, wc/pi, 'bandpass', Hanning(N));
% 绘制滤波器的幅频特性
freqz(b, 1, 1024, 2*pi);
```
该代码将生成一个FIR数字带通滤波器,并绘制其幅频特性。可以根据需要修改滤波器的参数,如通带边界频率、阻带边界频率、通带和阻带的宽度等来满足实际应用的需求。