📄 call_l2bp5.m
字号:
% 《数字信号处理教程——MATLAB释义与实现》第八章模拟滤波器频带变换演示程序的子程序
% 电子工业出版社出版 陈怀琛编著 2004年9月
% call_l2bp5.m 绘制带通滤波器的图形 坐标的对应关系已改 同时绘图 data:12.12
%
function []=call_l2bp5(h1,h2);
axes(h1);hold off;
axes(h2);hold off;
%这里设低通滤波器的通带衰减频率为fc=1,阻带衰减频率为fs=2;带通或带阻滤波器的中心频率f0 可以更改这些值
%给定的参数如下:(根据给定的设计其他滤波器的转化公式得出fc ,fs,f0
%如果有必要的话,这些参数可以从主函数传递过来,这样子函数的原形变为: call_l2bp5(h1,h2,dt,T,fc,fs,f0)
%还可以在图形上加edit控件,在调用本函数时得到其值 ,如: hedit1=uicontrol('style','edit',position',[ ]); dt=get(hedit1,'values');
dt=0.1;T=3; fc=1; fs=1.5; f0=5;omegac=2;
ws1=(T-fs)/dt+1; wc1=(T-fc)/dt+1; wc2=(T+fc)/dt+2; ws2=(T+fs)/dt+2; w0=T/dt+1;
pl2=[0:dt:T]; %原始低通滤波器所选的坐标范围,可以改变!
pl1=[-T:dt:T];
p1=pl1*j;
plp5=transform(pl2,f0,omegac,'lp2lp');
p5 =plp5*j;
php2=transform(pl2,f0,omegac,'lp2hp'); %从低通滤波器坐标范围变换来的高通滤波器的范围,一一对应的关系
p2=php2*j;
pbp3=transform(pl2,f0,omegac,'lp2bp');
pbp4=fliplr(pbp3); %% 为了改变在绘负半轴图时是从小到大的
p3=j*pbp3;
pbs4=transform(pl2,f0,omegac,'lp2bs'); %在作为带阻滤波器设计时可以用到
p4=j*pbs4;
for i=1:length(p1)
hl1(i)=1/abs((p1(i)^2 + 0.6180*p1(i) + 1)*(p1(i)^2 + 1.6180*p1(i) + 1)*(p1(i)+1));
end
hh1=hl1;
hbp1=hl1;
hbs1=hl1;
p1=[-T:dt:T]; %在定坐标时要把虚号去掉
mark1=1;
for j=1:2
for i=2:length(p2)
%低通滤波器
axes(h1);
if (j==2 & mark1==1)
mark1=0;
hold off;
end
if (i<=ws1 | i>=ws2) %这里10表示 1/0.1;
plot([p1(i-1),p1(i)],[hl1(i-1),hl1(i)],'color','r');axis([-T,T,0,1.2]);hold on
elseif ((i>ws1 & i<=wc1)|(i>=wc2 & i<ws2)) %这里24表示2.4/0.1;
plot([p1(i-1),p1(i)],[hl1(i-1),hl1(i)],'color','b');axis([-T,T,0,1.2]);hold on
else
plot([p1(i-1),p1(i)],[hl1(i-1),hl1(i)],'color','c');axis([-T,T,0,1.2]);hold on
end
if (j==2)
%带通滤波器绘制
axes(h2);
if (i<=ws1 | i>=ws2) %这里10表示 0.5/0.1;带通滤波器关于中心频率处对称,具体计算参见p166
plot([pbp3(i-1),pbp3(i)],[hbp1(i-1),hbp1(i)],'color','r');axis([-f0-T,f0+T,0,1.2]);hold on
elseif ((i>ws1 & i<=wc1)|(i>=wc2 & i<ws2)) %这里13表示(6.3-5)/0.1;
plot([pbp3(i-1),pbp3(i)],[hbp1(i-1),hbp1(i)],'color','b');axis([-f0-T,f0+T,0,1.2]);hold on
else
plot([pbp3(i-1),pbp3(i)],[hbp1(i-1),hbp1(i)],'color','c');axis([-f0-T,f0+T,0,1.2]);hold on
end
else
%带通滤波器绘制
axes(h2);
if (i<=ws1 | i>=ws2) %这里10表示 0.5/0.1;带通滤波器关于中心频率处对称,具体计算参见p166
plot([-pbp4(i-1),-pbp4(i)],[hbp1(i-1),hbp1(i)],'color','r');axis([-f0-T,f0+T,0,1.2]);hold on
elseif ((i>ws1 & i<=wc1)|(i>=wc2 & i<ws2)) %这里13表示(6.3-5)/0.1;
plot([-pbp4(i-1),-pbp4(i)],[hbp1(i-1),hbp1(i)],'color','b');axis([-f0-T,f0+T,0,1.2]);hold on
else
plot([-pbp4(i-1),-pbp4(i)],[hbp1(i-1),hbp1(i)],'color','c');axis([-f0-T,f0+T,0,1.2]);hold on
end
end
pause(0.1);
end
pause(1);
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -