How to avoid repeated computation when the result is a symmetric matrix?

3 visualizaciones (últimos 30 días)
Hi all,
When obtaining a symmetric matrix, we know that we only need to compute and store the elements of upper triangular part. Is there a way to only perform these computations related to the upper triangular part, such that the total number of computation can be reduced by almost half?
Check this example:
clear; clc;
a = rand(5, 1);
b = rand(5, 1);
c = rand(5, 1);
x = {a b c};
xtx = zeros(3, 3);
for i = 1:3
for j = 1:3
pass = x{i}' * x{j};
xtx(i, j) = xtx(i, j) + pass;
end
end
'xtx' is symmetric, but the for loop here computed all elements. Total number of vector products is 9, while we know only 6 products are really needed. If the number of computations is large, then the saving can be dramatic. So how can we solve this?
Many thanks!
  4 comentarios
Xh Du
Xh Du el 30 de Mzo. de 2017
so for i = j, the inner loop should be:
for j = i:3
Adam
Adam el 30 de Mzo. de 2017
I started out with that and changed it. You can just calculate the diagonal separately, but I guess j = i:3 is fine after all.

Iniciar sesión para comentar.

Respuesta aceptada

Xh Du
Xh Du el 31 de Mzo. de 2017
Guess answer is in the comment, credit: Adam.
https://uk.mathworks.com/matlabcentral/answers/332568-how-to-avoid-repeated-computation-when-the-result-is-a-symmetric-matrix#comment_441260

Más respuestas (0)

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by