0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python軸承故障診斷—基于EMD-CNN的故障分類

冬至子 ? 來源:建模先鋒 ? 作者:小蝸愛建模 ? 2023-12-12 16:41 ? 次閱讀

1 經(jīng)驗(yàn)?zāi)B(tài)分解EMD的Python示例

第一步,Python 中 EMD包的下載安裝:

# 下載
pip install EMD-signal


# 導(dǎo)入
from PyEMD import EMD

切記,很多同學(xué)安裝失敗,不是pip install EMD,也不是pip install PyEMD, 如果 pip list 中 已經(jīng)有 emd,emd-signal,pyemd包的存在,要先 pip uninstall 移除相關(guān)包,然后再進(jìn)行安裝。

第二步,導(dǎo)入相關(guān)包

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

第三步,生成一個(gè)信號(hào)示例

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

第四步,創(chuàng)建EMD對(duì)象,進(jìn)行分解

emd = EMD()
# 對(duì)信號(hào)進(jìn)行經(jīng)驗(yàn)?zāi)B(tài)分解
IMFs = emd(signal)

第五步,繪制原始信號(hào)和每個(gè)本征模態(tài)函數(shù)(IMF)

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


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


plt.show()

圖片

2 軸承故障數(shù)據(jù)的預(yù)處理

2.1 導(dǎo)入數(shù)據(jù)

參考之前的文章,進(jìn)行故障10分類的預(yù)處理,凱斯西儲(chǔ)大學(xué)軸承數(shù)據(jù)10分類數(shù)據(jù)集:

圖片

train_set、val_set、test_set 均為按照7:2:1劃分訓(xùn)練集、驗(yàn)證集、測(cè)試集,最后保存數(shù)據(jù)

圖片

上圖是數(shù)據(jù)的讀取形式以及預(yù)處理思路

2.2 制作數(shù)據(jù)集和對(duì)應(yīng)標(biāo)簽

第一步, 生成數(shù)據(jù)集

圖片

第二步,制作數(shù)據(jù)集和標(biāo)簽

# 制作數(shù)據(jù)集和標(biāo)簽
import torch


# 這些轉(zhuǎn)換是為了將數(shù)據(jù)和標(biāo)簽從Pandas數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)換為PyTorch可以處理的張量,
# 以便在神經(jīng)網(wǎng)絡(luò)中進(jìn)行訓(xùn)練和預(yù)測(cè)。


def make_data_labels(dataframe):
    '''
        參數(shù) dataframe: 數(shù)據(jù)框
        返回 x_data: 數(shù)據(jù)集     torch.tensor
            y_label: 對(duì)應(yīng)標(biāo)簽值  torch.tensor
    '''
    # 信號(hào)值
    x_data = dataframe.iloc[:,0:-1]
    # 標(biāo)簽值
    y_label = dataframe.iloc[:,-1]
    x_data = torch.tensor(x_data.values).float()
    y_label = torch.tensor(y_label.values, dtype=torch.int64)  # 指定了這些張量的數(shù)據(jù)類型為64位整數(shù),通常用于分類任務(wù)的類別標(biāo)簽
    return x_data, y_label


# 加載數(shù)據(jù)
train_set = load('train_set')
val_set = load('val_set')
test_set = load('test_set')


# 制作標(biāo)簽
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)
# 保存數(shù)據(jù)
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 故障數(shù)據(jù)的EMD分解可視化

選擇正常信號(hào)和 0.021英寸內(nèi)圈、滾珠、外圈故障信號(hào)數(shù)據(jù)來做對(duì)比

第一步,導(dǎo)入包,讀取數(shù)據(jù)

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')  # 正常信號(hào)
data2 = loadmat('21_1.mat') # 0.021英寸 內(nèi)圈
data3 = loadmat('21_2.mat') # 0.021英寸 滾珠
data4 = loadmat('21_3.mat') # 0.021英寸 外圈
# 注意,讀取出來的data是字典格式,可以通過函數(shù)type(data)查看。

第二步,數(shù)據(jù)集中統(tǒng)一讀取 驅(qū)動(dòng)端加速度數(shù)據(jù),取一個(gè)長(zhǎng)度為1024的信號(hào)進(jìn)行后續(xù)觀察和實(shí)驗(yàn)

# DE - drive end accelerometer data 驅(qū)動(dòng)端加速度數(shù)據(jù)
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)
# 劃窗取值(大多數(shù)窗口大小為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]

第三步,進(jìn)行數(shù)據(jù)可視化

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('內(nèi)圈')
plt.subplot(2,2,3)
plt.plot(data_list3)
plt.title('滾珠')
plt.subplot(2,2,4)
plt.plot(data_list4)
plt.title('外圈')
plt.show()

圖片

第四步,首先對(duì)正常數(shù)據(jù)進(jìn)行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)
# 創(chuàng)建 EMD 對(duì)象
emd = EMD()


# 對(duì)信號(hào)進(jìn)行經(jīng)驗(yàn)?zāi)B(tài)分解
IMFs = emd(data)


# 繪制原始信號(hào)和每個(gè)本征模態(tài)函數(shù)(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()

圖片

其次,內(nèi)圈故障EMD分解:

圖片

然后,滾珠故障EMD分解:

圖片

最后,外圈故障EMD分解:

圖片

注意,在信號(hào)的制作過程中,信號(hào)長(zhǎng)度的選取比較重要,選擇信號(hào)長(zhǎng)度為1024,既能滿足信號(hào)在時(shí)間維度上的分辨率,也能在后續(xù)的EMD分解中分解出數(shù)量相近的IMF分量,為進(jìn)一步做故障模式識(shí)別打下基礎(chǔ)。

2.4 故障數(shù)據(jù)的EMD分解預(yù)處理

對(duì)于EMD分解出的IMF分量個(gè)數(shù),并不是所有的樣本信號(hào)都能分解出8個(gè)分量,需要做一下定量分析:

import numpy as np
from PyEMD import EMD


# 加載訓(xùn)練集
train_xdata = load('trainX_1024_10c')
data = np.array(train_xdata)


# 創(chuàng)建 EMD 對(duì)象
emd = EMD()


print("測(cè)試集:", len(data))
count_min = 0
count_max = 0
count_7 = 0
# 對(duì)數(shù)據(jù)進(jìn)行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("分解結(jié)果IMF大于8:", count_max)
print("分解結(jié)果IMF小于7:", count_min)
print("分解結(jié)果IMF等于7:", count_7)

圖片

由結(jié)果可以看出,大部分信號(hào)樣本 都分解出8個(gè)分量,將近1/3的信號(hào)分解的不是8個(gè)分量。EMD設(shè)置不了分解出模態(tài)分量的數(shù)量(函數(shù)自適應(yīng)),為了使一維信號(hào)分解,達(dá)到相同維度的分量特征,有如下3種處理方式:

  • 刪除分解分量不統(tǒng)一的樣本(少量存在情況可以采用);
  • 對(duì)于分量個(gè)數(shù)少的樣本采用0值或者其他方法進(jìn)行特征填充,使其對(duì)齊其他樣本分量的維度(向多兼容);
  • 合并分量數(shù)量多的信號(hào)(向少兼容);

本文采用第二、三條結(jié)合的方式進(jìn)行預(yù)處理,即刪除分量小于7的樣本,對(duì)于分量大于7的樣本,把多余的分量進(jìn)行合并,使所有信號(hào)的分量特征保持同樣的維度。

圖片

3 基于EMD-CNN的軸承故障診斷分類

下面基于EMD分解后的軸承故障數(shù)據(jù),通過CNN進(jìn)行一維卷積作為的分類方法進(jìn)行講解:

3.1 訓(xùn)練數(shù)據(jù)、測(cè)試數(shù)據(jù)分組,數(shù)據(jù)分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
# 參數(shù)與配置
torch.manual_seed(100)  # 設(shè)置隨機(jī)種子,以使實(shí)驗(yàn)結(jié)果具有可重復(fù)性
device = torch.device("cuda" if torch.cuda.is_available() else "cpu") # 有GPU先用GPU訓(xùn)練


# 加載數(shù)據(jù)集
def dataloader(batch_size, workers=2):
    # 訓(xùn)練集
    train_xdata = load('trainX_1024_10c')
    train_ylabel = load('trainY_1024_10c')
    # 驗(yàn)證集
    val_xdata = load('valX_1024_10c')
    val_ylabel = load('valY_1024_10c')
    # 測(cè)試集
    test_xdata = load('testX_1024_10c')
    test_ylabel = load('testY_1024_10c')


    # 加載數(shù)據(jù)
    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
# 加載數(shù)據(jù)
train_loader, val_loader, test_loader = dataloader(batch_size)

3.2 定義EMDVGG1d網(wǎng)絡(luò)模型

圖片

3.3 設(shè)置參數(shù),訓(xùn)練模型

圖片

200個(gè)epoch,準(zhǔn)確率將近96%,用淺層的VGG效果明顯,繼續(xù)調(diào)參可以進(jìn)一步提高分類準(zhǔn)確率。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 神經(jīng)網(wǎng)絡(luò)

    關(guān)注

    42

    文章

    4772

    瀏覽量

    100809
  • EMD
    EMD
    +關(guān)注

    關(guān)注

    1

    文章

    43

    瀏覽量

    20056
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4797

    瀏覽量

    84729
  • vgg
    vgg
    +關(guān)注

    關(guān)注

    1

    文章

    11

    瀏覽量

    5199
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于labview的軸承故障診斷與健康監(jiān)測(cè)

    畢S做基于labview的軸承故障診斷與健康監(jiān)測(cè),但是感覺無從下手,沒有實(shí)物進(jìn)行數(shù)據(jù)采集,想來也只能模擬采集振動(dòng)信號(hào),但這個(gè)振動(dòng)信號(hào)又該如何產(chǎn)生,看網(wǎng)上有凱斯西儲(chǔ)大學(xué)軸承數(shù)據(jù),但又不知如何利用,,求教各位labview前輩大佬給
    發(fā)表于 03-18 23:33

    DSP的滾動(dòng)軸承實(shí)時(shí)故障診斷系統(tǒng)設(shè)

    。據(jù)統(tǒng)計(jì),在使用滾動(dòng)軸承的旋轉(zhuǎn)機(jī)械中,由于滾動(dòng)軸承損壞而引起的故障約占30%。由此可見,滾動(dòng)軸承故障診斷在工程中還是有其重要意義的
    發(fā)表于 09-29 16:54

    船舶感應(yīng)電機(jī)軸承故障診斷方法的幾點(diǎn)研究

    特征量其他振動(dòng)信號(hào)所淹沒;基于參數(shù)辨識(shí)的方法因?yàn)樾枰姍C(jī)的一些機(jī)械及電磁參數(shù),因而不利于故障診斷系統(tǒng)的通用性;瞬時(shí)功率分析法和氣隙轉(zhuǎn)矩分析法均需要船舶感應(yīng)電機(jī)軸承故障診斷系統(tǒng)的研究時(shí)采集定子電壓和電流
    發(fā)表于 10-21 10:59

    【轉(zhuǎn)】電力電子電路故障診斷方法

    。常用的有最小二乘法。 三、模式識(shí)別在故障診斷中的應(yīng)用 故障的模式識(shí)別就是從那些反映系統(tǒng)的信息中抽取出反映故障的特征,并根據(jù)這些特征的不同屬性,對(duì)故障進(jìn)行
    發(fā)表于 03-06 20:35

    【轉(zhuǎn)帖】傳感器的故障分類診斷方法

    最大值;漂移故障,信號(hào)以某一速率偏移原信號(hào);周期性干擾故障,原信號(hào)上疊加某一頻率的信號(hào)。傳感器故障診斷方法從不同角度出發(fā),故障診斷方法的
    發(fā)表于 07-13 17:19

    傳感器的故障分類診斷方法

    最大值;漂移故障,信號(hào)以某一速率偏移原信號(hào);周期性干擾故障,原信號(hào)上疊加某一頻率的信號(hào)。傳感器故障診斷方法從不同角度出發(fā),故障診斷方法的
    發(fā)表于 10-30 15:57

    基于DSP+MCU的列車滾動(dòng)軸承故障診斷系統(tǒng)研究

    ,對(duì)于列車的安全有著重大的影響。因此,開展列車滾動(dòng)軸承故障診斷的研究對(duì)避免重大事故、促進(jìn)經(jīng)濟(jì)發(fā)展具有相當(dāng)大的意義。
    發(fā)表于 07-09 06:30

    電機(jī)軸承故障診斷與分析

    很多工程師都在網(wǎng)上向我咨詢電機(jī)軸承故障診斷與分析的問題。面對(duì)五花八門的問題,有時(shí)候我可以根據(jù)一些信息進(jìn)行判斷,有時(shí)候什么信息也沒有,這樣的情況下我的所謂判斷只能是猜測(cè),恐怕距離真相,也十分遙遠(yuǎn)。大家
    發(fā)表于 09-01 09:01

    基于matlab的電機(jī)故障診斷

    基于matlab的電機(jī)故障診斷 基于 matlab 的電機(jī)故障診斷 班級(jí):電氣 09-6 班 組員: fudongshan……….……….……….一.引言三相鼠籠式異步電動(dòng)機(jī)因其結(jié)構(gòu)簡(jiǎn)單、使用方便
    發(fā)表于 09-03 09:12

    基于DSP的滾動(dòng)軸承實(shí)時(shí)故障診斷系統(tǒng)設(shè)計(jì)

    針對(duì)在線式設(shè)備故障診斷系統(tǒng)因其昂貴的造價(jià)、安裝和維護(hù)的不便而不適用于中小型設(shè)備故障檢測(cè)與診斷的特點(diǎn),設(shè)計(jì)了一種基于TMS320C6713 的滾動(dòng)軸承實(shí)時(shí)智能
    發(fā)表于 06-17 08:51 ?11次下載

    滾動(dòng)軸承故障診斷的實(shí)用技巧

      摘要:本文主要介紹滾動(dòng)軸承區(qū)別于實(shí)驗(yàn)室診斷的生產(chǎn)實(shí)用技巧。關(guān)鍵詞:滾動(dòng)軸承、故障診斷、振動(dòng)分析、實(shí)用技巧滾動(dòng)軸承在設(shè)備中的應(yīng)用非常廣泛,
    發(fā)表于 10-29 14:44 ?1609次閱讀

    基于EMD與Duffing振子的風(fēng)機(jī)軸承早期故障診斷研究

    基于EMD與Duffing振子的風(fēng)機(jī)軸承早期故障診斷研究_呂躍剛
    發(fā)表于 01-02 15:36 ?2次下載

    滾動(dòng)軸承故障診斷方法

    背景噪聲統(tǒng)計(jì)特性未知的情況下,提高軸承故障診斷系統(tǒng)的魯棒性和可靠性,構(gòu)建低成本、高可靠的滾動(dòng)軸承故障分析診斷系統(tǒng),實(shí)驗(yàn)結(jié)果表明,系統(tǒng)在訓(xùn)練信
    發(fā)表于 11-14 15:01 ?22次下載
    滾動(dòng)<b class='flag-5'>軸承</b><b class='flag-5'>故障診斷</b>方法

    基于CUDA加速的高速振動(dòng)信號(hào)故障診斷方法

    為解決傳統(tǒng)高鐵振動(dòng)信號(hào)故障診斷方法速度慢、難以滿足實(shí)時(shí)處理的要求,提出一種基于計(jì)算統(tǒng)一設(shè)備架構(gòu)( CUDA)加速的高鐵振動(dòng)信號(hào)故障診斷方法。首先利用CUDA架構(gòu)對(duì)高鐵數(shù)據(jù)進(jìn)行經(jīng)驗(yàn)?zāi)B(tài)分解(EMD
    發(fā)表于 01-02 16:17 ?3次下載
    基于CUDA加速的高速振動(dòng)信號(hào)<b class='flag-5'>故障診斷</b>方法

    基于多通道時(shí)頻信號(hào)的CNN智能故障診斷技術(shù)

    基于多通道時(shí)頻信號(hào)的CNN智能故障診斷技術(shù)
    發(fā)表于 07-05 16:44 ?27次下載