matrix multiplication without declaring the destination matrix first

1 Ansicht (letzte 30 Tage)
hey,
I'm trying to multiply two matrices (I don't want to use any shortcuts, I want to do the multiplication by defention). can I do it without declaring first on the matrix?
what I wrote is:
C2 = zeros(N)
for i = 1:N
for j = 1:N
for k = 1:N
C2(i,j) = C2(i,j) + A(i,k)*B(k,j);
end
end
end
but the action of C2 = zeroes(N) is time consuming since N=1000 in this case. anyway to skip this declaration?
Thank you!
  3 Kommentare
dpb
dpb am 29 Okt. 2019
C2(N,N)=0;
may be even a tiny fraction faster...whatever it takes, it's a nit in comparison to not preallocting for larger arrays.
Elinor Ginzburg
Elinor Ginzburg am 30 Okt. 2019
thank you very much! the problem was that without the ';' matlab printed the matrix, and it took some time.

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Matt J
Matt J am 29 Okt. 2019
Bearbeitet: Matt J am 29 Okt. 2019
You can loop backwards. Then the pre-allocation will be done silently.
clear C2
for i = N:-1:1
for j = N:-1:1
for k = 1:N
C2(i,j) = C2(i,j) + A(i,k)*B(k,j);
end
end
end
However, I don't know why you think the zeros command is the slow part of the code. I also don't know why you care about speed. The only reason it would make sense to do this is as a homework exercise, in which case speed should not be the issue.
  1 Kommentar
Elinor Ginzburg
Elinor Ginzburg am 30 Okt. 2019
thank you, I've found the problem - missins ';' after the zeros command. it took some time to print the matrix...

Melden Sie sich an, um zu kommentieren.

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!

Translated by