决策树的演变与理解


title: 决策树的演变与理解
date: 2019-09-19 20:20:35
categories:

  • 技术
    tags:
  • 机器学习
  • 决策树

决策树是机器学习十大算法之一,整理下决策树的演变,并把为何这么演变的原因阐述如下,以便加深理解。

决策树的演变与理解_第1张图片

思想起源

决策树的思想起源很简单,古语有云“朝霞不出门,晚霞行千里”,就是暗合决策树的思想。如果今天有朝霞则可以预测今天有雨;如果看到了晚霞,则代表天气很好,不会下雨。在这里面其实是一个if-else的分支判断。

1966年,CLS学习系统中就已经提出决策树算法的概念。

1979年,J.R Quinlan 给出ID3算法原型。

首先,举一个例子。如果通过【年龄】【职业】【信誉】来预测该用户是否会购买某个产品。

如果我们通过年龄来判断,如果<10不会购买,>10不确定。然后在age>10的基础上判断职业,如果是【学生】,则不会购买;如果是医生会购买;如果是律师不确定,进一步在age>10和职业为律师的基础上判断,如果信誉高的话,会购买,否则不会购买。

上述判断,其实生成了一棵决策树。

决策树从根节点到叶结点的一条路径就对应着一条合取规则,因此决策树容易转换成分类规则。

决策树的本质是从数据集中归纳出一组分类规则。

决策树生成思路

决策树设计为三类节点:根节点、叶子节点和内部节点。

  1. 如果从一个空缺的决策树开始,选择一个特征为根节点;
  2. 我们按照该特征条件进行划分,如果划分到某个子集为空,或子集中的所有样本已经归为同一类别,那么该子集就是叶子节点,否则为内部节点。
  3. 对于内部节点,需要选择一个新的类别继续对该子集进行划分,直到所有子集都为叶子节点。

ID3算法——信息熵的引入

特征选择在于选取对训练数据具有分类能力的特征,这样可以提高决策树学习的效率。为了衡量通过选择某个特征后,样本划分信息的变化。引入熵的概念(衡量信息的不确定性),熵的改变越大,说明用该特征的效果越好。

决策树的演变与理解_第2张图片

那么,通过确定某个特征,熵前后发生变化,学者引入了信息增益来衡量这种变化。

[外链图片转存失败(img-asWGRb7B-1568903351774)(https://tva1.sinaimg.cn/large/006y8mN6ly1g755hjob5xj30s40isn54.jpg)]

如此以来,我们可以通过信息增益来判断先选择哪个特征来生成决策树的效果更好。

ID3算法就是选择信息增益作为选取特征的标准。

ID3算法的描述

决策树的演变与理解_第3张图片

决策树的演变与理解_第4张图片

缺陷:信息增益偏向于选择特征值个数较多的特征。

比如,对于职业这个特征来说,有学生、律师、会计、教师、农民、士兵等待。

划分的越细,则信息越确定,熵则越小,信息增益则愈大。

对于性别这种特征候选数量较小的特征是不公平的。

C4.5算法的引入

为了解决“信息增益偏向于选择特征值个数较多的特征”这个问题。Quinlan提出了C4.5算法。

C4.5使用信息增益率为标准选择特征,解决“信息增益偏向于选择特征值个数较多的特征”的这个问题。

决策树的演变与理解_第5张图片

1993年,Quinlan发展了ID3算法,提出C4.5算法。

其中,ID3还有另一个分支为分类回归决策树算法(CART),CART可以用来回归预测。

C4.5算法的描述

决策树的演变与理解_第6张图片

CART算法的引入

上述的两种算法:ID3和C4.5,适用于分类算法,但是对于回归来说,决策树也可以有所应用。

CART算法就是一种通过决策树方法实现回归的算法。

在预测中,CART使用最小剩余方差(基尼指数)来判断数据集的最优划分,这个准则是期望划分之后的子树与样本点的误差方差最小。

决策树的演变与理解_第7张图片

CART进行预测是把叶子节点设定为一系列分段线性函数,这些分段线性函数是对源数据曲线的一种模拟。

决策树的演变与理解_第8张图片

CART算法描述

决策树的演变与理解_第9张图片

决策树的演变与理解_第10张图片

决策树的公共缺陷

决策树因为划分越细(树层数越多),在训练集得到的结果越准确,因而很容易过拟合。

为了解决决策树过拟合的问题,引入剪枝的方法。

剪枝主流方法有两类:先剪枝和后剪枝(悲观剪枝)。

先剪枝当子集的某个标准低于预定义的阈值时,子集的划分终止。

后剪枝在整个决策树生成完毕后,估算内部节点所覆盖样本节点的误判率,如果低于阈值,则将其变为叶子节点。

先剪枝效率高,适合大规模数据的粗略估计。但容易导致欠拟合

参考&致谢

  • 郑捷- 机器学习
  • 李航- 统计学习方法

你可能感兴趣的:(机器学习)