首页 > 编程语言 >Python轴承故障诊断 (14)高创新故障识别模型

Python轴承故障诊断 (14)高创新故障识别模型

时间:2024-10-25 18:16:49浏览次数:9  
标签:轴承 14 Python VMD FFT 故障诊断 故障 特征 CNN

往期精彩内容:

Python-凯斯西储大学(CWRU)轴承数据解读与分类处理

Pytorch-LSTM轴承故障一维信号分类(一)-CSDN博客

Pytorch-CNN轴承故障一维信号分类(二)-CSDN博客

Pytorch-Transformer轴承故障一维信号分类(三)-CSDN博客

三十多个开源数据集 | 故障诊断再也不用担心数据集了!

Python轴承故障诊断 (一)短时傅里叶变换STFT-CSDN博客

Python轴承故障诊断 (二)连续小波变换CWT-CSDN博客

Python轴承故障诊断 (三)经验模态分解EMD-CSDN博客

Python轴承故障诊断 (四)基于EMD-CNN的故障分类-CSDN博客

Python轴承故障诊断 (五)基于EMD-LSTM的故障分类-CSDN博客

Python轴承故障诊断 (六)基于EMD-Transformer的故障分类-CSDN博客

Python轴承故障诊断 (七)基于EMD-CNN-LSTM的故障分类-CSDN博客

Python轴承故障诊断 (八)基于EMD-CNN-GRU并行模型的故障分类-CSDN博客

Python轴承故障诊断 (九)基于VMD+CNN-BiLSTM的故障分类-CSDN博客

Python轴承故障诊断 (十)基于VMD+CNN-Transfromer的故障分类-CSDN博客

基于FFT + CNN - BiGRU-Attention 时域、频域特征注意力融合的轴承故障识别模型-CSDN博客

基于FFT + CNN - Transformer 时域、频域特征融合的轴承故障识别模型-CSDN博客

Python轴承故障诊断 (11)基于VMD+CNN-BiGRU-Attenion的故障分类-CSDN博客

交叉注意力融合时域、频域特征的FFT + CNN -BiLSTM-CrossAttention轴承故障识别模型-CSDN博客

交叉注意力融合时域、频域特征的FFT + CNN-Transformer-CrossAttention轴承故障识别模型-CSDN博客

轴承故障诊断 (12)基于交叉注意力特征融合的VMD+CNN-BiLSTM-CrossAttention故障识别模型_基于残差混合域注意力cnn的轴承故障诊断及其时频域可解释性-CSDN博客

Python轴承故障诊断 (13)基于故障信号特征提取的超强机器学习识别模型-CSDN博客

创新度高,效果明显!!

创新点:

1.预处理部分:结合快速傅里叶变换FFT和变分模态分解VMD来进行信号的时频、域特征提取,能够挖掘故障信号中的多尺度特征;

2.然后是利用CNN卷积神经网络提取故障信号预处理后的多尺度特征的空间特征,用BiLSTM提取故障信号预处理后的多尺度特征的时域特征;

3.最后利用交叉注意力进行时空特征的融合,从而提高特征的表示能力来实现故障信号的识别

前言

本文基于凯斯西储大学(CWRU)轴承数据,进行快速傅里叶变换(FFT)和变分模态分解VMD的数据预处理,最后通过Python实现基于交叉注意力CNN-BiLSTM-CrossAttention的时空特征融合模型对故障数据的分类。凯斯西储大学轴承数据的详细介绍可以参考下文:

Python-凯斯西储大学(CWRU)轴承数据解读与分类处理_凯斯西储大学轴承数据集-CSDN博客

1 模型整体结构

1.1 模型整体结构如下所示:

一维故障信号分别经过FFT变换、VMD分解处理,然后把变换分解后的结果进行堆叠,通过CNN、BiLSTM网络提取空间、时域特征,最后通过使用交叉注意力机制融合时域和频域的特征。可以通过计算注意力权重,使得模型更关注重要的特征,提高模型性能和泛化能力。

1.2 创新点详细介绍:

当处理故障信号时,时频域特征提取是非常重要的,而结合快速傅里叶变换(FFT)和变分模态分解(VMD)可以有效地挖掘信号中的多尺度特征。

(1)预处理——FFT:

FFT是一种广泛应用的频域分析方法,可以将信号从时域转换到频域,得到信号的频谱信息。通过FFT,我们可以获取信号在不同频率上的能量分布,进而了解信号的频率成分。然而,FFT只提供了信号在某个时刻的频谱信息,无法反映信号随时间的变化。

(2)预处理——VMD:

为了解决这个问题,可以引入变分模态分解(VMD)。VMD是一种基于信号自适应调整的模态分解方法,可以将信号分解为一系列模态函数,每个模态函数代表信号在不同尺度上的特征。通过VMD,我们可以获得信号在不同尺度上的时域特征信息。

(3)预处理——特征融合:

结合FFT和VMD,可以先利用FFT将信号转换到频域,得到信号的频谱信息。然后,同时对故障信号应用VMD,将其分解为一系列模态函数。这些模态函数代表了信号在不同尺度上的时域特征。通过分析这些信息,我们可以挖掘故障信号中的多尺度特征,从而更好地理解信号的时频特性。这种方法能够更全面地分析信号,有助于故障检测与诊断等应用场景中的信号处理任务。我们把经过FFT和VMD提取的多尺度特征融合后,作为创新网络模型的输入,送入网络中去训练。

(4)创新网络模型——CNN空间特征提取:

  • 输入:融合FFT、VMD的特征

  • 操作:对每个输入特征进行卷积和池化操作,提取空间特征

  • 输出:卷积池化后的特征表示,用于捕获不同频率下的振动空间特征

(5)创新网络模型——BiLSTM 时序特征提取:

  • 输入:融合FFT、VMD的特征

  • 操作:双向LSTM网络学习序列信息,关注重要的时序特征

  • 输出:经BiLSTM处理后的时序特征表示,具有更好的故障信号时序建模能力

(5)多尺度特征融合——交叉注意力机制特征融合:

  • 输入:CNN提取的空间特征,BiLSTM提取的时序特征

  • 交叉注意力机制:使用交叉注意力机制融合时域和频域的特征。可以通过计算注意力权重,使得模型更关注重要的特征,提高模型性能和泛化能力

2 轴承故障数据的预处理

2.1 导入数据

参考之前的文章,进行故障10分类的预处理,凯斯西储大学轴承数据10分类数据集:

train_set、val_set、test_set 均为按照7:2:1划分训练集、验证集、测试集,最后保存数据

2.2 故障FFT变换可视化

2.3 故障VMD分解可视化

2.4 故障数据的特征预处理数据集制作

 3 交叉注意力机制

3.1 Cross attention概念

  • Transformer架构中混合两种不同嵌入序列的注意机制

  • 两个序列必须具有相同的维度

  • 两个序列可以是不同的模式形态(如:文本、声音、图像)

  • 一个序列作为输入的Q,定义了输出的序列长度,另一个序列提供输入的K&V

3.2 Cross-attention算法 

  • 拥有两个序列S1、S2

  • 计算S1的K、V

  • 计算S2的Q

  • 根据K和Q计算注意力矩阵

  • 将V应用于注意力矩阵

  • 输出的序列长度与S2一致

在融合过程中,我们将经过CNN卷积池化操作的空间特征作为查询序列,BiLSTM输出的时序特征作为键值对序列。通过计算查询序列与键值对序列之间的注意力权重,我们可以对不同特征之间的关联程度进行建模。

4 基于FFT-VMD+CNN-BiLSTM-CrossAttention的轴承故障诊断分类

4.1 定义FFT-VMD+CNN-BiLSTM-CrossAttention分类网络模型

4.2 设置参数,训练模型

50个epoch,准确率100%,用FFT-VMD+CNN-BiLSTM-CrossAttention网络分类效果显著,快速傅里叶变换(FFT)和变分模态分解(VMD)可以有效地挖掘信号中的多尺度特征,创新模型能够充分提取轴承故障信号的空间和时序特征,收敛速度快,性能优越,精度高,交叉注意力机制能够对不同特征之间的关联程度进行建模,从故障信号频域、时域特征中属于提取出对模型识别重要的特征,效果明显,创新度高!

注意调整参数:

  • 可以适当增加CNN层数和隐藏层的维度,微调学习率;

  • 调整BiLSTM层数和维度数,增加更多的 epoch (注意防止过拟合)

  • 可以改变一维信号堆叠的形状(设置合适的长度和维度)

4.3 模型评估

准确率、精确率、召回率、F1 Score

故障十分类混淆矩阵:

5 代码、数据整理如下:

标签:轴承,14,Python,VMD,FFT,故障诊断,故障,特征,CNN
From: https://blog.csdn.net/2402_85668383/article/details/143241172

相关文章

  • c++/python/java/go用途介绍
    C++用途:系统编程:操作系统、驱动程序等底层开发。游戏开发:游戏引擎和高性能游戏应用,因其高效的性能和内存管理。嵌入式系统:适合资源受限的设备。科学计算:高性能计算和数值分析。金融系统:高频交易和复杂金融模型。Python用途:数据科学与分析:广泛用于数据处理和可视化......
  • linux中,使用python3 实现用硬链接的方式复制复合文件夹
    copy_with_hardlink.pyimportosimportargparsedefcopy_with_hardlinks(src,dst):ifnotos.path.exists(dst):os.makedirs(dst)foriteminos.listdir(src):src_item=os.path.join(src,item)dst_item=os.path.join(d......
  • 【Python爬虫实战】深入理解Python异步编程:从协程基础到高效爬虫实现
    #1024程序员节|征文#  ......
  • python-show_delta案例
    show_delta使用setenvmmcroot"/dev/mmcblk1p2rootwaitrwinitcall_debugprintk.time=1"dmesg>kerneltimescripts/bootgraph.plkerneltime>boot.svg#printk.time=1orCONFIG_PRINTK_TIME=yscripts/show_deltakerneltime>deltatimebootgr......
  • CPython逆向实战分析
    Python代码转换为C代码的时候,将会大大增加框架代码量。基础教程|Cython官方文档中文版(gitbooks.io)1、正向py->c先有正向,再有逆向pipinstallcython写一个简单的pyx文件.pyx文件是由Cython编程语言"编写"而成的Python扩展模块源代码文件print("hello")写一个......
  • 初探python栈帧逃逸
    前言以前在一些大型比赛就遇到这种题,一直没时间去研究,现在康复训练下:)生成器介绍生成器(Generator)是Python中一种特殊的迭代器,它可以在迭代过程中动态生成值,而不需要一次性将所有值存储在内存中。SimpleDemo这里定义一个生成器函数,生成器使用yield语句来产生值,每次调用生成......
  • 如何将GB28181/GB35114流媒体监控视频汇聚平台LiveGBS中自带的redis组件换成自己的Red
    @目录1、Redis服务2、如何切换REDIS?2.1、停止启动REDIS2.2、配置信令服务2.3、配置流媒体服务2.4、启动3、搭建GB28181视频直播平台1、Redis服务在LivGBS中Redis作为数据交换、数据订阅、数据发布的高速缓存服务。默认LiveCMS解压目录下会携带一个REDIS服务。如果已经有自己的r......
  • 02-python 数据类型
    python容器类型数据str序列操作字符串属于序列类型,所谓序列,指的是一块可存放多个值的连续内存空间,这些值按一定顺序排列,可通过每个值所在位置的编号(称为索引、下标)访问它们。s="hellomoluo"Python还支持索引值是负数,此类索引是从右向左计数,换句话说,从最后一个元素开始计......
  • python ES连接服务器的方法P9
    连接Elasticsearch(ES)服务器是进行数据搜索和分析的常用操作。Elasticsearch是一个基于Lucene的搜索引擎,提供了RESTfulAPI来进行索引、搜索和管理数据。以下是一个详细的Python代码示例,展示如何连接到Elasticsearch服务器并执行一些基本操作。这个示例使用了官方的elasticsearch-......
  • Node.js和Python在服务器端编程上有什么不同
    Node.js和Python在服务器端编程上有以下不同:1.设计哲学不同;2.性能不同;3.库支持和框架不同;4.同步/异步处理不同;5.语法简洁性不同;6.用途和适用场景不同。具体来说,Node.js基于事件驱动和非阻塞I/O模型,优于高并发处理,而Python则以简洁易读著称,广泛应用于科学计算、人工智能等领域。......