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

    浏览量

    29496
  • PSD
    PSD
    +关注

    关注

    0

    文章

    34

    浏览量

    45290
  • MATLAB仿真
    +关注

    关注

    4

    文章

    174

    浏览量

    19639
  • 频谱仪
    +关注

    关注

    7

    文章

    301

    浏览量

    35417
  • 傅里叶变换
    +关注

    关注

    5

    文章

    415

    浏览量

    42243
收藏 人收藏

    评论

    相关推荐

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

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

    一文道破傅里叶变换的本质,优缺点一目了然

    的缺点,就是不能实现时联合分析。傅里叶变换要从负无穷计算到正无穷,这在实际使用当中,跟即时性分析会有很大的矛盾。根据这一缺点,提出了短时傅里叶变换。后来的时间—频率分析也是以
    发表于 03-12 16:06

    傅里叶变换是什么?如何求傅里叶变换

    傅里叶变换是什么?三傅里叶变换的意义是什么?如何求傅里叶变换
    发表于 05-08 09:23

    DSP变换运算-傅里叶变换

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

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

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

    STFT短时傅里叶变换

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

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

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

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

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

    傅里叶变换基本性质 傅里叶变换本质 傅里叶变换的应用

    傅里叶变换基本性质 傅里叶变换本质 傅里叶变换的应用 傅里叶变换是现代数学、物理学、工程学等领域中非常重要的一种数学工具和基本理论。在信号处理、图像处理、通信技术、音乐分析、光学、医学
    的头像 发表于 09-07 16:18 5934次阅读

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

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

    傅里叶变换和反变换公式

    傅里叶变换和反变换公式  傅里叶变换和反变换在信号处理领域中被广泛应用。傅里叶变换是将一个时域信号转换为频域信号的过程,而傅里叶反
    的头像 发表于 09-07 16:53 1.1w次阅读

    如何由傅里叶变换推出傅里叶反变换

    如何由傅里叶变换推出傅里叶反变换  傅里叶变换和傅里叶反变换是信号处理和通信领域中的两个重要概念,是数字信号和连续信号的重要数学分析方法之一。傅里叶
    的头像 发表于 09-07 17:04 1516次阅读

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

    短时傅里叶变换和小波变换差别 短时傅里叶变换(short-time Fourier transform,STFT)和小波
    的头像 发表于 09-07 17:04 1903次阅读

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

    傅里叶变换和离散傅里叶变换的关系 傅里叶变换(Fourier Transform)是一种将时间域(或空间域)的信号转换为频率域(或波数域)的信号的数学工具。而离散傅里叶变换(Discr
    的头像 发表于 09-07 17:04 1667次阅读

    傅里叶变换的定义 傅里叶变换的意义

    傅里叶变换的定义 傅里叶变换的意义  傅里叶变换,表示能将满足一定条件的某个函数表示成三角函数(正弦和/或余弦函数)或者它们的积分的线性组合。 在不同的研究领域,傅里叶变换具有多种不同
    的头像 发表于 11-30 15:32 1004次阅读