统计学习方法笔记与习题解答(Chapter5)

决策树

笔记摘要

  • 决策树可以认为是if-then规则的集合,也可以认为是定义在特征空间上的条件概率分布
  • 根据损失函数最小化的原则建立决策树模型
  • 决策树的路径或其对应的if-then规则集合具有一个重要性质:互斥且完备
  • 决策树的学习算法包含特征选择、决策树的生成与决策树的剪枝
  • 决策树的生成对应于模型的局部选择,决策树的剪枝对应于模型的全局选择

H ( p ) = H ( X ) = i = 1 n p i log p i H(p)=H(X)=-\sum_{i=1}^{n}p_i\log p_i

  • 熵只与 X X 的分布有关,与 X X 取值无关

  • 定义 0 log 0 = 0 0\log0=0 ,熵是非负的

  • 表示随机变量不确定性的度量

条件熵

  • 随机变量 ( X , Y ) (X,Y) 的联合概率分布为

P ( X = x i , Y = y j ) = p i j , i = 1 , 2 , , n ; j = 1 , 2 , , m P(X=x_i,Y=y_j)=p_{ij}, i=1,2,\dots ,n;j=1,2,\dots ,m

  • 条件熵 H ( Y X ) H(Y|X) 表示在已知随机变量 X X 的条件下随机变量 Y Y 的不确定性
    H ( Y X ) = i = 1 n p i H ( Y X = x i ) H(Y|X)=\sum_{i=1}^np_iH(Y|X=x_i)
    其中 p i = P ( X = x i ) , i = 1 , 2 , , n p_i=P(X=x_i),i=1,2,\dots ,n

经验熵, 经验条件熵

  • 当熵和条件熵中的概率由数据估计(特别是极大似然估计)得到时,所对应的熵与条件熵分别称为经验熵和经验条件熵

信息增益

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

  • 熵与条件熵的差称为互信息

  • 决策树中的信息增益等价于训练数据集中的类与特征的互信息

  • 考虑ID这种特征, 本身是唯一的。按照ID做划分, 得到的经验条件熵为0, 会得到最大的信息增益。所以, 按照信息增益的准则来选择特征, 可能会倾向于取值比较多的特征

信息增益比

  • 使用信息增益比可以对上面倾向取值较多的特征的问题进行校正
    g R ( D , A ) = g ( D , A ) H A ( D ) H A ( D ) = i = 1 n D i D l o g 2 D i D g_R(D,A)=\frac{g(D,A)}{H_A(D)}\\ H_A(D)=-\sum_{i=1}^n\frac{D_i}{D}log_2\frac{D_i}{D}

ID3算法

输入:训练数据集 D D , 特征集 A A ,阈值 ϵ \epsilon
输出:决策树 T T

  1. 如果 D D 中所有实例属于同一类 C k C_k ,则 T T 为单节点树,并将类 C k C_k 作为该节点的类标记,返回 T T
  2. 如果 A A 是空集,则 T T 为单节点树,并将实例数最多的类作为该节点类标记,返回 T T
  3. 计算 g g , 选择信息增益最大的特征 A g A_g
  4. 如果 A g A_g 的信息增益小于 ϵ \epsilon ,则置 T T 为单节点树, D D 中实例数最大的类 C k C_k 作为类标记,返回 T T
  5. 否则,依 A g = a i A_g=a_i 将D划分若干非空子集 D i D_i D i D_i 中实例数最大的类 C k C_k 作为类标记,构建子结点,由结点及其子结点 构成树 T T ,返回 T T
  6. D i D_i 训练集, A A g A-A_g 为特征集,递归调用前面步骤,得到 T i T_i ,返回 T i T_i

C4.5的生成算法

  • 改用信息增益比来选择特征

输入:训练数据集 D D , 特征集 A A ,阈值 ϵ \epsilon
输出:决策树 T T

  1. 如果 D D 属于同一类 C k C_k T T 为单节点树,类 C k C_k 作为该节点的类标记,返回 T T
  2. 如果 A A 是空集, 置 T T 为单节点树,实例数最多的作为该节点类标记,返回 T T
  3. 计算 g g , 选择信息增益比最大的特征 A g A_g
  4. 如果 A g A_g 信息增益比小于 ϵ \epsilon T T 为单节点树, D D 中实例数最大的类 C k C_k 作为类标记,返回 T T
  5. 否则,依 A g = a i A_g=a_i 将D划分若干非空子集 D i D_i D i D_i 中实例数最大的类 C k C_k 作为类标记,构建子结点,由结点及其子结点 构成树 T T ,返回 T T
  6. D i D_i 训练集, A A g A-A_g 为特征集,递归调用前面步骤,得到 T i T_i ,返回 T i T_i
  • ID3和C4.5在生成上,差异只在准则的差异

树的剪枝

  • 决策树的剪枝往往通过极小化决策树整体的损失函数或代价函数来实现的
  • T T 的叶结点个数为 T |T| t t 是树 T T 的叶结点,该结点有 N t N_t 个样本点,其中 k k 类的样本点有 N t k N_{tk} 个, H t ( T ) H_t(T) 为叶结点 t t 上的经验熵, α 0 \alpha\geqslant 0 为参数,决策树学习的损失函数可以定义为
    C α ( T ) = i = 1 T N t H t ( T ) + α T C_\alpha(T)=\sum_{i=1}^{|T|}N_tH_t(T)+\alpha|T|
    其中
    H t ( T ) = k N t k N t log N t k N t H_t(T)=-\sum_k\frac{N_{tk}}{N_t}\log \frac{N_{tk}}{N_t}
    C ( T ) = t = 1 T N t H t ( T ) = t = 1 T k = 1 K N t k log N t k N t C(T)=\sum_{t=1}^{|T|}N_tH_t(T)\color{black}=-\sum_{t=1}^{|T|}\sum_{k=1}^KN_{tk}\log\frac{N_{tk}}{N_t}
    这时有
    C α ( T ) = C ( T ) + α T C_\alpha(T)=C(T)+\alpha|T|
    其中 C ( T ) C(T) 表示模型对训练数据的误差, T |T| 表示模型复杂度,参数 α 0 \alpha \geqslant 0 控制两者之间的影响

剪枝算法

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

输出:修剪后的子树 T α T_\alpha

  1. 计算每个结点的经验熵
  2. 递归地从树的叶结点向上回缩
    假设一组叶结点回缩到其父结点之前与之后的整体树分别是 T B T_B T A T_A ,其对应的损失函数分别是 C α ( T A ) C_\alpha(T_A) C α ( T B ) C_\alpha(T_B) ,如果 C α ( T A ) C α ( T B ) C_\alpha(T_A)\leqslant C_\alpha(T_B) 则进行剪枝,即将父结点变为新的叶结点
  3. 返回2,直至不能继续为止,得到损失函数最小的子树 T α T_\alpha
  • 决策树的剪枝算法可以由一种动态规划的算法实现

CART

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

最小二乘回归树生成算法

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

输入:训练数据集 D D
输出:回归树 f ( x ) f(x)
步骤:

  1. 遍历变量 j j ,对固定的切分变量 j j 扫描切分点 s s ,得到满足下面式子的 ( j , s ) (j,s)
    min j , s [ min c 1 x i R 1 ( j , s ) ( y i c 1 ) 2 + min c 2 x i R 2 ( j , s ) ( y i c 2 ) 2 ] \min\limits_{j,s}\left[\min\limits_{c_1}\sum\limits_{x_i\in R_1(j,s)}(y_i-c_1)^2+\min\limits_{c_2}\sum\limits_{x_i\in R_2(j,s)}(y_i-c_2)^2\right]
  2. 用选定的 ( j , s ) (j,s) , 划分区域并决定相应的输出值
    R 1 ( j , s ) = { x x ( j ) s } , R 2 ( j , s ) = { x x ( j ) > s } c ^ m = 1 N x i R m ( j , s ) y j , x R m , m = 1 , 2 R_1(j,s)=\{x|x^{(j)}\leq s\}, R_2(j,s)=\{x|x^{(j)}> s\} \\ \hat{c}_m= \frac{1}{N}\sum\limits_{x_i\in R_m(j,s)} y_j, x\in R_m, m=1,2
  3. 对两个子区域调用(1)(2)步骤, 直至满足停止条件
  4. 将输入空间划分为 M M 个区域 R 1 , R 2 , , R M R_1, R_2,\dots,R_M ,生成决策树:
    f ( x ) = m = 1 M c ^ m I ( x R m ) f(x)=\sum_{m=1}^M\hat{c}_mI(x\in R_m)
  • 课后题有详细例子

CART分类树的生成

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

  • 概率分布的基尼指数定义

G i n i ( p ) = k = 1 K p k ( 1 p k ) = 1 k = 1 K p k 2 Gini(p) = \sum_{k=1}^Kp_k(1-p_k)=1-\sum_{k=1}^Kp_k^2

  • 如果样本集合 D D 根据特征 A A 是否取某一可能值 a a 被分割成 D 1 D_1 D 2 D_2 两部分,则在特征 A A 的条件下,集合 D D 的基尼指数定义为
    G i n i ( D , A ) = D 1 D G i n i ( D 1 ) + D 2 D G i n i ( D 2 ) Gini(D,A)=\frac{|D_1|}{|D|}Gini(D_1)+\frac{|D_2|}{|D|}Gini(D_2)

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

  1. 设结点地训练数据集为 D D ,计算现有特征对该数据集的基尼指数。此时,对每一个特征 A A ,对其可能取得每个值 a a ,根据样本点对 A = a A=a 的测试为“是”或“否”将 D D 分成 D 1 D_1 D 2 D_2 两部分,计算 A = a A=a 时的基尼指数
  2. 在所有可能的特征 A A 以及它们所有可能的切分点 a a 中,选择基尼指数最小的特征及其对应的切分点作为最优特征与最优切分点。依照最优特征和最优切分点,从现结点生成两个子结点,将训练数据集依特征分配到两个子结点中去。
  3. 对两个子结点递归地调用1、2,直至满足停止条件
  4. 生成CART决策树
  • 算法停止计算的条件是结点中的样本个数小于预定阈值,或样本集的基尼指数小于指定阈值,或者没有更多特征

习题解答

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

    • 编写程序计算信息增益比,并利用C4.5算法生成决策树,得到结果如下
      特征(年龄)的信息增益比为: 0.052
      特征(有工作)的信息增益比为: 0.352
      特征(有自己的房子)的信息增益比为: 0.433
      特征(信贷情况)的信息增益比为: 0.232
      特征(年龄)的信息增益比为: 0.164
      特征(有工作)的信息增益比为: 1.000
      特征(有自己的房子)的信息增益比为: 0.340
    • 决策树
      {‘label:’: None, ‘feature’: 2, ‘tree’: {‘否’: {‘label:’: None, ‘feature’: 1, ‘tree’: {‘否’: {‘label:’: ‘否’, ‘feature’: None, ‘tree’: {}}, ‘是’: {‘label:’: ‘是’, ‘feature’: None, ‘tree’: {}}}}, ‘是’: {‘label:’: ‘是’, ‘feature’: None, ‘tree’: {}}}}
    • 结果与ID3算法完全相同
      在这里插入图片描述
  • 5.2 已知如表 5.2 所示的训练数据,试用平方误差损失准则生成一个二叉回归树
    在这里插入图片描述

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

    • 利用反证法,假设存在两个最小子树使损失函数最小
      设这两棵最小子树 为 T 1 T_1 ​ 和 T 2 T_2 ​ ,其剪枝位置分别是 t 1 t_1 ​ 和 t 2 t_2 ​ ,两者都能使得损失函数最小,即两者拥有相等的 C α ( T ) C_\alpha(T)​
      又有:
      C α ( t 1 ) < C α ( T t 1 ) C α ( t 2 ) < C α ( T t 2 ) C_\alpha(t_1)<C_\alpha(T_{t1})\\ C_\alpha(t_2)<C_\alpha(T_{t2})
      即剪枝 t 1 t_1 , t 2 t_2 ,总能使得整体损失函数减小,因此对于子树 T 1 T_1 , T 2 T_2 ,总存在进一步的剪枝,使得损失函数进一步减小(在 T 1 T_1 中剪枝 t 2 t_2 ,在 T 2 T_2 中剪枝 t 1 t_1 ),因此 T 1 T_1 , T 2 T_2 不是最优的子树。
      即不可能存在两棵及以上的最优子树
  • 5.4 证明 CART 剪枝算法中求出的子树序列 { T 0 , T 1 , , T n } \{T_0,T_1,⋅⋅⋅,T_n\} 分别是区间 α [ α i , α i + 1 ) α∈[α_i,α_{i+1}) 的最优子树 T α T_\alpha ,这里 i = 0 , 1 , , n , 0 = α 0 < α 1 < < α n < + i=0,1,⋅⋅⋅,n,0=\alpha_0<\alpha_1<\cdot\cdot\cdot<\alpha_n<+\infty

发布了135 篇原创文章 · 获赞 490 · 访问量 6万+

猜你喜欢

转载自blog.csdn.net/lyc44813418/article/details/91038767