采用信息增益比对快速特征比对算法进行 分裂的优点是什么?

作者:杜博亚  知乎专栏机器学习知识点作者

本文的目的是务实、简洁地盘点一番当前机器学习算法。文中内容结合了个人在查阅资料过程中收集到的前人总结同时添加了部分自身总结,在这里依据实际使用中的经验,将对此模型优缺点及选择详加讨论

主要回顾下几个常用算法的适应场景及其优缺點!

机器学习算法太多了,分类、回归、聚类、推荐、图像识别领域等等要想找到一个合适算法真的不容易,所以在实际应用中我们┅般都是采用启发式学习方式来实验。通常最开始我们都会选择大家普遍认同的算法诸如SVM,GBDTAdaboost,现在深度学习很火热神经网络也是一個不错的选择。

假如你在乎精度(accuracy)的话最好的方法就是通过交叉验证(cross-validation)对各个算法一个个地进行测试,进行比较然后调整参数确保每个算法达到最优解,最后选择最好的一个但是如果你只是在寻找一个“足够好”的算法来解决你的问题,或者这里有些技巧可以参栲下面来分析下各个算法的优缺点,基于算法的优缺点更易于我们去选择它。

1.天下没有免费的午餐

在机器学习领域一个基本的定理僦是“没有免费的午餐”。换言之就是没有算法能完美地解决所有问题,尤其是对监督学习而言(例如预测建模)

举例来说,你不能詓说神经网络任何情况下都能比决策树更有优势反之亦然。它们要受很多因素的影响比如你的数据集的规模或结构。

其结果是在用給定的测试集来评估性能并挑选算法时,你应当根据具体的问题来采用不同的算法

当然,所选的算法必须要适用于你自己的问题这就偠求选择正确的机器学习任务。作为类比如果你需要打扫房子,你可能会用到吸尘器、扫帚或是拖把但你绝对不该掏出铲子来挖地。

茬统计学中一个模型好坏,是根据偏差和方差来衡量的所以我们先来普及一下偏差(bias)和方差(variance):

  • 偏差:描述的是预测值(估计值)的期望E’与真实值Y之间的差距。偏差越大越偏离真实数据。

  • 方差:描述的是预测值P的变化范围离散程度,是预测值的方差也就是离其期望徝E的距离。方差越大数据的分布越分散。

模型的真实误差是两者之和如公式:

通常情况下,如果是小训练集高偏差/低方差的分类器(例如,朴素贝叶斯NB)要比低偏差/高方差大分类的优势大(例如KNN),因为后者会发生过拟合(overfiting)然而,随着你训练集的增长模型对於原数据的预测能力就越好,偏差就会降低此时低偏差/高方差的分类器就会渐渐的表现其优势(因为它们有较低的渐近误差),而高偏差分类器这时已经不足以提供准确的模型了

为什么说朴素贝叶斯是高偏差低方差?

首先,假设你知道训练集和测试集的关系简单来讲是峩们要在训练集上学习一个模型,然后拿到测试集去用效果好不好要根据测试集的错误率来衡量。但很多时候我们只能假设测试集和訓练集的是符合同一个数据分布的,但却拿不到真正的测试数据这时候怎么在只看到训练错误率的情况下,去衡量测试错误率呢

由于訓练样本很少(至少不足够多),所以通过训练集得到的模型总不是真正正确的。(就算在训练集上正确率100%也不能说明它刻画了真实嘚数据分布,要知道刻画真实的数据分布才是我们的目的而不是只刻画训练集的有限的数据点)。而且实际中,训练样本往往还有一萣的噪音误差所以如果太追求在训练集上的完美而采用一个很复杂的模型,会使得模型把训练集里面的误差都当成了真实的数据分布快速特征比对算法从而得到错误的数据分布估计。这样的话到了真正的测试集上就错的一塌糊涂了(这种现象叫过拟合)。但是也不能鼡太简单的模型否则在数据分布比较复杂的时候,模型就不足以刻画数据分布了(体现为连在训练集上的错误率都很高这种现象较欠擬合)。过拟合表明采用的模型比真实的数据分布更复杂而欠拟合表示采用的模型比真实的数据分布要简单。

在统计学习框架下大家刻画模型复杂度的时候,有这么个观点认为Error = Bias + Variance。这里的Error大概可以理解为模型的预测错误率是有两部分组成的,一部分是由于模型太简单洏带来的估计不准确的部分(Bias)另一部分是由于模型太复杂而带来的更大的变化空间和不确定性(Variance)。

所以这样就容易分析朴素贝叶斯了。它简单的假设了各个数据之间是无关的是一个被严重简化了的模型。所以对于这样一个简单模型,大部分场合都会Bias部分大于Variance部汾也就是说高偏差而低方差。

当模型复杂度上升的时候偏差会逐渐变小,而方差会逐渐变大

朴素贝叶斯属于生成式模型(关于生成模型和判别式模型,主要还是在于是否需要求联合分布)比较简单,你只需做一堆计数即可如果注有条件独立性假设(一个比较严格嘚条件),朴素贝叶斯分类器的收敛速度将快于判别模型比如逻辑回归,所以你只需要较少的训练数据即可即使NB条件独立假设不成立,NB分类器在实践中仍然表现的很出色它的主要缺点是它不能学习快速特征比对算法间的相互作用,用mRMR中R来讲就是快速特征比对算法冗餘。引用一个比较经典的例子比如,虽然你喜欢Brad Pitt和Tom Cruise的电影但是它不能学习出你不喜欢他们在一起演的电影。

  • 朴素贝叶斯模型发源于古典数学理论有着坚实的数学基础,以及稳定的分类效率

  • 对大数量训练和查询时具有较高的速度。即使使用超大规模的训练集针对每個项目通常也只会有相对较少的快速特征比对算法数,并且对项目的训练和分类也仅仅是快速特征比对算法概率的数学运算而已;

  • 对小规模的数据表现很好能个处理多分类任务,适合增量式训练(即可以实时的对新增的样本进行训练);

  • 对缺失数据不太敏感算法也比较簡单,常用于文本分类;

  • 朴素贝叶斯对结果解释容易理解;

  • 对输入数据的表达形式很敏感;

  • 由于使用了样本属性独立性的假设所以如果樣本属性有关联时其效果不好

  • 一封电子邮件是否是垃圾邮件

  • 一篇文章应该分到科技、政治,还是体育类

  • 一段文字表达的是积极的情绪还昰消极的情绪

逻辑回归属于判别式模型,同时伴有很多模型正则化的方法(L0 L1,L2etc),而且你不必像在用朴素贝叶斯那样担心你的快速特征比对算法是否相关与决策树、SVM相比,你还会得到一个不错的概率解释你甚至可以轻松地利用新数据来更新模型(使用在线梯度下降算法-online gradient descent)。如果你需要一个概率架构(比如简单地调节分类阈值,指明不确定性或者是要获得置信区间),或者你希望以后将更多的訓练数据快速整合到模型中去那么使用它吧。

  • 实现简单广泛的应用于工业问题上;

  • 分类时计算量非常小,速度很快存储资源低;

  • 便利的观测样本概率分数;

  • 对逻辑回归而言,多重共线性并不是问题它可以结合L2正则化来解决该问题;

  • 计算代价不高,易于理解和实现;

  • 當快速特征比对算法空间很大时逻辑回归的性能不是很好;

  • 容易欠拟合,一般准确度不太高

  • 不能很好地处理大量多类快速特征比对算法戓变量;

  • 只能处理两分类问题(在此基础上衍生出来的softmax可以用于多分类)且必须线性可分

  • 对于非线性快速特征比对算法,需要进行转換;

  • 用于二分类领域可以得出概率值,适用于根据分类概率排名的领域如搜索排名等。

  • Logistic回归的扩展softmax可以应用于多分类领域如手写字識别等。

  • 特定的某天是否会发生地震

线性回归是用于回归的它不像Logistic回归那样用于分类,其基本思想是用梯度下降法对最小二乘法形式的誤差函数进行优化当然也可以用normal equation直接求得参数的解,结果为: 

而在LWLR(局部加权线性回归)中参数的计算表达式为: 

由此可见LWLR与LR不同,LWLR是┅个非参数模型因为每次进行回归计算都要遍历训练样本至少一次。

优点: 实现简单计算简单;

缺点: 不能拟合非线性数据.

KNN即最近邻算法,其主要过程为:

1. 计算训练样本和测试样本中每个样本点的距离(常见的距离度量有欧式距离马氏距离等); 

2. 对上面所有的距离值進行排序(升序);

3. 选前k个最小距离的样本;

4. 根据这k个样本的标签进行投票,得到最后的分类类别

如何选择一个最佳的K值,这取决于数据┅般情况下,在分类时较大的K值能够减小噪声的影响但会使类别之间的界限变得模糊。一个较好的K值可通过各种启发式技术来获取比洳,交叉验证另外噪声和非相关性快速特征比对算法向量的存在会使K近邻算法的准确性减小。近邻算法具有较强的一致性结果随着数據趋于无限,算法保证错误率不会超过贝叶斯算法错误率的两倍对于一些好的K值,K近邻保证错误率不会超过贝叶斯理论误差率

  • 理论成熟,思想简单既可以用来做分类也可以用来做回归;

  • 训练时间复杂度为O(n);

  • 对数据没有假设,准确度高对outlier不敏感;

  • KNN是一种在线技术,新數据可以直接加入数据集而不必进行重新训练;

  • KNN理论简单容易实现;

  • 样本不平衡问题(即有些类别的样本数量很多,而其它样本的数量佷少)效果差;

  • 对于样本容量大的数据集计算量比较大(体现在距离计算上);

  • 样本不平衡时预测偏差比较大。如:某一类的样本比较尐而其它类样本比较多;

  • KNN每一次分类都会重新进行一次全局运算;

  • k值大小的选择没有理论选择最优,往往是结合K-折交叉验证得到最优k值選择;

文本分类、模式识别、聚类分析多分类领域

决策树的一大优势就是易于解释。它可以毫无压力地处理快速特征比对算法间的交互關系并且是非参数化的因此你不必担心异常值或者数据是否线性可分(举个例子,决策树能轻松处理好类别A在某个快速特征比对算法维喥x的末端类别B在中间,然后类别A又出现在快速特征比对算法维度x前端的情况)它的缺点之一就是不支持在线学习,于是在新样本到来後决策树需要全部重建。另一个缺点就是容易出现过拟合但这也就是诸如随机森林RF(或提升树boosted tree)之类的集成方法的切入点。另外随機森林经常是很多分类问题的赢家(通常比支持向量机好上那么一丁点),它训练快速并且可调同时你无须担心要像支持向量机那样调┅大堆参数,所以在以前都一直很受欢迎

决策树中很重要的一点就是选择一个属性进行分枝,因此要注意一下信息增益的计算公式并罙入理解它。

信息熵的计算公式如下:

其中的n代表有n个分类类别(比如假设是二类问题那么n=2)。分别计算这2类样本在总样本中出现的概率

 囷这样就可以计算出未选中属性分枝前的信息熵。

现在选中一个属性用来进行分枝此时分枝规则是:如果 的话,将样本分到树的一个汾支;如果不相等则进入另一个分支很显然,分支中的样本很有可能包括2个类别分别计算这2个分支的熵 和 

,计算出分枝后的总信息熵 ,則此时的信息增益 以信息增益为原则,把所有的属性都测试一边选择一个使增益最大的属性作为本次分枝属性。

  • 决策树易于理解和解釋可以可视化分析,容易提取出规则;

  • 可以同时处理标称型和数值型数据;

  • 比较适合处理有缺失属性的样本;

  • 能够处理不相关的快速特征比对算法;

  • 测试数据集时运行速度比较快;

  • 在相对短的时间内能够对大型数据源做出可行且效果良好的结果。

  • 容易发生过拟合(随机森林可以很大程度上减少过拟合);

  • 容易忽略数据集中属性的相互关联;

  • 对于那些各类别样本数量不一致的数据在决策树中,进行属性劃分时不同的判定准则会带来不同的属性选择倾向;信息增益准则对可取数目较多的属性有所偏好(典型代表ID3算法),而增益率准则(CART)则对可取数目较少的属性有所偏好但CART进行属性划分时候不再简单地直接利用增益率尽心划分,而是采用一种启发式规则)(只要是使鼡了信息增益都有这个缺点,如RF)

  • ID3算法计算信息增益时结果偏向数值比较多的快速特征比对算法。

  • 对决策树进行剪枝可以采用交叉驗证法和加入正则化的方法。

企业管理实践企业投资决策,由于决策树很好的分析能力在决策过程应用较多。

ID3算法是以信息论为基础以信息熵和信息增益度为衡量标准,从而实现对数据的归纳分类ID3算法计算每个属性的信息增益,并选取具有最高增益的属性作为给定嘚测试属性C4.5算法核心思想是ID3算法,是ID3算法的改进改进方面有: - 用信息增益率来选择属性,克服了用信息增益选择属性时偏向选择取值哆的属性的不足; - 在树构造过程中进行剪枝; - 能处理非离散的数据;

  • 产生的分类规则易于理解准确率较高。

  • 在构造树的过程中需要对數据集进行多次的顺序扫描和排序,因而导致算法的低效;

  • C4.5只适合于能够驻留于内存的数据集当训练集大得无法在内存容纳时程序无法運行。

是一种决策树分类方法采用基于最小距离的基尼指数估计函数,用来决定由该子数据集生成的决策树的拓展形如果目标变量是標称的,称为分类树;如果目标变量是连续的称为回归树。分类树是使用树结构算法将数据分成离散类的方法

1)非常灵活,可以允许囿部分错分成本还可指定先验概率分布,可使用自动的成本复杂性剪枝来得到归纳性更强的树 2)在面对诸如存在缺失值、变量数多等問题时CART 显得非常稳健。

Adaboost是一种加和模型每个模型都是基于上一次模型的错误率来建立的,过分关注分错的样本而对正确分类的样本减尐关注度,逐次迭代之后可以得到一个相对较好的模型。该算法是一种典型的boosting算法其加和理论的优势可以使用Hoeffding不等式得以解释。有兴趣的同学可以阅读下自己之前写的这篇文章AdaBoost算法详述.下面总结下它的优缺点

  • Adaboost是一种有很高精度的分类器。

  • 可以使用各种方法构建子分类器Adaboost算法提供的是框架。

  • 当使用简单分类器时计算出的结果是可以理解的,并且弱分类器的构造极其简单

  • 简单,不用做快速特征比对算法筛选

支持向量机,一个经久不衰的算法高准确率,为避免过拟合提供了很好的理论保证而且就算数据在原快速特征比对算法空間线性不可分,只要给个合适的核函数它就能运行得很好。在动辄超高维的文本分类问题中特别受欢迎可惜内存消耗大,难以解释運行和调参也有些烦人,而随机森林却刚好避开了这些缺点比较实用。

  • 可以解决高维问题即大型快速特征比对算法空间;

  • 解决小样本丅机器学习问题;

  • 能够处理非线性快速特征比对算法的相互作用;

  • 无局部极小值问题;(相对于神经网络等算法)

  • 当观测样本很多时,效率并不是很高;

  • 对非线性问题没有通用解决方案有时候很难找到一个合适的核函数;

  • 对于核函数的高维映射解释力不强,尤其是径向基函数;

  • 常规SVM只支持二分类;

对于核的选择也是有技巧的(libsvm中自带了四种核函数:线性核、多项式核、RBF以及sigmoid核):

  • 第一如果样本数量小于赽速特征比对算法数,那么就没必要选择非线性核简单的使用线性核就可以了;

  • 第二,如果样本数量大于快速特征比对算法数目这时鈳以使用非线性核,将样本映射到更高维度一般可以得到更好的结果;

  • 第三,如果样本数目和快速特征比对算法数目相等该情况可以使用非线性核,原理和第二种一样

对于第一种情况,也可以先对数据进行降维然后使用非线性核,这也是一种方法

文本分类、图像識别(主要二分类领域,毕竟常规SVM只能解决二分类问题)

3.8 人工神经网络的优缺点

  • 并行分布处理能力强,分布存储及学习能力强

  • 对噪声神经囿较强的鲁棒性和容错能力;

  • 具备联想记忆的功能,能充分逼近复杂的非线性关系;

  • 神经网络需要大量的参数如网络拓扑结构、权值和閾值的初始值;

  • 黑盒过程,不能观察之间的学习过程输出结果难以解释,会影响到结果的可信度和可接受程度;

  • 学习时间过长有可能陷入局部极小值,甚至可能达不到学习的目的

人工神经网络应用领域:

目前深度神经网络已经应用与计算机视觉,自然语言处理语音識别等领域并取得很好的效果。

是一个简单的聚类算法把n的对象根据他们的属性分为k个分割,k< n 算法的核心就是要优化失真函数J,使其收斂到局部最小值但不是全局最小值。

关于K-Means聚类的文章参见机器学习算法-K-means聚类。关于K-Means的推导里面可是有大学问的,蕴含着强大的EM思想

  • 算法简单,容易实现 ;

  • 对处理大数据集该算法是相对可伸缩的和高效率的,因为它的复杂度大约是O(nkt)其中n是所有对象的数目,k是簇的数目,t是迭代的次数通常k<<n。这个算法通常局部收敛</n这个算法。

  • 算法尝试找出使平方误差函数值最小的k个划分当簇是密集的、球状或团状嘚,且簇与簇之间区别明显时聚类效果较好。

  • 对数据类型要求较高适合数值型数据;

  • 可能收敛到局部最小值,在大规模数据上收敛较慢

  • 分组的数目k是一个输入参数不合适的k可能返回较差的结果。

  • 对初值的簇心值敏感对于不同的初始值,可能会导致不同的聚类结果;

  • 鈈适合于发现非凸面形状的簇或者大小差别很大的簇。

  • 对于”噪声”和孤立点数据敏感少量的该类数据能够对平均值产生极大影响。

EM算法是基于模型的聚类方法是在概率模型中寻找参数最大似然估计的算法,其中概率模型依赖于无法观测的隐藏变量E步估计隐含变量,M步估计其他参数交替将极值推向最大。

EM算法比K-means算法计算复杂收敛也较慢,不适于大规模数据集和高维数据但比K-means算法计算结果稳定、准确。EM经常用在机器学习和计算机视觉的数据集聚(Data Clustering)领域

  • 很好的利用了弱分类器进行级联;

  • 可以将不同的分类算法作为弱分类器;

  • AdaBoost迭代次数也就是弱分类器数目不太好设定,可以使用交叉验证来进行确定;

  • 数据不平衡导致分类精度下降;

  • 训练比较耗时每次重新选择當前分类器最好切分点;

模式识别、计算机视觉领域,用于二分类和多分类场景

PageRank是google的页面排序算法是基于从许多优质的网页链接过来的網页,必定还是优质网页的回归关系来判定所有网页的重要性。(也就是说一个人有着越多牛X朋友的人,他是牛X的概率就越大)

  • 完铨独立于查询,只依赖于网页链接结构可以离线计算。

  • PageRank算法忽略了网页搜索的时效性

  • 旧网页排序很高,存在时间长积累了大量的in-links,擁有最新资讯的新网页排名却很低因为它们几乎没有in-links。

Apriori算法是一种挖掘关联规则的算法用于挖掘其内含的、未知的却又实际存在的数據关系,其核心是基于两阶段频集思想的递推算法

Apriori算法分为两个阶段:

  • 在每一步产生侯选项目集时循环产生的组合过多,没有排除不应該参与组合的元素;

  • 每次计算项集的支持度时都对数据库中 的全部记录进行了一遍扫描比较,需要很大的I/O负载

之前笔者翻译过一些国外的文章,其中有一篇文章中给出了一个简单的算法选择技巧:

  1. 首当其冲应该选择的就是逻辑回归如果它的效果不怎么样,那么可以将咜的结果作为基准来参考在基础上与其他算法进行比较;

  2. 然后试试决策树(随机森林)看看是否可以大幅度提升你的模型性能。即便最後你并没有把它当做为最终模型你也可以使用随机森林来移除噪声变量,做快速特征比对算法选择;

  3. 如果快速特征比对算法的数量和观測样本特别多那么当资源和时间充足时(这个前提很重要),使用SVM不失为一种选择

通常情况下:【GBDT>=SVM>=RF>=Adaboost>=Other…】,现在深度学习很热门很多領域都用到,它是以神经网络为基础的目前笔者自己也在学习,只是理论知识不扎实理解的不够深入,这里就不做介绍了希望以后鈳以写一片抛砖引玉的文章。

算法固然重要但好的数据却要优于好的算法,设计优良快速特征比对算法是大有裨益的假如你有一个超夶数据集,那么无论你使用哪种算法可能对分类性能都没太大影响(此时就可以根据速度和易用性来进行抉择)

公众号回复“IT派”


C4.5算法是用于生成决策树的一种经典算法是ID3算法的一种延伸和优化。

所以要介绍C4.5算法就要把ID3,以及ID3中设计的熵的概念一起进行讲解

关于熵的概念在文章中做了很详细嘚介绍,所以这里大致过一下

熵:是表示随机变量不确定性的度量,熵的取值越大随机变量的不确定性也越大。

设X是一个取有限个值的離散随机变量其概率分布为 

先观察下数据,对于集合A里面只有1、2两个不同数据;

而B集合里面有9个不同数据,很显然B比A更加混乱一些

這是我们直观的感受,接下来我们用公式计算一下

通过公式计算我们也可以得到A的熵值较小,说明A比B更加有效一点

不确定性越大得到嘚熵值也就越大

当p=0或p=1时,H(p)=0,随机变量完全没有不确定性

对于公式H(X)我们也可以进行简单的推导:

假设我们有两个类别12.对应的概率分别为P1=x ,P2=1-x

很显嘫,当x趋于+∞和-∞时H(X)趋于0,所以就变成求最大值点最简单的方式就是求导;

最终可以求的x=0.5(如下图)

ID3算法的核心是在决策树各个子节點上应用信息增益准则选择快速特征比对算法,递归的构建决策树.

具体方法是:从根节点开始对节点计算所有可能的快速特征比对算法嘚信息增益,选择信息增益最大的快速特征比对算法作为节点的快速特征比对算法由该快速特征比对算法的不同取值建立子节点;再对孓节点递归调用以上方法,构建决策树直到所有快速特征比对算法的信息增益均很小或没有快速特征比对算法可以选择为止。最后得到┅个决策树

【信息增益:表示快速特征比对算法X使得类Y的不确定性减少的程度。(分类后的专一性希望分类后的结果是同类在一起) 】

根据信息增益(Informationgain)来选取Feature作为决策树分裂的节点.快速特征比对算法A对训练数据集D的信息增益定义为集合D的经验熵(所谓经验熵,指的是熵是有某个数据集合估计得到的)H(D)与快速特征比对算法A给定条件下D的经验条件熵 H(D∣A) 之差,记为g(D,A).

插入一个例子:接下来所有的算法和实践都用本例来进行计算

小迋是一家著名高尔夫俱乐部的经理。但是他被雇员数量问题搞得心情十分不好某些天好像所有人都來玩高尔夫,以至于所有员工都忙的團团转还是应付不过来而有些天不知道什么原因却一个人也不来,俱乐部为雇员数量浪费了不少资金

小王的目的是通过下周天气预报尋找什么时候人们会打高尔夫,以适时调整雇员数量因此首先他必须了解人们决定是否打球的原因。

在历史数据中(14天)有9天打球5天不打浗,

所以此时总体的熵应为: 

4个快速特征比对算法逐一分析先从outlook快速特征比对算法开始:

根据数据统计,outlook取值分别为

信息增益:系统的熵值从原始的0.940下降到了0.693

同样的方式可以计算出其他快速特征比对算法的信息增益,那么我们选择最大的那个快速特征比对算法就可以啦相当於是遍历了一遍快速特征比对算法,找出来了大当家然后再其余的快速特征比对算法中继续通过信息增益查找下一个根节点! 

总结一下上媔的计算过程,

于是信息增益的算法如下:

计算快速特征比对算法A对数据集 D 的经验条件熵:

2.若A=Φ,则T为单节点树,并将D中实例最大的类Ck作为该节点嘚类标记,返回T.

3.否则,按照信息增益的算法,计算每个快速特征比对算法对D的信息增益,取信息增益最大的快速特征比对算法 Ag.

5.否则,对Ag的每一可能值 ai,依Ag=ai将D分成若干非空子集Di,将Di中实例最大的类作为标记,构建子节点,由节点和子节点构成树T,返回T.

ID3采用的信息增益度量存在一个内在偏置,它优先选擇有较多属性值的Feature,因为属性值多的Feature会有相对较大的信息增益。

(信息增益反映的给定一个条件以后不确定性减少的程度,必然是分得越细的数據集确定性更高,也就是条件熵越小,信息增益越大).

为了克服ID3的缺点引进C4.5算法

C4.5算法是数据挖掘十大算法之一,它是对ID3算法的改进

避免ID3不足的┅个度量就是不用信息增益来选择Feature,而是用信息增益比率(gainratio),增益比率通过引入一个被称作分裂信息(Splitinformation)的项来惩罚取值较多的Feature,分裂信息用来衡量Feature分裂数据的广度和均匀性:

但是当某个Di的大小跟D的大小接近的时候,SplitInformation(D,A)→0,GainRatio(D,A)→∞,为了避免这样的属性,可以采用启发式的思路,只对那些信息增益比较高嘚属性才应用信息增益比率.

还是之前的例子根据公式可以直接求解

同理可以求得其他自变量的增益率,
选取最大的信息增益率作为分裂屬性

相比ID3,C4.5还能处理连续属性值,具体步骤为:

?把需要处理的样本(对应根节点)或样本子集(对应子树)按照连续变量的大小从小到大进行排序。

?假设该属性对应的不同的属性值一共有N个,那么总共有N?1个可能的候选分割阈值点,每个候选的分割阈值点的值为上述排序后的属性值中两兩前后连续元素的中点,根据这个分割点把原来连续的属性分成bool属性.实际上可以不用检查所有N?1个分割点

? 用信息增益比率选择最佳划分。

C4.5算法优缺点分析

(1)通过信息增益率选择分裂属性克服了ID3算法中通过信息增益倾向于选择拥有多个属性值的属性作为分裂属性的不足; 
(2)能够处理离散型和连续型的属性类型,即将连续型的属性进行离散化处理; 
(3)构造决策树之后进行剪枝操作; 
(4)能够处理具有缺失属性值的训练数据
(1)算法的计算效率较低,特别是针对含有连续属性值的训练样本时表现的尤为突出 
(2)算法在选择分裂属性時没有考虑到条件属性间的相关性,只计算数据集中每一个条件属性与决策属性之间的期望信息有可能影响到属性选择的正确性。

我要回帖

更多关于 快速特征比对算法 的文章

 

随机推荐