Paramerer setting for pmtm() multitaper method

6 vues (au cours des 30 derniers jours)
Kyle
Kyle le 11 Sep 2011
Hi all, I'm trying to do spectral analysis by pmtm method:
clear
clc; close all
% artificial data
Fs = 300; % Sampling frequency
T = 1/Fs; % Sample time
L = 3000; % Length of signal
t = (0:L-1)*T; % Time vector
% Sum of a 50 Hz sinusoid and a 120 Hz sinusoid
x = 0.7*sin(2*pi*50*t) + sin(2*pi*120*t);
y = x + 3*randn(size(t)); % Sinusoids plus noise
y=y(:);
% Spectral analysis
T = 0.5; % sec
W = 3; % -Hz
% Matlab multitaper method
nw = T*W; % nw is the time-bandwidth product
[Pxx, f] = pmtm(y, nw, [], Fs);
plot(f, Pxx) % PSD
title('Spectral analysis by Matlab')
The graph looks fine, but actually, I have no ideas to set T and W. I just randomly put some numbers there. Could anyone please explain as simple as possible that how to select T and W, also how many tapers should be implemented to a specified signal (with unknown frequency of cause in a practical case).
Many thanks for any help Kyle
  2 commentaires
bym
bym le 11 Sep 2011
have you read the reference cited? [1] Percival, D.B., and A.T. Walden, Spectral Analysis for Physical Applications: Multitaper and Conventional Univariate Techniques, Cambridge University Press, 1993.
Kyle
Kyle le 13 Sep 2011
Our library doesn't have this book unfortunately. Could you please suggest a few pages that may be mostly related so I can ask for an interloan. Thanks

Connectez-vous pour commenter.

Réponse acceptée

Wayne King
Wayne King le 13 Sep 2011
Hi Kyle, the mainlobe is approximately [-w/n, w/n]*Fs in Hz where Fs is your sampling frequency. For a given time-bandwidth product, nw, there are approximately 2*nw-1 Slepian tapers that have eigenvalues near unity, meaning that they have approximately all their energy in the bandwidth [-w/n,w/n]*Fs. The eigenvalue gives the proportion of energy in that band. To follow up on what Honglei wrote, as you increase your nw, you can use more tapers (because more of them will have eigenvalues near 1). Using more tapers increases the degrees of freedom and reduces the variance of your spectal estimate (it looks smoother), but widens the main lobe so you will less precisely localize the frequency of a peak and if there are multiple peaks within the mainlobe, those peaks can be smeared together (meaning multiple peaks may look like broad one).
Wayne
  1 commentaire
Kyle
Kyle le 13 Sep 2011
Thanks Wayne, that's very helpful, now I think I can understand the principle of multitaper method.
If I change T =2 and w = 1 in my code, so that w/T*Fs = 150 Hz, meaning that spectral power will be mostly distributed within the range [-150, 150]Hz in order to detect two peaks locating at 50Hz and 120Hz, does that make sense?

Connectez-vous pour commenter.

Plus de réponses (1)

Honglei Chen
Honglei Chen le 12 Sep 2011
Hi Kyle,
The time-bandwidth product, nw, gives you a trade-off of the variance and resolution. When it gets larger, more windows are applied to the signal so there are more averaging to the resulting spectrum. However, larger nw also means that for each window, the mainlobe is wider so the resolution takes a hit.
HTH,
Honglei
  1 commentaire
Kyle
Kyle le 13 Sep 2011
Hi Honglei, thank you for your helpful explanation.
What do you mean by "mainlobe" here? Can you give any hints for selecting appropriate "nw" value? thanks

Connectez-vous pour commenter.

Catégories

En savoir plus sur Parametric Spectral Estimation dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by