0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

谈谈Matlab短时傅里叶变换和小波变换的时频

冬至子 来源:算法工程师的学习日志 作者:搬砖工程师domi 2023-07-19 17:44 次阅读

简介

本文主要给定一小段音频,通过短时傅里叶变换和小波变换制作时频图。音频的采样率为44100,

图片

短时傅里叶变换

matlab中,短时傅里叶变换的分析函数为spectrogram,其使用情况如下:

功能 :使用短时傅里叶变换得到信号的频谱图。

语法

[S,F,T,P]=spectrogram(x,window,noverlap,nfft,fs)

[S,F,T,P]=spectrogram(x,window,noverlap,F,fs)

说明:当使用时无输出参数,会自动绘制频谱图;有输出参数,则会返回输入信号的短时傅里叶变换。当然也可以从函数的返回值S,F,T,P绘制频谱图,具体参见例子。

参数

x---输入信号的向量。默认情况下,即没有后续输入参数,x将被分成8段分别做变换处理,如果x不能被平分成8段,则会做截断处理。默认情况下,其他参数的默认值为:window---窗函数,默认为nfft长度的海明窗Hamming;noverlap---每一段的重叠样本数,默认值是在各段之间产生50%的重叠;nfft---做FFT变换的长度,默认为256和大于每段长度的最小2次幂之间的最大值。另外,此参数除了使用一个常量外,还可以指定一个频率向量F;fs---采样频率,默认值归一化频率。

Window---窗函数,如果window为一个整数,x将被分成window段,每段使用Hamming窗函数加窗。如果window是一个向量,x将被分成length(window)段,每一段使用window向量指定的窗函数加窗。所以如果想获取specgram函数的功能,只需指定一个256长度的Hann窗。

Noverlap---各段之间重叠的采样点数。它必须为一个小于window或length(window)的整数。其意思为两个相邻窗不是尾接着头的,而是两个窗有交集,有重叠的部分。

Nfft---计算离散傅里叶变换的点数。它需要为标量。

Fs---采样频率Hz,如果指定为[],默认为1Hz。

S---输入信号x的短时傅里叶变换。它的每一列包含一个短期局部时间的频率成分估计,时间沿列增加,频率沿行增加。如果x是长度为Nx的复信号,则S为nfft行k列的复矩阵,其中k取决于window,如果window为一个标量,则k = fix((Nx-noverlap)/(window-noverlap));如果window为向量,则k = fix((Nx-noverlap)/(length(window)-noverlap))。对于实信号x,如果nfft为偶数,则S的行数为(nfft/2+1),如果nfft为奇数,则行数为(nfft+1)/2,列数同上。

F---在输入变量中使用F频率向量,函数会使用Goertzel方法计算在F指定的频率处计算频谱图。指定的频率被四舍五入到与信号分辨率相关的最近的DFT容器(bin)中。而在其他的使用nfft语法中,短时傅里叶变换方法将被使用。对于返回值中的F向量,为四舍五入的频率,其长度等于S的行数。

T---频谱图计算的时刻点,其长度等于上面定义的k,值为所分各段的中点。

P---能量谱密度PSD(Power Spectral Density),对于实信号,P是各段PSD的单边周期估计;对于复信号,当指定F频率向量时,P为双边PSD。P矩阵的元素计算公式如下P(I,j)=k|S(I,j)|2,其中的的k是实值标量,定义如下对于单边PSD,计算公式如下,其中w(n)表示窗函数,Fs为采样频率,在0频率和奈奎斯特频率处,分子上的因子2改为1;

MATLAB程序:

[Au, Fs]=audioread('audio.mp3');   % Fs 采样率 44100
[B, F, T, P] = spectrogram(Au(:,1),1024,512,1024,Fs);   % B是F大小行T大小列的频率峰值,P是对应的能量谱密度
figure
imagesc(T,F,10*log10(abs(P)));
set(gca,'YDir','normal')
colorbar;
xlabel('时间 t/s');
ylabel('频率 f/Hz');
title('短时傅里叶时频图');

图片

注意:

  • nfft越大,频域的分辨率就越高(分辨率=fs/nfft),但离瞬时频率就越远;
  • noverlap影响时间轴的分辨率,越接近nfft,分辨率越高,相应的冗余就越多,计算量越大,但计算机只要能承受,问题不大。

小波变换

首先,在matlab中,小波变换的分析函数为cwt,其使用情况如下:

功能 :实现一维连续小波变换的函数。

语法

COEFS=cwt(S, SCALES, 'wname')

COEFS=cwt(S, SCALES, 'wname', 'plot')

COEFS=cwt(S, SCALES, 'wname', 'PLOTMODE')

COEFS=cwt(S, SCALES, 'wname', 'PLOTMODE', XLIM)

参数

COEFS=cwt(S, SCALES, 'wname') 采用'wname'小波,在正、实尺度SCALES下计算向量一维小波系数。

COEFS=cwt(S, SCALES, 'wname', 'plot') 除了计算小波系数外,还加以图形显示。

COEFS=cwt(S, SCALES, 'wname', 'PLOTMODE') 计算并画出连续小波变换的系数,并使用PLOTMODE对图形着色。

COEFS=cwt(S, SCALES, 'wname', 'plot') 相当于 格式 COEFS=cwt(S, SCALES, 'wname', 'PLOTMODE') 中的语法 COEFS=cwt(S, SCALES, 'wname', 'absglb')

COEFS=cwt(S, SCALES, 'wname', 'PLOTMODE', XLIM) 能够计算并画出连续小波变换的系数。系数使用PLOTMODE和XLIM进行着色。其中:XLIM=[x1,x2],并且有如下关系:1<=x1<=x2<=length(S)。

MODE值含义:

'lvl' scale-by-scale着色模式

'glb' 考虑所有尺度的着色模式

'abslvl'或'lvlabs' 使用系数绝对值的scale-by-scale着色模式

'absglb'或'glbabs' 使用系数绝对值并考虑所有尺度的着色模式

COEFS行的大小等于SCALES尺度的长度,COEFS列的大小等于信号S的长度。

MATLAB程序:

totalscal=1024*16;
wavename='cmor3-3';
Fc=centfrq(wavename); % 小波的中心频率
c=2*Fc*totalscal;    
scals=c./(1:totalscal);
f=scal2frq(scals,wavename,1/Fs); % 将尺度转换为频率   频率在0-500Hz取1024
coefs = cwt(Au(totalscal,1),scals,wavename); % 求连续小波系数
t=0:1/Fs:(totalscal-1)/Fs;
figure
imagesc(t,f,abs(coefs));
set(gca,'YDir','normal')
colorbar;
xlabel('时间 t/s');
ylabel('频率 f/Hz');
title('小波时频图');

图片

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 小波变换
    +关注

    关注

    2

    文章

    183

    浏览量

    29719
  • PSD
    PSD
    +关注

    关注

    0

    文章

    35

    浏览量

    45384
  • MATLAB仿真
    +关注

    关注

    4

    文章

    176

    浏览量

    19908
  • 频谱仪
    +关注

    关注

    7

    文章

    339

    浏览量

    36003
  • 傅里叶变换
    +关注

    关注

    6

    文章

    438

    浏览量

    42573
收藏 人收藏

    评论

    相关推荐

    短时傅里叶变换STFT原理详解

    传统傅里叶变换的分析方法大家已经非常熟悉了,特别是快速傅里叶变换(FFT)的高效实现给数字信号处理技术的实时应用创造了条件,从而加速了数字信号处理技术的发展。
    的头像 发表于 01-07 09:46 2742次阅读
    <b class='flag-5'>短时</b><b class='flag-5'>傅里叶变换</b>STFT原理详解

    DSP变换运算-傅里叶变换

    第24章 DSP变换运算-傅里叶变换本章节开始进入此教程最重要的知识点之一傅里叶变换。关于傅里叶变换,本章主要是把傅里叶相关的基础知识进行必要的介绍,没有这些基础知识的话,后面学习FF
    发表于 08-03 06:14

    变换思想及其在信号处理中的应用

    傅里叶变换短时傅里叶变换到小变换的思想发展过程中分析了小
    发表于 02-27 15:33 22次下载

    基于短时傅里叶变换的OFDM时间同步方法

    该文提出了一种基于短时傅里叶变换的OFDM符号同步方法。该方法通过短时傅里叶变换得到OFDM信号的二维幅度谱,并提取其中的周期平稳时结构信
    发表于 10-10 15:18 42次下载
    基于<b class='flag-5'>短时</b><b class='flag-5'>傅里叶变换</b>的OFDM时间同步方法

    STFT短时傅里叶变换

    关于短时傅里叶变换的原理及其在通信的应用。
    发表于 05-17 16:41 5次下载

    变换傅里叶变换好在哪里_小变换傅里叶变换详解

    变换傅里叶变换有什么区别吗?小变换傅里叶变换哪个好?我们通过小
    发表于 01-13 11:02 1.6w次阅读
    小<b class='flag-5'>波</b><b class='flag-5'>变换</b>比<b class='flag-5'>傅里叶变换</b>好在哪里_小<b class='flag-5'>波</b><b class='flag-5'>变换</b>与<b class='flag-5'>傅里叶变换</b>详解

    详解傅里叶变换与小变换

    详细讲述傅里叶变换和小变换原理
    发表于 01-16 14:34 9次下载

    傅里叶变换的介绍傅里叶变换有什么意义和应用

    傅里叶变换是数字信号处理领城种很重要的算法。傅里叶表明:任何连续测量的时序或信号,都可以表示为不同频率的正弦信号的无限叠加。而根据该原理的傅里叶变换算法利用直接测量到的原始信号,以累加方式来计算该
    发表于 04-30 08:00 2次下载
    <b class='flag-5'>傅里叶变换</b>的介绍<b class='flag-5'>傅里叶变换</b>有什么意义和应用

    分析之短时傅里叶变换STFT资源下载

    分析之短时傅里叶变换STFT资源下载
    发表于 04-26 11:35 7次下载

    短时傅里叶变换特点 短时傅里叶变换的意义

    短时傅里叶变换特点 短时傅里叶变换的意义  短时傅里叶变换(Short-time Fourier
    的头像 发表于 09-07 16:23 2017次阅读

    傅里叶变换移公式

    傅里叶变换移公式 傅里叶变换是一种将信号从时域转换到频域的数学工具。它可以将一个信号分解成一系列正弦和余弦的和,这些正弦和余弦的振幅和
    的头像 发表于 09-07 16:29 3578次阅读

    变换傅里叶变换的区别和联系

    变换傅里叶变换的区别和联系  1. 傅里叶变换和小变换的定义
    的头像 发表于 09-07 17:04 2729次阅读

    短时傅里叶变换和小变换差别

    短时傅里叶变换和小变换差别 短时傅里叶变换(short-time Fourier transf
    的头像 发表于 09-07 17:04 3175次阅读

    傅里叶变换和离散傅里叶变换的关系

    Fourier Transform,简称DFT)则是适用于离散信号的傅里叶变换方法。 傅里叶变换的基本原理是将一个连续的信号,分解成一系列简单的正弦或者余弦。而这些正弦
    的头像 发表于 09-07 17:04 2515次阅读

    什么是傅里叶变换和逆变换?为什么要用傅里叶变换?

    、工程、图像处理、信号处理等领域。 傅里叶变换的核心思想是,任何一个连续时间的周期性信号可以表示为无穷多个不同频率正弦(或复指数)的叠加。傅里叶变换将信号分解为不同频率的正弦元素,
    的头像 发表于 01-11 17:19 3716次阅读