【心电信号检测】基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM)实现ECG信号分类附matlab代码

简介: 【心电信号检测】基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM)实现ECG信号分类附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

随着社会不断进步和生活压力的不断上升,心脏疾病已经成为威胁人类健康的重要因素.心电信号(ECG)表征了人体心脏的电活动,可以通过心电图直观展现出来,在心脏疾病发病前,心电信号中一般会出现相应的心律失常现象,因此,对心电信号进行识别分类研究,对心脏病的诊断和治疗具有重要的意义.由此许多专家和学者对心电信号的识别分类进行了大量研究.心电信号的识别分类通常包括心电信号采集,心电信号预处理,提取心电特征,设计识别分类器等步骤.心电信号常含干扰噪声,噪声的存在会影响后期心电信号特征点R波峰的准确检测,并影响对心电信号识别分类率,故心电信号的预处理是心电信号识别分类的关键步骤。本文基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM)实现ECG信号分类。

⛄ 部分代码

clear

close all

clc

load(fullfile(pwd, "ECGData.mat"))

Fs = 128;

unique(ECGData.Labels)

M = size(ECGData.Data, 1);

idxsel = randperm(M, 4);

tiledlayout(2, 2, "Padding", "compact")


for numplot = 1:4

   nexttile

   plot(ECGData.Data(idxsel(numplot),1:3000))

   ylabel('Volts')

   xlabel('Samples')

   title(string(ECGData.Labels(idxsel(numplot))))

end


sampleSig = ECGData.Data(1,:);

sf = waveletScattering('SignalLength',numel(sampleSig),'SamplingFrequency',Fs)

feat = featureMatrix(sf,sampleSig);

lev = 1;

[S1,U1] = scatteringTransform(sf,ECGData.Data(find(ECGData.Labels=="ARR",1),:));

if true

   netScat = trainNetwork(scat_features_train,YTrain,layers,options);

else

   load(fullfile(pwd, "data", "netScat.mat"))

end


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 + "%")

⛄ 运行结果

⛄ 参考文献

[1] 袁丹阳. 基于小波包和神经网络的心电信号分类方法研究[D]. 天津工业大学, 2017.

[2] 张杨. 基于小波分析的ECG信号检测[D]. 厦门大学, 2007.

[3] 徐一轩, 伍卫国, 王思敏,等. 基于长短期记忆网络(LSTM)的数据中心温度预测算法[J]. 计算机技术与发展, 2019, 29(12):7.

[4] 岑小林, 胡佳宗, 陈援峰. 基于Matlab的小波提升与心电信号R波检测[J]. 数字技术与应用, 2014(6):2.

[5] 丁兴号, 邓善熙, 赵前程. 基于小波和神经网络的动态心电波形分类新方法[J]. 生物物理学报, 2003, 19(1):5.

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
30天前
|
机器学习/深度学习 算法 PyTorch
RPN(Region Proposal Networks)候选区域网络算法解析(附PyTorch代码)
RPN(Region Proposal Networks)候选区域网络算法解析(附PyTorch代码)
223 1
|
1天前
|
机器学习/深度学习 算法 Python
Python用RNN神经网络:LSTM、GRU、回归和ARIMA对COVID19新冠疫情人数时间序列预测
Python用RNN神经网络:LSTM、GRU、回归和ARIMA对COVID19新冠疫情人数时间序列预测
38 12
|
2天前
|
机器学习/深度学习 传感器 数据可视化
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
15 1
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
|
6天前
|
机器学习/深度学习 Python
Python用LSTM长短期记忆神经网络对不稳定降雨量时间序列进行预测分析
Python用LSTM长短期记忆神经网络对不稳定降雨量时间序列进行预测分析
16 0
|
7天前
|
机器学习/深度学习 数据采集 TensorFlow
R语言KERAS深度学习CNN卷积神经网络分类识别手写数字图像数据(MNIST)
R语言KERAS深度学习CNN卷积神经网络分类识别手写数字图像数据(MNIST)
26 0
|
8天前
|
机器学习/深度学习 数据可视化 网络架构
matlab使用长短期记忆(LSTM)神经网络对序列数据进行分类
matlab使用长短期记忆(LSTM)神经网络对序列数据进行分类
12 0
|
16天前
|
传感器 监控 安全
|
30天前
|
机器学习/深度学习 PyTorch 算法框架/工具
卷积神经元网络中常用卷积核理解及基于Pytorch的实例应用(附完整代码)
卷积神经元网络中常用卷积核理解及基于Pytorch的实例应用(附完整代码)
20 0
|
1月前
|
机器学习/深度学习 数据采集 人工智能
m基于深度学习网络的手势识别系统matlab仿真,包含GUI界面
m基于深度学习网络的手势识别系统matlab仿真,包含GUI界面
41 0
|
1月前
|
机器学习/深度学习 算法 计算机视觉
基于yolov2深度学习网络的火焰烟雾检测系统matlab仿真
基于yolov2深度学习网络的火焰烟雾检测系统matlab仿真

热门文章

最新文章