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。由此可见,在布尔型集合中,当正负样本的出现概率相等时信息熵最大。
信息熵是事物不确定性的度量标准,在决策树中,它不仅能用来
度量类别的不确定性,还可以用来度量包含不同特征的数据样本的不确定性。某个特征列向量的信息熵越大,说明该特征的不确定性越大,即混乱程度越大,因而应优先考虑从该特征着手进行切分。信息熵为决策树的切分提供了最重要的依据和标准。
- 信息增益
属性A对训练数据集D的信息增益为G(D, A),即集合D的信息熵
H(D)与属性A给定的条件下D的条件熵H(D|A)之差:
式中,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属性作为根节点的属性开始切分。
- 信息增益率
ID3算法采用信息增益的方式存在诸多问题。例如,在相同条件下,取值较多的属性(n较大)比取值较少的属性的信息增益要大,即信息增益作为标准容易偏向于取值较多的特征。比如,一个属性有2个取值,概率各为1/2;另一个属性有3个取值,概率各为1/3。其实它们都是完全不确定的变量,但是取3个值的比取2个值的信息增益要大。
C4.5算法对此进行了改进,它使用信息增益率(Information
Gain Ratio)作为切分准则。信息增益率是信息增益与特征熵的比
值:
式中,D为样本集合,A为样本属性,属性A的特征熵HA(D)的表达式如下:
根据上式,示例中Patrons属性的特征熵为:
也就是说,当通过信息增益率选择最优切分属性时,Patrons属性
和Type属性相比,应选择Patrons属性。
- 基尼系数
无论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算法建立起来的就是二叉树,进一步简化了计算。
- 均方误差
前文介绍的都是分类树的计算方法,输出的是离散的类别,例如
在餐厅等台或者不等台等。而回归树输出的是连续的数值,如预测房价等。为了实现回归树,需要使用适合回归的不纯度测度。均方误差(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树,最后使用交叉验证来检验各种剪枝的效果,选择泛化能力最好的剪枝策略。
相关文章:

opencv进阶18-基于opencv 决策树导论
1. 什么是决策树? 决策树是最早的机器学习算法之一,起源于对人类某些决策过程 的模仿,属于监督学习算法。 决策树的优点是易于理解,有些决策树既可以做分类,也可以做回归。在排名前十的数据挖掘算法中有两种是决策树[1…...

13.4 目标检测锚框标注 非极大值抑制
锚框的形状计算公式 假设原图的高为H,宽为W 锚框形状详细公式推导 以每个像素为中心生成不同形状的锚框 # s是缩放比,ratio是宽高比 def multibox_prior(data, sizes, ratios):"""生成以每个像素为中心具有不同形状的锚框"""in_he…...

【论文笔记】最近看的时空数据挖掘综述整理8.27
Deep Learning for Spatio-Temporal Data Mining: A Survey 被引用次数:392 [Submitted on 11 Jun 2019 (v1), last revised 24 Jun 2019 (this version, v2)] 主要内容: 该论文是一篇关于深度学习在时空数据挖掘中的应用的综述。论文首先介绍了时空数…...

【大模型】基于 LlaMA2 的高 star 的 GitHub 开源项目汇总
【大模型】基于 LlaMA2 的高 star 的 GitHub 开源项目汇总 Llama2 简介开源项目汇总NO1. FlagAlpha/Llama2-ChineseNO2. hiyouga/LLaMA-Efficient-TuningNO3. yangjianxin1/FireflyNO4. LinkSoul-AI/Chinese-Llama-2-7bNO5. wenge-research/YaYiNO6. michael-wzhu/Chinese-LlaM…...

解决elementUI打包上线后icon图标偶尔乱码的问题
解决vue-elementUI打包后icon图标偶尔乱码的问题 一、背景二、现象三、原因四、处理方法方式1:使用css-unicode-loader方式2:升高 sass版本到1.39.0方式3:替换element-ui的样式文件方式4:更换打包压缩方式知识扩展:方式…...

yolov3加上迁移学习和适度的数据增强形成的网络应用在输电线异物检测
Neural Detection of Foreign Objects for Transmission Lines in Power Systems Abstract. 输电线路为电能从一个地方输送到另一个地方提供了一条路径,确保输电线路的正常运行是向城市和企业供电的先决条件。主要威胁来自外来物,可能导致电力传输中断。…...

香橙派OrangePi zero H2+ 驱动移远EC200A
1 系统内核: Linux orangepizero 5.4.65-sunxi #2.2.2 SMP Tue Aug 15 17:45:28 CST 2023 armv7l armv7l armv7l GNU/Linux 1.1 下载内核头安装 下载:orangepi800 内核头rk3399链接https://download.csdn.net/download/weixin_37613240/87635781 1.1.1…...

写一个java中如何用JSch来连接sftp的类并做测试?(亲测)
当使用JSch连接SFTP服务器的类,并进行测试时,可以按照以下步骤操作: 添加JSch库的依赖项。在你的项目中添加JSch库的Maven依赖项(如前面所述)或下载JAR文件并将其包含在项目中。 <dependency> <groupId&…...

【沐风老师】如何在3dMax中将3D物体转化为样条线构成的对象?
在3dMax中如何把三维物体转化为由样条线构成的对象?通常这样的场景会出现在科研绘图或一些艺术创作当中,下面给大家详细讲解一种3dmax三维物体转样条线的方法。 第一部分:用粒子填充3D对象: 1.创建一个三维对象(本例…...

2023国赛数学建模思路 - 案例:随机森林
文章目录 1 什么是随机森林?2 随机深林构造流程3 随机森林的优缺点3.1 优点3.2 缺点 4 随机深林算法实现 建模资料 ## 0 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 1 什么是随机森林ÿ…...

wxpython:wx.html2 是好用的 WebView 组件
wxpython : wx.html2 是好用的 WebView 组件。 pip install wxpython4.2 wxPython-4.2.0-cp37-cp37m-win_amd64.whl (18.0 MB) Successfully installed wxpython-4.2.0 cd \Python37\Scripts wxdemo.exe 取得 wxPython-demo-4.2.0.tar.gz wxdocs.exe 取得 wxPython-docs-4.…...

《QT+PCL 第五章》点云特征-PFH
QT增加点云特征PFH 代码用法代码 #include <pcl/io/pcd_io.h> #include <pcl/features/normal_3d.h> #include <pcl/features/pfh.h>int main...

【分享】小型园区组网场景
小型园区组网图 在小型园区中,S2700&S3700通常部署在网络的接入层,S5700&S6700通常部署在网络的核心,出口路由器一般选用AR系列路由器。 接入交换机与核心交换机通过Eth-Trunk组网保证可靠性。 每个部门业务划分到一个VLAN中&#…...

LeetCode 1267. 统计参与通信的服务器
【LetMeFly】1267.统计参与通信的服务器 力扣题目链接:https://leetcode.cn/problems/count-servers-that-communicate/ 这里有一幅服务器分布图,服务器的位置标识在 m * n 的整数矩阵网格 grid 中,1 表示单元格上有服务器,0 表…...

169. 多数元素(哈希表)
169. 多数元素 给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。 你可以假设数组是非空的,并且给定的数组总是存在多数元素。 class Solution { public:int majorityElement(vector<int&…...

微服务集成spring cloud sentinel
目录 1. sentinel使用场景 2. sentinel组成 3. sentinel dashboard搭建 4. sentinel客户端详细使用 4.1 引入依赖 4.2 application.properties增加dashboard注册地址 4.3 手动增加限流配置类 4.4 rest接口及service类 4.5 通过dashboard动态配置限流规则 1. sentinel使…...

2023年最新版Windows环境下|Java8(jdk1.8)安装教程
个人主页:平行线也会相交 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 平行线也会相交 原创 收录于专栏【JavaSE_primary】 jdk1.8的下载和使用总共分为3个步骤: jdk1.8的下载、jdk1.8的安装、配置环境变量。 目录 一、jdk1.8下载…...

linux -- jdk 的安装
jdk 的安装 jdk包下载 链接: https://pan.baidu.com/s/1wa1TJGtCPKQqeCGDZWaP6g 密码: 8el6 安装及验证 ## jdk包上传次目录 /usr/local/software cd /usr/local/software tar -zxvf /usr/local/software/jdk-8u212-linux-x64.tar.gz -C /usr/local cd /usr/local mv jdk1…...

网络安全—黑客技术(学习笔记)
1.网络安全是什么 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 2.网络安全市场 一、是市场需求量高; 二、则是发展相对成熟…...
Java入职第十一天,深入了解静态代理和动态代理(jdk、cglib)
一、代理模式 一个类代表另一个类去完成扩展功能,在主体类的基础上,新增一个代理类,扩展主体类功能,不影响主体,完成额外功能。比如买车票,可以去代理点买,不用去火车站,主要包括静态代理和动态代理两种模式。 代理类中包含了主体类 二、静态代理 无法根据业务扩展,…...

Snappy算法:高速压缩和解压缩技术的顶尖玩家
文章首发地址 Snappy是一种快速压缩和解压缩数据的算法。它是由Google开发的,旨在提供高速的压缩和解压缩速度,同时保持较高的压缩比。 Snappy算法的设计目标是追求速度而不是最高的压缩率。相比于其他压缩算法(如Gzip或LZ77)&am…...

Python中的format()函数详细讲解
注:所以代码皆成功运行,可直接复制运行 一、基本使用 1、Python中的format()函数是一个格式字符串的函数,通过花括号{}识别替换字段,从而完成字符串的格式化。 #format后面放数字、字符串都可以 print("{}喜欢{}岁的{}&qu…...

11. 盛最多水的容器(c++题解)
11. 盛最多水的容器(c题解) 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大…...

历史最佳二季度表现后,爱奇艺想为用户提供更多价值
以爱奇艺为首,随着长视频平台相继转变运营思路,走向盈利目标,最早完成蜕变的爱奇艺,已开始迈向下一阶段。 近日,爱奇艺发布了截至6月30日的2023年第二季度财报。除了依然亮眼的内容表现、业绩成果外,爱奇艺…...

HDLBits-Verilog学习记录 | Verilog Language-Basics(2)
文章目录 9.Declaring wires | wire decl10. 7458 chip 9.Declaring wires | wire decl problem:Implement the following circuit. Create two intermediate wires (named anything you want) to connect the AND and OR gates together. Note that the wire that feeds the …...

Ubuntu22.0网络/网卡丢失
Ubuntu22.0开机突然连不上网了,右上角网络图标消失了,设置里网络也没有了“有线”,只剩下VPN了,试了好多种办法,最终终于解决了。 看到有些直接用的下面的两条命令,有解决的,不过我这不行。 s…...

Linux 常用
系统信息 查看CPU信息(型号) cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c查看物理CPU个数 cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l查看每个物理CPU中core的个数(即核数) cat /proc/cpuinfo | grep "c…...

AWS 提示证书签名过期无法自动更新
如果域名没有通过验证的话,证书的过去是没有办法自动更新的。 验证的方式也非常简单,通过下面的配置,把 CNAME添加到你的域名上面,AWS 就可会自动完成验证了。 当添加完成后,AWS 验证需要的时间大致在 30 分钟到 1 个…...

Git版本管理(01) 简介 基本提交相关命令
1 git简介 Git是一种分布式版本控制工具,用于跟踪文件和代码的变化,协调多个开发者之间的协作,并提供版本控制和代码管理的功能。 官方学习可参考文档-> Git版本控制工具特点总结如下: 分布式版本控制:Git采用分…...

解决 vue项目报错:digital envelope routines::unsupported
出现这个错误是因为 node.js V17版本中最近发布的OpenSSL3.0, 而OpenSSL3.0对允许算法和密钥大小增加了严格的限制,可能会对生态系统造成一些影响. 方法1:运行前$ npm run serve前 先运行 export NODE_OPTIONS--openssl-legacy-provider 方法2…...