matlab设计模拟带通滤波器

matlab设计模拟带通滤波器简单记录下在matlab上如何设计出模拟的带通滤波器,包括:巴特沃斯滤波器、切比雪夫I型滤波器、切比雪夫II型滤波器、椭圆型滤波器。代码如下:%设计带通滤波器%巴特沃斯、切比雪夫I型、切比雪夫II型

大家好,又见面了,我是你们的朋友全栈君。

简单记录下在matlab上如何设计出模拟的带通滤波器,包括:巴特沃斯滤波器、切比雪夫I型滤波器、切比雪夫II型滤波器、椭圆型滤波器。
代码如下:

%设计带通滤波器
%巴特沃斯、切比雪夫I型、切比雪夫II型、椭圆型滤波器

clear all;

%wp和ws分别是通带和阻带的频率(截止频率)。当wp和ws为二元矢量时,为带通或带阻滤波器,这时求出的Wn也是二元矢量;当wp和ws为一元矢量时,为低通或高通滤波器:当wp<ws时为低通滤波器,当wp>ws时为高通滤波器。

%wp和ws为二元矢量
wp=[0.1*2*pi 0.15*2*pi]; %设置通带频率
ws=[0.05*2*pi 0.2*2*pi]; %设置阻带频率

Rp=1; %设置通带波纹系数
Rs=20; %设置阻带波纹系数

%巴特沃斯滤波器设计
[N,Wn]=buttord(wp,ws,Rp,Rs,’s’); %求巴特沃斯滤波器阶数,输出参数N代表满足设计要求的滤波器的最小阶数,Wn是等效低通滤波器的截止频率
%无论是高通、带通和带阻滤波器,在设计中最终都等效于一个截止频率为Wn的低通滤波器(我现在也不是很理解为啥是这样,毕竟我也是刚接触滤波器)
fprintf(‘巴特沃斯滤波器 N= %4d\n’,N); %显示滤波器阶数
[bb,ab]=butter(N,Wn,’s’); %求巴特沃斯滤波器系数,即求传输函数的分子和分母的系数向量
W=0:0.01:2; %设置模拟频率
[Hb,wb]=freqs(bb,ab,W); %求巴特沃斯滤波器频率响应
plot(wb/pi,20*log10(abs(Hb)),’b’); %作图
hold on

%切比雪夫I型滤波器设计
[N,Wn]=cheb1ord(wp,ws,Rp,Rs,’s’); %求切比雪夫I型滤波器阶数
fprintf(‘切比雪夫I型滤波器 N= %4d\n’,N); %显示滤波器阶数
[bc1,ac1]=cheby1(N,Rp,Wn,’s’); %求切比雪夫I型滤波器系数,即求传输函数的分子和分母的系数向量
[Hc1,wc1]=freqs(bc1,ac1,W); %求切比雪夫I型滤波器频率响应
plot(wc1/pi,20*log10(abs(Hc1)),’k’); %作图

%切比雪夫II型滤波器设计
[N,Wn]=cheb2ord(wp,ws,Rp,Rs,’s’); %求切比雪夫II型滤波器阶数
fprintf(‘切比雪夫II型滤波器 N= %4d\n’,N);%显示滤波器阶数
[bc2,ac2]=cheby2(N,Rs,Wn,’s’); %求切比雪夫II型滤波器系数,即求传输函数的分子和分母的系数向量
[Hc2,wc2]=freqs(bc2,ac2,W); %求切比雪夫II型滤波器频率响应
plot(wc2/pi,20*log10(abs(Hc2)),’r’); %作图

%椭圆型滤波器设计
[N,Wn]=ellipord(wp,ws,Rp,Rs,’s’); %求椭圆型滤波器阶数
fprintf(‘椭圆型滤波器 N= %4d\n’,N); %显示滤波器阶数
[be,ae]=ellip(N,Rp,Rs,Wn,’s’); %求椭圆型滤波器系数,即求传输函数的分子和分母的系数向量
[He,we]=freqs(be,ae,W); %求椭圆型滤波器频率响应
%作图
plot(we/pi,20*log10(abs(He)),’g’);
axis([0 max(we/pi) -30 2]);
legend(‘巴特沃斯滤波器’,’切比雪夫I型滤波器’,’切比雪夫II型滤波器’,’椭圆型滤波器’);
xlabel(‘角频率{\omega}/{\pi}’);
ylabel(‘幅值/dB’);
line([0 max(we/pi)],[-20 -20],’color’,’k’,’linestyle’,’–‘);%在画布上画线
line([0 max(we/pi)],[-1 -1],’color’,’k’,’linestyle’,’–‘);
line([0.2 0.2],[-30 2],’color’,’k’,’linestyle’,’–‘);
line([0.3 0.3],[-30 2],’color’,’k’,’linestyle’,’–‘);

运行结果如下:

巴特沃斯滤波器 N= 4
切比雪夫I型滤波器 N= 3
切比雪夫II型滤波器 N= 3
椭圆型滤波器 N= 2

<span role="heading" aria-level="2">matlab设计模拟带通滤波器

 

 注:
1、求各种滤波器的传输函数的分子和分母向量系数的函数,例如:

[bc1,ac1]=cheby1(N,Rp,Wn,’s’); %求切比雪夫I型滤波器系数,即求传输函数的分子和分母的系数向量

这里的函数cheby1()中的参数为

cheby1(N,Rp,Wn,’type’,’s’);

其中注意’type’可为高通:’high’或带阻:‘stop’,如果不填的话,默认是低通或者带通,至于是低通还是带通,主要看你前面的wp和ws是二元矢量还是一元矢量:二元矢量对应带通,一元矢量对应低通。

2、matlab中的line()函数简单介绍:
https://blog.csdn.net/qq_36554582/article/details/83352155
————————————————
版权声明:本文为CSDN博主「逸凌123」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_36554582/article/details/83350837

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155297.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Android蓝牙开发教程(一)——搜索蓝牙设备[通俗易懂]

    Android蓝牙开发教程(一)——搜索蓝牙设备[通俗易懂]Android蓝牙功能的开发一直是很多新手头疼的问题,网上虽然也有很多教程贴,但大多都写得不全面,不能让我们真正掌握蓝牙开发的基本知识。本教程主要讲解搜索蓝牙设备、蓝牙设备之间的连接和蓝牙之间的通讯三个主要模块。掌握了这三个,基本就能进行简单的蓝牙开发了。先上效果图界面比较简单。主要有三个按钮,两个文本和一个列表。三个按钮主要对应打开蓝牙,搜索设备和发送信息三个功能。两个文本主…

    2022年7月15日
    27
  • matlab语法 axis on,matlab axis

    matlab语法 axis on,matlab axisaxisoff;%去掉坐标轴axistight;%紧坐标轴axisequal;%等比坐标轴axis([-0.1,8.1,-1.1,1.1]);%坐标轴的显示范围%gca:gca,h=figure(…);set(gca,’XLim’,[340]);%X轴的数据显示范围set(gca,’XTick’,[-3.14,0,3.14]);%X轴的记号点set(gca,’XTickla…

    2022年6月12日
    36
  • idea2021 激活码-激活码分享[通俗易懂]

    (idea2021 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~V…

    2022年3月22日
    75
  • 视频识别训练2.3(实现TensorFlow视频识别)

    视频识别训练2.3(实现TensorFlow视频识别)盯住梅西:TensorFlow目标检测实战https://baijiahao.baidu.com/s?id=1581115075233058548&amp;wfr=spider&amp;for=pc1、对于谷歌开源的TensorFlowObjectDetectionAPI视频物体识别系统实现教程http://blog.csdn.net/xiaoxiao123jun/article/detai…

    2022年5月31日
    45
  • reaver使用方法

    reaver使用方法闲话少叙使用方法:airmon-ngstartwlan0//启动mon0监控reaver-imon0-bMAC-a-S-vv//普通用法如果,90.9%进程后死机或停机,请记下PIN前四位数,用指令:reaver-imon0-bMAC-a-vv-pXXXX(PIN前四位数)其他命令airodump-ngmon0用来扫描周

    2022年6月4日
    65
  • centos 安装 python3_centos运行python脚本

    centos 安装 python3_centos运行python脚本注意:以下教程是让centOS7里面的Python2和Python3共存,并不是替换Python2。一、检查系统是否有gccgcc–version ——查询是否安装gcc-v——查询版本如果没有显示就执行下面yum安装gcc #查看gcc安装包yumsearchgcc#安装gccyum -yinstallgcc 安装下面依赖库(65个,…

    2025年12月9日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号