0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Python轴承故障诊断—基于EMD-CNN的故障分类

冬至子 来源:建模先锋 作者:小蜗爱建模 2023-12-12 16:41 次阅读

1 经验模态分解EMD的Python示例

第一步,Python 中 EMD包的下载安装:

# 下载
pip install EMD-signal


# 导入
from PyEMD import EMD

切记,很多同学安装失败,不是pip install EMD,也不是pip install PyEMD, 如果 pip list 中 已经有 emd,emd-signal,pyemd包的存在,要先 pip uninstall 移除相关包,然后再进行安装。

第二步,导入相关包

importnumpyasnp
from PyEMD import EMD
importmatplotlib.pyplotasplt
importmatplotlib
matplotlib.rc("font", family='Microsoft YaHei')

第三步,生成一个信号示例

t = np.linspace(0, 1, 1000)
signal = np.sin(11*2*np.pi*t*t) + 6*t*t

第四步,创建EMD对象,进行分解

emd = EMD()
# 对信号进行经验模态分解
IMFs = emd(signal)

第五步,绘制原始信号和每个本征模态函数(IMF)

plt.figure(figsize=(15,10))
plt.subplot(len(IMFs)+1, 1, 1)
plt.plot(t, signal, 'r')
plt.title("原始信号")


fornum, imfinenumerate(IMFs):
    plt.subplot(len(IMFs)+1, 1, num+2)
    plt.plot(t, imf)
    plt.title("IMF "+str(num+1))


plt.show()

图片

2 轴承故障数据的预处理

2.1 导入数据

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

图片

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

图片

上图是数据的读取形式以及预处理思路

2.2 制作数据集和对应标签

第一步, 生成数据集

图片

第二步,制作数据集和标签

# 制作数据集和标签
import torch


# 这些转换是为了将数据和标签从Pandas数据结构转换为PyTorch可以处理的张量,
# 以便在神经网络中进行训练和预测。


def make_data_labels(dataframe):
    '''
        参数 dataframe: 数据框
        返回 x_data: 数据集     torch.tensor
            y_label: 对应标签值  torch.tensor
    '''
    # 信号值
    x_data = dataframe.iloc[:,0:-1]
    # 标签值
    y_label = dataframe.iloc[:,-1]
    x_data = torch.tensor(x_data.values).float()
    y_label = torch.tensor(y_label.values, dtype=torch.int64)  # 指定了这些张量的数据类型为64位整数,通常用于分类任务的类别标签
    return x_data, y_label


# 加载数据
train_set = load('train_set')
val_set = load('val_set')
test_set = load('test_set')


# 制作标签
train_xdata, train_ylabel = make_data_labels(train_set)
val_xdata, val_ylabel = make_data_labels(val_set)
test_xdata, test_ylabel = make_data_labels(test_set)
# 保存数据
dump(train_xdata, 'trainX_1024_10c')
dump(val_xdata, 'valX_1024_10c')
dump(test_xdata, 'testX_1024_10c')
dump(train_ylabel, 'trainY_1024_10c')
dump(val_ylabel, 'valY_1024_10c')
dump(test_ylabel, 'testY_1024_10c')

2.3 故障数据的EMD分解可视化

选择正常信号和 0.021英寸内圈、滚珠、外圈故障信号数据来做对比

第一步,导入包,读取数据

import numpy as np
from scipy.io import loadmat
import numpy as np
from scipy.signal import stft
import matplotlib.pyplot as plt
import matplotlib
matplotlib.rc("font", family='Microsoft YaHei')


# 读取MAT文件
data1 = loadmat('0_0.mat')  # 正常信号
data2 = loadmat('21_1.mat') # 0.021英寸 内圈
data3 = loadmat('21_2.mat') # 0.021英寸 滚珠
data4 = loadmat('21_3.mat') # 0.021英寸 外圈
# 注意,读取出来的data是字典格式,可以通过函数type(data)查看。

第二步,数据集中统一读取 驱动端加速度数据,取一个长度为1024的信号进行后续观察和实验

# DE - drive end accelerometer data 驱动端加速度数据
data_list1 = data1['X097_DE_time'].reshape(-1)
data_list2 = data2['X209_DE_time'].reshape(-1)  
data_list3 = data3['X222_DE_time'].reshape(-1)
data_list4 = data4['X234_DE_time'].reshape(-1)
# 划窗取值(大多数窗口大小为1024)
time_step= 1024
data_list1 = data_list1[0:time_step]
data_list2 = data_list2[0:time_step]
data_list3 = data_list3[0:time_step]
data_list4 = data_list4[0:time_step]

第三步,进行数据可视化

plt.figure(figsize=(20,10))
plt.subplot(2,2,1)
plt.plot(data_list1)
plt.title('正常')
plt.subplot(2,2,2)
plt.plot(data_list2)
plt.title('内圈')
plt.subplot(2,2,3)
plt.plot(data_list3)
plt.title('滚珠')
plt.subplot(2,2,4)
plt.plot(data_list4)
plt.title('外圈')
plt.show()

图片

第四步,首先对正常数据进行EMD分解

import numpy as np
import matplotlib.pyplot as plt
from PyEMD import EMD


t = np.linspace(0, 1, time_step)
data = np.array(data_list1)
# 创建 EMD 对象
emd = EMD()


# 对信号进行经验模态分解
IMFs = emd(data)


# 绘制原始信号和每个本征模态函数(IMF)
plt.figure(figsize=(15,10))
plt.subplot(len(IMFs)+1, 1, 1)
plt.plot(t, data, 'r')
plt.title("Original signal", fontsize=10)


for num, imf in enumerate(IMFs):
    plt.subplot(len(IMFs)+1, 1, num+2)
    plt.plot(t, imf)
    plt.title("IMF "+str(num+1), fontsize=10)
    # 增加第一排图和第二排图之间的垂直间距
plt.subplots_adjust(hspace=0.4, wspace=0.2)
plt.show()

图片

其次,内圈故障EMD分解:

图片

然后,滚珠故障EMD分解:

图片

最后,外圈故障EMD分解:

图片

注意,在信号的制作过程中,信号长度的选取比较重要,选择信号长度为1024,既能满足信号在时间维度上的分辨率,也能在后续的EMD分解中分解出数量相近的IMF分量,为进一步做故障模式识别打下基础。

2.4 故障数据的EMD分解预处理

对于EMD分解出的IMF分量个数,并不是所有的样本信号都能分解出8个分量,需要做一下定量分析:

import numpy as np
from PyEMD import EMD


# 加载训练集
train_xdata = load('trainX_1024_10c')
data = np.array(train_xdata)


# 创建 EMD 对象
emd = EMD()


print("测试集:", len(data))
count_min = 0
count_max = 0
count_7 = 0
# 对数据进行EMD分解
for i in range(1631):
    imfs = emd(data[i], max_imf=8)  # max_imf=8
    if len(imfs) > 8 :
        count_max += 1
    elif len(imfs) < 7:
        count_min += 1
    elif len(imfs) == 7:
        count_7 += 1


print("分解结果IMF大于8:", count_max)
print("分解结果IMF小于7:", count_min)
print("分解结果IMF等于7:", count_7)

图片

由结果可以看出,大部分信号样本 都分解出8个分量,将近1/3的信号分解的不是8个分量。EMD设置不了分解出模态分量的数量(函数自适应),为了使一维信号分解,达到相同维度的分量特征,有如下3种处理方式:

  • 删除分解分量不统一的样本(少量存在情况可以采用);
  • 对于分量个数少的样本采用0值或者其他方法进行特征填充,使其对齐其他样本分量的维度(向多兼容);
  • 合并分量数量多的信号(向少兼容);

本文采用第二、三条结合的方式进行预处理,即删除分量小于7的样本,对于分量大于7的样本,把多余的分量进行合并,使所有信号的分量特征保持同样的维度。

图片

3 基于EMD-CNN的轴承故障诊断分类

下面基于EMD分解后的轴承故障数据,通过CNN进行一维卷积作为的分类方法进行讲解:

3.1 训练数据、测试数据分组,数据分batch

import torch
from joblib import dump, load
import torch.utils.data asData
import numpy as np
import pandas as pd
import torch
import torch.nn as nn
# 参数与配置
torch.manual_seed(100)  # 设置随机种子,以使实验结果具有可重复性
device = torch.device("cuda" if torch.cuda.is_available() else "cpu") # 有GPU先用GPU训练


# 加载数据集
def dataloader(batch_size, workers=2):
    # 训练集
    train_xdata = load('trainX_1024_10c')
    train_ylabel = load('trainY_1024_10c')
    # 验证集
    val_xdata = load('valX_1024_10c')
    val_ylabel = load('valY_1024_10c')
    # 测试集
    test_xdata = load('testX_1024_10c')
    test_ylabel = load('testY_1024_10c')


    # 加载数据
    train_loader = Data.DataLoader(dataset=Data.TensorDataset(train_xdata, train_ylabel),
                                   batch_size=batch_size, shuffle=True, num_workers=workers, drop_last=True)
    val_loader = Data.DataLoader(dataset=Data.TensorDataset(val_xdata, val_ylabel),
                                 batch_size=batch_size, shuffle=True, num_workers=workers, drop_last=True)
    test_loader = Data.DataLoader(dataset=Data.TensorDataset(test_xdata, test_ylabel),
                                  batch_size=batch_size, shuffle=True, num_workers=workers, drop_last=True)
    return train_loader, val_loader, test_loader


batch_size = 32
# 加载数据
train_loader, val_loader, test_loader = dataloader(batch_size)

3.2 定义EMDVGG1d网络模型

图片

3.3 设置参数,训练模型

图片

200个epoch,准确率将近96%,用浅层的VGG效果明显,继续调参可以进一步提高分类准确率。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 神经网络
    +关注

    关注

    42

    文章

    4576

    浏览量

    98798
  • EMD
    EMD
    +关注

    关注

    1

    文章

    43

    浏览量

    19915
  • python
    +关注

    关注

    51

    文章

    4678

    浏览量

    83477
  • vgg
    vgg
    +关注

    关注

    1

    文章

    11

    浏览量

    5145
收藏 人收藏

    评论

    相关推荐

    基于labview的轴承故障诊断与健康监测

    毕S做基于labview的轴承故障诊断与健康监测,但是感觉无从下手,没有实物进行数据采集,想来也只能模拟采集振动信号,但这个振动信号又该如何产生,看网上有凯斯西储大学轴承数据,但又不知如何利用,,求教各位labview前辈大佬给
    发表于 03-18 23:33

    DSP的滚动轴承实时故障诊断系统设

    。据统计,在使用滚动轴承的旋转机械中,由于滚动轴承损坏而引起的故障约占30%。由此可见,滚动轴承故障诊断在工程中还是有其重要意义的
    发表于 09-29 16:54

    船舶感应电机轴承故障诊断方法的几点研究

    特征量其他振动信号所淹没;基于参数辨识的方法因为需要电机的一些机械及电磁参数,因而不利于故障诊断系统的通用性;瞬时功率分析法和气隙转矩分析法均需要船舶感应电机轴承故障诊断系统的研究时采集定子电压和电流
    发表于 10-21 10:59

    【下载】《模拟电路故障诊断

    `编辑推荐  《模拟电路故障诊断》内容精炼、信息量大,无论是初学者还是资深的模拟电路设计师和工程师,都可以从《模拟电路故障诊断》中获得重要的参考信息。内容简介  《模拟电路故障诊断》是关于模拟电路
    发表于 10-20 17:56

    模拟电路故障诊断

    模拟电路故障诊断
    发表于 01-24 12:34

    【转】电力电子电路故障诊断方法

    。常用的有最小二乘法。 三、模式识别在故障诊断中的应用 故障的模式识别就是从那些反映系统的信息中抽取出反映故障的特征,并根据这些特征的不同属性,对故障进行
    发表于 03-06 20:35

    【转帖】传感器的故障分类诊断方法

    最大值;漂移故障,信号以某一速率偏移原信号;周期性干扰故障,原信号上叠加某一频率的信号。传感器故障诊断方法从不同角度出发,故障诊断方法的
    发表于 07-13 17:19

    传感器的故障分类诊断方法

    最大值;漂移故障,信号以某一速率偏移原信号;周期性干扰故障,原信号上叠加某一频率的信号。传感器故障诊断方法从不同角度出发,故障诊断方法的
    发表于 10-30 15:57

    基于DSP+MCU的列车滚动轴承故障诊断系统研究

    ,对于列车的安全有着重大的影响。因此,开展列车滚动轴承故障诊断的研究对避免重大事故、促进经济发展具有相当大的意义。
    发表于 07-09 06:30

    电机轴承故障诊断与分析

    很多工程师都在网上向我咨询电机轴承故障诊断与分析的问题。面对五花八门的问题,有时候我可以根据一些信息进行判断,有时候什么信息也没有,这样的情况下我的所谓判断只能是猜测,恐怕距离真相,也十分遥远。大家
    发表于 09-01 09:01

    基于matlab的电机故障诊断

    基于matlab的电机故障诊断 基于 matlab 的电机故障诊断 班级:电气 09-6 班 组员: fudongshan……….……….……….一.引言三相鼠笼式异步电动机因其结构简单、使用方便
    发表于 09-03 09:12

    滚动轴承故障诊断的实用技巧

      摘要:本文主要介绍滚动轴承区别于实验室诊断的生产实用技巧。关键词:滚动轴承故障诊断、振动分析、实用技巧滚动轴承在设备中的应用非常广泛,
    发表于 10-29 14:44 1491次阅读

    基于EMD与Duffing振子的风机轴承早期故障诊断研究

    基于EMD与Duffing振子的风机轴承早期故障诊断研究_吕跃刚
    发表于 01-02 15:36 1次下载

    基于LMD和SVDD的滚动轴承故障诊断方法_刘震坤

    基于LMD和SVDD的滚动轴承故障诊断方法_刘震坤
    发表于 03-18 09:16 1次下载

    基于多通道时频信号的CNN智能故障诊断技术

    基于多通道时频信号的CNN智能故障诊断技术
    发表于 07-05 16:44 27次下载