Matrix-vector operations without loops
11 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Valeri Aronov
am 14 Okt. 2021
Bearbeitet: Valeri Aronov
am 14 Okt. 2021
How do I do this without loops:
HessW = rand(length(x), length(x), length(f));
GradW = rand(length(x), length(f));
A = zeros(length(x));
for i=1:length(f)
for j=1:length(x)
for k=1:length(x)
A(j) = A(j) + 2*HessW(j,k,i)*GradW(k,i);
end
end
end
Thanks
0 Kommentare
Akzeptierte Antwort
Weitere Antworten (1)
Rik
am 14 Okt. 2021
You can use permute to reshape the second array and use the implicit expansion to do the multiplication in one go. Then sum over two dimensions to get your vector.
Note that you shouldn't use length. Use numel or size instead.
x=rand(5,1);f=rand(3,1);
HessW = rand(numel(x), numel(x), numel(f));
GradW = rand(numel(x), numel(f));
A=2*HessW.*permute(GradW,[3 1 2]);
sum(A,[2 3])
A = zeros(length(x));
for i=1:length(f)
for j=1:length(x)
for k=1:length(x)
A(j) = A(j) + 2*HessW(j,k,i)*GradW(k,i);
end
end
end
A
2 Kommentare
Rik
am 14 Okt. 2021
Gosh! I am thinking of keeping the loops for readability. Is that because I am such an inept reader of MATLAB code? ;-)
Rik
am 14 Okt. 2021
You can split it up in steps. You should also include comments that explain why you are doing what you're doing.
%change the order of dimensions so this is a 1xNxN array
GradW_permuted=permute(GradW,[3 1 2]);
%do element-wise multiplication
A=2*HessW.*GradW_permuted;
%sum over the second and third dimension to get the vector
A=sum(A,[2 3])
These comments don't explain the purpose, because your question did not do so.
I would not suggest leaving in the loops, as they harm the performance of the code.
If you worry about readability of you code, make sure to write comments. Explain what you're doing. I often say half you text should be green. That is overdoing it, but your functions should have documentation and you code should have comments.
Siehe auch
Kategorien
Mehr zu Matrix Indexing finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!