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

news/2024/6/17 19:55:03 标签: matlab, 开发语言, 信号处理, 算法, cnn

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

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

程序运行环境为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;
% 恢复故障信号

出图如下:


http://www.niftyadmin.cn/n/5373640.html

相关文章

软件价值11-简单计算器

用python的tkinter做的简单计算器 代码: import tkinter as tkdef button_click(item):global expressionexpression expression str(item)input_text.set(expression)def button_clear():global expressionexpression ""input_text.set(""…

2024腾讯云游戏服务器租用多少钱一年?

2024年更新腾讯云游戏联机服务器配置价格表,可用于搭建幻兽帕鲁、雾锁王国等游戏服务器,游戏服务器配置可选4核16G12M、8核32G22M、4核32G10M、16核64G35M、4核16G14M等配置,可以选择轻量应用服务器和云服务器CVM内存型MA3或标准型SA2实例&am…

【C语言】通过socket看系统调用过程

一、通过socket看系统调用过程 在Linux操作系统中,系统调用是用户空间与内核空间之间交互的一种方式。当一个应用程序需要执行操作系统级别的任务时,比如创建一个网络套接字(socket),它必须通过系统调用请求内核来执行…

生成验证码-超简单

引言 在Web开发中,验证码是一种常见的防止恶意破解、自动化提交的有效手段。在Java项目中,我们可以使用Hutool工具库快速实现验证码功能。Hutool是一个Java工具包,它以简洁易用著称,其中包含了验证码模块,可以让我们轻…

TestNG基础教程

TestNG基础教程 一、常用断言二、执行顺序三、依赖测试四、参数化测试1、通过dataProvider实现2、通过xml配置(这里是直接跑xml) 五、testng.xml常用配置方式1、分组维度控制2、类维度配置3、包维度配置 六、TestNG并发测试1、通过注解来实现2、通过xml来…

使用rem单位制,实现页面适应性窗口元素

目录 REM单位: 媒体查询: 引入资源: REM适配方案: 适配方案一: rem媒体查询less技术 适配方案二: REM单位: rem(rootem)是一个相对单位,类似于em,em是父元素字体大小。 不同的…

【操作系统】1.操作系统的基本概念

1.操作系统的基本概念 1.1. 操作系统的概念 软件是计算机系统的灵魂,而作为软件核心的操作系统,已与现代计算机系统密不可分。 计算机系统自上而下可大致分为4部分: 用户 应用程序 操作系统 硬件 操作系统管理各种计算机硬件,为…

ChatGPT高效提问—prompt常见用法(续篇五)

ChatGPT高效提问—prompt常见用法(续篇五) 1.1 种子词 ​ 种子词(seed word)通常指的是在对话中使用的初始提示或关键词,用于引导ChatGPT生成相关回复。种子词可以是一个词、短语或句子,通常与对话的主题…