Help me vectorize this code

6 visualizaciones (últimos 30 días)
VisLab
VisLab el 7 de Nov. de 2013
Editada: Andrei Bobrov el 8 de Nov. de 2013
for x=1:1:rows
for y=1:1:cols
RE_p(y,x) = RE(y,x,bestori_map(y,x));
RO_p(y,x) = RO(y,x,bestori_map(y,x));
end
end
- RE, RO: arrays of size cols*rows*8;
- bestori_map: array of size cols*rows;
what is the best way (and/or fastest) to vectorize this piece of code withouth the need of for cycles ?
Thank you
  2 comentarios
Cedric
Cedric el 7 de Nov. de 2013
Editada: Cedric el 7 de Nov. de 2013
What are RE, RO, and bestori_map?
VisLab
VisLab el 8 de Nov. de 2013
Editada: VisLab el 8 de Nov. de 2013
RE, RO - arrays of size cols*rows*8
bestori_map - array of size cols*rows

Iniciar sesión para comentar.

Respuesta aceptada

Andrei Bobrov
Andrei Bobrov el 8 de Nov. de 2013
s = size(RE);
[ii,jj] = ndgrid(1:s(1),1:s(2));
ij = sub2ind(s,ii(:),jj(:),bestori_map(:));
RE_p = reshape(RE(ij),s(1:2));
RO_p = reshape(RO(ij),s(1:2));
  1 comentario
VisLab
VisLab el 8 de Nov. de 2013
Works like a charm!
If you'd care to briefly explain the process it would be awesome.
Thank you very much :)

Iniciar sesión para comentar.

Más respuestas (1)

Walter Roberson
Walter Roberson el 7 de Nov. de 2013
Editada: Andrei Bobrov el 8 de Nov. de 2013
[X, Y] = ndgrid(1:rows, 1:cols);
X = X(:);
Y = Y(:);
Z = reshape( bestori_map(1:rows,1:cols), [], 1);
linidx = sub2ind(size(RE), X,Y, Z);
RE_p(1:rows,1:cols ) = reshape(RE(linidx),rows, cols );
linidx = sub2ind(size(RO), X, Y, Z);
RO_p(1:rows,1:cols) = reshape(RO(linidx),rows, cols, );
Note: if RE and RO are the same size then you can re-use linidx instead of re-calculating it.
  4 comentarios
Andrei Bobrov
Andrei Bobrov el 8 de Nov. de 2013
Hi VisLab! Your RO and RE - functions or arrays?
VisLab
VisLab el 8 de Nov. de 2013
arrays of cols*rows*8 size (RE,RO) and cols*rows (RE_p,RO_p, bestori_map), respectively.

Iniciar sesión para comentar.

Categorías

Más información sobre Software Development Tools en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by