I'm looking to eliminate the following for loop:

6 visualizaciones (últimos 30 días)
John
John el 13 de En. de 2012
I'm looking to eliminate the following for loop:
for j=1:96
rn(ijk(j))=rn(ijk(j))+mp(j);
end
Background: rn is a 200x3x3 matrix, ijk is a 1800x1 matrix and np is a 12x8 matrix. ijk describes the mapping between mp and (the much larger) rn. For example, when j=1, mp(j)=0.84 and ijk(1)=601. This loop is embedded in a much larger loop.
There has got to be a way to eliminate the for loop presented here. Any suggestions?

Respuesta aceptada

Sean de Wolski
Sean de Wolski el 13 de En. de 2012
Perhaps:
idx = 1:96;
rn(ijk(idx))=rn(ijk(idx))+mp(idx);
  3 comentarios
Alex
Alex el 13 de En. de 2012
I just played around with a similar setup and I'm getting the same answer using either method.
One way that it could be causing different answers is if the data types are different (ex. doubles vs cells).
You can further debug this to see what is going on by reducing the problem. Start with a smaller idx (even 1) to see if you are getting the same results both ways. If 1 works, make idx bigger until you find the problem.
Sean de Wolski
Sean de Wolski el 13 de En. de 2012
Could you try each method in its entirety in two different functions and then compare the results after? Perhaps you're performing the same operation twice or not preallocating the matrices the same way (i.e. different sized results)

Iniciar sesión para comentar.

Más respuestas (2)

John
John el 18 de En. de 2012
Here was the problem: my vector ijk pointed to same index in rn at multiple times. For example, consider
mp=[0.1;0.2;0.3]; ijk=[1,2,1]; rn=zeros(4,1);
The vectorized function gives: idx = 1:3; rn(ijk(idx))=rn(ijk(idx))+mp(idx);
rn =
0.3000
0.2000
0
0
The loop expression gives:
for j=1:3 rn(ijk(j))=rn(ijk(j))+mp(j); end
rn =
0.4000
0.2000
0
0
I'm still not sure how to vectorize the code for this special case, but the answers provided by Sean and Alex are correct to the question.

Sean de Wolski
Sean de Wolski el 18 de En. de 2012
%Data:
mp=[0.1;0.2;0.3];
ijk=[1,2,1];
rnsz = [4 1]; %the size you want rn to be:
%Engine:
rn = accumarray(ijk',mp',rnsz); % Build rn; note transpose of subs/vals
  1 comentario
John
John el 18 de En. de 2012
Winner! Awesome!
Wish I had known this command earlier.
Thanks again.

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by