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 commentaire

Matt J
Matt J le 25 Déc 2013
What variable represents "the answer"?

Connectez-vous pour commenter.

 Réponse acceptée

Matt J
Matt J le 25 Déc 2013

0 votes

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 commentaires

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

Connectez-vous pour commenter.

Plus de réponses (1)

Image Analyst
Image Analyst le 25 Déc 2013

0 votes

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

Question posée :

Huy
le 25 Déc 2013

Commenté :

Huy
le 26 Déc 2013

Community Treasure Hunt

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

Start Hunting!

Translated by