How to get the time frequency plot using autoregrssive model?

1 回表示 (過去 30 日間)
yogesh  pratap
yogesh pratap 2017 年 3 月 9 日
編集済み: Greg Dionne 2017 年 3 月 16 日
I want to have a time frequency plot using parametric methods, plz anyone help.

採用された回答

Greg Dionne
Greg Dionne 2017 年 3 月 9 日
編集済み: Greg Dionne 2017 年 3 月 9 日
If you have the Signal Processing Toolbox, try PYULEAR, PBURG, PCOV, PMCOV. Those will give you a periodogram for a given time slice.
You can either call it once per time slice, or if you'd like to do it all in one shot, you can give it a column for each estimate. Something like this pseudo-code:
function pburgspectrogram(x, order, nwin, noverlap, nfft, Fs)
% x - the input signal
% order - the model order
% nwin - the number of samples for any one given estimate
% noverlap - the number of overlapping samples between windows
% nfft - how many points you want for the FFT.
% Fs - sample rate of signal
nx = length(x);
ncol = fix((nx-noverlap)/(nwin-noverlap));
coloffsets = (0:(ncol-1))*(nwin-noverlap);
rowindices = (1:nwin)';
xin = x(rowindices+coloffsets);
T = (coloffsets+(nwin/2)')/Fs;
[Pxx,F] = pburg(xin,order,nfft,Fs);
imagesc(T, F, 10*log10(abs(Pxx)+eps));
set(gca,'YDir','normal');
xlabel('Time');
ylabel('Frequency');
colorbar;
Example
load mtlb
pburgspectrogram(mtlb, 6, 128, 120, 128, Fs);
  1 件のコメント
Greg Dionne
Greg Dionne 2017 年 3 月 16 日
編集済み: Greg Dionne 2017 年 3 月 16 日
Looks like you have an older version of MATLAB that doesn't have implicit expansion.
Replace:
xin = x(rowindices+coloffsets);
with
xin = x(bsxfun(@plus,rowindices,coloffsets));
That should get it to work (at least as far back as R2014b). Use whatever you want for x... so long as it's a column vector. If you have something earlier than that you'll need a for-loop.

サインインしてコメントする。

その他の回答 (0 件)

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by