Matlab imfilter uint8 overflow

Hello,
I created a gaussian filter. Then I divide every element by the smallest element so my gaussian filter is in integer. When i convolve an image with it, I get 255 for everything. How do I fix this ? I want to convolve using integer values not decimals. Thanks.

Respuestas (1)

Walter Roberson
Walter Roberson el 9 de Abr. de 2016

0 votos

double() the data before convolving.

5 comentarios

RuiQi
RuiQi el 9 de Abr. de 2016
I am trying to prove the linearity of the gaussian ie G(Ia + Ib) = G(Ia) + G(Ib). I tried subtracting the result before getting the max element in the result G(Ia+Ib) - G(Ia) - G(Ib) but I cant seem to get a zero.
Walter Roberson
Walter Roberson el 9 de Abr. de 2016
That is a different matter. You asked how to avoid saturating at 255, and that question has been answered.
RuiQi
RuiQi el 9 de Abr. de 2016
ok but imshow gives me white what do i do
Guillaume
Guillaume el 9 de Abr. de 2016
Editada: Guillaume el 9 de Abr. de 2016
With doubles, by default imshow assumes the range [0 1] for intensities. Convert the data back to uint8, or specify the DisplayRange in imshow to be [0 255]:
imshow(uint8(yourimage));
%or
imshow(yourimage, [0 255]);
imagesc(yourimage)
to display it automatically scaled according to the data it contains. This will not be the same as either of Guillaume's suggestions (which would normally be valid) because your filters are producing values larger than 255.

Iniciar sesión para comentar.

Etiquetas

Preguntada:

el 9 de Abr. de 2016

Comentada:

el 10 de Abr. de 2016

Community Treasure Hunt

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

Start Hunting!

Translated by