У меня есть две очень большие матрицы (60x25000), и я хотел бы вычислить корреляцию между столбцами только между двумя матрицами. Например:
corrVal(1) = corr(mat1(:,1), mat2(:,1);
corrVal(2) = corr(mat1(:,2), mat2(:,2);
...
corrVal(i) = corr(mat1(:,i), mat2(:,i);
Для меньших матриц я могу просто использовать:
colCorr = diag( corr( mat1, mat2 ) );
но это не работает для очень больших матриц, так как у меня заканчивается память. Я подумал о том, чтобы разделить матрицы на части для вычисления корреляций, а затем объединить результаты, но вычисление корреляции между комбинациями столбцов кажется бесполезным, что мне на самом деле неинтересно.
Есть ли быстрый способ напрямую вычислить то, что мне интересно?
Изменить. Раньше я использовал цикл, но его просто замедлили:
mat1 = rand(60,5000);
mat2 = rand(60,5000);
nCol = size(mat1,2);
corrVal = zeros(nCol,1);
tic;
for i = 1:nCol
corrVal(i) = corr(mat1(:,i), mat2(:,i));
end
toc;
Это занимает ~ 1 секунду
tic;
corrVal = diag(corr(mat1,mat2));
toc;
Это занимает ~ 0,2 секунды.
diag
все еще работает (более минуты). - person Jacob   schedule 13.02.2012