1 简介

在滚动轴承的故障诊断时,传统的频谱分析法通常采用共振解调技术 , 具有良好的效果 ,但当内圈 、 滚动体或多点故障时,解调谱线却很难分辨故障类型小波包是小波理论在信号处理应用领域的又一重大发展,它在小波理论的基础上引人了最优基准准则,目前已在通信、 图像处理、分形 、信号检测等方面获得成功应用小波包分解是多分辨率分析的推广,是一种比小波分析更为精细的信号时频分析方法 ,它将频带进行多层次划分 , 对小波分析没有细分的高频部分也进行了分解,并能根据被分析信号的特征 , 自适应地 选择频带,使之与信号频谱相匹配 ,从而提高时频分辨率, 因此它是一种非常有效的信号处理方法。本文将用小波包分析方法构造滚动轴承状态检测信号的能量特征向量,再用神经网络方法对滚动轴承的状态进行识别。

1 小波包理论

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_故障诊断

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_数据_02

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_数据_03

2 特征频率估算 滚动轴承各部件发生单点故障时 , 其特征信号频率为

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_数据_04

3 构造能量特征向量 当轴承在负载旋转过程中出现疲劳 、 压痕或局部腐蚀等故障时 , 将产生冲击振动 , 而这些振动反复互激又会引起更大的振颤 , 用加速度传感器获取运动中轴承的振动加速度信号 , 由于轴承的故障使得该振动信号在某些频带内的信号能量减小 , 而使另外一些频带内的信号能量增强 , 因此 , 在各频率成分信号的能量中, 包含了丰富的故障信息 ,某种或某几种频率成分能量 的改变代表一种故障,基于这点,由轴承振动信号的各频段能量相对值构造轴承故障特征向量。

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_加载_05

2 部分代码


          
          
%%%%以下提取小波包重构信号的故障诊断
  • 1.

          
          
clc
  • 1.

          
          
clear
  • 1.

          
          
fs=12e3;
  • 1.

          
          
load zhengchang.mat;%加载正常信号
  • 1.

          
          
load 98.mat;
  • 1.

          
          
s1=X098_DE_time(19001:1:20000,1);% 正常情况下驱动端数据
  • 1.

          
          
% s1=X098_FE_time(1:1:10000,1);% 正常情况下驱动端数据
  • 1.

          
          
load in.mat;%加载内圈故障信号
  • 1.

          
          
% load fan_in.mat;%加载风扇端内圈故障信号
  • 1.

          
          
load 106.mat;
  • 1.

          
          
s2=X106_DE_time(19001:1:20000,1);% 内圈故障信号情况下驱动端数据
  • 1.

          
          
% s2=X279_FE_time(1:1:10000,1);% 内圈故障信号情况下驱动端数据
  • 1.

          
          
% load fan_ball.mat;%加载滚动体故障信号
  • 1.

          
          
load ball.mat;%加载滚动体故障信号
  • 1.

          
          
load 119.mat;
  • 1.

          
          
s3=X119_DE_time(19001:1:20000,1);% 滚动体故障情况下驱动端数据
  • 1.

          
          
% s3=X283_FE_time(1:1:10000,1);% 滚动体故障情况下驱动端数据
  • 1.

          
          
% load fan_out_12.mat;%加载外圈12点位置故障信号
  • 1.

          
          
load out_12.mat;%加载外圈12点位置故障信号
  • 1.

          
          
load 158.mat;
  • 1.

          
          
s4=X158_DE_time(14001:1:15000,1);% 外圈12点位置情况下驱动端数据
  • 1.

          
          
% s4=X305_FE_time(1:1:10000,1);% 外圈12点位置情况下驱动端数据
  • 1.

          
          
n=3;
  • 1.

          
          
ji='db5';
  • 1.

          
          
wpt=wpdec(s1,n,ji);%使用db5小波包分解正常信号到底三层,使用shannon熵
  • 1.

          
          
% plot(wpt);
  • 1.

          
          
rcfs10=wprcoef(wpt,[n,0]);%利用相应的频段进行重构
  • 1.

          
          
rcfs11=wprcoef(wpt,[n,1]);
  • 1.

          
          
rcfs12=wprcoef(wpt,[n,2]);
  • 1.

          
          
rcfs13=wprcoef(wpt,[n,3]);
  • 1.

          
          
rcfs14=wprcoef(wpt,[n,4]);
  • 1.

          
          
rcfs15=wprcoef(wpt,[n,5]);
  • 1.

          
          
rcfs16=wprcoef(wpt,[n,6]);
  • 1.

          
          
rcfs17=wprcoef(wpt,[n,7]);
  • 1.

          
          
cfs10=wpcoef(wpt,[n,0]);%提取小波包分解系数
  • 1.

          
          
cfs11=wpcoef(wpt,[n,1]);
  • 1.

          
          
cfs12=wpcoef(wpt,[n,2]);
  • 1.

          
          
cfs13=wpcoef(wpt,[n,3]);
  • 1.

          
          
cfs14=wpcoef(wpt,[n,4]);
  • 1.

          
          
cfs15=wpcoef(wpt,[n,5]);
  • 1.

          
          
cfs16=wpcoef(wpt,[n,6]);
  • 1.

          
          
cfs17=wpcoef(wpt,[n,7]);
  • 1.

          
          
wpt1=wpdec(s2,n,ji);
  • 1.

          
          
rcfs20=wprcoef(wpt1,[n,0]);
  • 1.

          
          
rcfs21=wprcoef(wpt1,[n,1]);
  • 1.

          
          
rcfs22=wprcoef(wpt1,[n,2]);
  • 1.

          
          
rcfs23=wprcoef(wpt1,[n,3]);
  • 1.

          
          
rcfs24=wprcoef(wpt1,[n,4]);
  • 1.

          
          
rcfs25=wprcoef(wpt1,[n,5]);
  • 1.

          
          
rcfs26=wprcoef(wpt1,[n,6]);
  • 1.

          
          
rcfs27=wprcoef(wpt1,[n,7]);
  • 1.

          
          
cfs20=wpcoef(wpt1,[n,0]);
  • 1.

          
          
cfs21=wpcoef(wpt1,[n,1]);
  • 1.

          
          
cfs22=wpcoef(wpt1,[n,2]);
  • 1.

          
          
cfs23=wpcoef(wpt1,[n,3]);
  • 1.

          
          
cfs24=wpcoef(wpt1,[n,4]);
  • 1.

          
          
cfs25=wpcoef(wpt1,[n,5]);
  • 1.

          
          
cfs26=wpcoef(wpt1,[n,6]);
  • 1.

          
          
cfs27=wpcoef(wpt1,[n,7]);
  • 1.

          
          
wpt2=wpdec(s3,n,ji);
  • 1.

          
          
rcfs30=wprcoef(wpt2,[n,0]);
  • 1.

          
          
rcfs31=wprcoef(wpt2,[n,1]);
  • 1.

          
          
rcfs32=wprcoef(wpt2,[n,2]);
  • 1.

          
          
rcfs33=wprcoef(wpt2,[n,3]);
  • 1.

          
          
rcfs34=wprcoef(wpt2,[n,4]);
  • 1.

          
          
rcfs35=wprcoef(wpt2,[n,5]);
  • 1.

          
          
rcfs36=wprcoef(wpt2,[n,6]);
  • 1.

          
          
rcfs37=wprcoef(wpt2,[n,7]);
  • 1.

          
          
cfs30=wpcoef(wpt2,[n,0]);
  • 1.

          
          
cfs31=wpcoef(wpt2,[n,1]);
  • 1.

          
          
cfs32=wpcoef(wpt2,[n,2]);
  • 1.

          
          
cfs33=wpcoef(wpt2,[n,3]);
  • 1.

          
          
cfs34=wpcoef(wpt2,[n,4]);
  • 1.

          
          
cfs35=wpcoef(wpt2,[n,5]);
  • 1.

          
          
cfs36=wpcoef(wpt2,[n,6]);
  • 1.

          
          
cfs37=wpcoef(wpt2,[n,7]);
  • 1.

          
          
wpt3=wpdec(s4,n,ji);
  • 1.

          
          
rcfs40=wprcoef(wpt3,[n,0]);
  • 1.

          
          
rcfs41=wprcoef(wpt3,[n,1]);
  • 1.

          
          
rcfs42=wprcoef(wpt3,[n,2]);
  • 1.

          
          
rcfs43=wprcoef(wpt3,[n,3]);
  • 1.

          
          
rcfs44=wprcoef(wpt3,[n,4]);
  • 1.

          
          
rcfs45=wprcoef(wpt3,[n,5]);
  • 1.

          
          
rcfs46=wprcoef(wpt3,[n,6]);
  • 1.

          
          
rcfs47=wprcoef(wpt3,[n,7]);
  • 1.

          
          
cfs40=wpcoef(wpt3,[n,0]);
  • 1.

          
          
cfs41=wpcoef(wpt3,[n,1]);
  • 1.

          
          
cfs42=wpcoef(wpt3,[n,2]);
  • 1.

          
          
cfs43=wpcoef(wpt3,[n,3]);
  • 1.

          
          
cfs44=wpcoef(wpt3,[n,4]);
  • 1.

          
          
cfs45=wpcoef(wpt3,[n,5]);
  • 1.

          
          
cfs46=wpcoef(wpt3,[n,6]);
  • 1.

          
          
cfs47=wpcoef(wpt3,[n,7]);
  • 1.

          
          
for i=1:2^n
  • 1.

          
          
E(i)=(norm(wpcoef(wpt,[n,i-1]),2))^2;%求第i个节点的范数平方,其实也就是平方和,即能量
  • 1.

          
          
end
  • 1.

3 仿真结果

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_加载_06

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_故障诊断_07

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_数据_08

4 参考文献

基于小波包分析的滚动轴承故障诊断[J].张国新,刘祚时.电子科技. 江西理工大学学报. 2007,(01)

【故障诊断分析】基于小波包能量分析轴承故障诊断含Matlab源码_数据_09