www.gusucode.com > 局部均值分解源代码 难得的matlab程序代码源码 > lmd/lmd1.m
function[PF,A,SI]=lmd1(m) %最后一个PF是残余分量 %A是瞬时赋值 %SI是纯调频函数,求它的瞬时频率就是需要的频率 c=m; k=0; wucha1=0.001; n_l=nengliang(m); while 1 k=k+1; a=1; h=c; [pf,a,si]=zhaochun1(a,h,wucha1); c=c-pf; PF(k,:)=pf; A(k,:)=a; SI(k,:)=si; c_pos=pos(c); n_c=nengliang(c); n_pf=nengliang(pf); %停止调节 %1.emd用的是三次样条求包络,要求至少3个极值点,所以这里c的极值点个数也应该至少为3 %2.如果上一个PF的极值点数比下一个PF的极值点数少,说明结果也不正确(这个也可以作为停止条件考虑进去) %上面一句是否可以等价于当前PF的极值点个数一定要大于等于残量(c)的极值点个数(目前是用这个作为停止条件的一个参考写入程序) %3.当前PF分量的能量应该大于残量c的能量(这个有待商榷) %4.残余能量不能大于信号能量 if n_pf<n_c if length(c_pos)<3 || n_c<n_l/10 ||k==3%|| n_pf<n_c%||n_c>n_l PF(k+1,:)=c; break end end end