第9章 決策樹(shù)算法_第1頁(yè)
第9章 決策樹(shù)算法_第2頁(yè)
第9章 決策樹(shù)算法_第3頁(yè)
第9章 決策樹(shù)算法_第4頁(yè)
第9章 決策樹(shù)算法_第5頁(yè)
已閱讀5頁(yè),還剩61頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第9章決策樹(shù)算法1編輯ppt本章大綱:

決策樹(shù)算法原理常用決策樹(shù)算法決策樹(shù)剪枝由決策樹(shù)提取分類(lèi)規(guī)則應(yīng)用實(shí)例分析2編輯ppt9.1決策樹(shù)算法原理優(yōu)點(diǎn):使用者不需要了解很多背景知識(shí),只要訓(xùn)練事例能用屬性→結(jié)論的方式表達(dá)出來(lái),就能用該算法學(xué)習(xí);決策樹(shù)模型效率高,對(duì)訓(xùn)練集數(shù)據(jù)量較大的情況較為適合;分類(lèi)模型是樹(shù)狀結(jié)構(gòu),簡(jiǎn)單直觀,可將到達(dá)每個(gè)葉結(jié)點(diǎn)的路徑轉(zhuǎn)換為IF→THEN形式的規(guī)則,易于理解;決策樹(shù)方法具有較高的分類(lèi)精確度。3編輯ppt9.1決策樹(shù)算法原理傳統(tǒng)的數(shù)據(jù)分類(lèi)操作通常有以下兩個(gè)步驟:模型訓(xùn)練階段:根據(jù)給定的訓(xùn)練集,找到合適的映射函數(shù)H:→C的表示模型。使用上一步訓(xùn)練完成的函數(shù)模型預(yù)測(cè)數(shù)據(jù)的類(lèi)別,或利用該函數(shù)模型,對(duì)數(shù)據(jù)集中的每一類(lèi)數(shù)據(jù)進(jìn)行描述,形成分類(lèi)規(guī)則。4編輯ppt9.1決策樹(shù)算法原理工作過(guò)程:決策樹(shù)分類(lèi)模型的工作過(guò)程圖5編輯ppt9.1決策樹(shù)算法原理定義9.1給定一個(gè)訓(xùn)練數(shù)據(jù)集D=,其中每個(gè)實(shí)例,稱(chēng)為例子,訓(xùn)練數(shù)據(jù)集中包含以下屬性A=。同時(shí)給定類(lèi)別集合C。對(duì)于訓(xùn)練數(shù)據(jù)集D,決策樹(shù)是指具有以下性質(zhì)的樹(shù):每個(gè)內(nèi)部節(jié)點(diǎn)都被標(biāo)記一個(gè)屬性Ai。每個(gè)弧都被標(biāo)記一個(gè)值,這個(gè)值對(duì)應(yīng)于相應(yīng)父結(jié)點(diǎn)的屬性。每個(gè)葉節(jié)點(diǎn)都被標(biāo)記一個(gè)類(lèi)Cj。6編輯ppt9.1決策樹(shù)算法原理定義9.2分裂準(zhǔn)則定義為在決策樹(shù)算法中將訓(xùn)練數(shù)據(jù)集D中的元組劃分為個(gè)體類(lèi)的最好的方法與策略,它告訴我們?cè)诠?jié)點(diǎn)N上測(cè)試哪個(gè)屬性合適,如何選擇測(cè)試與測(cè)試的方法,從節(jié)點(diǎn)N上應(yīng)該生長(zhǎng)出哪些分支。定義9.3分裂屬性Xi定義為決策樹(shù)中每個(gè)內(nèi)部節(jié)點(diǎn)都對(duì)應(yīng)的一個(gè)用于分裂數(shù)據(jù)集的屬性。XiA=7編輯ppt9.1決策樹(shù)算法原理定義9.4

如果Xi是連續(xù)屬性,那么分裂準(zhǔn)則的形式為Xi,其中,就稱(chēng)為節(jié)點(diǎn)n的分裂點(diǎn)。定義9.5如果Xi是離散屬性,那么的形式為,其中,就稱(chēng)為節(jié)點(diǎn)n的分裂子集。注意:分裂準(zhǔn)則與分裂屬性、分裂點(diǎn)、分裂子集并不等同,它們是四個(gè)不同的概念,并且分裂子集分裂點(diǎn)分裂屬性分裂準(zhǔn)則8編輯ppt9.1決策樹(shù)算法原理將上面的定義結(jié)合實(shí)際的決策樹(shù)例子可得決策樹(shù)圖如下圖9-1,圖9-2,圖9-3所示,圖中設(shè)X為分裂屬性,是屬性X的已知值。

圖9-2按照分裂點(diǎn)劃分而成的決策樹(shù)圖與相關(guān)的具體例子圖9編輯ppt9.1決策樹(shù)算法原理

圖9-3按照分裂子集劃分而成的決策樹(shù)圖與相關(guān)的兩個(gè)具體例子圖10編輯ppt9.1決策樹(shù)算法原理圖9-4按照分裂子集劃分而成的決策樹(shù)(只能是二叉樹(shù))圖與相關(guān)的具體例子圖

11編輯ppt9.1決策樹(shù)算法原理目前主要使用如下幾個(gè)量化評(píng)估標(biāo)準(zhǔn)(1)預(yù)測(cè)準(zhǔn)確性(2)模型強(qiáng)健性(3)描述的簡(jiǎn)潔性(4)計(jì)算復(fù)雜性(5)處理規(guī)模性12編輯ppt9.2常用決策樹(shù)算法ID3算法

ID3是Quinlan于1986年提出的,是機(jī)器學(xué)習(xí)中一種廣為人知的一個(gè)算法,它的提出開(kāi)創(chuàng)了決策樹(shù)算法的先河,而且是國(guó)際上最早最有影響的決策樹(shù)方法,在該算法中,引入了信息論中熵的概念,利用分割前后的熵來(lái)計(jì)算信息增益,作為判別能力的度量。

13編輯ppt9.2.1ID3算法

定義9.6信息熵自信息量只能反映符號(hào)的不確定性,而信息熵可以用來(lái)度量整個(gè)信源X整體的不確定性。設(shè)某事物具有n種相互獨(dú)立的可能結(jié)果(或稱(chēng)狀態(tài)):,每一種結(jié)果出現(xiàn)的概率分別為且有:(9.1)那么,該事物所具有的不確定量為:(9.2)

14編輯ppt9.2.1ID3算法上式即為著名的香農(nóng)信息量公式。注意到式中的對(duì)數(shù)以2為底,當(dāng)n=2時(shí)且時(shí),熵=1比特。由此可見(jiàn),一個(gè)等概率的二選一事件具有1比特的不確定性。所以,可以把一個(gè)等概率的二選一事件所具有信息量定為信息量的單位。任何一個(gè)事件能夠分解成n個(gè)可能的二選一事件,它的信息量就是n比特。15編輯ppt9.2.1ID3算法Quinlan的首創(chuàng)性工作主要是在決策樹(shù)的學(xué)習(xí)算法中第一次引入了信息論中的互信息(稱(chēng)之為信息增益),以之作為屬性選擇的標(biāo)準(zhǔn),并且將建樹(shù)的方法嵌入在其中,其核心是在決策樹(shù)的各級(jí)節(jié)點(diǎn)上選擇屬性,用信息增益作為屬性選擇標(biāo)準(zhǔn)16編輯ppt9.2.1ID3算法下面給出的是ID3算法中將香農(nóng)的信息熵定義應(yīng)用到?jīng)Q策樹(shù)構(gòu)造中,進(jìn)而給出的信息增益的定義。

設(shè)訓(xùn)練數(shù)據(jù)集D=,是n維有窮向量空間,其中是有窮離散符號(hào)集,D中的每個(gè)元素,叫做例子,其中設(shè)PD和ND是D的兩個(gè)子集,分別叫做正例集和反例集。17編輯ppt9.2.1ID3算法

假設(shè)訓(xùn)練數(shù)據(jù)集D中的正例集PD和反例集ND的大小分別為p和n,則ID3基于下面兩個(gè)假設(shè)給出該決策樹(shù)算法中信息增益的定義,因?yàn)樾畔⑹怯枚M(jìn)制編碼的,所以在下面的公式定義中都用以2為底的對(duì)數(shù)。(1)在訓(xùn)練數(shù)據(jù)集D上的一棵正確決策樹(shù)對(duì)任意例子的分類(lèi)概率同D中正反例的概率一致;(2)一棵決策樹(shù)能對(duì)一個(gè)例子做出正確類(lèi)別判斷所需的信息量如下公式所示:18編輯ppt9.2.1ID3算法

如果以屬性A作為決策樹(shù)的根,A具有v個(gè)值,它將A分為v個(gè)子集,假設(shè)中含有p個(gè)正例和n個(gè)反例,那么子集所需的信息期望是,那么,以屬性A為根所需的信息期望如下公式所示:因此,以A為根的信息增益如下公式所示:

19編輯ppt9.2.1ID3算法上面給出的ID3中的信息論的相關(guān)定義主要是在兩類(lèi)分類(lèi)問(wèn)題的前提下,下面給出將其擴(kuò)展到多類(lèi)后的相關(guān)定義描述。設(shè)訓(xùn)練數(shù)據(jù)集D一共有m類(lèi)樣例,每類(lèi)樣例數(shù)為:。同樣以屬性A作為決策樹(shù)的根,具有v個(gè)值,它將D分為v個(gè)子集,假設(shè)子集中任意元組屬于類(lèi)C的概率用表示,并用估計(jì)。那么,該子集的信息量定義如下所示:

那么以A為根分類(lèi)后所需的信息期望如下面公式所示:20編輯ppt9.2.2C4.5算法

(1)分裂(2)連續(xù)數(shù)據(jù)(3)缺失數(shù)據(jù)(4)規(guī)則21編輯ppt9.2.2.1C4.5的分裂屬性選擇度量ID系列的算法為什么會(huì)產(chǎn)生歸納偏置呢?歸納偏置是一系列前提,這些前提與訓(xùn)練數(shù)據(jù)一起演繹論證未來(lái)實(shí)例分類(lèi)。如果給定一個(gè)訓(xùn)練數(shù)據(jù)集,那么通常有很多決策樹(shù)與這些樣例一致。所以,要描述ID系列算法的歸納偏置,應(yīng)找到它從所有一致假設(shè)中選擇一個(gè)的根據(jù)。22編輯ppt9.2.2.1C4.5的分裂屬性選擇度量ID系列的搜索策略為:(1)優(yōu)先選擇較短的樹(shù)而不是較長(zhǎng)的;(2)選擇那些信息增益高的屬性離根節(jié)點(diǎn)較近的樹(shù)。結(jié)論:ID系列算法的歸納偏置是因?yàn)樗谶x的時(shí)候較短的樹(shù)比較長(zhǎng)的樹(shù)優(yōu)先所產(chǎn)生的,也就是那些信息增益高的屬性更靠近的根節(jié)點(diǎn)將會(huì)有優(yōu)先生成樹(shù)的特權(quán)。23編輯ppt9.2.2.1C4.5的分裂屬性選擇度量為了避免這個(gè)偏置,彌補(bǔ)ID系列算法的不足就要舍棄信息增益這個(gè)度量而選擇別的決策屬性作為度量標(biāo)準(zhǔn)。Quinlan在他1986年中的論文中提出了一種可以使用的度量標(biāo)準(zhǔn):增益比率。增益比率通過(guò)加入一個(gè)被稱(chēng)為分裂信息(splitinformation)的項(xiàng)來(lái)懲罰類(lèi)似Date這樣的屬性,分裂信息用來(lái)衡量屬性分裂數(shù)據(jù)的廣度和均勻性,它由如下公式所示:

24編輯ppt9.2.2.1C4.5的分裂屬性選擇度量增益比率的公式如下所示:

25編輯ppt9.2.2.2C4.5對(duì)連續(xù)數(shù)據(jù)的處理ID3算法最初的定義是假設(shè)屬性值是離散值,但在實(shí)際環(huán)境中,有很多屬性是連續(xù)的,不能夠用一個(gè)確定的標(biāo)準(zhǔn)來(lái)對(duì)其進(jìn)行劃分。C4.5使用下面的一系列處理過(guò)程來(lái)對(duì)連續(xù)的屬性劃分成離散的屬性,進(jìn)而達(dá)到能夠建立決策樹(shù)的目的。26編輯ppt9.2.2.2C4.5對(duì)連續(xù)數(shù)據(jù)的處理Step1根據(jù)訓(xùn)練數(shù)據(jù)集D中各個(gè)屬性的值對(duì)該訓(xùn)練數(shù)據(jù)集進(jìn)行排序;Step2利用其中各屬性的值對(duì)該訓(xùn)練數(shù)據(jù)集動(dòng)態(tài)地進(jìn)行劃分;Step3在劃分后的得到的不同的結(jié)果集中確定一個(gè)閾值,該閾值將訓(xùn)練數(shù)據(jù)集數(shù)據(jù)劃分為兩個(gè)部分;Step4針對(duì)這兩邊各部分的值分別計(jì)算它們的增益或增益比率,以保證選擇的劃分使得增益最大。27編輯ppt9.2.2.3C4.5對(duì)缺失數(shù)據(jù)的處理為了評(píng)估屬性A是否是決策節(jié)點(diǎn)n的最佳測(cè)試屬性,要計(jì)算決策樹(shù)在該節(jié)點(diǎn)的信息增益Gain(D,A)。假定<,c()>是S中的一個(gè)訓(xùn)練樣例,并且其屬性A的通過(guò)值分得的信息值表示為

.28編輯ppt9.2.2.4C4.5對(duì)生成規(guī)則的利用只要生成了決策樹(shù)后,就可以把樹(shù)轉(zhuǎn)換成一個(gè)IF-THEN規(guī)則的集合。當(dāng)然,每種算法生成的決策樹(shù)都可以轉(zhuǎn)換成相應(yīng)的if-then規(guī)則,C4.5算法處理規(guī)則與其他算法不同在于它把規(guī)則存儲(chǔ)在一個(gè)二維數(shù)組中,每一行都代表著樹(shù)中的一個(gè)規(guī)則,即從樹(shù)根到葉子之間的一個(gè)路徑.29編輯ppt9.2.3CART算法

CART(ClassificationandRegressionTrees)算法是由幾位統(tǒng)計(jì)學(xué)家L.Breiman,J.Friedman,R.Olshen和C.Stone在發(fā)表的刊物《分類(lèi)與回歸樹(shù)》中提出的一種產(chǎn)生二叉決策樹(shù)分類(lèi)模型的技術(shù)。它與前面Quinlan提出的ID系列算法和C4.5不同的是,使用的屬性度量標(biāo)準(zhǔn)是Gini指標(biāo),它和后面將要介紹的算法的共同點(diǎn)也是在于都是利用了相同的屬性度量標(biāo)準(zhǔn)Gini指標(biāo)。30編輯ppt9.2.3CART算法Gini指標(biāo)主要是度量數(shù)據(jù)劃分或訓(xùn)練數(shù)據(jù)集D的不純度為主,系數(shù)值的屬性作為測(cè)試屬性,Gini值越小,表明樣本的“純凈度”越高。Gini指標(biāo)定義為如下公式:31編輯ppt9.2.3CART算法由于二叉樹(shù)不易產(chǎn)生數(shù)據(jù)碎片,精確度往往也會(huì)高于多叉樹(shù),所以在CART算法中,統(tǒng)計(jì)學(xué)家們采用了二元?jiǎng)澐?,在分支?jié)點(diǎn)上進(jìn)行Gini值的測(cè)試,如果滿(mǎn)足一定純度則劃分到左子樹(shù),否則劃分到右子樹(shù),最終生成一棵二叉決策樹(shù)。在只有二元分裂的時(shí)候,對(duì)于訓(xùn)練數(shù)據(jù)集D中的屬性A將D分成的D1和D2,則給定劃分D的Gini指標(biāo)如下公式所示:32編輯ppt9.2.3CART算法對(duì)于離散值屬性,在算法中遞歸的選擇該屬性產(chǎn)生最小Gini指標(biāo)的子集作為它的分裂子集。對(duì)于連續(xù)值屬性,必須考慮所有可能的分裂點(diǎn)。其策略類(lèi)似于上面ID3中介紹的信息增益處理方法,可以用如下公式所示:33編輯ppt9.2.3CART算法CART算法在滿(mǎn)足下列條件之一,即視為葉節(jié)點(diǎn)不再進(jìn)行分支操作。(1)所有葉節(jié)點(diǎn)的樣本數(shù)為1、樣本數(shù)小于某個(gè)給定的最小值或者樣本都屬于同一類(lèi)的時(shí)候;(2)決策樹(shù)的高度達(dá)到用戶(hù)設(shè)置的閾值,或者分支后的葉節(jié)點(diǎn)中的樣本屬性都屬于同一個(gè)類(lèi)的時(shí)候;(3)當(dāng)訓(xùn)練數(shù)據(jù)集中不再有屬性向量作為分支選擇的時(shí)候。34編輯ppt9.2.4PUBLIC算法

前面幾個(gè)小節(jié)的決策樹(shù)算法都是先建樹(shù)再剪枝。PUBLIC(PruningandBuildingIntegratedinClassification)算法[8,17]將建樹(shù)、剪枝結(jié)合到一步完成,即是預(yù)剪枝,在建樹(shù)階段不生成會(huì)被剪枝的子樹(shù),從而大大提高了效率。

PUBLIC算法的建樹(shù)是基于SPRINT方法、對(duì)其決策樹(shù)的剪枝使用的是基于最小編碼代價(jià)的MDL算法,但MDL原則不能直接應(yīng)用。35編輯ppt9.2.5SLIQ算法SLIQ(SupervisedLearningInQuest)算法利用3種數(shù)據(jù)結(jié)構(gòu)來(lái)構(gòu)造樹(shù),分別是屬性表、類(lèi)表和類(lèi)直方圖。SLIQ算法在建樹(shù)階段,對(duì)連續(xù)屬性采取預(yù)排序技術(shù)與廣度優(yōu)先相結(jié)合的策略生成樹(shù),對(duì)離散屬性采取快速的求子集算法確定劃分條件。具體步驟如下:Step1建立類(lèi)表和各個(gè)屬性表,并且進(jìn)行預(yù)排序,即對(duì)每個(gè)連續(xù)屬性的屬性表進(jìn)行獨(dú)立排序,以避免在每個(gè)節(jié)點(diǎn)上都要給連續(xù)屬性值重利用新排序;Step2如果每個(gè)葉節(jié)點(diǎn)中的樣本都能歸為一類(lèi),則算法停止;否則轉(zhuǎn)(3);Step3利用屬性表尋找擁有最小Gini值的劃分作為最佳劃分方案。36編輯ppt9.2.5SLIQ算法Step4根據(jù)第3步得到的最佳方案劃分節(jié)點(diǎn),判斷為真的樣本劃歸為左孩子節(jié)點(diǎn),否則劃歸為右孩子節(jié)點(diǎn)。這樣,(3)(4)步就構(gòu)成了廣度優(yōu)先的生成樹(shù)策略。Step5更新類(lèi)表中的第二項(xiàng),使之指向樣本劃分后所在的葉節(jié)點(diǎn)。Step6轉(zhuǎn)到步驟(2)。37編輯ppt9.2.6SPRINT算法SPRINT算法是對(duì)SLIQ算法的改進(jìn),其目的有兩個(gè):一是為了能夠更好的并行建立決策樹(shù),二是為了使得決策樹(shù)T適合更大的數(shù)據(jù)集。SPRINT(ScalableParallelizableInductionofClassificationTree)算法是一種可擴(kuò)展的、可并行的歸納決策樹(shù),它完全不受內(nèi)存限制,運(yùn)行速度快,且允許多個(gè)處理器協(xié)同創(chuàng)建一個(gè)決策樹(shù)模型。

38編輯ppt9.2.6SPRINT算法SPRINT算法定義了兩種數(shù)據(jù)結(jié)構(gòu),分別是屬性表和直方圖。屬性表由一組三元組<屬性值、類(lèi)別屬性、樣本號(hào)>組成,它隨節(jié)點(diǎn)的擴(kuò)張而劃分,并附屬于相應(yīng)的子節(jié)點(diǎn)。與SLIQ算法不同,SPRINT算法采取傳統(tǒng)的深度優(yōu)先生成樹(shù)策略,具體步驟如下:

Step1生成根節(jié)點(diǎn),并為所有屬性建立屬性表,同時(shí)預(yù)排序連續(xù)屬性的屬性表。Step2如果節(jié)點(diǎn)中的樣本可歸為一類(lèi),則算法停止;否則轉(zhuǎn)(3)。Step3利用屬性表尋找擁有最小Gini值的劃分作為最佳劃分方案。算法依次掃描該節(jié)點(diǎn)上的每張屬性表。Step4根據(jù)劃分方案,生成該節(jié)點(diǎn)的兩個(gè)子節(jié)點(diǎn),。Step5劃分該節(jié)點(diǎn)上的各屬性表,使之關(guān)聯(lián)到或上。39編輯ppt9.2.6SPRINT算法Step6分別轉(zhuǎn)到步驟(2)考察,節(jié)點(diǎn)。SPRINT算法在剪枝階段進(jìn)行基于MDL的剪枝,至此構(gòu)成了SPRINT算法的串行化算法。將串行化算法稍加改進(jìn),就成為并行化算法:將訓(xùn)練數(shù)據(jù)集平均分布到n個(gè)處理器上,而后每個(gè)處理器生成自己的數(shù)據(jù)分片。由于連續(xù)屬性值要求全局排序,因此要將n個(gè)處理器上的連續(xù)屬性的屬性表綜合重新排序,再平均分布到n個(gè)處理器上。在建立Hash表之前,需要從n個(gè)處理器上收集所有的樣本號(hào)信息。40編輯ppt9.3決策樹(shù)剪枝在現(xiàn)實(shí)世界中,獲得的數(shù)據(jù)并不可能保證其完美性與完整性,所以,在當(dāng)被用來(lái)創(chuàng)建決策樹(shù)的訓(xùn)練數(shù)據(jù)集中存在有噪聲,或者數(shù)量太少以至于不能產(chǎn)生目標(biāo)函數(shù)的有代表性的采樣的時(shí)候,我們使用決策樹(shù)算法生成的決策樹(shù)很多分支反映的是訓(xùn)練數(shù)據(jù)集中的異常。在上面任意一種情況發(fā)生的時(shí)候,利用簡(jiǎn)單算法產(chǎn)生的樹(shù)會(huì)出現(xiàn)過(guò)擬合訓(xùn)練樣例的現(xiàn)象。41編輯ppt9.3決策樹(shù)剪枝在利用決策樹(shù)算法進(jìn)行分類(lèi)的過(guò)程中,有兩個(gè)過(guò)程,在9.1節(jié)中有介紹,第一個(gè)過(guò)程我們必須要利用訓(xùn)練數(shù)據(jù)來(lái)進(jìn)行決策樹(shù)分類(lèi)模型的建立,另一個(gè)過(guò)程則是將建立好的決策樹(shù)分類(lèi)模型對(duì)給定的測(cè)試數(shù)據(jù)進(jìn)行分類(lèi)。42編輯ppt9.3.1預(yù)剪枝預(yù)剪枝也稱(chēng)為先剪枝,在該方法中主要是通過(guò)提前停止樹(shù)的構(gòu)造(例如,通過(guò)確定在給定的節(jié)點(diǎn)不再分裂或劃分訓(xùn)練元組的子集)來(lái)對(duì)決策樹(shù)進(jìn)行剪枝。一旦停止以后,剩下的那個(gè)節(jié)點(diǎn)就成為了樹(shù)葉。該樹(shù)葉可能持有子集元組中最頻繁的類(lèi)或這些元組的概率分布。43編輯ppt9.3.1預(yù)剪枝預(yù)剪枝判斷停止決策樹(shù)的生長(zhǎng)的方法大體上可以歸納為以下幾種:(1)一種最為簡(jiǎn)單的方法就是在決策樹(shù)到達(dá)一定高度的情況下就停止樹(shù)的生長(zhǎng);(2)到達(dá)此結(jié)點(diǎn)的實(shí)例具有相同的特征向量,而不必一定屬于同一類(lèi),也可停止生長(zhǎng)。這種情況可以處理數(shù)據(jù)中的數(shù)據(jù)沖突問(wèn)題;(3)到達(dá)此結(jié)點(diǎn)的實(shí)例個(gè)數(shù)小于某一個(gè)閾值也可停止樹(shù)的生長(zhǎng);(4)更為普遍的做法是計(jì)算每次擴(kuò)張對(duì)系統(tǒng)性能的增益,如果這個(gè)增益值小于某個(gè)閾值則不進(jìn)行擴(kuò)展。如果在最好情況下的擴(kuò)展增益都小于閾值,即使有些葉子結(jié)點(diǎn)的實(shí)例不屬于同一類(lèi),也停止樹(shù)的增長(zhǎng)。44編輯ppt9.3.2后剪枝

后剪枝算法已經(jīng)得到了廣泛的應(yīng)用,這個(gè)算法最初是由Breiman等提出,它首先構(gòu)造完整的決策樹(shù),允許決策樹(shù)過(guò)度擬合訓(xùn)練數(shù)據(jù),然后對(duì)那些置信度不夠的結(jié)點(diǎn)的子樹(shù)用葉子結(jié)點(diǎn)來(lái)替代,這個(gè)葉子結(jié)點(diǎn)所應(yīng)標(biāo)記的類(lèi)別為子樹(shù)中大多數(shù)實(shí)例所屬的類(lèi)別。45編輯ppt悲觀錯(cuò)誤剪枝PEP(PessimisticErrorPruning)REP方法進(jìn)行剪枝具有以下優(yōu)點(diǎn):(1)運(yùn)用REP方法得到的決策樹(shù)是關(guān)于測(cè)試數(shù)據(jù)集的具有最高精度的子樹(shù),并且是規(guī)模最小的樹(shù)。(2)它的計(jì)算復(fù)雜性是線性的,這是因?yàn)闆Q策樹(shù)中的每個(gè)非葉子結(jié)點(diǎn)只需要訪問(wèn)一次就可以評(píng)估其子樹(shù)被修剪的概率。(3)由于使用獨(dú)立的測(cè)試數(shù)據(jù)集,和原始決策樹(shù)相比,修剪后的決策樹(shù)對(duì)未來(lái)新事例的預(yù)測(cè)偏差較小。46編輯ppt悲觀錯(cuò)誤剪枝PEP(PessimisticErrorPruning)正是由于REP方法出現(xiàn)的一系列問(wèn)題,隨后Quinlan提出了可以在一定程度彌補(bǔ)上面缺陷的PEP方法,也就是悲觀剪枝方法。該方法引入了統(tǒng)計(jì)學(xué)上連續(xù)修正的概念來(lái)彌補(bǔ)這一個(gè)缺陷,在評(píng)價(jià)子樹(shù)的訓(xùn)練錯(cuò)誤的公式中添加了一個(gè)常數(shù),假定每個(gè)葉節(jié)點(diǎn)都自動(dòng)對(duì)實(shí)例的某部分進(jìn)行錯(cuò)誤的分類(lèi)。47編輯ppt悲觀錯(cuò)誤剪枝PEP(PessimisticErrorPruning)所用來(lái)剪枝的度量的基本思想可以概述為以下幾點(diǎn):(1)假設(shè)訓(xùn)練數(shù)據(jù)集生成原始樹(shù)為T(mén),某一葉子結(jié)點(diǎn)的實(shí)例個(gè)數(shù)為,其中錯(cuò)誤分類(lèi)的個(gè)數(shù)為;(2)我們定義訓(xùn)練數(shù)據(jù)集的誤差率如下公式9.13所示:(9.13)由于訓(xùn)練數(shù)據(jù)集既用來(lái)生成決策樹(shù)又用來(lái)修剪樹(shù),所以是有偏倚的,利用它來(lái)修剪的決策樹(shù)樹(shù)并不是最精確,最好的;(3)為此,Quinlan在誤差估計(jì)度量中增加了連續(xù)性校正,將誤差率的公式修改為如下公式9.14所示:

(9.14)48編輯ppt悲觀錯(cuò)誤剪枝PEP(PessimisticErrorPruning)

那么,同樣的,我們假設(shè)s為樹(shù)T的子樹(shù)的其中一個(gè)子節(jié)點(diǎn),則該子樹(shù)的葉子結(jié)點(diǎn)的個(gè)數(shù)為,的分類(lèi)誤差率如下公式所示:在定量的分析中,為簡(jiǎn)單起見(jiàn),我們用誤差總數(shù)取代上面誤差率的表示,即有公式:

那么,對(duì)于子樹(shù),它的分類(lèi)誤差總數(shù)如下公式所示:49編輯ppt最小錯(cuò)誤剪枝MEP(MinimumErrorPruning)MEP方法是由Niblett和Bratko首先提出來(lái)的,它在一個(gè)相對(duì)獨(dú)立的數(shù)據(jù)集上從樹(shù)的葉子結(jié)點(diǎn)開(kāi)始,向上搜索一個(gè)單一的樹(shù)來(lái)使分類(lèi)誤差的期望概率達(dá)到最小,但它并不需要一個(gè)額外的修剪數(shù)據(jù)集。使用的信息來(lái)自于訓(xùn)練數(shù)據(jù)集,其目的是在未知的數(shù)據(jù)集上產(chǎn)生最小預(yù)測(cè)分類(lèi)錯(cuò)誤率。50編輯ppt代價(jià)-復(fù)雜度剪枝CCP(Cost-ComplexityPruning)CCP方法就是著名的CART(ClassificationandRegressionTrees)剪枝算法,它包含兩個(gè)步驟:(1)自底向上,通過(guò)對(duì)原始決策樹(shù)中的修剪得到一系列的樹(shù),其中是由中的一個(gè)或多個(gè)子樹(shù)被替換所得到的,為未經(jīng)任何修剪的原始樹(shù),為只有一個(gè)結(jié)點(diǎn)的樹(shù)。(2)評(píng)價(jià)這些樹(shù),根據(jù)真實(shí)誤差率來(lái)選擇一個(gè)最優(yōu)秀的樹(shù)作為最后被剪枝的樹(shù)。51編輯ppt基于錯(cuò)誤剪枝EBP(Error-BasedPruning)EBP剪枝法是一種應(yīng)用于C4.5算法的自下向上的剪枝法,被認(rèn)為是PEP剪枝法的改進(jìn),因?yàn)镋BP剪枝基于對(duì)訓(xùn)練數(shù)據(jù)集的更加悲觀的估計(jì)。同PEP剪枝,EBP僅利用訓(xùn)練數(shù)據(jù)集來(lái)構(gòu)建和剪枝決策樹(shù)。假設(shè)可將葉結(jié)點(diǎn)覆蓋的實(shí)例看作統(tǒng)計(jì)樣本,葉結(jié)點(diǎn)對(duì)實(shí)例的分類(lèi)錯(cuò)誤率遵循二項(xiàng)式分布,并利用置信因子CF控制剪枝的程度。我們將CF定義為如下公式所示:

52編輯ppt9.4由決策樹(shù)提取分類(lèi)規(guī)則決策樹(shù)分類(lèi)方法有它的優(yōu)點(diǎn),但是也有一定的局限性,比如,利用算法生成的決策樹(shù)的規(guī)模會(huì)因?yàn)橛?xùn)練數(shù)據(jù)集的巨大而變得過(guò)大使得難以理解,可讀性差。如果直接從決策樹(shù)中提取出IF-THEN規(guī)則,建立基于規(guī)則的分類(lèi)器,與決策樹(shù)分類(lèi)器相比,IF-THEN規(guī)則可能更容易理解,特別是當(dāng)決策樹(shù)分支非常大時(shí)也一樣。53編輯ppt9.5應(yīng)用實(shí)例分析下面我們利用上面表9-1根據(jù)天氣是否打網(wǎng)球的訓(xùn)練數(shù)據(jù)集,利用ID3算法來(lái)判斷某天是否適合打網(wǎng)球。(1)類(lèi)別屬性信息熵的計(jì)算由于未分區(qū)前,訓(xùn)練數(shù)據(jù)集中共有14個(gè)實(shí)例,其中有9個(gè)實(shí)例屬于p類(lèi)(適合打網(wǎng)球的),5個(gè)實(shí)例屬于n類(lèi)(不適合打網(wǎng)球),因此分區(qū)前類(lèi)別屬性的熵為:54編輯ppt9.5應(yīng)用實(shí)例分析(2)非類(lèi)別屬性信息熵的計(jì)算若選擇Outlook為測(cè)試屬性。=0.694bit55編輯ppt9.5應(yīng)用實(shí)例分析因此,這種劃分的信息增益是:同理,可以求出其它三個(gè)屬性的信息增益為,,。由上可知,屬性值Outlook在各個(gè)屬性中具有最高的增益,被選作分裂屬性。則第一個(gè)根節(jié)點(diǎn)T被用標(biāo)記,并對(duì)于每個(gè)屬性值生長(zhǎng)一個(gè)分支:(3)遞歸地創(chuàng)建決策樹(shù)的樹(shù)枝和葉子選擇作為測(cè)試屬性后,將訓(xùn)練實(shí)例集分為三個(gè)子集,生成三個(gè)子節(jié)點(diǎn),對(duì)每個(gè)子節(jié)點(diǎn)遞歸采用上述過(guò)程進(jìn)行分類(lèi)直至每個(gè)節(jié)點(diǎn)都成為葉節(jié)點(diǎn)而已。

56編輯ppt9.5應(yīng)用實(shí)例分析屬性值Outlook在各個(gè)屬性中具有最高的增益,被選作分裂屬性。則第一個(gè)根節(jié)點(diǎn)T被用標(biāo)記,并對(duì)于每個(gè)屬性值生長(zhǎng)一個(gè)分支:根據(jù)信息增益結(jié)果生成的以O(shè)utlook為根節(jié)點(diǎn)的初級(jí)決策樹(shù)圖

57編輯ppt9.5應(yīng)用實(shí)例分析A.分析圖中的sunny分支,計(jì)算其子屬性的信息增益值來(lái)決定子分裂屬性形成子分支之一。針對(duì)sunny中的子訓(xùn)練數(shù)據(jù)集分支,有兩個(gè)類(lèi)別,該分支中有3個(gè)實(shí)例屬于n類(lèi),有2個(gè)實(shí)例屬于p類(lèi),因此針對(duì)分支的信息熵為:若以:sunny分支中的屬性Temperature為測(cè)試屬性,則測(cè)試屬性Temperature的信息量為:58編輯ppt9.5應(yīng)用實(shí)例分析其信息增益為:若以:sunny分支中的屬性Humidity為測(cè)試屬性,則測(cè)試屬性Humidity的信息量為:

0.00bit其信息增益為:若以:sunny分支中的屬性Wind為測(cè)試屬性

,則測(cè)試屬性windy的信息量為:

0.468bit其信息增益為:=0.971-0.468=0.493bit0.971-0.00=0.971bit59編輯ppt9.5應(yīng)用實(shí)例分析這時(shí)生成的決策樹(shù)如圖所示:決策樹(shù)構(gòu)造圖260編輯ppt9.5應(yīng)用實(shí)例分析B.分析圖9-8中的:rain分支,計(jì)算其子屬性的信息增益值來(lái)確定子分裂屬性形成子分支之三。針對(duì):rain中的子訓(xùn)練數(shù)據(jù)集分支,有兩個(gè)類(lèi)別,該分支中有3個(gè)實(shí)例屬于n類(lèi),有2個(gè)實(shí)例屬于p類(lèi),因此針對(duì)分支的信息熵為:若以:rain分支中的屬性Temperature為測(cè)試屬性,則測(cè)試屬性Temper

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論