calculate the correlation of a number of time series
Show older comments
If I have a matrix:
data = rand(365,5);
What is the most appropriate way of calculating the correlation between each column and the mean of the remaining columns. For example, for the first column:
R = nonzeros(tril(corrcoef(data(:,1),mean(data(:,2:end)')'),-1));
How could I repeat this procedure so that I have 5 correlation values i.e. for each series?
Accepted Answer
More Answers (2)
bym
on 19 Jul 2012
Don't know what you are trying to accomplish, but here is one way
clc; clear
data = rand(365,5);
for k = 1:5
r = corrcoef(data(:,1),mean(data(:,2:end),2));
R(k) = r(2);
data = circshift(data,-1);
end
R
1 Comment
Andrei Bobrov
on 20 Jul 2012
data = circshift(data,[0 -1]);
Teja Muppirala
on 20 Jul 2012
diag( corr( bsxfun(@minus, sum(data,2), data), data) )
1 Comment
Teja Muppirala
on 20 Jul 2012
CORR is from the Statistics Toolbox
Categories
Find more on Correlation and Convolution in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!