gabor原子的产生

        看了几篇文章,关于信号的稀疏逼近,gabor原子库一般用于语音信号的表示和去噪,由于其良好的时频逼近性能,以及原子库的过完备性,可以用于表示一维信号。

其参数有4个,(s,u,v,w)分别表示尺度拉伸、位移中心、频率变化、相位变化。将参数离散化,对于32位长的信号,用200个点来逼近得到10804个原子。matlab代码如下

 a=2;
delta_u=1/2;
delta_v=pi;
delta_w=pi/6;
N=32;
M=log2(N);
k=1;
T=2e-6;
Fs=100e6;
Ts=1/Fs;
t=0:Ts:T-Ts;
L=length(t);
for j=1:M
    s(j)=a^j;
    P=N*(2^(-j+1));
    Q=2^(j+1);
    for p=1:(P+1)
        u(p)=(p-1)*(a^j)*delta_u;
        for q=1:(Q+1)
            v(q)=(q-1)*(a^j)*delta_v;
            for i=1:13
                w(i)=(i-1)*delta_w;
                grt(k,1:L)=1/sqrt(s(j))*exp(-pi*((t-u(p))/s(j)).^2).*cos(v(q)*t+w(i));
                k=k+1;
            end
        end
    end    
end        
  % 一共得到10803个原子,选取了10个原子显示 
figure;
for tu=1:10
subplot(5,5,tu)
plot(t,grt((tu-1)*500+1,:));
end

图片如下

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值