I don't know why the answer of this code is NaN. Help me please. thanks so much
for a = 01:20
filename = [num2str(a,'%02d') '_training' '.tif'];
img = imread(filename);
img1=imrotate(img,90,'bilinear');
C=rgb2gray(img1);
%co-occurrence matrix
glcm=graycomatrix(C,'GrayLimits',[0 255],'NumLevels',256,'Offset',[-1 -1]);
p=glcm/sum(glcm(:));
entropy=0;
for i=1:256
for j =1:256
entropy=entropy-p(i,j)*log2(p(i,j));
end
end
kq(a,:)=[entropy];
end

1 comentario

Matt J
Matt J el 25 de Dic. de 2013
What variable represents "the answer"?

Iniciar sesión para comentar.

 Respuesta aceptada

Matt J
Matt J el 25 de Dic. de 2013

0 votos

What prevents p(i,j) from being 0 in
entropy=entropy-p(i,j)*log2(p(i,j));
Note
>> 0*log(0)
ans =
NaN

3 comentarios

Huy
Huy el 25 de Dic. de 2013
how can i fix it? how can i overcome this problem?
Matt J
Matt J el 25 de Dic. de 2013
Editada: Matt J el 25 de Dic. de 2013
if p(i,j)==0
blablabla
end
or, discarding the for-loops,
entropy=p.*log(p);
entropy(isnan(entropy)) = blablabla
Huy
Huy el 25 de Dic. de 2013
thanks so much

Iniciar sesión para comentar.

Más respuestas (1)

Image Analyst
Image Analyst el 25 de Dic. de 2013

0 votos

Often a small number is added to values before taking log
smallNumber = 1; % % Whatever...
p(p==0) = smallNumber;
Now do your log.

Preguntada:

Huy
el 25 de Dic. de 2013

Comentada:

Huy
el 26 de Dic. de 2013

Community Treasure Hunt

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

Start Hunting!

Translated by