一定用得到数据预处理:去噪、滤波方法!限幅滤波、中值滤波、均值滤波、递推平均滤波,直接运行!

news/2025/2/20 23:30:45/

​适用平台:Matlab2020版本及以上

在实际应用中,滤波、去噪都是用于信号处理的工具,通常用于机器学习/深度学习技术前的数据预处理阶段,主要作用在于对信号进行平滑处理或者去除噪声,从而提取出信号中的有用信息或者改善信号的质量,以提高故障识别的性能。对于处理非平稳信号和快速变化的故障非常关键,下面对四种滤波、去噪方法进行介绍:

限幅滤波:限幅滤波的原理是通过设置一个阈值来限制信号的变化范围,超出阈值的信号被削弱或替换为临近值。

特点:

  • 优点:简单易实现,对于存在异常值或噪声干扰的信号能够有效抑制异常波形的影响。

  • 缺点:在信号变化剧烈时可能造成信号失真,且对于不同信号特征需要调整不同的阈值,不适用于所有情况。

  • 应用场景:适用于信号中存在明显异常值,离群值或者噪声的情况。

中值滤波:中值滤波是将信号中每个采样点的值替换为相应采样窗口中的中间值。该方法对于异常值和噪声有较好的抑制效果。

特点:

  • 优点:能够有效去除信号中的椒盐噪声和脉冲噪声,保留信号的边缘特征。

  • 缺点:计算量较大,对于持续的高频噪声可能滤波效果不佳,且滤波窗口的大小需要合理选择。

  • 应用场景:适用于去除椒盐噪声和脉冲噪声等非高斯噪声,如图像处理、语音信号处理等。

均值滤波:均值滤波是通过计算信号中每个采样点的邻域平均值来实现滤波,用于平滑信号,减少噪声。

特点:

  • 优点:简单易实现,对于高斯噪声和白噪声有较好的滤波效果,能够保留信号的整体趋势。

  • 缺点:对于信号中存在尖峰或脉冲噪声效果不佳,可能导致信号的平滑度过高而丢失细节信息。

  • 应用场景:适用于高斯噪声和白噪声的滤波,如信号平滑、数据预处理等。

递推平均滤波:递推平均滤波是一种滤波器,通过对连续采样数据进行加权平均来获得滤波后的输出,具有快速响应和低存储要求。

特点:

  • 优点:具有较好的抗干扰能力和快速响应特性,适用于处理动态变化的信号。

  • 缺点:在信号的瞬时变化较大时,可能造成输出延迟和失真。

  • 应用场景:递推平均滤波结合了滑动窗口和加权平均的特点,能够在保持信号的动态特性的同时,有效地抑制噪声和干扰,适用于处理动态变化的信号。

结果分析:以上述原始信号为例,从4个种滤波方式比较得出:

  • 限幅滤波:限幅滤波将信号中超过预设阈值的部分限制在阈值范围内,未超过的部分保持不变。因此,滤波结果是在保留信号大部分特征的同时,将异常值或噪声部分进行了削弱或替换,使得信号整体更加稳定。

  • 中值滤波:中值滤波将每个采样点的值替换为相应采样窗口中的中间值。这种方式能够有效地去除椒盐噪声和脉冲噪声,保留信号的边缘特征,使得滤波后的信号更加平滑且不失真。

  • 均值滤波:均值滤波通过计算每个采样点的邻域平均值来实现滤波,从而平滑信号并减少噪声。滤波结果是对信号进行了平滑处理,保留了信号的整体趋势,但可能丢失一些细节信息,特别是对于尖峰或脉冲噪声效果不佳。

  • 递推平均滤波:递推平均滤波通过对连续采样数据进行加权平均来获得滤波后的输出。由于是递推方式,滤波结果具有快速响应和较低的存储要求,在信号瞬时变化较大时,会导致输出延迟和失真,对高频噪声的滤波效果也不及其它滤波方法。

综上,这四种滤波方式的滤波结果各有特点。限幅滤波能够有效地削弱或替换异常值或噪声,中值滤波能够保留信号边缘特征,均值滤波能够平滑信号并减少噪声,递推平均滤波具有快速响应和低存储要求。在选择滤波方式时,需多方面权衡进行选择。

代码:

clc;              % 清空命令窗口
clear all;        % 清空工作区%% 限幅滤波算法
original_data = xlsread('示例数据.xlsx'); % 读取原始数据
threshold_amp = 0.5;                      % 设置幅度阈值
len = length(original_data);              % 计算数据长度
for i = 2:len-1% 判断数据是否超出阈值if abs(original_data(i) - original_data(i-1)) > threshold_amp || abs(original_data(i+1) - original_data(i)) > 0.1amplified_data(i) = (original_data(i-1) + original_data(i+1)) * 0.5; % 超出阈值则进行限幅滤波elseamplified_data(i) = original_data(i);                                % 保持不变end
end% 绘制限幅滤波前后的序列
figure(1);
subplot(2,1,1);
plot(original_data);
xlabel('原始序列','FontSize',13);
subplot(2,1,2);
plot(amplified_data, 'Color', [0.4 0.1 0.9]);
xlabel('限幅滤波后的序列','FontSize',13);
% 保存数据到文件
xlswrite('限幅滤波后的序列.xlsx', amplified_data); % 将数据保存为Excel文件
........
........

滤波后的信号我们将其自动写入Excel表格中,方便大家后续处理。

欢迎感兴趣的小伙伴联系小编获得完整版代码哦~,关注小编会继续推送更有质量的学习资料、文章程序代码~


http://www.ppmy.cn/news/1369556.html

相关文章

Springboot 项目读取yaml的配置文件信息给静态方法使用,以及通过配置 ResourceBundle 类读取config.properties

读取yaml 的配置文件 配置文件信息 iot_saas_tenement:user_id: 7........8d9bprivate_key: MII.......qQbj_url: http://4.....5:8088project_name: iot_s.......rojectdevice_name: te.....ice 创建一个类 ProxyProperties 读取配置文件信息,并对外提供get方法 …

关于NAT的几种类型

NAT网络地址转换(Network Address Translation)主要用于解决IP地址不足而提出的,NAT主要有以下几类 1、S-NAT(Source Network Address Translation)基于源地址的NAT 2、D-NAT(Destination Network Addres…

C语言 快速排序——qsort函数的介绍

qsort函数 1. 函数介绍2. 函数使用2.1 整型排序2.2 字符排序2.3 字符串排序2.4 结构体排序 3. 用冒泡思想模拟qsort函数 我们以往使用冒泡排序和选择排序等对数据进行排序时,有可能会遇到搞不清排序次数,运行时间过长等一些问题,并且这些排序…

Spring:FactoryBean预加载逻辑以及自定义实现Mybatis的接口扫描

Spring:FactoryBean预加载逻辑以及自定义实现Mybatis的接口扫描 1 前言 参考Mybatis框架的Mapper注解扫描Mapper接口的业务逻辑,其中集成Spring的逻辑里使用到了Spring框架的FactoryBean拓展点,本文针对Spring FactoryBean的加载流程进行分…

软考笔记--构件与软件复用

构件也称为组件(component),是一个功能相对独立的具有可复用价值的软件单元。在面向对象的方法中,一个构件有一组对象组成,包含可一些协作的类的集成,它们协同工作来提供一种系统功能。可复用性是指系统和其…

2024年阿里云2核4G云服务器性能如何?价格便宜有点担心

阿里云2核4G服务器多少钱一年?2核4G服务器1个月费用多少?2核4G服务器30元3个月、85元一年,轻量应用服务器2核4G4M带宽165元一年,企业用户2核4G5M带宽199元一年。本文阿里云服务器网整理的2核4G参加活动的主机是ECS经济型e实例和u1…

Angular项目升级的一般步骤?

升级Angular项目是一个重要的任务,可以带来性能改进、新功能和安全性增强等好处。以下是升级Angular项目的一般步骤: 1、备份项目文件: 在进行升级之前,务必对整个项目进行备份,以防意外情况发生。 2、查看当前版本&…

【框架】Spring 框架重点解析

Spring 框架重点解析 1. Spring 框架中的单例 bean 是线程安全的吗? 不是线程安全的 Spring 框架中有一个 Scope 注解,默认的值是 singleton,即单例的;因为一般在 Spring 的 bean 对象都是无状态的(在生命周期中不被…