• 大小: 2KB
    文件类型: .m
    金币: 1
    下载: 0 次
    发布日期: 2021-11-30
  • 语言: Matlab
  • 标签: mallat算法  MATLAB  

资源简介

MATLAB实现小波分析mallat经典算法

资源截图

代码片段和文件信息

%%小波谱分析mallat算法经典程序 

clc;clear;
%% 1.正弦波定义
f1=50; % 频率1
f2=100; % 频率2
fs=2*(f1+f2); % 采样频率
Ts=1/fs; % 采样间隔
N=120; % 采样点数
n=1:N;
y=sin(2*pi*f1*n*Ts)+sin(2*pi*f2*n*Ts); % 正弦波混合
figure(1)
plot(y);
title(‘两个正弦信号‘)
figure(2)
stem(abs(fft(y)));
title(‘两信号频谱‘)
%% 2.小波滤波器谱分析
h=wfilters(‘db30‘‘l‘); % 低通
g=wfilters(‘db30‘‘h‘); % 高通
h=[hzeros(1N-length(h))]; % 补零(圆周卷积,且增大分辨率变于观察)
g=[gzeros(1N-length(g))]; % 补零(圆周卷积,且增大分辨率变于观察)
figure(3);
stem(abs(fft(h)));
title(‘低通滤波器图‘)
figure(4);
stem(abs(fft(g)));
title(‘高通滤波器图‘)
%% 3.MALLET分解算法(圆周卷积的快速傅里叶变换实现)
sig1=ifft(fft(y).*fft(h)); % 低通(低频分量)
sig2=ifft(fft(y).*fft(g)); % 高通(高频分量)
figure(5); % 信号图
subplot(211)
plot(real(sig1));
title(‘分解信号1‘)
subplot(212)
plot(real(sig2));
title(‘分解信号2‘)
figure(6); % 频谱图
subplot(211)
stem(abs(fft(sig1)));
title

评论

共有 条评论