Calculate the difference between adjacent pixels

Hello Team,
I have written this Matlab code to calculate the absolute difference between horizontally adjacent pixels.
imageArray = imread('index.jpg');
information = imfinfo('index.jpg')
for j = 1:1:information.Height - 1
for i = 1:1:information.Width - 2
D_hor(i,j) = abs(imageArray(i,j) - imageArray(i+1, j))
i = i +1
end
j = j+1
end
Once I started verifying the code using a simple Matrix, it displayed incorrect results.
Can you please help me?
Regards,

 Respuesta aceptada

jonas
jonas el 30 de Sept. de 2018

0 votos

Try this instead

abs(diff(imageArray,1,2)) 

7 comentarios

Matlab Student
Matlab Student el 30 de Sept. de 2018
It works, thanks you Jonas.
jonas
jonas el 30 de Sept. de 2018
Happy to help!
Hello again Jonas,
I have one more question please. The code should work fine even without the i=i+1 and j=j+1 statements cause the for loop statement controls the step by 1 "for i=1:1:information.height-1" (:1: should do the job).
Am I right?
imageArray = imread('index.jpg');
information = imfinfo('index.jpg')
for j = 1:1:information.Height - 1
for i = 1:1:information.Width - 2
abs(diff(imageArray,1,2))
end
end
jonas
jonas el 2 de Oct. de 2018
Editada: jonas el 2 de Oct. de 2018
Hi! You do not need the loops at all in this case. This is enough:
imageArray = imread('index.jpg');
information = imfinfo('index.jpg')
abs(diff(imageArray,1,2))
But yes, in general you are correct in that you do not need those lines at the end of for loops to adjust the looping variable.
Thank you (flower)
Good Morning Jonas,
May I ask how can I calculate the same in the vertical direction? I mean how to calculate the difference between vertically adjacent pixels?
Thanks in advance,
Just change the dimension argument from 2 to 1 :)
abs(diff(imageArray,1,1))

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Programming en Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 30 de Sept. de 2018

Comentada:

el 3 de Oct. de 2018

Community Treasure Hunt

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

Start Hunting!

Translated by