matlab中stft和spectrogram函数区别

2024-06-19 14:48

本文主要是介绍matlab中stft和spectrogram函数区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在最开头,两个几乎没有差别。
结果一模一样,只是取了分帧加窗fft的不同点而已。
先贴上程序。

clear;
clc;
close all;[sig,fs] = audioread('1.wav');
window_len = 400;
nfft = 1024;
windowt = hamming(window_len);
hoplen = window_len/2;% matlab自带stft
[stfts,f_stft,t_stft] = stft(sig, fs, 'Window',windowt, 'OverlapLength',hoplen, 'FFTLength',nfft);
figure;
y_stft = abs(stfts(:,:));
imagesc(t_stft, f_stft, 20*log10(y_stft));
xlabel('Samples');
ylabel('Freqency');
title(['自带stft nfft=' num2str(nfft) ', windowlen=' num2str(window_len) ' 短时傅里叶变换']);
colorbar;% matlab自带spectrogram函数
[spectrograms, f_spectrograms, t_spectrograms, p] = spectrogram(sig, windowt, hoplen, nfft, fs);
figure;
y_spectrograms = abs(spectrograms(end:-1:1,:));
imagesc(t_spectrograms, f_spectrograms, 20*log10(y_spectrograms));
xlabel('Samples'); 
ylabel('Freqency');
xlabel('Samples');
ylabel('Freqency');
title(['自带spectrogram, nfft=' num2str(nfft) ', windowlen=' num2str(window_len)]);
colorbar;% N = 0; %选择一个帧验证,可注释掉
% sig_s = sig(window_len*N + 1 + hoplen : window_len*N + window_len + hoplen).*windowt;
% y_fft = fft(sig_s, nfft);
% f_fft = fs*(1:(nfft))/nfft;
% y_fft = abs(y_fft);
% figure;
% plot(f_fft,y_fft)% 自己写的fft加窗求得stft
frame_num = floor((length(sig)-window_len) / hoplen + 1);
my_spectrogram = zeros(nfft/2+1, frame_num);
my_stft = zeros(nfft, frame_num);
for i = 1:frame_numsig_sfft = sig(1+hoplen*(i-1) : hoplen*(i-1)+window_len).*windowt;yfft_new = abs(fft(sig_sfft, nfft));my_spectrogram(:,i) = [yfft_new(nfft/2+1 : end); yfft_new(1)];my_stft(:,i) = [yfft_new(nfft/2+2 : end); yfft_new(1 : nfft/2+1)];
end
figure;
imagesc(t_stft, f_stft, 20*log10(my_stft));
xlabel('Samples');
ylabel('Freqency');
title(['分帧加窗fft后的stft, nfft=' num2str(nfft) ', windowlen=' num2str(window_len)]);
colorbar;
if (length(unique(y_stft == my_stft)) == 1) % ans = 1 说明完全一致disp('stft 验证正确');
end
if (length(unique(y_spectrograms == my_spectrogram)) == 1)disp('spectrogram 验证正确');
end

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
输出

stft 验证正确
spectrogram 验证正确

点数对应关系:
在这里插入图片描述

这篇关于matlab中stft和spectrogram函数区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075326

相关文章

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod

Golan中 new() 、 make() 和简短声明符的区别和使用

《Golan中new()、make()和简短声明符的区别和使用》Go语言中的new()、make()和简短声明符的区别和使用,new()用于分配内存并返回指针,make()用于初始化切片、映射... 详细介绍golang的new() 、 make() 和简短声明符的区别和使用。文章目录 `new()`

Python中json文件和jsonl文件的区别小结

《Python中json文件和jsonl文件的区别小结》本文主要介绍了JSON和JSONL两种文件格式的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 众所周知,jsON 文件是使用php JSON(JavaScripythonpt Object No

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

什么是 Ubuntu LTS?Ubuntu LTS和普通版本区别对比

《什么是UbuntuLTS?UbuntuLTS和普通版本区别对比》UbuntuLTS是Ubuntu操作系统的一个特殊版本,旨在提供更长时间的支持和稳定性,与常规的Ubuntu版本相比,LTS版... 如果你正打算安装 Ubuntu 系统,可能会被「LTS 版本」和「普通版本」给搞得一头雾水吧?尤其是对于刚入

python中json.dumps和json.dump区别

《python中json.dumps和json.dump区别》json.dumps将Python对象序列化为JSON字符串,json.dump直接将Python对象序列化写入文件,本文就来介绍一下两个... 目录1、json.dumps和json.dump的区别2、使用 json.dumps() 然后写入文

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>