Python計(jì)算信息熵實(shí)例
計(jì)算信息熵的公式:n是類別數(shù),p(xi)是第i類的概率
假設(shè)數(shù)據(jù)集有m行,即m個(gè)樣本,每一行最后一列為該樣本的標(biāo)簽,計(jì)算數(shù)據(jù)集信息熵的代碼如下:
from math import log def calcShannonEnt(dataSet): numEntries = len(dataSet) # 樣本數(shù) labelCounts = {} # 該數(shù)據(jù)集每個(gè)類別的頻數(shù) for featVec in dataSet: # 對(duì)每一行樣本 currentLabel = featVec[-1] # 該樣本的標(biāo)簽 if currentLabel not in labelCounts.keys(): labelCounts[currentLabel] = 0 labelCounts[currentLabel] += 1 shannonEnt = 0.0 for key in labelCounts: prob = float(labelCounts[key])/numEntries # 計(jì)算p(xi) shannonEnt -= prob * log(prob, 2) # log base 2 return shannonEnt
補(bǔ)充知識(shí):python 實(shí)現(xiàn)信息熵、條件熵、信息增益、基尼系數(shù)
我就廢話不多說(shuō)了,大家還是直接看代碼吧~
import pandas as pd import numpy as np import math ## 計(jì)算信息熵 def getEntropy(s): # 找到各個(gè)不同取值出現(xiàn)的次數(shù) if not isinstance(s, pd.core.series.Series): s = pd.Series(s) prt_ary = pd.groupby(s , by = s).count().values / float(len(s)) return -(np.log2(prt_ary) * prt_ary).sum() ## 計(jì)算條件熵: 條件s1下s2的條件熵 def getCondEntropy(s1 , s2): d = dict() for i in list(range(len(s1))): d[s1[i]] = d.get(s1[i] , []) + [s2[i]] return sum([getEntropy(d[k]) * len(d[k]) / float(len(s1)) for k in d]) ## 計(jì)算信息增益 def getEntropyGain(s1, s2): return getEntropy(s2) - getCondEntropy(s1, s2) ## 計(jì)算增益率 def getEntropyGainRadio(s1, s2): return getEntropyGain(s1, s2) / getEntropy(s2) ## 衡量離散值的相關(guān)性 import math def getDiscreteCorr(s1, s2): return getEntropyGain(s1,s2) / math.sqrt(getEntropy(s1) * getEntropy(s2)) # ######## 計(jì)算概率平方和 def getProbSS(s): if not isinstance(s, pd.core.series.Series): s = pd.Series(s) prt_ary = pd.groupby(s, by = s).count().values / float(len(s)) return sum(prt_ary ** 2) ######## 計(jì)算基尼系數(shù) def getGini(s1, s2): d = dict() for i in list(range(len(s1))): d[s1[i]] = d.get(s1[i] , []) + [s2[i]] return 1-sum([getProbSS(d[k]) * len(d[k]) / float(len(s1)) for k in d]) ## 對(duì)離散型變量計(jì)算相關(guān)系數(shù),并畫出熱力圖, 返回相關(guān)性矩陣 def DiscreteCorr(C_data): ## 對(duì)離散型變量(C_data)進(jìn)行相關(guān)系數(shù)的計(jì)算 C_data_column_names = C_data.columns.tolist() ## 存儲(chǔ)C_data相關(guān)系數(shù)的矩陣 import numpy as np dp_corr_mat = np.zeros([len(C_data_column_names) , len(C_data_column_names)]) for i in range(len(C_data_column_names)): for j in range(len(C_data_column_names)): # 計(jì)算兩個(gè)屬性之間的相關(guān)系數(shù) temp_corr = getDiscreteCorr(C_data.iloc[:,i] , C_data.iloc[:,j]) dp_corr_mat[i][j] = temp_corr # 畫出相關(guān)系數(shù)圖 fig = plt.figure() fig.add_subplot(2,2,1) sns.heatmap(dp_corr_mat ,vmin= - 1, vmax= 1, cmap= sns.color_palette('RdBu' , n_colors= 128) , xticklabels= C_data_column_names , yticklabels= C_data_column_names) return pd.DataFrame(dp_corr_mat) if __name__ == "__main__": s1 = pd.Series(['X1' , 'X1' , 'X2' , 'X2' , 'X2' , 'X2']) s2 = pd.Series(['Y1' , 'Y1' , 'Y1' , 'Y2' , 'Y2' , 'Y2']) print('CondEntropy:',getCondEntropy(s1, s2)) print('EntropyGain:' , getEntropyGain(s1, s2)) print('EntropyGainRadio' , getEntropyGainRadio(s1 , s2)) print('DiscreteCorr:' , getDiscreteCorr(s1, s1)) print('Gini' , getGini(s1, s2))
以上這篇Python計(jì)算信息熵實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 利用Python中的Xpath實(shí)現(xiàn)一個(gè)在線匯率轉(zhuǎn)換器
- Python實(shí)現(xiàn)匯率轉(zhuǎn)換操作
- Python實(shí)現(xiàn)制度轉(zhuǎn)換(貨幣,溫度,長(zhǎng)度)
- Python實(shí)現(xiàn)類似比特幣的加密貨幣區(qū)塊鏈的創(chuàng)建與交易實(shí)例
- 用python實(shí)現(xiàn)一個(gè)簡(jiǎn)單計(jì)算器(完整DEMO)
- 基于Python編寫一個(gè)計(jì)算器程序,實(shí)現(xiàn)簡(jiǎn)單的加減乘除和取余二元運(yùn)算
- python GUI模擬實(shí)現(xiàn)計(jì)算器
- python怎么提高計(jì)算速度
- python 實(shí)現(xiàn)一個(gè)圖形界面的匯率計(jì)算器
相關(guān)文章
Python中斷言Assertion的一些改進(jìn)方案
python中的斷言Assertion使用起來(lái)很方便,但是也不盡如人意的地方,所以這篇文章通過(guò)幾個(gè)方面對(duì)Python中的斷言進(jìn)行了改進(jìn),感興趣的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-10-10python使用tensorflow深度學(xué)習(xí)識(shí)別驗(yàn)證碼
這篇文章主要介紹了python使用tensorflow深度學(xué)習(xí)識(shí)別驗(yàn)證碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04python實(shí)戰(zhàn)練習(xí)做一個(gè)隨機(jī)點(diǎn)名的程序
讀萬(wàn)卷書不如行萬(wàn)里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Python實(shí)現(xiàn)一個(gè)隨機(jī)點(diǎn)名的程序,大家可以在過(guò)程中查缺補(bǔ)漏,提升水平2021-10-10只用40行Python代碼就能寫出pdf轉(zhuǎn)word小工具
今天咱們介紹一個(gè)pdf轉(zhuǎn)word的免費(fèi)小工具,滿足這么一個(gè)不常見但是偶爾會(huì)出來(lái)煩人的需求文中有非常詳細(xì)的代碼示例,對(duì)小伙伴們很有幫助,需要的朋友可以參考下2021-05-05Python實(shí)現(xiàn)判斷變量是否是函數(shù)方式
這篇文章主要介紹了Python實(shí)現(xiàn)判斷變量是否是函數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02用60行代碼實(shí)現(xiàn)Python自動(dòng)搶微信紅包
這篇文章主要介紹了用60行代碼實(shí)現(xiàn)Python自動(dòng)搶微信紅包,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02