MATLAB环境下用于提取冲击信号的几种解卷积方法

卷积混合考虑了信号的时延,每一个单独源信号的时延信号都会和传递路径发生一 次线性瞬时混合;解卷积的过程就是找一个合适的滤波器,进行反卷积运算,得到源信号的近似解。

声音不可避免的会发生衍射、反射等现象,所以,源声信号及其时延信号在传递过程中会发生卷积然后到达麦克风。所以,卷积模型更符合实际工程问题,利用解卷积思路用于振动、声音信号的信号处理以及齿轮、轴承的故障特征增强的有最小熵解卷积、最大相关峭度解卷积、多点最优最小熵解卷积调整、最大二阶循环平稳盲解卷积等方法。

程序运行环境为MATLAB R2018A,包含用于提取冲击信号的几种解卷积方法,可用于一维信号处理与机械故障诊断,也可用于金融时间序列,地震信号,机械振动信号,语音信号,声信号等一维时间序列信号。几种方法如下:

[1]最大相关峭度解卷积

[2]二维最小熵解卷积

[3]多点最优最小熵解卷积

[4]最小熵解卷积d-范数精确解方法

部分程序如下:

%%  最大相关峭度解卷积
%从非常强烈的白噪声中提取周期脉冲
clc;clear
n = 0:999;
%带噪声的信号
x = 3*(mod(n,100)==0) + randn(size(n));

    
%% 二维最小熵解卷积
% -------- 1d解卷积 ------
clc;clear
n = 0:999;
 %测试信号
 x = [sin(n/30) + 0.2*(mod(n,21)==0)];
 % 100次迭代, 30样本点FIR滤波器
 

% -------- 2d解卷积示例 ------
%提取类冲击信号,0.2*(mod(n,21)==0)为干扰信号,并绘制结果。
n = 0:999;
x = [sin(n/30) + 0.2*(mod(n,21)==0);sin(n/13) + 0.2*(mod(n,21)==0)];% 100次迭代, 30样本点FIR滤波器    

   
%% 多点最优最小熵解卷积
%简单振动故障模型
close all
n = 0:4999;
%滤波器
h = [-0.05 0.1 -0.4 -0.8 1 -0.8 -0.4 0.1 -0.05];
faultn = 0.05*(mod(n,50)==0);
fault = filter(h,1,faultn);
noise = wgn(1,length(n),-25);
%测试信号
x = sin(2*pi*n/30) + 0.2*sin(2*pi*n/60) + 0.1*sin(2*pi*n/15) + fault;
xn = x + noise;
window = ones(1,1);
%设计1000个样本点的FIR滤波器
L = 1000;
%恢复周期为50的故障信号


n = 0:9999;
h = [-0.05 0.1 -0.4 -0.8 1 -0.8 -0.4 0.1 -0.05];
faultn = 0.05*(mod(n,50)==0);
fault = filter(h,1,faultn);
noise = wgn(1,length(n),-25);
x = sin(2*pi*n/30) + 0.2*sin(2*pi*n/60) + 0.1*sin(2*pi*n/15) + fault;
xn = x + noise;
window = ones(1,1);
L = 1000;
% 绘制10至300区间的频谱
range = [10:0.1:300];

 
%提取故障信号,假设周期在45到55之间
 window = ones(1,1); 
range = [45:0.1:55];
 %绘制产生的故障信号
figure;
plot( y_best(1:1000) );
%title(strcat(['Extracted fault signal (period=', num2str(T_best), ')'])

%% 最小熵解卷积d-范数精确解方法
n = 0:1999;
h = [-0.05 0.1 -0.4 -0.8 1 -0.8 -0.4 0.1 -0.05];
faultn = 0.05*(mod(n,50)==0);
fault = filter(h,1,faultn);
noise = wgn(1,length(n),-40);
x = sin(2*pi*n/30) + 0.2*sin(2*pi*n/60) + 0.1*sin(2*pi*n/15) + fault;
xn = x + noise;
% 设计20个样本点的FIR滤波器
L = 20;
% 恢复故障信号

出图如下:

最近更新

  1. TCP协议是安全的吗?

    2024-02-08 07:40:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-08 07:40:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-08 07:40:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-08 07:40:01       20 阅读

热门阅读

  1. 隐私计算技术创新赋能金融数字化转型

    2024-02-08 07:40:01       37 阅读
  2. C++之多线程(multi-thread)

    2024-02-08 07:40:01       42 阅读
  3. PostgreSQL不停机迁移数据

    2024-02-08 07:40:01       26 阅读
  4. sklearn.preprocessing 特征编码汇总

    2024-02-08 07:40:01       31 阅读
  5. Rust语言入门小结(第1篇)

    2024-02-08 07:40:01       30 阅读
  6. 设计模式(行为型模式)中介者模式

    2024-02-08 07:40:01       32 阅读
  7. LeetCode动态规划的解题思路

    2024-02-08 07:40:01       30 阅读
  8. HTML系列 -> <meta charset=“utf-8“>

    2024-02-08 07:40:01       33 阅读
  9. Spark的timestamp 数据时间问题

    2024-02-08 07:40:01       41 阅读
  10. ORACLE的 软 软 软 解析!

    2024-02-08 07:40:01       36 阅读
  11. 【大数据面试题】005 谈一谈 Flink Watermark 水印

    2024-02-08 07:40:01       33 阅读
  12. FolkMQ “单线程“消息中间件(开源) v1.0.32 发布

    2024-02-08 07:40:01       39 阅读
  13. [AIGC] 开源流程引擎哪个好,如何选型?

    2024-02-08 07:40:01       33 阅读