How to compute fast?

1 visualizzazione (ultimi 30 giorni)
Mohammod Minhajur Rahman
Mohammod Minhajur Rahman il 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 Commenti
Bob Thompson
Bob Thompson il 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 il 28 Feb 2019
Hi Bob, thank you for your time. I would wait for a solution while trying by myself.

Accedi per commentare.

Risposta accettata

Jos (10584)
Jos (10584) il 28 Feb 2019
Modificato: Jos (10584) il 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 ...

Più risposte (0)

Categorie

Scopri di più su Get Started with MATLAB in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by