关于经典决策树算法ID3、C4.5及CART树的部分细节梳理,原文见决策树算法。
决策树可以从两个视角理解。
经典决策树有ID3、C4.5以及CART树,其功能和学习过程各有异同,简单对比。
算法 | 分裂标准 | 树类型 | 特征类型 | 缺失 | 剪枝 | 任务 |
---|---|---|---|---|---|---|
ID3 | 信息增益 | 多叉 | 离散 | No | 无剪枝 | 分类 |
C4.5 | 信息增益比 | 多叉 | 离散/连续 | Yes | 有剪枝 | 分类 |
CART | 基尼系数 | 二叉 | 离散/连续 | Yes | 有剪枝 | 分类/回归 |
一些其它差异
连续值不再有限,不能直接取其可能取值划分,可采用二分法(bi-partition)。给定样本集 D D D和连续属性 a a a,其有 n n n个不同取值,从小到大排序得 { a 1 , a 2 , … , a n } \{a^1, a^2, \dots, a^n\} {a1,a2,…,an},则划分点可以依次选取测试
T a = { a i + a i + 1 2 ∣ 1 ≤ i ≤ n − 1 } T_a=\big\{\frac{a^i + a^{i+1}}{2}|1\le i\le n-1\big\} Ta={2ai+ai+1∣1≤i≤n−1}
注意,与离散属性不同,若当前节点划分属性为连续特征,该属性还可作其为后代节点的划分属性。
一般分为预剪枝和后剪枝两种。
预剪枝降低过拟合风险,基于“贪心思想”,也会带来欠拟合的风险;后剪枝欠拟合风险小,但训练时间开销比未剪枝或预剪枝大的多。
在XGBoost里,做法是这样的。在每个节点上都会将含缺失值样本往左右分支各倒流一次,然后计算对Objective的影响,选效果好的方向,作为缺失值应该流向的方向。
比如特征A(A>0或A<=0或A=null),那么首先忽略含缺失值样本,正常样本导流到到左子树与右子树;将含缺失值样本导向左子树,计算Objective_L;将含缺失值样本导向右子树,计算Objective_R。选择Objective较小的方向,作为缺失值应该分流的方向。
常见的几种终止条件有
信息熵,表示随机变量的不确定性。
H ( p ) = − ∑ i = 1 n p i l o g ( p i ) H(p) = -\sum_{i=1}^n p_ilog(p_i) H(p)=−i=1∑npilog(pi)
其中
0 ≤ H ( p ) ≤ l o g ( n ) 0 \le H(p) \le log(n) 0≤H(p)≤log(n)
条件熵,表示在已知随机变量 X X X的情况下 Y Y Y的不确定性。
H ( Y ∣ X ) = ∑ i = 1 n p i H ( Y ∣ X = x i ) H(Y|X) = \sum_{i=1}^n p_i H(Y|X=x_i) H(Y∣X)=i=1∑npiH(Y∣X=xi)
其中
p i = P ( X = x i ) , i = 1 , … , n p_i = P(X = x_i), i=1,\dots, n pi=P(X=xi),i=1,…,n
信息增益,表示得知特征 X X X的信息使 Y Y Y不确定的减少程度。熵 H ( Y ) H(Y) H(Y)与条件熵 H ( Y ∣ X ) H(Y \mid X) H(Y∣X)之差称为互信息。决策树学习中的信息增益等级于训练数据集中类与特征的互信息。
g ( D , A ) = H ( D ) − H ( D ∣ A ) g(D, A) = H(D) - H(D|A) g(D,A)=H(D)−H(D∣A)
信息增益比,考虑信息增益相对值。训练数据经验熵较大时,信息增益偏大;信息增益偏向特征类别较多的特征。信息增益比有所矫正。
g R ( D , A ) = g ( D , A ) H ( D ) g_R(D, A) = \frac{g(D, A)}{H(D)} gR(D,A)=H(D)g(D,A)
基尼系数,表示一个随机变量变为其对立事件的概率,也可以衡量随机变量的不确定性。
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}^K p_k(1-p_k) = 1 - \sum_{k=1}^K p_k^2 Gini(p)=k=1∑Kpk(1−pk)=1−k=1∑Kpk2
如图,基尼系数和熵之半很接近,都可以近似代表分类误差率。