黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

簡(jiǎn)單決策樹調(diào)用&可視化【Python】

系統(tǒng) 2002 0

決策樹部分理論支撐

1* 通過選取一定的特征來降低數(shù)據(jù)的不確定性(熵)

2* 建議尋找多分類問題的最優(yōu)特征的最優(yōu)候選值。把多分類問題轉(zhuǎn)換成多幾層遞歸的二分類問題,防止數(shù)據(jù)對(duì)特征值的控制敏感。

3* 停止條件

  • 取得了最夠好的分類結(jié)果
  • 遞歸到了預(yù)定的最深深度
  • 葉子節(jié)點(diǎn)的純度
  • 分裂次數(shù)達(dá)到極限
  • 最大特征數(shù)
  • . . .

4* 相關(guān)公式

  • e n t r o p y ( D ) = ? ∑ i = 1 n P i l o g 2 P i entropy(D) = -\sum_{i=1}^n P_ilog_2 P_i e n t r o p y ( D ) = ? i = 1 n ? P i ? l o g 2 ? P i ?
    e n t r o p y ( D , A ) = ∑ i = 1 k D A i D l o g 2 D A i entropy(D,A) = \sum_{i=1}^k \frac {D_{A_i}}{D} log_2D_{A_i} e n t r o p y ( D , A ) = i = 1 k ? D D A i ? ? ? l o g 2 ? D A i ? ?
    g a i n ( D , A ) = e n t r o p y ( D ) ? e n t r o p y ( D , A ) gain(D,A) = entropy(D) - entropy(D,A) g a i n ( D , A ) = e n t r o p y ( D ) ? e n t r o p y ( D , A )
    原本的熵 減去 考慮某種特征條件A之后的熵,得到信息增益
    g a i n r a t e ( D , A ) = g a i n ( D , A ) / e n t r o p y ( D , A ) gain_rate(D,A) = gain(D,A)/entropy(D,A) g a i n r ? a t e ( D , A ) = g a i n ( D , A ) / e n t r o p y ( D , A )
    同理,根據(jù)同樣的方法可以得到 信息增益率

簡(jiǎn)單決策樹調(diào)用&可視化【Python】_第1張圖片

            
              
                import
              
               pandas 
              
                as
              
               pd

              
                import
              
               numpy 
              
                as
              
               np
df 
              
                =
              
               pd
              
                .
              
              read_csv
              
                (
              
              
                'C:\\Users\\76485\\Desktop\\column.2C.csv'
              
              
                )
              
              
                '''
導(dǎo)入數(shù)據(jù)源&導(dǎo)入基本包;
交互命令窗口輸入df.head()查看前五行數(shù)據(jù)
'''
              
              
X 
              
                =
              
               df
              
                .
              
              drop
              
                (
              
              
                'V7'
              
              
                ,
              
              axis 
              
                =
              
              
                1
              
              
                )
              
              
                #drop進(jìn)行有選擇的數(shù)據(jù)刪除,刪除頭標(biāo)簽為'V7'的列數(shù)據(jù)
              
              
y 
              
                =
              
               df
              
                .
              
              V7

              
                '''
軸用來為超過一維的數(shù)組定義屬性,二維數(shù)據(jù):0軸沿著行的方向向下,1軸沿著列的水平方向延伸
'''
              
              
                '''
#將文字轉(zhuǎn)換為數(shù)字的標(biāo)準(zhǔn)化程序

from sklearn.preprocessing import LabelEncoder
labelencoder = LabelEncoder()
for col in data.columns:
    data[col] = labelencoder.fit_transform(data[col])

'''
              
              
                #from sklearn.cross_validation import train_test_split#該包在新版本中,如下實(shí)現(xiàn)
              
              
                from
              
               sklearn
              
                .
              
              model_selection 
              
                import
              
               train_test_split
X_train
              
                ,
              
               X_test
              
                ,
              
               y_train
              
                ,
              
               y_test 
              
                =
              
               train_test_split
              
                (
              
              X
              
                ,
              
               y
              
                ,
              
               random_state
              
                =
              
              
                1
              
              
                )
              
              
                #將數(shù)據(jù)集拆分為訓(xùn)練集和測(cè)試集
              
              
                from
              
               sklearn 
              
                import
              
               tree
clf 
              
                =
              
               tree
              
                .
              
              DecisionTreeClassifier
              
                (
              
              max_depth 
              
                =
              
              
                4
              
              
                )
              
              
                #建樹
              
              
clf 
              
                =
              
               clf
              
                .
              
              fit
              
                (
              
              X_train
              
                ,
              
               y_train
              
                )
              
              

test_rec 
              
                =
              
               X_test
              
                .
              
              iloc
              
                [
              
              
                1
              
              
                ,
              
              
                :
              
              
                ]
              
              
clf
              
                .
              
              predict
              
                (
              
              
                [
              
              test_rec
              
                ]
              
              
                )
              
              
                #測(cè)試集測(cè)試,交互窗口輸入
              
              
                '''
Ans:
Out[16]: array(['NO'], dtype=object)
'''
              
              

y_test
              
                .
              
              iloc
              
                [
              
              
                1
              
              
                ]
              
              
                #調(diào)出真實(shí)結(jié)果,交互窗口輸入
              
              
                '''
Ans:
Out[17]: 'NO' 
'''
              
              
                from
              
               sklearn
              
                .
              
              metrics 
              
                import
              
               accuracy_score
rate_ac 
              
                =
              
               accuracy_score
              
                (
              
              y_test
              
                ,
              
               clf
              
                .
              
              predict
              
                (
              
              X_test
              
                )
              
              
                )
              
              
                #測(cè)試模型準(zhǔn)確率
              
              
                print
              
              
                (
              
              rate_ac
              
                )
              
              
                '''
0.8205128205128205 穩(wěn)定在80%左右,建樹層數(shù)對(duì)準(zhǔn)確率影響較小
'''
              
              
                '''決策樹可視化'''
              
              
                '''
with open("lc-is.dot", 'w') as f:
     f = tree.export_graphviz(clf,
                              out_file=f,
                              max_depth = 3,
                              impurity = True,
                              feature_names = list(X_train),
                              class_names = ['AB', 'NO'],
                              rounded = True,
                              filled= True )
'''
              
              
                from
              
               sklearn
              
                .
              
              tree 
              
                import
              
               DecisionTreeClassifier

              
                import
              
               pydotplus
              
                #若提示沒有此包,需在cmd-Anaconda Prompt鍵入install pydotplus
              
              
                from
              
               IPython
              
                .
              
              display 
              
                import
              
               Image

              
                from
              
               IPython
              
                .
              
              display 
              
                import
              
               display

              
                from
              
               sklearn
              
                .
              
              tree 
              
                import
              
               export_graphviz
              
                #需手動(dòng)下載并配置絕對(duì)路徑
              
              
                import
              
               os
os
              
                .
              
              environ
              
                [
              
              
                "PATH"
              
              
                ]
              
              
                +=
              
               os
              
                .
              
              pathsep 
              
                +
              
              
                'C:/Program Files (x86)/Graphviz2.38/bin/'
              
              
                #沙雕pydotplus,配置環(huán)境變量(路徑)
              
              

dot_tree 
              
                =
              
               tree
              
                .
              
              export_graphviz
              
                (
              
              clf
              
                ,
              
              out_file
              
                =
              
              
                None
              
              
                ,
              
              
                                feature_names
              
                =
              
              
                [
              
              
                'V1'
              
              
                ,
              
              
                'V2'
              
              
                ,
              
              
                'V3'
              
              
                ,
              
              
                'V4'
              
              
                ,
              
              
                'V5'
              
              
                ,
              
              
                'V6'
              
              
                ]
              
              
                ,
              
              
                                class_names
              
                =
              
              
                [
              
              
                'AB'
              
              
                ,
              
              
                'NO'
              
              
                ]
              
              
                ,
              
              
                                filled
              
                =
              
              
                True
              
              
                ,
              
               
                                rounded
              
                =
              
              
                True
              
              
                ,
              
              
                                special_characters
              
                =
              
              
                True
              
              
                )
              
              
graph 
              
                =
              
               pydotplus
              
                .
              
              graph_from_dot_data
              
                (
              
              dot_tree
              
                )
              
              
img 
              
                =
              
               Image
              
                (
              
              graph
              
                .
              
              create_png
              
                (
              
              
                )
              
              
                )
              
              
graph
              
                .
              
              write_png
              
                (
              
              
                "out.png"
              
              
                )
              
            
          

更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論