johnbenny 发表于 2007-5-4 20:40

如何改进这个模极大算法滤波程序?

%____进行模极大值的处理:
C=0.8;
%此参数需要调节,为了在最大尺度上设定合适阈值,以确定最大尺度上该保留的模极大值点。
D4_wpeak=wpeak(level,:);
M=max(D4_wpeak);
Thr=C*M/level; %阈值计算,可参考论文:"3mm波段脉冲雷达系统研究和小波去噪分析"。
D4_wpeak=D4_wpeak.*(abs(D4_wpeak)>Thr);
%模极大值的处理方式:
%在尺度j上极大值点位置,构造一个搜索区域,
%在尺度j-1中,极大值点落在该区域的点保留,其他的置0;
D3_wpeak=wpeak(level-1,:);
D4_p=(D4_wpeak~=0);
O_d4=3;%该参数确定在上一级搜索极大值的范围,可以调整。
for P_d4=O_d4:(length(D4_wpeak)-O_d4);
    if D4_p(P_d4)==1;
      for i=1:O_d4-1;
      D4_p(P_d4-i)=1;
      end ;
    end;   
end;
D3_wpeak=D3_wpeak.*D4_p;
D2_wpeak=wpeak(level-2,:);
D3_p=(D3_wpeak~=0);
O_d3=3;%该参数确定在上一级搜索极大值的范围,可以调整。
for P_d3=O_d3:(length(D3_wpeak)-O_d3);
    if D3_p(P_d3)==1;
      for i=1:O_d3-1;
      D3_p(P_d3-i)=1;
      end ;
    end;   
end;
D2_wpeak=D2_wpeak.*D3_p;
%第一层单独处理,在第二层极大值点位置上,保留第一层相应极大值点:
D1_wpeak=wpeak(1,:);
D2_p=(D2_wpeak~=0);
D1_wpeak=D1_wpeak.*D2_p;
wpeak=;
wpeak=wpeak';

滤波之后的图,最后信号失真的厉害,不知道什么原因,小弟把模极大去噪的程序贴了出来,哪个大虾帮忙看看,能改进一下吗?谢谢。。。附件是整个程序。

johnbenny 发表于 2007-5-5 09:50

哪位大虾帮我看看啊。我该如何改进一下。。。

johnbenny 发表于 2007-5-6 16:56

怎么没人懂吗。。。急啊。。。。
页: [1]
查看完整版本: 如何改进这个模极大算法滤波程序?