购买
下载掌阅APP,畅读海量书库
立即打开
畅读海量书库
扫码下载掌阅APP

第5章
决策树

决策树(decision tree)是一种基本的分类与回归方法。本章主要讨论用于分类的决策树。决策树模型呈树形结构,在分类问题中,表示基于特征对实例进行分类的过程。它可以认为是if-then规则的集合,也可以认为是定义在特征空间与类空间上的条件概率分布。其主要优点是模型具有可读性,分类速度快。学习时,利用训练数据,根据损失函数最小化的原则建立决策树模型。预测时,对新的数据利用决策树模型进行分类。决策树学习通常包括3个步骤:特征选择、决策树的生成和决策树的修剪。这些决策树学习的思想主要来源于由Quinlan在1986年提出的ID3算法和1993年提出的C4.5算法,以及由Breiman等人在1984年提出的CART算法。

本章首先介绍决策树的基本概念,然后通过ID3算法和C4.5算法介绍特征的选择、决策树的生成以及决策树的修剪,最后介绍CART算法。

5.1 决策树模型与学习

5.1.1 决策树模型

定义5.1(决策树) 分类决策树模型是一种描述对实例进行分类的树形结构。决策树由结点(node)和有向边(directed edge)组成。结点有两种类型:内部结点(internal node)和叶结点(leaf node)。内部结点表示一个特征或属性,叶结点表示一个类。

用决策树分类,从根结点开始,对实例的某一特征进行测试,根据测试结果,将实例分配到其子结点,这时,每一个子结点对应该特征的一个取值。如此递归地对实例进行测试并分配,直至达到叶结点。最后将实例分到叶结点的类中。

图5.1是一个决策树模型,图中圆和方框分别表示内部结点和叶结点。

图5.1 决策树模型

5.1.2 决策树与if-then规则

可以将决策树看成一个if-then规则的集合。将决策树转换成if-then规则的过程如下:由决策树的根结点到叶结点的每一条路径构建一条规则;路径上内部结点的特征对应规则的条件,而叶结点的类对应规则的结论。决策树的路径或其对应的if-then规则集合具有一个重要的性质:互斥并且完备。这就是说,每一个实例都被一条路径或一条规则所覆盖,而且只被一条路径或一条规则所覆盖。这里所谓覆盖是指实例的特征与路径上的特征一致或实例满足规则的条件。

5.1.3 决策树与条件概率分布

决策树还表示给定特征条件下类的条件概率分布,这一条件概率分布定义在特征空间的一个划分(partition)上。将特征空间划分为互不相交的单元(cell)或区域(region),并在每个单元定义一个类的概率分布就构成了一个条件概率分布。决策树的一条路径对应于划分中的一个单元。决策树所表示的条件概率分布由各个单元给定条件下类的条件概率分布组成。假设 X 为表示特征的随机变量, Y 为表示类的随机变量,那么这个条件概率分布可以表示为 P Y|X )。 X 取值于给定划分下单元的集合, Y 取值于类的集合。各叶结点(单元)上的条件概率往往偏向某一个类,即属于某一类的概率较大。决策树分类时将该结点的实例强行分到条件概率大的那一类去。

图5.2(a)示意地表示特征空间的一个划分。图中的大正方形表示特征空间。这个大正方形被若干个小矩形分割,每个小矩形表示一个单元。特征空间划分上的单元构成了一个集合, X 取值为单元的集合。为简单起见,假设只有两类:正类和负类,即 Y 取值为+1和–1。小矩形中的数字表示单元的类。图5.2(b)示意地表示特征空间划分确定时,特征(单元)给定条件下类的条件概率分布。图5.2(b)中条件概率分布对应于图5.2(a)的划分。当某个单元 c 的条件概率满足 P Y =+1| X = c )>0.5时,则认为这个单元属于正类,即落在这个单元的实例都被视为正例。图5.2(c)为对应于图5.2(b)中条件概率分布的决策树。

5.1.4 决策树学习

假设给定训练数据集

D ={( x 1 , y 1 ),( x 2 , y 2 ),…,( x N , y N )}

其中 为输入实例(特征向量), n 为特征个数, y i ∈{1,2,…, K }为类标记, i =1,2,…, N N 为样本容量。决策树学习的目标是根据给定的训练数据集构建一个决策树模型,使它能够对实例进行正确的分类。

决策树学习本质上是从训练数据集中归纳出一组分类规则。与训练数据集不相矛盾的决策树(即能对训练数据进行正确分类的决策树)可能有多个,也可能一个都没有。我们需要的是一个与训练数据矛盾较小的决策树,同时具有很好的泛化能力。从另一个角度看,决策树学习是由训练数据集估计条件概率模型。基于特征空间划分的类的条件概率模型有无穷多个。我们选择的条件概率模型应该不仅对训练数据有很好的拟合,而且对未知数据有很好的预测。

图5.2 决策树对应于条件概率分布

决策树学习用损失函数表示这一目标。如下所述,决策树学习的损失函数通常是正则化的极大似然函数。决策树学习的策略是以损失函数为目标函数的最小化。

当损失函数确定以后,学习问题就变为在损失函数意义下选择最优决策树的问题。因为从所有可能的决策树中选取最优决策树是NP完全问题,所以现实中决策树学习算法通常采用启发式方法,近似求解这一最优化问题。这样得到的决策树是次最优(sub-optimal)的。

决策树学习的算法通常是一个递归地选择最优特征,并根据该特征对训练数据进行分割,使得对各个子数据集有一个最好的分类的过程。这一过程对应对特征空间的划分,也对应决策树的构建。首先,构建根结点,将所有训练数据都放在根结点。选择一个最优特征,按照这一特征将训练数据集分割成子集,使得各个子集有一个在当前条件下最好的分类。如果这些子集已经能够被基本正确分类,那么构建叶结点,并将这些子集分到所对应的叶结点中去;如果还有子集不能被基本正确分类,那么就对这些子集选择新的最优特征,继续对其进行分割,构建相应的结点。如此递归地进行下去,直至所有训练数据子集被基本正确分类,或者没有合适的特征为止。最后每个子集都被分到叶结点上,即都有了明确的类。这就生成了一棵决策树。

以上方法生成的决策树可能对训练数据有很好的分类能力,但对未知的测试数据未必有很好的分类能力,即可能发生过拟合现象。我们需要对已生成的树自下而上进行剪枝,将树变得更简单,从而使它具有更好的泛化能力。具体地,就是去掉过于细分的叶结点,使其回退到父结点,甚至更高的结点,然后将父结点或更高的结点改为新的叶结点。

如果特征数量很多,也可以在决策树学习开始的时候对特征进行选择,只留下对训练数据有足够分类能力的特征。

可以看出,决策树学习算法包含特征选择、决策树的生成与决策树的剪枝过程。由于决策树表示一个条件概率分布,所以深浅不同的决策树对应不同复杂度的概率模型。决策树的生成对应于模型的局部选择,决策树的剪枝对应于模型的全局选择。决策树的生成只考虑局部最优,相对地,决策树的剪枝则考虑全局最优。

决策树学习常用的算法有ID3、C4.5与CART,下面结合这些算法分别叙述决策树学习的特征选择、决策树的生成和剪枝过程。

5.2 特征选择

5.2.1 特征选择问题

特征选择在于选取对训练数据具有分类能力的特征,这样可以提高决策树学习的效率。如果利用一个特征进行分类的结果与随机分类的结果没有很大差别,则称这个特征是没有分类能力的。经验上扔掉这样的特征对决策树学习的精度影响不大。通常特征选择的准则是信息增益或信息增益比。

首先通过一个例子来说明特征选择问题。

例5.1 [1] 表5.1是一个由15个样本组成的贷款申请训练数据。数据包括贷款申请人的4个特征(属性):第1个特征是年龄,有3个可能值:青年,中年,老年;第2个特征是有工作,有两个可能值:是,否;第3个特征是有自己的房子,有两个可能值:是,否;第4个特征是信贷情况,有3个可能值:非常好,好,一般。表的最后一列是类别,是否同意贷款,取两个值:是,否。

希望通过所给的训练数据学习一个贷款申请的决策树,用以对未来的贷款申请进行分类,即当新的客户提出贷款申请时,根据申请人的特征利用决策树决定是否批准贷款申请。

特征选择是决定用哪个特征来划分特征空间。

图5.3表示从表5.1数据学习到的两个可能的决策树,分别由两个不同特征的根结点构成。图5.3(a)所示的根结点的特征是年龄,有3个取值,对应于不同的取值有不同的子结点。图5.3(b)所示的根结点的特征是有工作,有两个取值,对应于不同的取值有不同的子结点。两个决策树都可以从此延续下去。问题是:究竟选择哪个特征更好些?这就要求确定选择特征的准则。直观上,如果一个特征具有更好的分类能力,或者说,按照这一特征将训练数据集分割成子集,使得各个子集在当前条件下有最好的分类,那么就更应该选择这个特征。信息增益(information gain)就能够很好地表示这一直观的准则。

表5.1 贷款申请样本数据表

图5.3 不同特征决定的不同决策树

5.2.2 信息增益

为了便于说明,先给出熵与条件熵的定义。

在信息论与概率统计中,熵(entropy)是表示随机变量不确定性的度量。设 X 是一个取有限个值的离散随机变量,其概率分布为

P X = x i )= p i , i =1,2,…, n

则随机变量 X 的熵定义为

在式(5.1)中,若 p i =0,则定义0log0=0。通常,式(5.1)中的对数以2为底或以e为底(自然对数),这时熵的单位分别称作比特(bit)或纳特(nat)。由定义可知,熵只依赖于 X 的分布,而与 X 的取值无关,所以也可将 X 的熵记作 H p ),即

熵越大,随机变量的不确定性就越大。从定义可验证

当随机变量只取两个值,如1,0时,即 X 的分布为

P X =1)= p,P X =0)=1− p, 0≤ p ≤1

熵为

这时,熵 H p )随概率 p 变化的曲线如图5.4所示(单位为比特)。

图5.4 分布为伯努利分布时熵与概率的关系

p =0或 p =1时 H p )=0,随机变量完全没有不确定性。当 p =0.5时, H p )=1,熵取值最大,随机变量不确定性最大。

设有随机变量( X,Y ),其联合概率分布为

P X = x i , Y = y j )= p ij , i =1,2,…, n , j =1,2,…, m

条件熵 H Y|X )表示在已知随机变量 X 的条件下随机变量 Y 的不确定性。随机变量 X 给定的条件下随机变量 Y 的条件熵(conditional entropy) H Y|X )定义为 X 给定条件下 Y 的条件概率分布的熵对 X 的数学期望:

这里, p i = P X = x i ), i =1,2,…, n

当熵和条件熵中的概率由数据估计(特别是极大似然估计)得到时,所对应的熵与条件熵分别称为经验熵(empirical entropy)和经验条件熵(empirical conditional entropy)。此时,如果有0概率,令0log0=0。

信息增益(information gain)表示得知特征 X 的信息而使得类 Y 的信息的不确定性减少的程度。

定义5.2(信息增益) 特征 A 对训练数据集 D 的信息增益 g D,A )定义为集合 D 的经验熵 H D )与特征 A 给定条件下 D 的经验条件熵 H D|A )之差,即

一般地,熵 H Y )与条件熵 H Y|X )之差称为互信息(mutual information)。决策树学习中的信息增益等价于训练数据集中类与特征的互信息。

决策树学习应用信息增益准则选择特征。给定训练数据集 D 和特征 A ,经验熵 H D )表示对数据集 D 进行分类的不确定性。而经验条件熵 H D|A )表示在特征 A 给定的条件下对数据集 D 进行分类的不确定性。那么它们的差,即信息增益,就表示由于特征 A 而使得对数据集 D 的分类的不确定性减少的程度。显然,对于数据集 D 而言,信息增益依赖于特征,不同的特征往往具有不同的信息增益。信息增益大的特征具有更强的分类能力。

根据信息增益准则的特征选择方法是:对训练数据集(或子集) D ,计算其每个特征的信息增益,并比较它们的大小,选择信息增益最大的特征。

设训练数据集为 D ,| D |表示其样本容量,即样本个数。设有 K 个类 C k k =1,2,…, K ,| C k |为属于类 C k 的样本个数, 。设特征 A n 个不同的取值{ a 1 , a 2 ,…, a n },根据特征 A 的取值将 D 划分为 n 个子集 D 1 , D 2 ,…, D n ,| D i |为 D i 的样本个数 =| D |。记子集 D i 中属于类 C k 的样本的集合为 D ik ,即 D ik = D i ∩C k ,| D ik |为 D ik 的样本个数。于是信息增益的算法如下。

算法5.1(信息增益的算法)

输入:训练数据集 D 和特征 A

输出:特征 A 对训练数据集 D 的信息增益 g D,A )。

(1)计算数据集 D 的经验熵 H D

(2)计算特征 A 对数据集 D 的经验条件熵 H D|A

(3)计算信息增益

例5.2 对表5.1所给的训练数据集 D ,根据信息增益准则选择最优特征。

首先计算经验熵 H D ):

然后计算各特征对数据集 D 的信息增益。分别以 A 1 A 2 A 3 A 4 表示年龄、有工作、有自己的房子和信贷情况4个特征,则

这里 D 1 D 2 D 3 分别是 D A 1 (年龄)取值为青年、中年和老年的样本子集。类似地,

最后,比较各特征的信息增益值。由于特征 A 3 (有自己的房子)的信息增益值最大,所以选择特征 A 3 作为最优特征。

5.2.3 信息增益比

以信息增益作为划分训练数据集的特征,存在偏向于选择取值较多的特征的问题。使用信息增益比(information gain ratio)可以对这一问题进行校正。这是特征选择的另一准则。

定义5.3(信息增益比) 特征 A 对训练数据集 D 的信息增益比 g R D,A )定义为其信息增益 g D,A )与训练数据集 D 关于特征 A 的值的熵 H A D )之比,即

其中, n 是特征 A 取值的个数。

5.3 决策树的生成

本节将介绍决策树学习的生成算法。首先介绍ID3的生成算法,然后再介绍C4.5中的生成算法。这些都是决策树学习的经典算法。

5.3.1 ID3算法

ID3算法的核心是在决策树各个结点上应用信息增益准则选择特征,递归地构建决策树。具体方法是:从根结点(root node)开始,对结点计算所有可能的特征的信息增益,选择信息增益最大的特征作为结点的特征,由该特征的不同取值建立子结点;再对子结点递归地调用以上方法,构建决策树;直到所有特征的信息增益均很小或没有特征可以选择为止,最后得到一棵决策树。ID3相当于用极大似然法进行概率模型的选择。

算法5.2(ID3算法)

输入:训练数据集 D ,特征集 A 阈值 ε

输出:决策树 T

(1)若 D 中所有实例属于同一类 C k ,则 T 为单结点树,并将类 C k 作为该结点的类标记,返回 T

(2)若 A =∅,则 T 为单结点树,并将 D 中实例数最大的类 C k 作为该结点的类标记,返回 T

(3)否则,按算法5.1计算 A 中各特征对 D 的信息增益,选择信息增益最大的特征 A g

(4)如果 A g 的信息增益小于阈值 ε ,则置 T 为单结点树,并将 D 中实例数最大的类 C k 作为该结点的类标记,返回 T

(5)否则,对 A g 的每一可能值 a i ,依 A g = a i D 分割为若干非空子集 D i ,将 D i 中实例数最大的类作为标记,构建子结点,由结点及其子结点构成树 T ,返回 T

(6)对第 i 个子结点,以 D i 为训练集,以 A−{A g }为特征集,递归地调用步骤(1)~步骤(5),得到子树 T i ,返回 T i

例5.3 对表5.1的训练数据集,利用ID3算法建立决策树。

利用例5.2的结果,由于特征 A 3 (有自己的房子)的信息增益值最大,所以选择特征 A 3 作为根结点的特征。它将训练数据集 D 划分为两个子集 D 1 A 3 取值为“是”)和 D 2 A 3 取值为“否”)。由于 D 1 只有同一类的样本点,所以它成为一个叶结点,结点的类标记为“是”。

D 2 则需从特征 A 1 (年龄), A 2 (有工作)和 A 4 (信贷情况)中选择新的特征。计算各个特征的信息增益:

g D 2 , A 1 )= H D 2 )− H D 2 | A 1 )=0.918−0.667=0.251

g D 2 , A 2 )= H D 2 )− H D 2 | A 2 )=0.918

g D 2 , A 4 )= H D 2 )− H D 2 | A 4 )=0.474

选择信息增益最大的特征 A 2 (有工作)作为结点的特征。由于 A 2 有两个可能取值,从这一结点引出两个子结点:一个对应“是”(有工作)的子结点,包含3个样本,它们属于同一类,所以这是一个叶结点,类标记为“是”;另一个是对应“否”(无工作)的子结点,包含6个样本,它们也属于同一类,所以这也是一个叶结点,类标记为“否”。

这样生成一棵如图5.5所示的决策树,该决策树只用了两个特征(有两个内部结点)。

图5.5 决策树的生成

ID3算法只有树的生成,所以该算法生成的树容易产生过拟合。

5.3.2 C4.5的生成算法

C4.5算法与ID3算法相似,C4.5算法对ID3算法进行了改进。C4.5算法在生成的过程中,用信息增益比来选择特征。

算法5.3(C4.5的生成算法)

输入:训练数据集 D ,特征集 A 阈值 ε

输出:决策树 T

(1)如果 D 中所有实例属于同一类 C k ,则置 T 为单结点树,并将 C k 作为该结点的类,返回 T

(2)如果 A =∅,则置 T 为单结点树,并将 D 中实例数最大的类 C k 作为该结点的类,返回 T

(3)否则,按式(5.10)计算 A 中各特征对 D 的信息增益比,选择信息增益比最大的特征 A g

(4)如果 A g 的信息增益比小于阈值 ε ,则置 T 为单结点树,并将 D 中实例数最大的类 C k 作为该结点的类,返回 T

(5)否则,对 A g 的每一可能值 a i ,依 A g = a i D 分割为若干非空子集 D i ,将 D i 中实例数最大的类作为标记,构建子结点,由结点及其子结点构成树 T ,返回 T

(6)对结点 i ,以 D i 为训练集,以 A−{A g }为特征集,递归地调用步骤(1)~步骤(5),得到子树 T i ,返回 T i

5.4 决策树的剪枝

决策树生成算法递归地产生决策树,直到不能继续下去为止。这样产生的树往往对训练数据的分类很准确,但对未知的测试数据的分类却没有那么准确,即出现过拟合现象。过拟合的原因在于学习时过多地考虑如何提高对训练数据的正确分类,从而构建出过于复杂的决策树。解决这个问题的办法是考虑决策树的复杂度,对已生成的决策树进行简化。

在决策树学习中将已生成的树进行简化的过程称为剪枝(pruning)。具体地,剪枝从已生成的树上裁掉一些子树或叶结点,并将其根结点或父结点作为新的叶结点,从而简化分类树模型。

本节介绍一种简单的决策树学习的剪枝算法。

决策树的剪枝往往通过极小化决策树整体的损失函数(loss function)或代价函数(cost function)来实现。设树 T 的叶结点个数为| T |, t 是树 T 的叶结点,该叶结点有 N t 个样本点,其中 k 类的样本点有 N tk 个, k =1,2,…, K H t T )为叶结点 t 上的经验熵, α ≥0为参数,则决策树学习的损失函数可以定义为

其中经验熵为

在损失函数中,将式(5.11)右端的第1项记作

这时有

式(5.14)中, C T )表示模型对训练数据的预测误差,即模型与训练数据的拟合程度,| T |表示模型复杂度,参数 α ≥0控制两者之间的影响。较大的 α 促使选择较简单的模型(树),较小的 α 促使选择较复杂的模型(树)。 α =0意味着只考虑模型与训练数据的拟合程度,不考虑模型的复杂度。

剪枝就是当 α 确定时,选择损失函数最小的模型,即损失函数最小的子树。当 α 值确定时,子树越大,往往与训练数据的拟合越好,但是模型的复杂度就越高;相反,子树越小,模型的复杂度就越低,但是往往与训练数据的拟合不好。损失函数正好表示了对两者的平衡。

可以看出,决策树生成只考虑了通过提高信息增益(或信息增益比)对训练数据进行更好的拟合。而决策树剪枝通过优化损失函数还考虑了减小模型复杂度。决策树生成学习局部的模型,而决策树剪枝学习整体的模型。

式(5.11)或式(5.14)定义的损失函数的极小化等价于正则化的极大似然估计。所以,利用损失函数最小原则进行剪枝就是用正则化的极大似然估计进行模型选择。

图5.6表示决策树剪枝过程。下面介绍剪枝算法。

算法5.4(树的剪枝算法)

输入:生成算法产生的整个树 T ,参数 α

输出:修剪后的子树 T α

(1)计算每个结点的经验熵。

(2)递归地从树的叶结点向上回缩。

图5.6 决策树的剪枝

设一组叶结点回缩到其父结点之前与之后的整体树分别为 T B T A ,其对应的损失函数值分别是 C α T B )与 C α T A ),如果

则进行剪枝,即将父结点变为新的叶结点。

(3)返回步骤(2),直至不能继续为止,得到损失函数最小的子树 T α

注意,式(5.15)只需考虑两个树的损失函数的差,其计算可以在局部进行。所以,决策树的剪枝算法可以由一种动态规划的算法实现。类似的动态规划算法可参考文献 [10]

5.5 CART算法

分类与回归树(classification and regression tree,CART)模型由Breiman等人在1984年提出,是应用广泛的决策树学习方法。CART同样由特征选择、树的生成及剪枝组成,既可以用于分类也可以用于回归。以下将用于分类与回归的树统称为决策树。

CART是在给定输入随机变量 X 条件下输出随机变量 Y 的条件概率分布的学习方法。CART假设决策树是二叉树,内部结点特征的取值为“是”和“否”,左分支是取值为“是”的分支,右分支是取值为“否”的分支。这样的决策树等价于递归地二分每个特征,将输入空间即特征空间划分为有限个单元,并在这些单元上确定预测的概率分布,也就是在输入给定的条件下输出的条件概率分布。

CART算法由以下两步组成:

(1)决策树生成:基于训练数据集生成决策树,生成的决策树要尽量大。

(2)决策树剪枝:用验证数据集对已生成的树进行剪枝并选择最优子树,这时用损失函数最小作为剪枝的标准。

5.5.1 CART生成

决策树的生成就是递归地构建二叉决策树的过程。对回归树用平方误差最小化准则,对分类树用基尼指数(Gini index)最小化准则,进行特征选择,生成二叉树。

1.回归树的生成

假设 X Y 分别为输入和输出变量,并且 Y 是连续变量,给定训练数据集

D ={( x 1 , y 1 ),( x 2 , y 2 ),…,( x N , y N )}

考虑如何生成回归树。

一棵回归树对应着输入空间(即特征空间)的一个划分以及在划分的单元上的输出值。假设已将输入空间划分为 M 个单元 R 1 , R 2 ,…, R M ,并且在每个单元 R m 上有一个固定的输出值 c m ,于是回归树模型可表示为

当输入空间的划分确定时,可以用平方误差 来表示回归树对训练数据的预测误差,用平方误差最小的准则求解每个单元上的最优输出值。易知,单元 R m 上的 c m 的最优值 R m 上的所有输入实例 x i 对应的输出 y i 的均值,即

问题是怎样对输入空间进行划分。这里采用启发式的方法,选择第 j 个变量 x ( j ) 和它取的值 s 作为切分变量(splitting variable)和切分点(splitting point),并定义两个区域:

然后寻找最优切分变量 j 和最优切分点 s 。具体地,求解

对固定输入变量 j 可以找到最优切分点 s

遍历所有输入变量,找到最优的切分变量 j ,构成一个对( j,s )。依此将输入空间划分为两个区域。接着,对每个区域重复上述划分过程,直到满足停止条件为止。这样就生成一棵回归树。这样的回归树通常称为最小二乘回归树(least squares regression tree),现将算法叙述如下。

算法5.5(最小二乘回归树生成算法)

输入:训练数据集 D

输出:回归树 f x )。

在训练数据集所在的输入空间中,递归地将每个区域划分为两个子区域并决定每个子区域上的输出值,构建二叉决策树:

(1)选择最优切分变量 j 与切分点 s ,求解

遍历变量 j ,对固定的切分变量 j 扫描切分点 s ,选择使式(5.21)达到最小值的对( j,s )。

(2)用选定的对( j,s )划分区域并决定相应的输出值:

(3)继续对两个子区域调用步骤(1)和步骤(2),直至满足停止条件。

(4)将输入空间划分为 M 个区域 R 1 , R 2 ,…, R M ,生成决策树:

2.分类树的生成

分类树用基尼指数选择最优特征,同时决定该特征的最优二值切分点。

定义5.4(基尼指数) 分类问题中,假设有 K 个类,样本点属于第 k 类的概率为 p k ,则概率分布的基尼指数定义为

对于二类分类问题,若样本点属于第1个类的概率是 p ,则概率分布的基尼指数为

对于给定的样本集合 D ,其基尼指数为

这里, C k D 中属于第 k 类的样本子集, K 是类的个数。

如果样本集合 D 根据特征 A 是否取某一可能值 a 被分割成 D 1 D 2 两部分,即

D 1 ={( x,y )∈ D|A x )= a},D 2 = D−D 1

则在特征 A 的条件下,集合 D 的基尼指数定义为

基尼指数Gini( D )表示集合 D 的不确定性,基尼指数Gini( D,A )表示经 A = a 分割后集合 D 的不确定性。基尼指数值越大,样本集合的不确定性也就越大,这一点与熵相似。

图5.7显示二类分类问题中基尼指数Gini( p )、熵(单位比特)之半 H p )/2和分类误差率的关系。横坐标表示概率 p ,纵坐标表示损失。可以看出基尼指数和熵之半的曲线很接近,都可以近似地代表分类误差率。

图5.7 二类分类中基尼指数、熵之半和分类误差率的关系

算法5.6(CART生成算法)

输入:训练数据集 D ,停止计算的条件。输出:CART决策树。根据训练数据集,从根结点开始,递归地对每个结点进行以下操作,构建二叉决策树:

(1)设结点的训练数据集为 D ,计算现有特征对该数据集的基尼指数。此时,对每一个特征 A ,对其可能取的每个值 a ,根据样本点对 A = a 的测试为“是”或“否”将 D 分割成 D 1 D 2 两部分,利用式(5.25)计算 A = a 时的基尼指数。

(2)在所有可能的特征 A 以及它们所有可能的切分点 a 中,选择基尼指数最小的特征及其对应的切分点作为最优特征与最优切分点。依最优特征与最优切分点,从现结点生成两个子结点,将训练数据集依特征分配到两个子结点中去。

(3)对两个子结点递归地调用步骤(1)和步骤(2),直至满足停止条件。

(4)生成CART决策树。

算法停止计算的条件是结点中的样本个数小于预定阈值或样本集的基尼指数小于预定阈值(样本基本属于同一类),或者没有更多特征。

例5.4 根据表5.1所给训练数据集,应用CART算法生成决策树。

首先计算各特征的基尼指数,选择最优特征以及其最优切分点。仍采用例5.2的记号,分别以 A 1 A 2 A 3 A 4 表示年龄、有工作、有自己的房子和信贷情况4个特征,并以1,2,3表示年龄的值为青年、中年和老年,以1,2表示有工作和有自己的房子的值为是和否,以1,2,3表示信贷情况的值为非常好、好和一般。

求特征 A 1 的基尼指数:

由于Gini( D,A 1 =1)和Gini( D,A 1 =3)相等,且最小,所以 A 1 =1和 A 1 =3都可以选作 A 1 的最优切分点。

求特征 A 2 A 3 的基尼指数:

Gini( D,A 2 =1)=0.32

Gini( D,A 3 =1)=0.27

由于 A 2 A 3 只有一个切分点,所以它们就是最优切分点。

求特征 A 4 的基尼指数:

Gini( D,A 4 =1)=0.36

Gini( D,A 4 =2)=0.47

Gini( D,A 4 =3)=0.32

Gini( D,A 4 =3)最小,所以 A 4 =3为 A 4 的最优切分点。

A 1 A 2 A 3 A 4 几个特征中,Gini( D,A 3 =1)=0.27最小,所以选择特征 A 3 为最优特征, A 3 =1为其最优切分点。于是根结点生成两个子结点,一个是叶结点。对另一个结点继续使用以上方法在 A 1 A 2 A 4 中选择最优特征及其最优切分点,结果是 A 2 =1。依此计算得知,所得结点都是叶结点。

对于本问题,按照CART算法所生成的决策树与按照ID3算法所生成的决策树完全一致。

5.5.2 CART剪枝

CART剪枝算法从“完全生长”的决策树的底端剪去一些子树,使决策树变小(模型变简单),从而能够对未知数据有更准确的预测。CART剪枝算法由两步组成:首先从生成算法产生的决策树 T 0 底端开始不断剪枝,直到 T 0 的根结点,形成一个子树序列{ T 0 , T 1 ,…, T n };然后通过交叉验证法在独立的验证数据集上对子树序列进行测试,从中选择最优子树。

1.剪枝,形成一个子树序列

在剪枝过程中,计算子树的损失函数:

其中, T 为任意子树, C T )为对训练数据的预测误差(如基尼指数),| T |为子树的叶结点个数, α ≥0为参数, C α T )为参数是 α 时的子树 T 的整体损失。参数 α 权衡训练数据的拟合程度与模型的复杂度。

对固定的 α ,一定存在使损失函数 C α T )最小的子树,将其表示为 T α T α 在损失函数 C α T )最小的意义下是最优的。容易验证这样的最优子树是唯一的。当 α 大的时候,最优子树 T α 偏小;当 α 小的时候,最优子树 T α 偏大。极端情况:当 α =0时,整体树是最优的。当 α →∞时,根结点组成的单结点树是最优的。

Breiman等人证明:可以用递归的方法对树进行剪枝。将 α 从小增大,0= α 0 < α 1 <…< α n <+∞,产生一系列的区间[ α i , α i +1 ), i =0,1,…, n ;剪枝得到的子树序列对应着区间 α ∈[ α i , α i +1 ), i =0,1,…, n 的最优子树序列{ T 0 , T 1 ,…, T n },序列中的子树是嵌套的。

具体地,从整体树 T 0 开始剪枝。对 T 0 的任意内部结点 t ,以 t 为单结点树的损失函数是

t 为根结点的子树 T t 的损失函数是

α =0及 α 充分小时,有不等式

α 增大时,在某一 α

α 再增大时,不等式(5.29)反向。只要 T t t 有相同的损失函数值,而 t 的结点少,因此 t T t 更可取,对 T t 进行剪枝。

为此,对 T 0 中每一内部结点 t ,计算

它表示剪枝后整体损失函数减少的程度。在 T 0 中剪去 g t )最小的 T t ,将得到的子树作为 T 1 ,同时将最小的 g t )设为 α 1 T 1 为区间[ α 1 , α 2 )的最优子树。

如此剪枝下去,直至得到根结点。在这一过程中,不断地增加 α 的值,产生新的区间。

2.在剪枝得到的子树序列 T 0 , T 1 ,…, T n 中通过交叉验证选取最优子树 T α

具体地,利用独立的验证数据集,测试子树序列 T 0 , T 1 ,…, T n 中各棵子树的平方误差或基尼指数。平方误差或基尼指数最小的决策树被认为是最优的决策树。在子树序列中,每棵子树 T 1 , T 2 ,…, T n 都对应一个参数 α 1 , α 2 ,…, α n 。所以,当最优子树 T k 确定时,对应的 α k 也确定了,即得到最优决策树 T α

现在写出CART剪枝算法。

算法5.7(CART剪枝算法)

输入:CART算法生成的决策树 T 0

输出:最优决策树 T α

(1)设 k =0, T = T 0

(2)设 α =+∞。

(3)自下而上地对各内部结点 t 计算 C T t ),| T t |以及

这里, T t 表示以 t 为根结点的子树, C T t )是对训练数据的预测误差,| T t |是 T t 的叶结点个数。

(4)对 g t )= α 的内部结点 t 进行剪枝,并对叶结点 t 以多数表决法决定其类,得到树 T

(5)设 k = k +1, α k = α T k = T

(6)如果 T k 不是由根结点及两个叶结点构成的树,则回到步骤(2);否则,令 T k = T n

(7)采用交叉验证法在子树序列 T 0 , T 1 ,…, T n 中选取最优子树 T α

本章概要

1.分类决策树模型是表示基于特征对实例进行分类的树形结构。决策树可以转换成一个if-then规则的集合,也可以看作是定义在特征空间划分上的类的条件概率分布。

2.决策树学习旨在构建一个与训练数据拟合很好并且复杂度小的决策树。因为从可能的决策树中直接选取最优决策树是NP完全问题,现实中采用启发式方法学习次优的决策树。

决策树学习算法包括3个部分:特征选择、树的生成和树的剪枝。常用的算法有ID3算法、C4.5算法和CART算法。

3.特征选择的目的在于选取对训练数据能够分类的特征。特征选择的关键是其准则,常用的准则如下:

(1)样本集合 D 对特征 A 的信息增益(ID3):

其中, H D )是数据集 D 的熵, H D i )是数据集 D i 的熵, H D|A )是数据集 D 对特征 A 的条件熵, D i D 中特征 A 取第 i 个值的样本子集, C k D 中属于第 k 类的样本子集, n 是特征 A 取值的个数, K 是类的个数。

(2)样本集合 D 对特征 A 的信息增益比(C4.5):

其中, g D,A )是信息增益, H A D )是 D 关于特征 A 的值的熵。

(3)样本集合 D 的基尼指数(CART):

特征 A 条件下集合 D 的基尼指数:

4.决策树的生成。通常使用信息增益最大、信息增益比最大或基尼指数最小作为特征选择的准则。决策树的生成往往通过计算信息增益或其他指标,从根结点开始,递归地产生决策树。这相当于用信息增益或其他准则不断地选取局部最优的特征,或将训练集分割为能够基本正确分类的子集。

5.决策树的剪枝。由于生成的决策树存在过拟合问题,需要对它进行剪枝,以简化学到的决策树。决策树的剪枝往往从已生成的树上剪掉一些叶结点或叶结点以上的子树,并将其父结点或根结点作为新的叶结点,从而简化生成的决策树。

继续阅读

介绍决策树学习方法的文献很多,关于ID3可见文献 [1] ,C4.5可见文献 [2] ,CART可见文献 [3] 和文献 [4] 。决策树学习的一般性介绍可见文献 [5] ~文献 [7] 。与决策树类似的分类方法还有决策列表(decision list)。决策列表与决策树可以相互转换 [8] ,决策列表的学习方法可见文献 [9]

习题

5.1 根据表5.1所给的训练数据集,利用信息增益比(C4.5算法)生成决策树。

5.2 已知如表5.2所示的训练数据,试用平方误差损失准则生成一个二叉回归树。

表5.2 训练数据表

5.3 证明CART剪枝算法中,当 α 确定时,存在唯一的最小子树 T α 使损失函数 C α T )最小。

5.4 证明CART剪枝算法中求出的子树序列{ T 0 , T 1 ,…, T n }分别是区间 α ∈[ α i , α i +1 )的最优子树 T α ,这里 i =0,1,…, n ,0= α 0 < α 1 <…< α n <+∞。

参考文献

[1] OLSHEN R A, QUINLAN J R. Induction of decision trees[J]. Machine Learning, 1986, 1(1):81–106.

[2] OLSHEN R A, QUINLAN J R.C4.5:programs for machine learning[M]. Morgan Kaufmann, 1992.

[3] OLSHEN R A, BREIMAN L, FRIEDMAN J, et al. Classification and regression trees[M]. Wadsworth, 1984.

[4] RIPLEY B. Pattern recognition and neural networks[M]. Cambridge University Press, 1996.

[5] LIU B. Web data mining:Exploring hyperlinks, contents and usage data[M]. Springer-Verlag, 2006.

[6]HYAFIL L, RIVEST R L. Constructing optimal binary decision trees is NP-complete[J]. Information Processing Letters, 1976, 5(1):15–17.

[7] HASTIE T, TIBSHIRANI R, FRIEDMAN J. The elements of statistical learning:data mining, inference, and prediction[M].范明,柴玉梅,昝红英,等译. Springer, 2001.

[8] YAMANISHI K.A learning criterion for stochastic rules[J]. Machine Learning, 1992, 9(2–3):165–203.

[9] LI H, YAMANISHI K. Text classification using ESC-based stochastic decision lists[J]. Information Processing&Management, 2002, 38(3):343–361.

[10] LI H, ABE N. Generalizing case frames using a thesaurus and the MDL principle[J]. Computational Linguistics, 1998, 24(2):217–244.


[1] 此例取自参考文献 [5] +Dli93lLitlQptXAX6z2fxQApY4ExLvTEHhOcq2vzEgVYlg6nqWhs6AYk/tDaCZK

点击中间区域
呼出菜单
上一章
目录
下一章
×