How to vectorize this code with logical idexing

Hi all,
I have the following code, how can I avoid the for to make it faster?
a=[10:5:50];
b=[10:20:50];
c=rand(size(a));
for i=length(b)-1
d=c(a>=b(i) & a<b(i+1));
end
thanks
cheers

1 comentario

Since you're only storing the last values of d in each iteration, you can skip the for-loop completely:
i = length(b)-1
d = c(a>=b(i)) & a<b(i+1))
but I am pretty sure you intend to do something else.
What should happen with the values of d obtained in the iterations 1 to length(b)-2?

Iniciar sesión para comentar.

 Respuesta aceptada

Andrei Bobrov
Andrei Bobrov el 14 de Mayo de 2014
Editada: Andrei Bobrov el 15 de Mayo de 2014
a=[10:5:50];
b=[10:20:50];
c=rand(size(a));
[~,ii] = histc(a,b);
d = accumarray(ii(:),c(:),size(b(:)),@(x){x})

3 comentarios

pietro
pietro el 15 de Mayo de 2014
Editada: pietro el 15 de Mayo de 2014
Hi Andrei,
thanks. I tried with my code but the empty bins at the end of the array are skipped. Here an axample:
a=[10:5:20, 55:5:90];
b=[10:20:170];
c=rand(size(a));
[er,ii] = histc(a,b);
d = accumarray(ii(:),c(:),[],@(x){x});
d should be a 8 elements array instead it is 4 elements array. How could I do to take into account the empty bins at the end of the array?
Andrei Bobrov
Andrei Bobrov el 15 de Mayo de 2014
corrected
pietro
pietro el 15 de Mayo de 2014
It works. Thanks

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Productos

Etiquetas

Preguntada:

el 14 de Mayo de 2014

Comentada:

el 15 de Mayo de 2014

Community Treasure Hunt

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

Start Hunting!

Translated by