声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1917|回复: 4

[编程技巧] 平滑伪Wigner-Ville分布计算程序

[复制链接]
发表于 2012-8-28 18:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
% Wigner-Ville分布计算程序
function[WVD,t,f]=SWWignerVille(Sig,SampFreq,FreqBins,GLen,HLen)
%  Sig      : 输入信号
%  FreqBins : 频率轴划分区间数(默认值:512)
%  SampFreq : 信号的采集频率
%  alfa     : 窗函数控制参数
%  GLen     : 窗函数g的长度(默认值:FreqBins/5)
%  HLen     : 窗函数h的长度(默认值:FreqBins/4)
%  WVD      :   SWWigner-Ville计算结果

if (nargin<1),
    error('At least 1 input required');
end;
% Sig=hilbert(real(Sig));    % 计算信号的解析信号
SigLen=length(Sig);        % 获取信号的长度
if (nargin<2),
    SampFreq=1;
elseif (nargin<3),
    FreqBins=512;
elseif (nargin<4),
    GLen=floor(FreqBins/5);   
    HLen=floor(FreqBins/4);
end;
FreqBins=2^nextpow2(FreqBins);
FreqBins=min(FreqBins,SigLen);
GLen=GLen+1-rem(GLen,2);
HLen=HLen+1-rem(HLen,2);
GWin=window(@gausswin,GLen);
HWin=window(@gausswin,HLen);
Lg=(GLen-1)/2;
Lh=(HLen-1)/2;
HWin=HWin/HWin(Lh+1);
WVD=zeros(FreqBins,SigLen);
wait=waitbar(0,'Under calculation,please wait...');

for kk=1:SigLen,
    waitbar(kk/SigLen,wait);
    MTau=min([kk+Lg-1,SigLen-kk+Lg,round(FreqBins/2)-1,Lh]);
    k=-min([Lg,SigLen-kk]):min([Lg,kk-1]);
    SubG=GWin(Lg+1+k);
    SubG=SubG/sum(SubG);
    WVD(1,kk)=sum(SubG.*Sig(kk-k,1).*conj(Sig(kk-k)));  %
    for tau=1:MTau,
      k=-min([Lg,SigLen-kk-tau]):min([Lg,kk-tau-1]);
      SubG=GWin(Lg+1+k);
      SubG=SubG/sum(SubG);
      R=sum(SubG.*Sig(kk+tau-k,1).*conj(Sig(kk-tau-k)));
      WVD(1+tau,kk)=HWin(Lh+tau+1)*R;
      R=sum(SubG.*Sig(kk-tau-k,1).*conj(Sig(kk+tau-k)));
      WVD(FreqBins+1-tau,kk)=HWin(Lh-tau+1)*R;
    end;   
end;
close(wait);
WVD=fft(WVD);
f=linspace(0,0.5,FreqBins)*SampFreq;
t=(0:(SigLen-1))/SampFreq;
set(gcf,'position',[20 100 500 430]);
set(gcf,'color','w');
axes('position',[0.1 0.45 0.53 0.5]);
mesh(t,f,abs(WVD));
axis([min(t) max(t) min(f) max(f)]);
colorbar;
xlabel('t/s');
ylabel('f/Hz');
title('平滑伪Wigner-Ville分布');

输入以下:
%  SampFreq=100;
%  FreqBins=512;
%  t=0:1/SampFreq:4;
%  Sig=sin(20*pi*t)+sin(80*pi*t);
%  WignerVille(Sig,SampFreq,FreqBins,Freqbins/5,FreqBins/4);

出现以下错误:
??? Index exceeds matrix dimensions.

Error in ==> SWWignerVille at 43
    WVD(Temp,kk)=sum(SubG.*Sig(kk-k,1).*conj(Sig(kk-k)));

谁能给修改下。谢谢
回复
分享到:

使用道具 举报

 楼主| 发表于 2012-9-6 08:59 | 显示全部楼层
发表于 2012-9-6 10:31 | 显示全部楼层
  1. WVD(1,kk)=sum(SubG.*Sig(kk-k,1).*conj(Sig(kk-k)));
复制代码
改为:
  1. WVD(1,kk)=sum(SubG'.*Sig(kk-k).*conj(Sig(kk-k)));
复制代码
后面还有类似错误,自己改吧

评分

1

查看全部评分

发表于 2012-9-6 22:15 | 显示全部楼层
发表于 2012-10-20 16:54 | 显示全部楼层
想请教楼主一下,这个平滑算法是根据什么文献编写的?时频工具箱中的算法似乎和你是一样的,但是我找不到这个算法的理论文献。
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-5-16 16:58 , Processed in 0.101857 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表