最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

matlab wc wp,MATLAB

互联网 admin 14浏览 0评论

matlab wc wp,MATLAB

clear

%%%%%%%%带通滤波器%%%%%%%%%%%

WP1=0.1*pi;WP2=0.5*pi;

WS1=0.04*pi;WS2=0.8*pi;

Ap=1;As=50; % 数字带通滤波器技术指标

T=2;%一般取2

wc1=(2/T)*tan(WP1/2);

wc2=(2/T)*tan(WP2/2);

wr1=(2/T)*tan(WS1/2);

wr2=(2/T)*tan(WS2/2);%双线性下,数字到模拟指标的转换

B=wc2-wc1; %带通滤波器的通带宽度

w0=sqrt(wc1*wc2);

normwr1=(((wr1^2)-(w0^2))/(B*wr1));

normwr2=(((wr2^2)-(w0^2))/(B*wr2));

normwc1=(((wc1^2)-(w0^2))/(B*wc1));

normwc2=(((wc2^2)-(w0^2))/(B*wc2)); %带通到低通的频率变换

if abs(normwr1)>abs(normwr2) %选通带截止频率较大者

normwr=abs(normwr2)

else normwr=abs(normwr1)

end

normwc=1; %将指标转换成归一化模拟低通滤波器的指标

[N,normw]=buttord(normwc,normwr,Ap,As,'s')%设计归一化的模拟低通滤波器阶数N和截止频率

[bLP,aLP]=butter(N,normw,'s'); %计算相应的模拟滤波器系统函数G(p)

[bBP,aBP]=lp2bp(bLP,aLP,w0,B); %模拟域频率变换,将G(P)变换成模拟带通滤波器H(s) [numd,dend]=bilinear(bBP,aBP,0.5); %用双线性变换法将H(s)转换成数字带通滤波器H(z) ?

f=67; %周期67Hz

nt=1; %显示两个周期

N1=128; T=1/f; dt=T/N1; %把周期分成128分

k1=0:nt*N1-1; nx=k1*dt;

x=square(2*pi*f*nx,50); %方波产生函数50%的占空比

subplot(3,2,1);

stem(nx,x);

xlabel('tn(s)')

ylabel('x')

title('方波时域图67Hz')

L=8*N1;

X=fft(x,L);

X1=fftshift(X);

W1=linspace (-pi,pi,L);

subplot(3,2,2);

matlab wc wp,MATLAB

clear

%%%%%%%%带通滤波器%%%%%%%%%%%

WP1=0.1*pi;WP2=0.5*pi;

WS1=0.04*pi;WS2=0.8*pi;

Ap=1;As=50; % 数字带通滤波器技术指标

T=2;%一般取2

wc1=(2/T)*tan(WP1/2);

wc2=(2/T)*tan(WP2/2);

wr1=(2/T)*tan(WS1/2);

wr2=(2/T)*tan(WS2/2);%双线性下,数字到模拟指标的转换

B=wc2-wc1; %带通滤波器的通带宽度

w0=sqrt(wc1*wc2);

normwr1=(((wr1^2)-(w0^2))/(B*wr1));

normwr2=(((wr2^2)-(w0^2))/(B*wr2));

normwc1=(((wc1^2)-(w0^2))/(B*wc1));

normwc2=(((wc2^2)-(w0^2))/(B*wc2)); %带通到低通的频率变换

if abs(normwr1)>abs(normwr2) %选通带截止频率较大者

normwr=abs(normwr2)

else normwr=abs(normwr1)

end

normwc=1; %将指标转换成归一化模拟低通滤波器的指标

[N,normw]=buttord(normwc,normwr,Ap,As,'s')%设计归一化的模拟低通滤波器阶数N和截止频率

[bLP,aLP]=butter(N,normw,'s'); %计算相应的模拟滤波器系统函数G(p)

[bBP,aBP]=lp2bp(bLP,aLP,w0,B); %模拟域频率变换,将G(P)变换成模拟带通滤波器H(s) [numd,dend]=bilinear(bBP,aBP,0.5); %用双线性变换法将H(s)转换成数字带通滤波器H(z) ?

f=67; %周期67Hz

nt=1; %显示两个周期

N1=128; T=1/f; dt=T/N1; %把周期分成128分

k1=0:nt*N1-1; nx=k1*dt;

x=square(2*pi*f*nx,50); %方波产生函数50%的占空比

subplot(3,2,1);

stem(nx,x);

xlabel('tn(s)')

ylabel('x')

title('方波时域图67Hz')

L=8*N1;

X=fft(x,L);

X1=fftshift(X);

W1=linspace (-pi,pi,L);

subplot(3,2,2);

发布评论

评论列表 (0)

  1. 暂无评论