MATLAB|时序数据中的稀疏辅助信号去噪和模式识别

简介: MATLAB|时序数据中的稀疏辅助信号去噪和模式识别

一、概述

本文通过结合线性时不变滤波器、正交多分辨率表示和基于稀疏性的方法,解决了处理批处理模式时间序列数据时的信号去噪和模式识别问题。利用数字滤波器状态空间表示的频谱变换,将高阶零相低通、高通和带通无限脉冲响应滤波器设计为矩阵的新方法。还提出了一种基于近端梯度的技术,用于对一类特殊的零相位高通和带通数字滤波器进行因式分解,以便因式分解积保持滤波器的零相性质,并在信号模型中加入输入的稀疏导数分量。为了展示本文新颖的滤波器设计的应用,验证并提出了新的信号模型,以同时去噪和识别感兴趣的模式。首先使用我们提出的滤波器设计来测试现有的信号模型,该模型同时结合了线性时间不变(LTI)滤波器和基于稀疏性的方法。将本文提出的滤波器设计与现有信号模型相结合,开发了一种称为稀疏性辅助信号去噪(SASD)的新信号模型。使用仿真数据,证明了SASD信号模型在不同阶次滤波器和噪声水平下的鲁棒性。此后,提出并推导出一种称为稀疏性辅助模式识别(SAPR)的新信号模型。在SAPR中,还将LTI带通滤波器和基于稀疏性的方法与正交多分辨率表示(如小波)相结合,以检测输入信号中的特定模式。最后,本文将信号去噪和模式识别任务相结合,并推导出一种称为稀疏性辅助信号去噪和模式识别(SASDPR)的新信号模型。分别使用睡眠脑电图数据来检测K复合物和睡眠纺锤体,从而说明了SAPR和SASDPR框架的功能。


二、算例及仿真

📢算例一:

稀疏辅助信号去噪( SASD )算法同时结合全变差去噪和低通滤波对含噪信号进行滤波,从而保持了信号的不连续性。

             

📢算例二:

使用带状矩阵演示零相位滤波的示例:

         

📢算例三:

稀疏辅助信号去噪( SASD )算法同时结合全变差去噪和低通滤波对含噪信号进行滤波,从而保持了信号的不连续性。在这个例子中,我们使用LPF、TVD、SASS和SASD对心电信号进行去噪:

         

📢算例四:

稀疏辅助信号去噪和模式识别 (SASDPR) 将同时去噪和检测给定信号中感兴趣的振荡模式:

         

📢算例五:

稀疏辅助信号去噪和模式识别 (SASDPR) 将同时去噪和检测给定信号中感兴趣的振荡模式:

           

📢算例六:

稀疏辅助模式识别 (SAPR) 将检测信号中的小波模式:

       

三、Matlab代码实现

部分代码:

function [y, f, s, x, w] = generate_signal( fs, sigma )
%% 初始化噪声电平和信号长度
rng('default')
N = 10*fs;
n = 0:N-1;
%% 产生低频合成成分
f = 0.1;
f = sin(2*f/fs*pi*n);      
%% 振荡
s = zeros(size(n));
o = 13;
s(200+(1:fs)) = sin(2*pi*o/fs*(1:fs)) .* hamming(fs)';
%% 稀疏分段常数
x = zeros(size(n));
x(100:110) = -1;
x(400:420) = 1;
%% 添加噪音
w = sigma*randn(size(n));
y = f+s+x+w;
end


function [y, f, s, x, w] = generate_signal( fs, sigma )
%% 初始化噪声电平和信号长度
rng('default')
N = 10*fs;
n = 0:N-1;
%% 产生低频合成成分
f = 0.1;
f = sin(2*f/fs*pi*n);      
%% 振荡
s = zeros(size(n));
o = 13;
s(200+(1:fs)) = sin(2*pi*o/fs*(1:fs)) .* hamming(fs)';
%% 稀疏分段常数
x = zeros(size(n));
x(100:110) = -1;
x(400:420) = 1;
%% 添加噪音
w = sigma*randn(size(n));
y = f+s+x+w;
end
function [y, f, s, x, w] = generate_signal( fs, sigma )
%% 初始化噪声电平和信号长度
rng('default')
N = 10*fs;
n = 0:N-1;
%% 产生低频合成成分
f = 0.1;
f = sin(2*f/fs*pi*n);      
%% 振荡
s = zeros(size(n));
o = 13;
s(200+(1:fs)) = sin(2*pi*o/fs*(1:fs)) .* hamming(fs)';
%% 稀疏分段常数
x = zeros(size(n));
x(100:110) = -1;
x(400:420) = 1;
%% 添加噪音
w = sigma*randn(size(n));
y = f+s+x+w;
end
function [y, f, s, x, w] = generate_signal( fs, sigma )
%% 初始化噪声电平和信号长度
rng('default')
N = 10*fs;
n = 0:N-1;
%% 产生低频合成成分
f = 0.1;
f = sin(2*f/fs*pi*n);      
%% 振荡
s = zeros(size(n));
o = 13;
s(200+(1:fs)) = sin(2*pi*o/fs*(1:fs)) .* hamming(fs)';
%% 稀疏分段常数
x = zeros(size(n));
x(100:110) = -1;
x(400:420) = 1;
%% 添加噪音
w = sigma*randn(size(n));
y = f+s+x+w;
end
相关文章
|
4天前
|
算法 数据安全/隐私保护
matlab程序,傅里叶变换,频域数据,补零与不补零傅里叶变换
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
4天前
|
数据安全/隐私保护
matlab 曲线光滑,去毛刺,去离群值,数据滤波,高通滤波,低通滤波,带通滤波,带阻滤波
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
4天前
|
数据安全/隐私保护
时域与频域数据互相转换,傅里叶变换与逆傅里叶变换,matlab程序,时域转频域
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
4天前
|
计算机视觉
MATLAB用Lasso回归拟合高维数据和交叉验证
MATLAB用Lasso回归拟合高维数据和交叉验证
|
4天前
|
SQL 移动开发 算法
MATLAB改进模糊C均值聚类FCM在电子商务信用评价应用:分析淘宝网店铺数据|数据分享
MATLAB改进模糊C均值聚类FCM在电子商务信用评价应用:分析淘宝网店铺数据|数据分享
|
4天前
|
机器学习/深度学习 数据可视化
Matlab决策树对空气质量和天气温度及天气数据做交通出行推荐预测|数据分享
Matlab决策树对空气质量和天气温度及天气数据做交通出行推荐预测|数据分享
|
4天前
|
数据挖掘 数据库
数据分享|MATLAB、R基于Copula方法和k-means聚类的股票选择研究上证A股数据
数据分享|MATLAB、R基于Copula方法和k-means聚类的股票选择研究上证A股数据
|
4天前
|
计算机视觉
MATLAB偏最小二乘回归(PLSR)和主成分回归(PCR)分析光谱数据
MATLAB偏最小二乘回归(PLSR)和主成分回归(PCR)分析光谱数据
|
4天前
|
数据采集 算法 数据可视化
MATLAB、R用改进Fuzzy C-means模糊C均值聚类算法的微博用户特征调研数据聚类研究
MATLAB、R用改进Fuzzy C-means模糊C均值聚类算法的微博用户特征调研数据聚类研究
|
4天前
|
机器学习/深度学习 数据可视化 网络架构
Matlab用深度学习循环神经网络RNN长短期记忆LSTM进行波形时间序列数据预测
Matlab用深度学习循环神经网络RNN长短期记忆LSTM进行波形时间序列数据预测

热门文章

最新文章