첨부 실행 코드는 나눔고딕코딩 폰트를 사용합니다.
유용한 소스 코드가 있으면 icodebroker@naver.com으로 보내주시면 감사합니다.
블로그 자료는 자유롭게 사용하세요.

■ 엔트로피 구하기

------------------------------------------------------------------------------------------------------------------------

using System;

 

#region 엔트로피 구하기 - GetEntropy(valueArray)

 

/// <summary>

/// 엔트로피 구하기

/// </summary>

/// <param name="valueArray">값 배열</param>

/// <returns>엔트로피</returns>

public double GetEntropy(int[] valueArray)

{

    int    length  = valueArray.Length;

    int    total   = 0;

    double entropy = 0d;

    double probability;

 

    for(int i = 0; i < length; i++)

    {

        total += valueArray[i];

    }

 

    for(int i = 0; i < length; i++)

    {

        probability = (double) valueArray[i] / total;

 

        if(probability != 0)

        {

            entropy += (-probability * Math.Log(probability, 2));

        }

    }

 

    return entropy;

}

 

#endregion

------------------------------------------------------------------------------------------------------------------------

Posted by 사용자 icodebroker
TAG , ,

댓글을 달아 주세요