Effacer les filtres
Effacer les filtres

How to compute fast?

1 vue (au cours des 30 derniers jours)
Mohammod Minhajur Rahman
Mohammod Minhajur Rahman le 28 Fév 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 commentaires
Bob Thompson
Bob Thompson le 28 Fév 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 le 28 Fév 2019
Hi Bob, thank you for your time. I would wait for a solution while trying by myself.

Connectez-vous pour commenter.

Réponse acceptée

Jos (10584)
Jos (10584) le 28 Fév 2019
Modifié(e) : Jos (10584) le 28 Fév 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 ...

Plus de réponses (0)

Catégories

En savoir plus sur Get Started with MATLAB dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by