【MATLAB第5期】源码分享#基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM) 的ECG信号分类模型,含源代码+中文注释,保姆级教学

简介: 【MATLAB第5期】源码分享#基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM) 的ECG信号分类模型,含源代码+中文注释,保姆级教学

【MATLAB第5期】源码分享#基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM) 的ECG信号分类模型,含源代码+中文注释,保姆级教学


引言


1.小波散射网络


关于小波散射网络,可参考一篇文章:

小波散射网络初级探索 - 哥廷根数学学派的文章 - 知乎 哥廷根数学学派:小波散射网络初级探索

本文讲解如何使用小波时间散射网络(WTSN)和长短期记忆网络(LSTM) 对人体心电图 (ECG)信号进行分类。在小波散射中,数据通过一系列的小波变换、非线性化和平均化过程,以产生时间序列的低方差表示。小波时间散射产生了对输入信号微小变化不敏感的信号表示,而几乎不会影响到分类准确率。本文中使用的数据公开,在github网站可以下载。

代码免费下载链接:←←←点击即可下载,整理不易,求个关注~


2.数据描述


本文使用3种 ECG 数据:心律失常数据ARR、充血性心力衰竭数据CHF和正常窦性心律数据NSR,共使用来自3个 PhysioNet 数据库的162条ECG 记录:MIT-BIH心律失常数据库、MIT-BIH正常窦性心律数据库和BIDMC充血性心力衰竭数据库。 共有96个心律失常患者的信号,30个充血性心力衰竭患者的信号,以及36个正常窦性心律患者的信号,目标就是训练分类器来区分心律失常 (ARR)、充血性心力衰竭 (CHF)和正常窦性心律 (NSR)3类信号。

本示例说明如何使用小波时间散射和LSTM对人心电图(ECG)信号进行分类。 我们将训练一个长期短期记忆网络来识别以上心律。


一、加载和预处理数据


数据是162个采样信号,以128Hz的频率(Fs)采样。

load(fullfile(pwd, "ECGData.mat"))%导入数据
Fs = 128;

ECGData是一个结构数组,包含两个字段:Data 和 Labels。数据是一个 162×65536的矩阵,其中每一行是以128Hz采样的ECG信号。每个ECG时间序列的总持续时间为512秒。标签是一个 162×1 的标签元胞数组,每行1个数据。

这些信号分为三类:

unique(ECGData.Labels)

%ans = 3×1 cell 数组

%{‘ARR’}

%{‘CHF’}

%{‘NSR’}

其中ARR是指心律异常(心律失常)的信号,CHF是指充血性心力衰竭,NSR是指心律正常(正常窦性心律)

让我们看看其中一些信号是什么样的。

M = size(ECGData.Data, 1);%提取数据样本行数
idxsel = randperm(M, 4);%随机选取其中4个样本编号
tiledlayout(2, 2, "Padding", "compact")%建立2*2的图像窗口
%依次画出这4个样本的信号数据特征(提取前3000个序列数据)
for numplot = 1:4
    nexttile
    plot(ECGData.Data(idxsel(numplot),1:3000))
    ylabel('Volts')
    xlabel('Samples')
    title(string(ECGData.Labels(idxsel(numplot))))
end


二、使用小波散射自动特征提取


1.小波散射特征提取


小波散射是一种可用于自动提取低方差,紧凑特征的技术,该方法可以最大程度地减少类内的差异,同时保留各个类之间的可区分性。我们可以提供这些功能,而不是将原始表示提供给LSTM,以便网络可以快速学习模式并随后对信号进行分类。


sampleSig = ECGData.Data(1,:);%选取第一行样本
sf = waveletScattering('SignalLength',numel(sampleSig),'SamplingFrequency',Fs)
feat = featureMatrix(sf,sampleSig);%自动提取特征

sf = waveletScattering - 属性:

SignalLength: 65536

InvarianceScale: 256

QualityFactors: [8 1]

Boundary: “periodic”

SamplingFrequency: 128

Precision: “double”

OversamplingFactor: 0


2.提取特征前后特征尺寸对比


变量 feat 包含从信号中自动提取的特征。 在此示例中,我们使用2层网络提取所有要素。

提取特征前sampleSig包含要素:

提取特征后 feat包含要素:

与原始信号的长度相比,特征尺寸减少了95%


3.可视化提取的特征


我们可以独立检查来自每一层的特征

lev = 1;
[S1,U1] = scatteringTransform(sf,ECGData.Data(find(ECGData.Labels=="ARR",1),:));
[S2,U2] = scatteringTransform(sf,ECGData.Data(find(ECGData.Labels=="NSR",1),:));
scattergram(sf,S1,'FilterBank',lev);
title(sprintf('Scattering Level %d: Class I sample',lev));


scattergram(sf,S2,‘FilterBank’,lev);

title(sprintf(‘Scattering Level %d: Class II sample’,lev));

注意:上面显示的只是一种可视化提取了哪些特征的方法。 为每个信号提取一个499x8特征矩阵。


三、提取训练和测试集中所有信号的特征


让我们将数据集随机划分为训练数据集和测试数据集。


1.提取训练和测试集中所有信号的特征


让我们将数据集随机划分为训练数据集和测试数据集。

%load(fullfile(pwd, "data", "PartitionedData.mat"))
idxRandomized = randperm(M);%样本顺序打乱
trainSize = 113;%113个样本训练
testSize = M-trainSize;%162-113=49个样本测试
trainData = zeros(trainSize, size(ECGData.Data,2));%113*65536 double数据格式
trainLabels = cell(trainSize,1);%113*1 cell数据格式
testData = zeros(testSize, size(ECGData.Data,2));%49*65536 double数据格式
testLabels = cell(testSize,1);%49*1 cell数据格式

使用我们现有的小波散射变换,为训练和测试数据集计算散射特征。

scat_features_train = cell(trainSize,1);%113*1 cell 数据结构,每个cell是499*8
scat_features_test = cell(testSize,1);%49*1 cell数据结构,每个cell是499*8


四、利用散射特征训练LSTM


1.建立训练模型


现在让我们建立一个非常简单的LSTM网络进行训练。

[inputSize,~] = size(scat_features_train{1});
YTrain = categorical(trainLabels);
numHiddenUnits = 100;%隐含层神经元数
numClasses = numel(unique(YTrain));%类别数量
maxEpochs = 125;%训练次数
miniBatchSize = 1000;%最小批处理数量
layers = [ ...
    sequenceInputLayer(inputSize)
    lstmLayer(numHiddenUnits,'OutputMode','last')
    fullyConnectedLayer(numClasses)
    softmaxLayer
    classificationLayer];

并建立一些通用的训练选项。

options = trainingOptions('adam', ...%adam学习器
    'InitialLearnRate',0.01,...%初始学习率
    'MaxEpochs',maxEpochs, ...
    'MiniBatchSize',miniBatchSize, ...
    'SequenceLength','shortest', ...%“最短”—截断每个小批中的序列,使其长度与最短序列相同。
    'Shuffle','never',...%不打乱数据
    'Plots','training-progress');

现在我们准备训练或者导入已经训练好的网络。

if true
    netScat = trainNetwork(scat_features_train,YTrain,layers,options);
else
    load(fullfile(pwd, "data", "netScat.mat"))
end


2.评估LSTM模型


现在我们可以测试我们训练好的模型:

YTest = categorical(testLabels);%提取测试输出实际类别
YPred = classify(netScat,scat_features_test, 'MiniBatchSize',miniBatchSize, 'SequenceLength','shortest');
accuracy = round((sum(YPred == YTest)./numel(YTest))*100);%正确率
confusionchart(YTest, YPred, "RowSummary", "row-normalized");
title("Accuracy: " + accuracy + "%")

3.提高分类准确度


如果您对结果不满意,则可以对散射滤波器组中的一个可选参数进行微调,以获得所需的结果。 invariance scale 的默认值是信号长度的一半(以样本为单位)。

您始终可以扫描 invariance scale 并使用贝叶斯优化来找出LSTM网络的超参数的正确组合。


五、总结


本示例使用小波时间散射和LSTM将ECG波形分类为三个诊断类别之一。 小波散射被证明是功能强大的特征提取器,它只需要一组最少用户指定的参数即可产生一组可靠的分类特征。














































目录
打赏
0
0
0
0
267
分享
相关文章
基于GA遗传优化TCN-GRU时间卷积神经网络时间序列预测算法matlab仿真
本项目基于MATLAB2022a开发,提供无水印算法运行效果预览及核心程序(含详细中文注释与操作视频)。通过结合时间卷积神经网络(TCN)和遗传算法(GA),实现复杂非线性时间序列的高精度预测。TCN利用因果卷积层与残差连接提取时间特征,GA优化超参数(如卷积核大小、层数等),显著提升模型性能。项目涵盖理论概述、程序代码及完整实现流程,适用于金融、气象、工业等领域的时间序列预测任务。
基于ECC簇内分组密钥管理算法的无线传感器网络matlab性能仿真
本程序基于ECC(椭圆曲线密码学)簇内分组密钥管理算法,对无线传感器网络(WSN)进行MATLAB性能仿真。通过对比网络通信开销、存活节点数量、网络能耗及数据通信量四个关键指标,验证算法的高效性和安全性。程序在MATLAB 2022A版本下运行,结果无水印展示。算法通过将WSN划分为多个簇,利用ECC生成和分发密钥,降低计算与通信成本,适用于资源受限的传感器网络场景,确保数据保密性和完整性。
基于GA遗传优化TCN时间卷积神经网络时间序列预测算法matlab仿真
本内容介绍了一种基于遗传算法优化的时间卷积神经网络(TCN)用于时间序列预测的方法。算法运行于 Matlab2022a,完整程序无水印,附带核心代码、中文注释及操作视频。TCN通过因果卷积层与残差连接学习时间序列复杂特征,但其性能依赖超参数设置。遗传算法通过对种群迭代优化,确定最佳超参数组合,提升预测精度。此方法适用于金融、气象等领域,实现更准确可靠的未来趋势预测。
网络安全与信息安全:知识分享####
【10月更文挑战第21天】 随着数字化时代的快速发展,网络安全和信息安全已成为个人和企业不可忽视的关键问题。本文将探讨网络安全漏洞、加密技术以及安全意识的重要性,并提供一些实用的建议,帮助读者提高自身的网络安全防护能力。 ####
113 17
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将从网络安全漏洞、加密技术和安全意识三个方面进行探讨,旨在提高读者对网络安全的认识和防范能力。通过分析常见的网络安全漏洞,介绍加密技术的基本原理和应用,以及强调安全意识的重要性,帮助读者更好地保护自己的网络信息安全。
83 10
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将介绍网络安全的重要性,分析常见的网络安全漏洞及其危害,探讨加密技术在保障网络安全中的作用,并强调提高安全意识的必要性。通过本文的学习,读者将了解网络安全的基本概念和应对策略,提升个人和组织的网络安全防护能力。
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
在数字化时代,网络安全和信息安全已成为我们生活中不可或缺的一部分。本文将介绍网络安全漏洞、加密技术和安全意识等方面的内容,并提供一些实用的代码示例。通过阅读本文,您将了解到如何保护自己的网络安全,以及如何提高自己的信息安全意识。
108 10
网络安全与信息安全:漏洞、加密与意识的交织
在数字时代的浪潮中,网络安全与信息安全成为维护数据完整性、保密性和可用性的关键。本文深入探讨了网络安全中的漏洞概念、加密技术的应用以及提升安全意识的重要性。通过实际案例分析,揭示了网络攻击的常见模式和防御策略,强调了教育和技术并重的安全理念。旨在为读者提供一套全面的网络安全知识框架,从而在日益复杂的网络环境中保护个人和组织的资产安全。
云计算与网络安全:云服务、网络安全、信息安全等技术领域的融合与挑战
本文将探讨云计算与网络安全之间的关系,以及它们在云服务、网络安全和信息安全等技术领域中的融合与挑战。我们将分析云计算的优势和风险,以及如何通过网络安全措施来保护数据和应用程序。我们还将讨论如何确保云服务的可用性和可靠性,以及如何处理网络攻击和数据泄露等问题。最后,我们将提供一些关于如何在云计算环境中实现网络安全的建议和最佳实践。
网络安全与信息安全知识分享
本文深入探讨了网络安全漏洞、加密技术以及安全意识三个方面,旨在帮助读者更好地理解和应对网络安全威胁。通过分析常见的网络安全漏洞类型及其防范措施,详细介绍对称加密和非对称加密的原理和应用,并强调提高个人和企业安全意识的重要性,为构建更安全的网络环境提供指导。
104 2