opencv进阶18-基于opencv 决策树导论

1. 什么是决策树?

决策树是最早的机器学习算法之一,起源于对人类某些决策过程 的模仿,属于监督学习算法

决策树的优点是易于理解,有些决策树既可以做分类,也可以做回归。在排名前十的数据挖掘算法中有两种是决策树[1]。决策树有许多不同版本,典型版本是最早出现的ID3算法,以及对其改进后形成的C4.5算法,这两种算法可用于分类。对ID3算法改进的另一个分支为“分类和回归树”(Classification AndRegression Trees,CART)算法,可用于分类或回归。CART算法为随机森林和Boosting等重要算法提供了基础。在OpenCV中,决策树实现的是CART算法

2.决策树原理

2.1 决策树的基本思想

最早的决策树是利用if-then结构来分割数据的,其中,if表示条
件,then就是选择或决策。

2.2 决策树的表示方法

在决策树中,通常将样本向量中的特征称为样本的属性,下文将
使用“属性”这一习惯性称呼。

决策树通过把样本从根节点排列到某个叶子节点对样本进行分类。 根节点是树第一次切分的位置,叶子节点即为样本所属的分类标签。
树上的每一个节点都表示了对样本的某个属性的测试,并且该节点的每一个后继分支对应于该属性的一个可能值。分类样本的方法是从这棵树的根节点开始,测试这个节点指定的属性,然后按照给定样本的该属性值对应的树枝向下移动。这一过程在以新节点为根的子树上重复。

下面用顾客在271餐厅就餐时的等台意愿示例说明决策树[1]。表5-
1为数据集样本的属性列表,表5-2为数据集,在数据集中共12个样
本,每个样本有10个属性,样本的标签为是否愿意等台,因此这是一个二分类问题。从已有的数据集推断出的决策树的结构如图5-1所示。

在这里插入图片描述
表5-2 餐厅等台意愿数据集

在这里插入图片描述

在这里插入图片描述
如图5-1所示,方框中带有问号的为根节点(按给定的属性切分数
据),其余为叶子节点(标签)。

开始时决策树根据餐厅用餐人数多少(Patrons属性)将数据集切分为3个子集,左子集为无人用餐,中间子集为有一些人用餐,右子集为客满。其他子树的根节点原理与之类似。

当有新的未知数据出现时,即可根据特征简单地遍历树并到达确定标签,即是否愿意等台。尽管例子很简单,但它清楚地体现了决策树模型的可解释性,以及学习简单规则的能力。

从示例可知,决策树的核心问题是:自顶向下的各个节点应选择
何种属性进行切分,才能获得最好的分类器?因此,选择最佳切分属性是决策树的关键所在。

2.3 最佳切分属性的选择

评 价 最 佳 切 分 属 性 通 常 是 基 于 样 本 不 纯 度 减 少 (ImpurityReduction)或者纯度增益(Purity Gain)这一思想的。样本纯度指的是集合中样本类型的同质性(Homogeneity),如果数据集中只有一种类型的样本,则该数据集的样本纯度最高,不纯度最低。数据集中样本类型越多,则样本纯度越低,不纯度越高。显然,我们希望样本集按某属性切分后,其样本纯度提高,不纯度降低,即切分后样本集的纯度增益越大越好。

为 了 计 算 纯 度 增 益 , 需 要 定 义 不 纯 度 测 度 ( Impurity
Measure),即计算不纯度的方法;然后用节点切分前的不纯度减去切分后的不纯度,得到不纯度减少(即纯度增益)的指标;最后选择使不纯度减少最多的属性进行切分。

不同种类的决策树采用不同的方式测量样本的不纯度,例如信息熵、基尼系数、圴方误差等。下面介绍几种常用的计算不纯度和选择最优切分属性的方法。

1. 信息熵
ID3算法使用信息增益(Information Gain)选择最佳属性构建决策树,即使用能获得最大信息增益的属性作为划分当前数据集的最佳属性。想要了解信息增益的计算方法,首先需要了解其概念。

信息熵(Information Entropy)是美国信息学家香农于1948年提
出的。信息是对不确定性的消除,而不确定性可以用概率来度量。某事件出现的概率越高,其不确定性就越低,反之,不确定性就越高。信息熵是消除不确定性所需信息量的度量,即未知事件可能含有的信息量。事件出现的概率越低,不确定性越大,则信息量越大,熵越大;概率越高,不确定性越小,则信息量越小,熵越小

下面从信息论的角度介绍信息熵与信息增益[1]。定义不确定性函
数I表示事件的信息量,它与事件发生的概率p应满足以下条件:

◎ I§≥0, I(1)=0,即任何事件的信息量都是非负的,概率为1
的事件的信息量为0。

◎I(p1∙p2)=I(p1)+I(p2),即两个独立事件所产生的信息量应等于
各自信息量之和。

◎ I§连续,且为概率p的单调递减函数,概率的微小变化对应
于信息量的微小变化。

人们发现,对数函数同时满足上述条件,因此,可使用式(5-1)
表示事件的信息量:

在这里插入图片描述

式中,若取a=2,就是常说的信息单位bit(比特)。例如,抛一枚正常硬币出现正面的事件给出的信息量为−log2(0.5)=1bit。如果对于一枚铸造时有偏差的硬币,且出现正面的概率为0.99,则抛此硬币出现正面的事件给出的信息量为

−log2(0.99)=0.0145bit。

如果有多个事件,那么这些事件的平均信息量应如何计算呢?

假设事件v1, …, vJ发生的概率为p1, …, pJ,其中,[p1, …, pJ]为离
散概率分布。则多个事件的平均信息量用式(5-2)定义:

在这里插入图片描述
式中,H§为离散分布p的信息熵,p=[p1, …, pJ]。在有关熵的所有
计算中,定义0lg0=0。如果事件仅有两种类型(布尔型),则概率为
p=[p1, 1−p1]。

在这里插入图片描述

假设D是一个有14个样本的布尔型集合,包括9个正样本,5个负样
本。根据式(5-2)计算D的信息熵如下:

在这里插入图片描述
如果D的所有成员都属于同一类,即H(D)=H([1, 0]),则D的信息
熵H(D)→0。如果D中正负样本的出现概率均为0.5,则H(D)=H([0.5,
0.5])=1。由此可见,在布尔型集合中,当正负样本的出现概率相等时信息熵最大。

信息熵是事物不确定性的度量标准,在决策树中,它不仅能用来
度量类别的不确定性,还可以用来度量包含不同特征的数据样本的不确定性。某个特征列向量的信息熵越大,说明该特征的不确定性越大,即混乱程度越大,因而应优先考虑从该特征着手进行切分。信息熵为决策树的切分提供了最重要的依据和标准。

  1. 信息增益

属性A对训练数据集D的信息增益为G(D, A),即集合D的信息熵
H(D)与属性A给定的条件下D的条件熵H(D|A)之差:

5-3
式中,n表示针对属性A,样本集合被切分为n个子集(即属性A的n种取值);|Di|表示按属性A切分后的第i个子集的样本数量,|D|表示样本集合D的样本数量。

H(D)度量了D的不确定性,条件熵H(D|A)度量了在知道属性A以后D
剩下的不确定性,由此可知,H(D)−H(D|A)就度量了D在知道属性A以后不确定性的减少程度。这个度量在信息论中称为互信息,在决策树ID3算法中称为信息增益。

回到前文介绍的餐厅示例,原始数据集D包含[x1, …, x12]共12个
样本,每个样本的特征向量有10个属性,标签为是否会等台,其中,
[x1, x3, x4, x6, x8, x12]6人决定等台,[x2x5, x7, x9, x110, x11]6人
决定不等台。如图5-2(a)所示,按Patrons属性可以切分为None、Some和Full共3个子集,即n=3(Patrons属性的3种取值)。按Patrons属性切分的信息增益如下:

在这里插入图片描述
如图5-2(b)所示,按Type属性可以分为French、Italian、Thai
和Burger共4个子集,即n=4(Type属性的4种取值)。按Type属性切分的信息增益如下:

在这里插入图片描述

在这里插入图片描述

显然G(D, Patrons) > G(D, Type)。事实上,按Patrons属性切分
的信息增益是最高的。因此,选择Patrons属性作为根节点的属性开始切分。

  1. 信息增益率

ID3算法采用信息增益的方式存在诸多问题。例如,在相同条件下,取值较多的属性(n较大)比取值较少的属性的信息增益要大,即信息增益作为标准容易偏向于取值较多的特征。比如,一个属性有2个取值,概率各为1/2;另一个属性有3个取值,概率各为1/3。其实它们都是完全不确定的变量,但是取3个值的比取2个值的信息增益要大

C4.5算法对此进行了改进,它使用信息增益率(Information
Gain Ratio)作为切分准则。信息增益率是信息增益与特征熵的比
值:

在这里插入图片描述

式中,D为样本集合,A为样本属性,属性A的特征熵HA(D)的表达式如下:

在这里插入图片描述
根据上式,示例中Patrons属性的特征熵为:

在这里插入图片描述

也就是说,当通过信息增益率选择最优切分属性时,Patrons属性
和Type属性相比,应选择Patrons属性。

  1. 基尼系数

无论ID3算法还是C4.5算法,都是基于信息熵模型的,涉及大量对
数运算。为了简化运算,同时保留信息熵模型的优点,CART算法提出了使用基尼系数来代替信息增益率。基尼系数(Gini Index)代表了模型的不纯度,基尼系数越小,模型的不纯度越低,对应的属性越好

具体而言,在分类问题中,假设样本共有J个类别,第j类的概率
为pj,则基尼系数的表达式为:
在这里插入图片描述

式中,|Dj|为第j类样本的数量,|D|为样本集D的样本数量。

如果是二分类问题,若样本属于第一类的概率是p,则基尼系数的
表达式为:

在这里插入图片描述
如果根据属性A把D分成n个部分,则在属性A的条件下,D的基尼系
数的表达式为:

在这里插入图片描述
基尼系数最小的那个属性进行切分。

二分类节点不纯度与某一类样本出现概率p的关系曲线如图5-3所示,为了便于比较,将信息熵缩小了两倍,使其与基尼系数曲线都通过(0.5, 0.5)点。

在这里插入图片描述

从图5-3可以看出,基尼系数和信息熵的曲线非常接近。因此,
尼系数可以作为熵模型的一个近似替代
。而CART算法就是使用基尼系数来选择决策树的特征的。同时,为了进一步简化,CART算法每次仅仅对某个特征的值进行二分,这样CART算法建立起来的就是二叉树,进一步简化了计算。

  1. 均方误差

前文介绍的都是分类树的计算方法,输出的是离散的类别,例如
在餐厅等台或者不等台等。而回归树输出的是连续的数值,如预测房价等。为了实现回归树,需要使用适合回归的不纯度测度。均方误差(Mean Squared Error,MSE)主要用于回归树,为观测值与预测值之差的平方。

在这里插入图片描述
式中,|D|是数据集D的样本数量,yi和 分别为第i个样本的输出值和
预测值。可以用输出值yi的平均值来代替预测值:

在这里插入图片描述
如果根据属性A将集合D切分为n个子集,则切分后的均方误差为:

在这里插入图片描述
CART回归模型使用了均方误差的度量方式,其目标是对于任意切
分属性A对应的任意节点S两边划分成的数据集D1和D2,求出使数据集D1和D2各自的均方差最小,同时,D1和D2的均方差之和最小所对应的属性,表达式为:

在这里插入图片描述
其中,c1为D1数据集的样本输出均值,c2为D2数据集的样本输出均值。

CART分类树采用叶子节点中概率最大的类别作为当前节点的预测
类别。回归树输出的不是类别,它采用的是用最终叶子的均值或者中位数来预测输出结果。

停止标准

如前文所述,决策树遵循贪婪的递归分裂节点,它们是如何停止
又是何时停止的呢?

实际上,可以应用许多策略来定义停止标准(Stopping Criteria)。最常见的是数据点的最小数量,如果进一步切分会违反此约束,则停止切分。
另一个停止标准是树的深度。停止标准与其他参数一起可以帮助我们实现具有较好泛化能力的决策树模型。非常深或具有太多非叶子节点的决策树通常会导致过拟合。

剪枝

由于决策树的建立完全依赖训练样本,因此算法很容易对训练集
过拟合,导致泛化能力变差。为了解决过拟合问题,需要对决策树进行剪枝(Pruning),即去掉一些节点,包括叶子节点和中间节点,以简化决策树。剪枝类似于线性回归的正则化,可以增加决策树的泛化能力

剪枝的常用方法有预剪枝和后剪枝两种。

预剪枝是在构建决策树过程中,提前终止决策树的生长,从而避免产生过多节点。该方法简单,但实用性不强,因为很难准确判断应何时终止生长。

后剪枝是在决策树构建完成后再去掉一些节点。常见的后剪枝方法有悲观错误剪枝、最小错误剪枝、代价复杂度剪枝和基于错误的剪枝四种。OpenCV中的CART算法采用的是代价复杂度剪枝,即先生成决策树,然后生成所有可能的剪枝后的CART树,最后使用交叉验证来检验各种剪枝的效果,选择泛化能力最好的剪枝策略。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/1550014.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

linux优化ssd磁盘,Ubuntu下针对ssd硬盘优化

本人的Ubuntu 12.10是安装在三星64g的ssd上,所以有必要对此进行优化,发挥ssd的最佳性能,至于ssd的4k对齐,在ubuntu 11.10以上的版本不用担心,因为在格式化时就已经对齐了,建议手动分区,首先分一…

工业控制计算机固态硬盘,工业控制电脑ssd固态硬盘怎么正确使用?

工业控制电脑ssd固态硬盘怎么正确使用? 日期:2020年11月18日 上午11:08 浏览:169 次 工业控制电脑ssd固态硬盘怎么正确使用? 固态硬盘(solid state Drives) ,也被称为“SSD”和“固盘”,普通的硬盘和固态硬…

网吧服务器固态硬盘使用,无盘服务器初次使用SSD固态硬盘应注意使用备用盘

如果你是初次使用SSD硬盘,在安装网吧无盘服务器上的时候,请先把一块硬盘划分一块干净的分区以备出现突发情况下使用,如果你SSD划分了好几个区,做为了多个用途,那么最好你要备用一块硬盘,划分分区跟SSD硬盘一…

SSD固态硬盘优化(转)

转自“http://www.ipc.me/ying-pan-you-hua-ji-qiao.html” SSD优化(固态硬盘优化)是如何优化的呢?相信许多人都对此一概不知,以下分享的是关于固态硬盘优化技巧,希望对正在使用SSD硬盘的童鞋有所帮助…… 众所周知&am…

三星固态速度测试软件,三星SSD固态硬盘优化工具Samsung Magician使用说明

前言:之前一直只有INTEL的固态硬盘有专用优化工具TOOLBOX,其实三星在今年也推出了类似的工具,名字叫Samsung Magician,并且现在咱们顺网的服务器使用的都是三星的SSD,所以现在来咨询这个固态硬盘应该如何优化的用户也越来越多,今天就教大家一下如何使用这个工具!若有遗漏,不足或…

SSD固态硬盘优化设置图文教程

一、开启AHCI优化SSD的第一步首先就是要确保你的磁盘读写模式为AHCI,一般来讲如果你的电脑是windows7系统,只需要在安装系统前进入BIOS设置下磁盘读写模式为“AHCI”即可,如果您已经安装过windows7,并且不确定是否磁盘工作在AHCI模…

什么是网闸+网闸和防火墙的区别

网闸的原理 网闸是用于隔离网络、阻断对内网具有潜在攻击可能的一切网络连接,它会重新封装数据,确保这个数据是安全的,这个时候,在放它进入内网。使外部攻击者无法直接入侵、攻击或破坏内网,保障了内部主机的安全。&am…

将AI融入CG特效工作流;对谈Dify创始人张路宇;关于Llama 2的一切资源;普林斯顿LLM高阶课程;LLM当前的10大挑战 | ShowMeAI日报

👀日报&周刊合集 | 🎡生产力工具与行业应用大全 | 🧡 点赞关注评论拜托啦! 🤖 将AI融入CG特效工作流,体验极致的效率提升 BV1pP411r7HY 这是 B站UP主 特效小哥studio 和 拓星研究所 联合投稿的一个AI特…

disabled and validated 不能DML

Inserting Rows Not Allowed in Table with DISABLED and VALIDATED Constraint (Doc ID 139337.1)​编辑To Bottom Problem Description: You create a table with a referential integrity constraint (a foreign key constraint) referencing a view constraint.SQL> C…

为什么计算机关机慢,现在告诉你,为什么电脑关机速度慢或关不了机

原标题:现在告诉你,为什么电脑关机速度慢或关不了机 电脑关机越来越慢,这个问题是不是让你感到十分头疼?接下来,小编给你支几招。 电脑在关机前,一定要关闭所有打开的程序。如果后台打开的程序过多&#xf…

计算机关机速度,关机速度慢

许多网民用了一段时间电脑后发现电脑关机速度慢了许多,但是不知道怎么优化电脑,让速度提高。下面本文为您盘点关机速度慢原因有哪些,并且告诉您加快关机速度的方法。 关机速度慢的原因是什么? 1.电脑存在木马病毒或者恶意插件&…

计算机关机慢怎么解决方法,电脑关机很慢,详细教您win7电脑关机很慢的解决方法...

电脑的问题千千万万,但是我们人类的智慧却也是永无止尽的。所以这几天网上帖子最多讨论的就是“电脑关机很慢”,每个人都在说自己的win7系统的电脑关机巨慢。所以为了解决网上小伙伴们遇到的问题,小编我今天就来给你们讲讲win7电脑关机很慢的…

学优计算机怎么关机,Windows7电脑关机速度慢的解决办法

最近一位Windows7用户反馈,电脑的关机速度越来越慢了,于是就问小编有没办法解决这个问题。其实电脑关机速度慢和开机速度慢一个道理,基本都是由于磁盘、电源等问题造成的。下面小编就给大家讲解Windows7系统关机速度慢的解决办法。 注&#x…

笔记本Windows10 关机突然变慢解决记录

平时笔记本点击关机后很快屏幕关闭,然后2--3秒后鼠标灯也灭了;但是昨天关机时,突然发现屏幕还是很快关闭,鼠标灯却亮了好几分钟才熄灭,于是在网上找了很多帖子,都没有解决问题,找笔记本售后在线…

为什么计算机关机慢,为什么电脑关机速度很慢_加快电脑关机速度的具体办法...

我们的电脑使用久后,就会出现各种各样的问题,如关机慢、卡顿等情况。那具体是因为什么原因造成的电脑关机速度慢呢?我们又该怎么来解决这一情况呢?今天系统城小编就来为大家分享关于加快电脑关机速度的具体办法,一起往下看吧。 具体办法如下: 方法一:清理垃圾 1、 关机慢可…

计算机关机慢什么原因,电脑关机速度很慢?什么原因?怎么解决?

自从微软的xp系统推出了舞台后,目前最低级的电脑系统就是win7系统,大部分人的电脑系统也是win7。电脑在win7系统使用下也会遇到许多的难题,其中的一种就是关机速度,有些人发现自己的电脑关机速度越来越慢了,过去十几秒…

计算机重启很慢,教您win7电脑关机很慢的解决方法

电脑在我们生活中出现的次数堪比我们每天吃的一日三餐,每天都离不开要使用它的时候。那么,今天小编就来跟你们说一个问题,那就是当遇到电脑关机速度很慢的时候,我们要怎么解决。今天小编我就告诉你win7电脑开机很慢的解决办法。 电…

Linux下关机速度慢

1、问题描述 最近装了deepwineqq 和wchat,但是莫名其妙的关机速度变得很慢,最后在网上找了资料以后解决办法如下 2、解决方案 2.1 打开system.conf文件 sudo vim /etc/systemd/system.conf 注:如果你没有安装vim的话使用vi也都是一样的&…

电脑关机很慢是怎么回事

可能很多朋友在给电脑关机时,都会遇到电脑关机速度慢的情况,其实很多时候都是因为有程序在运行的结果,我们只要关闭一些任务进程就可以改善这个问题。 更多win11教程尽在小白系统重装官网 系统:win10系统 电脑:联想I…

计算机关机慢怎么解决方法,你知道电脑关机慢怎么解决吗?

加快计算机关机速度 您是否厌倦了等待计算机关闭的烦恼?关闭计算机的速度非常慢,这并非常见问题。但是,只需几个简单的步骤就可以轻松纠正它。实际上,在Windows可以完成其主要关闭操作之前,需要关闭许多程序和进程。 但…