Effacer les filtres
Effacer les filtres

How do I test for correlation between digital data series?

2 vues (au cours des 30 derniers jours)
Chris
Chris le 4 Déc 2013
Modifié(e) : Wayne King le 5 Déc 2013
This may be a dumb question. I have two digital data series:
a = [-1 1 -1 -1 -1 1 1 -1 -1 -1 1 1]; b = [1 -1 1 -1 1 1 -1 -1 -1 -1 1 -1];
What's the best way to determine whether they are correlated? Corr? Chi-square? If chi-square, how exactly (there are several functions)?
Thanks

Réponse acceptée

Wayne King
Wayne King le 5 Déc 2013
Modifié(e) : Wayne King le 5 Déc 2013
xcorr() is in the Signal Processing Toolbox. You can calculate the cross correlation in the frequency domain and then invert.
a = [-1 1 -1 -1 -1 1 1 -1 -1 -1 1 1];
b = [1 -1 1 -1 1 1 -1 -1 -1 -1 1 -1];
npad = length(a)+length(b)-1;
crosspec = fft(a,npad).*conj(fft(b,npad));
xcr = fftshift(ifft(crosspec));
anorm = norm(a,2)^2;
bnorm = norm(b,2)^2;
xcr = xcr./sqrt(anorm*bnorm);
lags = -length(a)+1:length(a)-1;
stem(lags,xcr,'markerfacecolor',[0 0 1])
Or you can use corrcoef() -- again this is not the best for time series.
R = corrcoef(a,b);

Plus de réponses (1)

Wayne King
Wayne King le 4 Déc 2013
Modifié(e) : Wayne King le 4 Déc 2013
The best way is to compute the cross correlation sequence.
The reason you want to do that is with time series data, you want to account for the fact that the two series may differ only by a shift.
a = [-1 1 -1 -1 -1 1 1 -1 -1 -1 1 1]; b = [1 -1 1 -1 1 1 -1 -1 -1 -1 1 -1];
[c,lags] = xcorr(a,b,'coeff');
stem(lags,c)
Look at some of the "Examples and How Tos" here
  1 commentaire
Chris
Chris le 4 Déc 2013
I get an error when I run that: "Undefined function 'xcorr' for input arguments of type 'char'." Still get an error even if I convert a & b to logicals.
Also, in my case there is no concern about a time shift, does that mean I can use some other method to test for correlation?

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by