我试图找到音频信号的FFT峰值的幅度和频率。 执行FFT后,我使用了以下代码;
peak_points = [];
fmin = 60;
fmax = 1000;
region_of_interest = fmax>f & f>fmin;
froi = f(region_of_interest);
[p_max,loc] = max(seg_fft2(region_of_interest))
% index into froi to find the frequency of the peaks
p_max;
f_p_max = froi(loc);
[points, locatn] = findpeaks(seg_fft2(region_of_interest));
aboveMax = points > 0.4*p_max;
if any(aboveMax)
peak_points = [peak_points ; points(aboveMax) locatn(aboveMax)];
end
虽然我能够获得正确的振幅,locatn(aboveMax)
并没有给我频率.....
我需要做些什么才能获得频率值?我尝试了以下行,而不是locatn(aboveMax)
froi(locatn(aboveMax))
,但我收到了错误
???使用==>时出错horzcat
CAT参数维度不一致。
答案 0 :(得分:0)
那是因为locatn
是索引的向量,所以你需要使用它们来索引你的频率向量,例如froi(locatn)
如果froi
是您的频率向量,则应该为您提供峰值的频率