Borrar filtros
Borrar filtros

I have the following code (recognizing individuals pixels of a matrix). For a high number of images, this is very time consuming. Therefore, ¿Could the loop be avoided ? Thanks!

2 visualizaciones (últimos 30 días)
V=zeros(x,y,num_images,'uint16')
for k=1:num_images
for i= 1:x
for j= 1:y
if B(i,j,k)==0
V(i,j,k)= A(i,j,k)/3
else
V(i,j,k)= A(i,j,k)/3+(2^15)
end
end
end
end
  1 comentario
KSSV
KSSV el 22 de Dic. de 2016
First you terminate the outputs with ;. Else it will take hell lot of time, because it will print result on the screen.
V=zeros(x,y,num_images,'uint16') ;
for k=1:num_images
for i= 1:x
for j= 1:y
if B(i,j,k)==0
V(i,j,k)= A(i,j,k)/3 ;
else
V(i,j,k)= A(i,j,k)/3+(2^15) ;
end
end
end
end

Iniciar sesión para comentar.

Respuesta aceptada

David Barry
David Barry el 22 de Dic. de 2016
Editada: David Barry el 22 de Dic. de 2016
It's difficult to know the relationship between A, B and V from your example code but I am assuming they are of equal dimensions. In which case I think you probably want something like this instead of the loop.
V = zeros(size(B));
V(B == 0) = A(B == 0)/3;
V(B ~= 0) = A(B ~=0)/3 + 2^15;

Más respuestas (2)

Santi
Santi el 22 de Dic. de 2016
Very nice and simple answer, worked! Thanks a lot

John BG
John BG el 22 de Dic. de 2016
there is no need to initialise the void V, go straight to the indices returned from functions
  • find( zeros())
  • find( nonzeros())
A=A/3
V(find(zeros(B)))=A(find(zeros(B)))+2^15
V(find(nonzeros(B)))=A(find(nonzeros(B)))
if you find my answer useful would you please mark it as Accepted Answer by clicking on the ACCEPT ANSWER button?
thanks in advance for time and attention
John BG
  1 comentario
Jan
Jan el 19 de Feb. de 2017
Editada: Jan el 20 de Feb. de 2017
Both lines do not work:
  • nonzeros() replies the vector of the non-zero elements and the information about the position inside B is lost.
  • zeros() creates an array of zeros with the elements of B as dimensions. Therefore find(zeros(B)) will reply the empty matrix.

Iniciar sesión para comentar.

Categorías

Más información sobre Matrix Indexing 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