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

本文主要是介绍一定用得到数据预处理:去噪、滤波方法!限幅滤波、中值滤波、均值滤波、递推平均滤波,直接运行!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

​适用平台: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.chinasem.cn/article/770526

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

Open3D 基于法线的双边滤波

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 输入参数: 输出参数: 参数影响: 2.2完整代码 三、实现效果 3.1原始点云 3.2滤波后点云 Open3D点云算法汇总及实战案例汇总的目录地址: Open3D点云算法与点云深度学习案例汇总(长期更新)-CSDN博客 一、概述         基于法线的双边

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi