基于EMD的滚动轴承故障诊断算法matlab仿真

news2024/11/25 16:29:04

目录

1.算法运行效果图预览

2.算法运行软件版本

3.部分核心程序

4.算法理论概述

4.1EMD的基本原理

固有模态函数(IMF)

筛分过程

4.2 基于EMD的滚动轴承故障诊断算法

信号预处理

EMD分解

特征提取

故障诊断

5.算法完整程序工程


1.算法运行效果图预览

2.算法运行软件版本

matlab2022a

3.部分核心程序

.......................................................................
axes(handles.axes5) 
[x,t,ssf,yy,fxs]=plotspec2(IMF(1,:),1/fs);
plot(t,x)   
xlabel('Sample number');
ylabel(['imf(',num2str(1),')']); 
title(['imf(',num2str(1),')信号']);
xlim([0,t(end)]);

axes(handles.axes7) 
plot(ssf,abs(fxs))         % plot magnitude spectrum
xlabel('频率'); 
ylabel('幅度')   % label the axes
title(['imf(',num2str(1),')频谱']);
    
axes(handles.axes8) 
[yt,Vm]=func_baoluo(IMF(1,:),fs,1);
[maxv,maxl]=max(Vm);
hold on
plot(yt(maxl),maxv,'r*');
title(['imf(',num2str(1),')包络谱']);
xlim([0,500]);


axes(handles.axes9) 
[x,t,ssf,yy,fxs]=plotspec2(IMF(2,:),1/fs);
plot(t,x)   
xlabel('Sample number');
ylabel(['imf(',num2str(2),')']); 
title(['imf(',num2str(2),')信号']);
xlim([0,t(end)]);

axes(handles.axes10) 
plot(ssf,abs(fxs))         % plot magnitude spectrum
xlabel('频率'); 
ylabel('幅度')   % label the axes
title(['imf(',num2str(2),')频谱']);
    
axes(handles.axes11) 
[yt,Vm]=func_baoluo(IMF(2,:),fs,1);
[maxv,maxl]=max(Vm);
hold on
plot(yt(maxl),maxv,'r*');
title(['imf(',num2str(2),')包络谱']);
xlim([0,500]);





if LEVELview>=3
figure;
for i=1:LEVELview
    

    [x,t,ssf,yy,fxs]=plotspec2(IMF(i,:),1/fs);
    
    subplot(LEVEL,3,3*i-2);
    plot(t,x)   
    xlabel('Sample number');
    ylabel(['imf(',num2str(i),')']); 
    title(['imf(',num2str(i),')信号']);
    xlim([0,t(end)]);
    
    
    subplot(LEVEL,3,3*i-1);
    plot(ssf,abs(fxs))         % plot magnitude spectrum
    xlabel('频率'); 
    ylabel('幅度')   % label the axes
    title(['imf(',num2str(i),')频谱']);
    
    
    subplot(LEVEL,3,3*i);

    [yt,Vm]=func_baoluo(IMF(i,:),fs,1);
    [maxv,maxl]=max(Vm);
    maxv
    hold on
    plot(yt(maxl),maxv,'r*');
    
    title(['imf(',num2str(i),')包络谱']);
    xlim([0,500]);
    
end
end

% --- Executes on button press in pushbutton4.
function pushbutton4_Callback(hObject, eventdata, handles)
% hObject    handle to pushbutton4 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
clc;
clear;
close all;


% --- Executes on button press in pushbutton5.
function pushbutton5_Callback(hObject, eventdata, handles)
% hObject    handle to pushbutton5 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
parameters;

figure;
for i=1:LEVEL
y_cum = cumest(IMF(i,:)',4,512);
    subplot(LEVEL,2,2*i-1);
    plot(t,x)   
    xlabel('Sample number');
    ylabel(['imf(',num2str(i),')']); 
    title(['imf(',num2str(i),')信号']);
    xlim([0,t(end)]);
    
    
    subplot(LEVEL,2,2*i);
    plot(y_cum)   
    title(['imf(',num2str(i),')高阶谱']);
end
17_013m

4.算法理论概述

        基于经验模态分解(Empirical Mode Decomposition,EMD)的滚动轴承故障诊断算法是一种有效的非平稳信号处理方法,特别适用于处理非线性、非平稳的振动信号。该方法通过自适应地将复杂信号分解为一系列固有模态函数(Intrinsic Mode Functions,IMFs),进而提取出信号的时频特征,为滚动轴承的故障诊断提供有力支持。

4.1EMD的基本原理

        EMD方法的核心思想是根据信号自身的局部时域特性,自适应地将其分解为一系列固有模态函数。每个IMF代表信号中不同频率尺度的振荡模式,且具有明确的物理意义。

固有模态函数(IMF)

固有模态函数是满足以下两个条件的函数:

  1. 在整个数据序列中,极值点(包括极大值点和极小值点)的数量与过零点的数量相等或最多相差一个。
  2. 在任意时刻,由局部极大值点定义的上包络线和由局部极小值点定义的下包络线的均值为零。

筛分过程

EMD通过以下步骤对信号进行筛分,得到一系列IMF:

4.2 基于EMD的滚动轴承故障诊断算法

信号预处理

        首先,对采集到的滚动轴承振动信号进行预处理,包括降噪、去趋势等,以减少噪声和其他干扰因素对故障诊断的影响。

EMD分解

        将预处理后的信号作为输入,应用EMD方法进行分解,得到一系列IMF。每个IMF代表信号中不同频率尺度的振荡模式,反映了滚动轴承不同故障特征的信息。

特征提取

        从分解得到的IMFs中提取出与滚动轴承故障相关的特征。常用的特征包括IMF的能量、均方根值、峰值、峭度等。这些特征能够有效地描述滚动轴承的状态和故障类型。

故障诊断

        利用提取的特征构建故障诊断模型实现对滚动轴承故障类型的自动识别和诊断。

        为了验证基于EMD的滚动轴承故障诊断算法的有效性,可以采用实验数据进行验证。首先,采集不同状态下(正常、不同故障类型)的滚动轴承振动信号;然后,应用EMD方法进行信号分解和特征提取;最后,利用提取的特征训练故障诊断模型,并对测试数据进行故障诊断。通过比较诊断结果与真实故障类型的符合程度,评估算法的性能和准确性。

5.算法完整程序工程

OOOOO

OOO

O

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python爱心光波完整代码

文章目录 环境需求完整代码详细分析环境需求 python3.11.4PyCharm Community Edition 2023.2.5pyinstaller6.2.0(可选,这个库用于打包,使程序没有python环境也可以运行,如果想发给好朋友的话需要这个库哦~)【注】 python环境搭建请见:https://want595.blog.csdn.net/arti…

3d导入模型怎样显示原本材质---模大狮模型网

要在导入3D模型时保留原本的材质,您可以尝试以下方法: 导入前检查文件格式:确保您所使用的3D软件支持导入模型的文件格式。不同的软件对文件格式的支持有所差异,选择正确的文件格式可以更好地保留原始材质。 使用正确的材质库&am…

pip freeze 导出的requirements.txt文件含有 @file

使用 pip freeze > requirements.txt 导出的文件中含有 file:// 使用这个文件在其他环境下安装就会出现 找不到路径的错误 原因是这种方法生成的文件只能用于本地环境,无法供他们使用 使用以下方式生成文件 解决:pip list --formatfreeze …

【数据库系统概论】第6章-关系数据库理论

真别看吧,抄ppt而已啊 文章目录 6.1 引言6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式(Normal Form)6.2.4 BC范式6.2.5 规范化小结 6.1 引言 我们有这样一张表: but 为啥这样设计呢?由此引出怎样设计一个关系数据库…

C++的多继承和虚继承

目录 多继承的定义和用法定义多继承多继承中派生类对象的内存布局访问基类成员多继承带来的问题 虚继承虚继承的语法虚继承对象的内存布局虚继承中的构造虚继承的缺点 多继承的定义和用法 C支持多继承,即一个派生类可以有多个基类。 很多时候,单继承就…

Spring boot:3.X + Security OAuth2 自定义登录页面、登出后跳转到登录页

本文描述了基于 Spring Oauth2 的 code 模式&#xff0c;实现登陆同时授权、自定义登录界面、登出页面的功能。 1.Maven依赖&#xff1a; <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactI…

文件打包上传linux服务器,通过http协议url下载

背景&#xff1a;服务器部署tomcat&#xff0c;已经运行项目 直接在编译后的class文件新建文件&#xff0c;把想要下载的文件放入&#xff0c; 编译后新建文件存放 访问时&#xff0c;加zl/xxx.zip

Springboot拦截器及统一异常处理

文章目录 一、Java中异常相关概念1、异常类2、异常处理方法3、注意事项4、自定义异常 二、配置全局异常处理1、统一返回体定义2、定义异常处理实现类3、全局异常处理类 三、Springboot拦截器1、定义拦截器2、注册拦截器 四、验证效果 一、Java中异常相关概念 1、异常类 Throw…

微信小程序开发系列-07组件

在开发小程序的过程中会遇到一个常见的问题&#xff0c;怎样将其他同事提供的样式或者第三方的样式载入自己的工程&#xff0c;本文基于这个问题为索引&#xff0c;探索下小程序的组件。 什么是组件 组件是视图层的基本组成单元。组件自带一些功能与微信风格一致的样式。一个…

C++标准模板库(STL)

标准模板库&#xff08;STL&#xff09;是一组C模板类&#xff0c;提供常见的编程数据结构和函数&#xff0c;如列表、堆栈、数组等。它是一个容器类、算法和迭代器的库。它是一个通用库&#xff0c;因此&#xff0c;它的组件是参数化的。模板类的相关知识是使用STL的先决条件。…

vivado set_max_delay案例分析

案例分析 在一些设计中&#xff0c;某些信号在特定模式下具有恒定值。例如&#xff0c;在功能模式下&#xff0c;测试信号不切换&#xff0c;因此与VDD或VSS相连这取决于它们的活动水平。这也适用于在设计完成后不切换的信号已通电。同样&#xff0c;今天的设计有多种功能模式…

优秀数据库开发工具Navicat Premium 16 Mac/win中文版

Navicat Premium 16作为一款综合性的数据库开发工具&#xff0c;可以支持主流的数据库管理系统&#xff0c;如MySQL、MariaDB、Oracle、SQL Server等。无论是进行数据库建模、数据导入导出、SQL脚本编辑&#xff0c;还是数据同步、备份恢复等操作&#xff0c;Navicat Premium 1…

Linux安装常用的软件(jdk,MySQL,nginx)并完成对前后端项目的部署发布

linux软件安装&#xff1a; 安装方式介绍&#xff1a; 二进制发布包安装&#xff1a; 软件已经针对具体平台编译打包发布&#xff0c;只要解压&#xff0c;修改配置即可 rpm安装&#xff1a; 软件已经按照redhat的包管理规范进行打包&#xff0c;使用rpm命令进行安装&#xff0…

Java 类加载与字节码技术

3 类加载与字节码技术 3.1 类文件结构 类文件结构字节码指令编译期处理类加载阶段类加载器运行期优化 根据 JVM 规范&#xff0c;类文件结构如下 ClassFile {u4 magic;u2 minor_version; // 小版本号u2 major_version; // 主版本号u2 constant_pool_count; // 常量池cp_info…

《我与地坛》当时只道是寻常;只是当时已惘然

《我与地坛》当时只道是寻常&#xff1b;只是当时已惘然 史铁生&#xff08;1951/1/4-2010/12/31&#xff09;&#xff0c;作家&#xff0c;散文家&#xff0c;代表作有《我与地坛》《命若琴弦》《奶奶的星星》等。 文章目录 《我与地坛》当时只道是寻常&#xff1b;只是当时已…

Thinkphp+vue+mysql学生作业管理系统21j0r

运行环境:phpstudy/wamp/xammp等 开发语言&#xff1a;php 后端框架&#xff1a;Thinkphp5 前端框架&#xff1a;vue.js 服务器&#xff1a;apache 数据库&#xff1a;mysql 数据库工具&#xff1a;Navicat/phpmyadmin 为设计一个安全便捷&#xff0c;并且使用户更好获取本学院…

c基础学习(一)

学习网站&#xff1a; C语言的过去与未来 - C语言教程 - C语言网 (dotcpp.com)https://www.dotcpp.com/course/c-intros/ C 语言简介 - C 语言教程 - 网道 (wangdoc.com)https://wangdoc.com/clang/intro 变量&#xff1a; #include<stdio.h> /*引入头文件-- 标准…

深入浅出理解转置卷积Conv2DTranspose

温故而知新&#xff0c;可以为师矣&#xff01; 一、参考资料 论文&#xff1a;A guide to convolution arithmetic for deep learning github源码&#xff1a;Convolution arithmetic bilibili视频&#xff1a;转置卷积&#xff08;transposed convolution&#xff09; 转置…

【Linux】深度解剖环境变量

> 作者简介&#xff1a;დ旧言~&#xff0c;目前大二&#xff0c;现在学习Java&#xff0c;c&#xff0c;c&#xff0c;Python等 > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;熟悉并掌握Linux的环境变量。 > 毒鸡汤&#x…

【2023 CCF 大数据与计算智能大赛】基于TPU平台实现超分辨率重建模型部署 基于FSRCNN的TPU平台超分辨率模型部署方案

2023 CCF 大数据与计算智能大赛 基于TPU平台实现超分辨率重建模型部署 基于FSRCNN的TPU平台超分辨率模型部署方案 WELL 刘渝 人工智能 研一 西安交通大学 中国-西安 1461003622qq.com 史政立 网络空间安全 研一 西安交通大学 中国-西安 1170774291qq.com 崔琳、张…