matlab(实例):滤波器(低通、带通、高通,使用butter函数、filter函数)

一、题目:已知一个时域信号,包含三个频率(50Hz、150Hz、300Hz),分别设计并使用低通滤波器、带通滤波器、高通滤波器,对其进行滤波,画出滤波信号的时域图和频谱图。

x = sin(2\pi*50t )+sin(2\pi*150t )+sin(2\pi*300t )

二、解题过程:

①函数介绍:

本次编码使用函数butter函数和filter函数

1、butter()

用于计算滤波器系数

语法:

      [b,a] = butter(n,Wn)
      [b,a] = butter(n,Wn,ftype)

      [z,p,k] = butter(___)
      [A,B,C,D] = butter(___)

      [___] = butter(___,'s')

输入参数
      n - 滤波器阶数
        整数标量
      Wn - 截止频率,注意:Wn = fc_low/(fs/2)
        标量 | 二元素向量
      ftype - 滤波器类型
        'low' | 'bandpass' | 'high' | 'stop'

输出参数
      b,a - 传递函数系数
        行向量
      z,p,k - 零点、极点和增益
        列向量、标量
      A,B,C,D - 状态空间矩阵
        矩阵

2、filter()

使用滤波器对信号进行滤波

语法
      y = filter(b,a,x)
      y = filter(b,a,x,zi)
      y = filter(b,a,x,zi,dim)
      [y,zf] = filter(___)

输入参数
      b - 有理传递函数的分子系数
        向量
      a - 有理传递函数的分母系数
        向量
      x - 输入数据
        向量 | 矩阵 | 多维数组
      zi - 滤波器延迟的初始条件
        [] (默认值) | 向量 | 矩阵 | 多维数组
      dim - 沿其运算的维度
        正整数标量

输出参数
      y - 滤波后的数据
        向量 | 矩阵 | 多维数组
      zf - 滤波器延迟的最终条件
        向量 | 矩阵 | 多维数组

②代码

1、低通滤波器

clc 
clear
close all

% 创建一个测试信号
fs = 1000; % 采样频率
t = 0:1/fs:1; % 时间向量
x = sin(2*pi*50*t) + sin(2*pi*150*t) + 0.5*sin(2*pi*300*t); % 包含50Hz、150Hz和300Hz成分的信号

fc_low = 100; % 低截止频率
fc_high = 200; % 高截止频率

N = 7; % 滤波器阶数

[b, a] = butter(N, fc_low/(fs/2), 'low'); % 计算低通滤波器系数
% [b, a] = butter(N, [fc_low/(fs/2), fc_high/(fs/2)], 'bandpass'); % 计算中通滤波器系数
% [b, a] = butter(N, fc_high/(fs/2), 'high'); % 计算中高通滤波器系数


% 使用中通滤波器对信号进行滤波
y = filter(b, a, x);

% 绘制原始信号和滤波后的信号
figure;
subplot(2,1,1);
plot(t, x);
title('原始信号');
xlabel('t/s');
ylabel('幅值');

subplot(2,1,2);
plot(t, y);
title('滤波信号');
xlabel('t/s');
ylabel('幅值');

% 傅里叶变换,画频谱图
Ns = 100; % 傅里叶变换采样点数
delta_f = fs/Ns; % 频率分辨率
x_f = (0:Ns-1)*delta_f; % 频域信号横轴
S_f = fft(x(1:Ns));
figure(2)
subplot(2,1,1)
stem(x_f, abs(S_f), 'filled');
title('原信号频谱')
xlabel('f/Hz')
ylabel('幅值')

y_f = (0:Ns-1)*delta_f; % 频域信号横轴
Y_f = fft(y(1:Ns));
subplot(2,1,2)
stem(y_f, abs(Y_f), 'filled');
title('滤波信号频谱')
xlabel('f/Hz')
ylabel('幅值')

2、带通滤波器

clc 
clear
close all

% 创建一个测试信号
fs = 1000; % 采样频率
t = 0:1/fs:1; % 时间向量
x = sin(2*pi*50*t) + sin(2*pi*150*t) + 0.5*sin(2*pi*300*t); % 包含50Hz、150Hz和300Hz成分的信号

fc_low = 100; % 低截止频率
fc_high = 200; % 高截止频率

N = 7; % 滤波器阶数

% [b, a] = butter(N, fc_low/(fs/2), 'low'); % 计算低通滤波器系数
[b, a] = butter(N, [fc_low/(fs/2), fc_high/(fs/2)], 'bandpass'); % 计算中通滤波器系数
% [b, a] = butter(N, fc_high/(fs/2), 'high'); % 计算中高通滤波器系数


% 使用中通滤波器对信号进行滤波
y = filter(b, a, x);

% 绘制原始信号和滤波后的信号
figure;
subplot(2,1,1);
plot(t, x);
title('原始信号');
xlabel('t/s');
ylabel('幅值');

subplot(2,1,2);
plot(t, y);
title('滤波信号');
xlabel('t/s');
ylabel('幅值');

% 傅里叶变换,画频谱图
Ns = 100; % 傅里叶变换采样点数
delta_f = fs/Ns; % 频率分辨率
x_f = (0:Ns-1)*delta_f; % 频域信号横轴
S_f = fft(x(1:Ns));
figure(2)
subplot(2,1,1)
stem(x_f, abs(S_f), 'filled');
title('原信号频谱')
xlabel('f/Hz')
ylabel('幅值')

y_f = (0:Ns-1)*delta_f; % 频域信号横轴
Y_f = fft(y(1:Ns));
subplot(2,1,2)
stem(y_f, abs(Y_f), 'filled');
title('滤波信号频谱')
xlabel('f/Hz')
ylabel('幅值')

3、高通滤波器

clc 
clear
close all

% 创建一个测试信号
fs = 1000; % 采样频率
t = 0:1/fs:1; % 时间向量
x = sin(2*pi*50*t) + sin(2*pi*150*t) + 0.5*sin(2*pi*300*t); % 包含50Hz、150Hz和300Hz成分的信号

fc_low = 100; % 低截止频率
fc_high = 200; % 高截止频率

N = 7; % 滤波器阶数

% [b, a] = butter(N, fc_low/(fs/2), 'low'); % 计算低通滤波器系数
% [b, a] = butter(N, [fc_low/(fs/2), fc_high/(fs/2)], 'bandpass'); % 计算中通滤波器系数
[b, a] = butter(N, fc_high/(fs/2), 'high'); % 计算中高通滤波器系数


% 使用中通滤波器对信号进行滤波
y = filter(b, a, x);

% 绘制原始信号和滤波后的信号
figure;
subplot(2,1,1);
plot(t, x);
title('原始信号');
xlabel('t/s');
ylabel('幅值');

subplot(2,1,2);
plot(t, y);
title('滤波信号');
xlabel('t/s');
ylabel('幅值');

% 傅里叶变换,画频谱图
Ns = 100; % 傅里叶变换采样点数
delta_f = fs/Ns; % 频率分辨率
x_f = (0:Ns-1)*delta_f; % 频域信号横轴
S_f = fft(x(1:Ns));
figure(2)
subplot(2,1,1)
stem(x_f, abs(S_f), 'filled');
title('原信号频谱')
xlabel('f/Hz')
ylabel('幅值')

y_f = (0:Ns-1)*delta_f; % 频域信号横轴
Y_f = fft(y(1:Ns));
subplot(2,1,2)
stem(y_f, abs(Y_f), 'filled');
title('滤波信号频谱')
xlabel('f/Hz')
ylabel('幅值')

三、结语

对于傅里叶变换,本文不再赘述,可看本人之前的文章;

要注意截止频率Wn的取值,需要除以二倍的采样频率;

有问题可以留言,本人尽量解答

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/663660.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

孩子用的灯什么样的好?安利几款适合孩子用的护眼台灯

随着学生们重返校园,家长和孩子们忙于新学期的准备工作,眼睛健康的考量自然也在其中。这也是为何近年来护眼台灯越来越受到欢迎的原因之一。作为一个长期近视并且日常用眼时间较长的人,我本人对护眼台灯有着长期的使用经历,并对它…

halcon程序如何导出C#文件

1.打开halcon文件; 2.写好需要生成C#文件的算子或函数; 3.找到档案-输出,如下图; 4.点击输出,弹出如下窗口 (1)可以修改导出文件的存储路径 (2)选择C#-HALCON/.NET &…

window11 设置 ubuntu2204 至最佳体验(安装/右键菜单/root用户/docker)

前言 在 window 中如果不使用 ubuntu 命令行会非常不方便,还好微软提供了 ubuntu 的终端,下载安装后简单设置下就可以愉快的使用了。 本文会涉及的方面 安装右键菜单设置root 用户设置docker 设置 安装 ubuntu 到微软的软件商店中下载安装即可&…

AndroidFlutter混合开发

为什么要有混合开发 我们知道,Flutter是可以做跨平台开发的,即一份Flutter的Dart代码,可以编译到多个平台上运行。这么做的好处就是,在不降低多少性能的情况下,尽最大可能的节省开发的时间成本,直接将开发…

【OrangePi AIpro】香橙派 AIpro 解锁开发新潜能

目录 引言 一、开箱初印象 二、硬件配置概览 三、软件环境搭建 网络配置【VScode】安装配置、插件及远程SSH连接SSH 访问 OrangePi AIpro配置 vim安装外设开发库 四、实战项目体验 USB 摄像头测试1、使用 fswebcam 测试 USB 摄像头2、使用 mjpg-streamer 测试 USB 摄像头&a…

Microsoft Outlook Lite 引入短信功能

随着科技的不断进步,我们的沟通方式也在不断演变。微软最新推出的 Outlook Lite 应用,不仅为我们提供了一个轻量级的电子邮件管理工具,现在更是带来了一项令人兴奋的新功能——短信服务。 Outlook Lite:轻量级,功能全…

WiFi模块网络配置基本设置

WiFi模块网络如何配置?WiFi模块网络配置基本设置如下:   1、网络配置与AT命令   请求串口或其他交互接口输入SSID或密码。   虽然通过串口AT命令配置网络很简单,但是需要串口输入,一般需要在单片机系统上提供一个人机交互接…

打工人福音⚡:公牛充电交互协议,建议收藏!

分享《一套免费开源充电桩物联网系统,是可以立马拿去商用的!》 协议原文件下载地址: 链接: https://pan.baidu.com/s/1kW15Nfe9cjPDFLGPYJ-zUg?pwdagq2 提取码: agq2 1 总则 1.1 协议概述 本协议适用于公司所有充电产品包括交直流充电桩、…

vueRouter路由总结

https://blog.csdn.net/qq_24767091/article/details/119326884

CUDA学习(2)

什么是CUDA CUDA(Compute Unified Device Architecture),统一计算设备架构,英伟达推出的基于其GPU的通用高性能计算平台和编程模型。 借助CUDA,开发者可以充分利用英伟达GPU的强大计算能力加速各种计算任务。 软件生…

MathType软件2024最新简体中文汉化版本下载

在数字化时代背景下,教育与科研领域正经历着深刻的变革。随着在线教育和远程工作的兴起,数学作为基础学科之一,其内容的高效、精准编辑和呈现变得尤为重要。MathType软件应运而生,以其强大的数学公式编辑器功能,广泛应…

校园疫情防控|基于SprinBoot+vue的校园疫情防控系统(源码+数据库+文档)

校园疫情防控系统 目录 基于SprinBootvue的校园疫情防控系统 一、前言 二、系统设计 三、系统功能设计 1系统功能模块 2后台功能模块 5.2.1管理员功能 5.2.2学生功能 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#x…

基于单片机的汽车防盗报警系统设计与实现

摘要: 为了有效保护车辆,防止车辆被盗,汽车防盗报警系统的设计成为研究的热点问题 。 基于 STC89C52 单片机设计了一套汽车防盗报警系统,该系统由硬件和软件两部分组成,通过高效集成电路形成完整的控制系统&#xff…

快解析内网穿透,无需公网IP

今天聊聊一个公网IP地址可以带来什么? 公网IP是全球可路由的地址,通俗的说,如果你设置的防火墙允许,你的设备有公网地址,那么你就可以在世界上的任何地方通过互联网访问到你的设备,如果你的电脑有公网地址&#xff0c…

第5章 锁与进程间通信(3)

目录 5.4 其他IPC机制 5.4.1 信号 5.4.2 管道和套接字 5.5 小结 本专栏文章将有70篇左右,欢迎关注,查看后续文章。 5.4 其他IPC机制 5.4.1 信号 kill命令: 作用:发送指定信号。 信号分为: 传统32个信号。 用于实…

JavaWeb笔记整理+图解——Filter过滤器

欢迎大家来到这一篇章——Filter过滤器 监听器和过滤器都是JavaWeb服务器三大组件(Servlet、监听器、过滤器)之一,他们对于Web开发起到了不可缺少的作用。 ps:想要补充Java知识的同学们可以移步我已经完结的JavaSE笔记,里面整理了大量详细的知识点和图解,可以帮你快速掌…

[SWPU 2019]神奇的二维码、buuctf部分web题

目录 [SWPU 2019]神奇的二维码 [LitCTF 2023]Http pro max plus [SWPUCTF 2021 新生赛]finalrce ​[鹏城杯 2022]简单包含 [SWPUCTF 2022 新生赛]ez_ez_php(revenge) [GKCTF 2020]cve版签到 cve-2020-7066: [SWPU 2019]神奇的二维码 解码看看,是…

让AI学相机对焦: Learning to AutoFocus

前言 分析来自谷歌发表在 CVPR 2020 上的论文 Learning to Autofocus :https://arxiv.org/pdf/2004.12260 目前网上对这篇论文的分析较少,有的分析并没有指出关键点,如:论文解读: Learning to AutoFocus-CSDN博客&am…

Iphone自动化指令每隔固定天数打开闹钟关闭闹钟(一)

注意:因为是第一次用iphone的快捷指令,不是很明白,所以之后多次运行发现有bug,所以快捷指令部分在下一章重新写,我用两个日期测试了,没问题,这一章可以当做熟悉快捷指令的一些操作用&#xff0c…

算法学习笔记(7.3)-贪心算法(最大切分乘问题)

目录 ##问题描述 ##问题思考 ##贪心策略确定 ##代码实现 ##时间复杂度 ##正确性验证 ##问题描述 给定一个正整数 𝑛 ,将其切分为至少两个正整数的和,求切分后所有整数的乘积最大是多少 ##问题思考 假设我们将 𝑛 切分为 &…