Filter löschen
Filter löschen

How to compute fast?

1 Ansicht (letzte 30 Tage)
Mohammod Minhajur Rahman
Mohammod Minhajur Rahman am 28 Feb. 2019
Hi, I have the following code that I need to vectorize to compute faster:
Here,
neq = 3197;
length(K1) = 152;
d1 is such d1{1,i} = 3197 by 1;
delNonZero = 152 by 1;
cd = zeros(neq,neq);
for i = 1:length(K1)
for j = 1:length(K1)
cd =cd+ d1{1,i}*d1{1,j}'*mean([delNonZero(i) delNonZero(j)]);
end
end
  4 Kommentare
Bob Thompson
Bob Thompson am 28 Feb. 2019
Got it. I am not an expert in those things, so hopefully somebody else can offer you a better solution. I will say that I don't know if you can eliminate the loops because of your desire to look at just a few elements at a time, rather than just looking at entire rows or the like.
Mohammod Minhajur Rahman
Mohammod Minhajur Rahman am 28 Feb. 2019
Hi Bob, thank you for your time. I would wait for a solution while trying by myself.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Jos (10584)
Jos (10584) am 28 Feb. 2019
Bearbeitet: Jos (10584) am 28 Feb. 2019
Some suggestions:
  • replace mean(A,B) by (A+B)/2
  • you can have j run from i to length(K1), since everything seems symmetric (unless there are complex numbers involved):
for i = 1:..
cd = cd + d1{i,1}*d1{i,1}'*delNonZero(i) ;
for j = i+1: ..
cd = cd + 2*d1{i,1}*d1{j,1}'*(delNonZero(i)+delNonZero(j))/2; % you can remove the 2's !!
end
end
  • do not use the function CD as avariable name ...

Weitere Antworten (0)

Kategorien

Mehr zu Get Started with MATLAB 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