当前位置:网站首页>Implementation of ICEEMDAN Decomposition Code in MATLAB
Implementation of ICEEMDAN Decomposition Code in MATLAB
2022-08-04 07:02:00 【Doraemon 001】
0, Preface
This article explains the ICEEMDAN decomposition method and shares the code.
1. Implementation of ICEEMDAN
The following is the main function part:
ecg=data;%data is a signal data to be decomposed, please replace it with your own data%% parameter settingsNstd = 0.2;nr = 1;MaxIter = 5000;%%ICEEMDAN[modes]=iceemdan(ecg,Nstd,NR,MaxIter,1);%iceemdanmodes=modes';t=1:length(ecg);[a b]=size(modes);figure;subplot(a+1,1,1);plot(t,ecg);% the ECG signal is in the first row of the subplotylabel('original')set(gca,'xtick',[])title('ICEEMDAN')axis tight;for i=2:asubplot(a+1,1,i);plot(t,modes(i-1,:));ylabel (['IMF ' num2str(i-1)]);set(gca,'xtick',[])xlim([1 length(ecg)])endsubplot(a+1,1,a+1)plot(t,modes(a,:))ylabel(['IMF ' num2str(a)])xlim([1 length(ecg)])xlabel('sample point')The code of the sub-function iceemdan:
function [modes]=iceemdan(x,Nstd,NR,MaxIter,SNRFlag)% The current is an improved version, introduced in:%[1] Colominas MA, Schlotthauer G, Torres ME. "Improve complete ensemble EMD: A suitable tool for biomedical signal processing"% Biomedical Signal Processing and Control vol. 14 pp. 19-29 (2014)%The CEEMDAN algorithm was first introduced at ICASSP 2011, Prague, Czech Republic%The authors will be thankful if the users of this code reference the work%where the algorithm was first presented:%[2] Torres ME, Colominas MA, Schlotthauer G, Flandrin P. "A Complete Ensemble Empirical Mode Decomposition with Adaptive Noise"% Proc. 36th Int. Conf. on Acoustics, Speech and Signa Processing ICASSP 2011 (May 22-27, Prague, Czech Republic)%Author: Marcelo A. Colominas%contact: [email protected]%Last version: 25 feb 2015desvio_x=std(x);x=x/desvio_x;[a,b]=size(x);temp=zeros(b,1);modes=zeros(b,1);aux=zeros(a,b);for i=1:NRwhite_noise{i}=randn(size(x));%creates the noise realizationsend;for i=1:NRmodes_white_noise{i}=emd(white_noise{i},'display',0);%calculates the modes of white gaussian noiseend;% save interval modes_white_noisefor i=1:NR %calculates the first modexi=x+Nstd*modes_white_noise{i}(:,1)'/std(modes_white_noise{i}(:,1));[temp, o, it]=emd(xi,'MaxNumIMF',1,'SiftMaxIterations',MaxIter,'display',0);aux=aux+(xi-temp')/NR;% nnnnnnnnnnnnnnnnJub local envelopeend;modes= (x-aux)'; %saves the first modemedias = aux; %r1k=1;aux=zeros(a,b);es_imf = min(size(emd(medias(1,:),'SiftMaxIterations',MaxIter,'display',0)));while es_imf>1 %calculates the rest of the modesfor i=1:NRtamanio=size(modes_white_noise{i});if tamanio(2)>=k+1noise=modes_white_noise{i}(:,k+1);if SNRFlag == 2noise=noise/std(noise); %adjust the std of the noiseend;noise=Nstd*noise;try[temp,o,it]=emd(medias(1,:)+std(medias(1,:))*noise','MaxNumIMF',1,'SiftMaxIterations',MaxIter,'display',0);catchtemp=emd(medias(1,:)+std(medias(1,:))*noise','MaxNumIMF',1,'SiftMaxIterations',MaxIter,'display',0);end;elsetry[temp, o, it]=emd(medias(1,:),'MaxNumIMF',1,'SiftMaxIterations',MaxIter,'display',0);catchtemp=emd(medias(1,:),'MaxNumIMF',1,'SiftMaxIterations',MaxIter,'display',0);end;end;aux=aux+(medias(1,:)+std(medias(1,:))*noise'-temp')/NR;% r2 r3 r...end;modes=[modes (medias(1,:)-aux)'];medias = aux;aux=zeros(size(x));k=k+1;es_imf = min(size(emd(medias(1,:),'SiftMaxIterations',MaxIter,'display',0)));end;modes = [modes (medias(1,:))'];modes=modes*desvio_x;The above code can be run directly to achieve signal decomposition.
边栏推荐
猜你喜欢
随机推荐
普通用户 远程桌面连接 服务器 Remote Desktop Service
Faster - RCNN principle and repetition code
电脑知识:台式电脑应该选择品牌和组装,值得收藏
注册表设置默认浏览器 win7,winserver 2008,winserver 2012
nacos 返回 403 unknown user 太他么坑了 源码解析
无监督特征对齐的迁移学习理论框架
并发概念基础:线程安全与线程间通信
网络安全工程师们改不掉的“老毛病”
Database: Organize Four Practical SQL Server Scripting Functions
golang 坐标格式 转换 GCJ02ToWGS84
VS 2017编译 QT no such slot || 找不到*** 问题
VMD combined with ISSA to optimize LSSVM power prediction
Nacos 原理
LeetCode刷题
基于Webrtc和Janus的多人视频会议系统开发5 - 发布媒体流到Janus服务器
【HIT-SC-MEMO1】哈工大2022软件构造 复习笔记1
EfficientNet解读:神经网络的复合缩放方法(基于tf-Kersa复现代码)
冰歇webshell初探
桌面右键的NVIDIA去除与恢复
并发概念基础:并发、同步、阻塞









