I'm trying to find entropy from a Probability Mass Function (PMF) using the following equation:
Where is a PMF value and m is the amount of values of the PMF.
From there I created this code:
entropy = 0;
pmf = [0.1, 0.015, .. , 0.02, 0.1];
% Summation
for l = 1:length(pmf)
entropy = entropy + pmf(l) * log2(pmf(l));
fprintf('Entropy Val %d: %f.20 \n', l, entropy)
end
entropy = entropy * -1;
But the entropy value started to give out a NaN value when . Is there a way to avoid that?

 채택된 답변

Matt J
Matt J 2022년 3월 22일
편집: Matt J 2022년 3월 22일

0 개 추천

entropy=-cumsum(pmf.*log2(pmf),'omitnan');
fprintf('Entropy Val %d: %f.20 \n', l:numel(entropy), entropy)

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Entering Commands에 대해 자세히 알아보기

태그

질문:

2022년 3월 22일

편집:

2022년 3월 22일

Community Treasure Hunt

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

Start Hunting!

Translated by