算法学习笔记:决策树(上)(decision tree):理解篇

2024-02-28 14:10

本文主要是介绍算法学习笔记:决策树(上)(decision tree):理解篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

啥是决策树?决策树是一种对样本数据进行自上而下树形分类的模型。

一般来说,一颗决策树的组成包括:内部结点(internal node)、叶结点(leaf node)、有向边(directed edge)。

 

先来举个例子感性认识下决策树,来自《百面机器学习》上一对母女的对话,内容如下:

母亲:“闺女,我又给你找了个合适的对象,见不见?”      

女儿:“多大?”--------------------------年龄        母亲:“26岁。”        

  • 女儿:“长得帅吗?”--------------------长相        母亲:“还可以,不算太帅。”      

  • 女儿:“工资高吗?”--------------------工资        母亲:“中等偏上。”

  • 女儿:“会写代码吗?”-----------------是否会写代码        母亲:“人家是程序员,代码写得棒着呢。”

女儿问问题的过程也是她做决定的过程,可以看作一个典型的决策树分类,见或不见是通过对方的年龄、长相、工资和是否会写代码等特征或者说属性来进行逐步判断的。这颗过程可以描述成下面这样:

例1:相亲见不见树

>>上面这个例子有其特殊性,因为从女儿的问题顺序可以对照树的结点的顺序或位置。

现在再举个更一般的例子,下面是李航的《统计学习方法》中的一组贷款申请样本数据,根据这组数据建立一颗决策树用来判断是否对申请人发放贷款,数据如下:

例2:贷款申请样本数据
ID年龄有工作有自己的房子信贷情况类别
1青年一般
2青年
3青年
4青年一般
5青年一般
6中年一般
7中年
8中年
9中年非常好
10中年非常好
11老年非常好
12老年
13老年
14老年非常好
15老年一般

首先,我们先来观察下数据。贷款机构收集了每位申请人的4类特征或属性,分别是:

  • (1)年龄:青年、中年、老年三类,记为A1

  • (2)是否有工作:有工作和无工作两类,记为A2

  • (3)是否有房:有房和无房两类,记为A3

  • (4)信贷情况:一般、好、非常好三类,记为A4

  • 现在我们并不能从这4类数据中直接看出它们在决策树上的出场顺序,或者说对于是否发放贷款的重要程度。

接下来,我们看看树的生成过程。这里先梳理一下建树的基本思路:

  • (1)第一步:选出(根)结点。在A1、A2、A3、A4中选出一个最优的作为根结点,至于怎么定义最优和怎么选,等到下面再说。假设选择了A2—是否有工作作为根结点。

  • (2)第二步:分割数据集。样本数据集已根据A2分成了2个子数据集,如下(a)和(b)所示。

(a) 有工作
ID年龄有工作有自己的房子信贷情况类别
3青年
4青年一般
8中年
13老年
14老年非常好
(b) 无工作
ID年龄有工作有自己的房子信贷情况类别
1青年一般
2青年
5青年一般
6中年一般
7中年
9中年非常好
10中年非常好
11老年非常好
12老年
15老年一般
  • (3)第三步:分别分析数据子集。分别观察下这2个子集:表(a)的类别都是“是”,也就是说,从样本数据来看有工作的申请人会被发放贷款,这时生成一个叶结点,这个树枝就生长结束了。而表(b)的类别还是混乱的,还没有被分类好,咋办?继续对(b)的数据继续进行类似(1)和(2)的选择、分解和分析。

  • (4)第四步:重复(1)。在表(b)剩下的3个特征择优作为新的结点。这里假设选择了A3—是否有房作为新结点。

  • (5)第五步:重复(2)。表(b)的数据又被分为2个子集,如下表(c)和(d)所示。

(c) 无工作的条件下有房
ID年龄有工作有自己的房子信贷情况类别
9中年非常好
10中年非常好
11老年非常好
12老年
(d) 无工作的条件下无房
ID年龄有工作有自己的房子信贷情况类别
1青年一般
2青年
5青年一般
6中年一般
7中年
15老年一般
  • (6)第六步:重复(3)。此时的表(c)和(d)均已完全分类,故分别生成两个叶结点。至此决策树构建结束,完整的决策树如下所示。

例2:是否发放贷款树

 

再来观察下上面的这颗决策树:

“完全正确”的决策树可能不止一个,也可能一个也没有。若把根结点“有工作”和结点“有自己的房子”调换位置,新的决策树仍然可以对这个数据集“完全正确”的分类;如果数据集中出现几个噪声,那么“完全正确”的决策树可能不存在。大部分情况下,“完全正确”意味着过拟合所以,“最优”的决策树是那颗与训练数据矛盾较小的树并且具备不错的泛化能力

②求解“最优”决策树的问题是一个NP-C问题(Non-deterministic Polynomial Complete)。关于啥是NPC问题详见 别人的博客(https://blog.csdn.net/sinat_21591675/article/details/86521190),这里需要理解的是这个求解最优的过程需要遍历所有的树!有必要么?回答是没有。所以一般退而求其次选择“次最优(sub-optimal)”的解,即采用所谓的启发式方法求解。

③决策树结点的选择称为“特征选择”。“特征选择”的准则有多种,包括:信息增益(infoinformation gain),也称为KL散度 (K-L divergence);信息增益比(infoinformation gain ratio);基尼指数(gini index)。详见我的另一篇文章:

 

最后学术性地归纳下:

  1. 一般来说,决策树需经过(1)特征选择、(2)树的构造、(3)树的剪枝三个过程。
  2. 常见决策树算法:ID3(1986年,Quinlan)、C4.5(1993年,Quinlan)、CART(1984年,Breiman)。
  3. 决策树是较为基础的监督学习模型,可用于分类问题(分类树)和回归(回归树)问题,在现实社会中,市场营销领域的销售问题、医疗领域的诊断问题、航空领域的故障诊断等问题使用较多。

这篇关于算法学习笔记:决策树(上)(decision tree):理解篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/755728

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

硬件基础知识——自学习梳理

计算机存储分为闪存和永久性存储。 硬盘(永久存储)主要分为机械磁盘和固态硬盘。 机械磁盘主要靠磁颗粒的正负极方向来存储0或1,且机械磁盘没有使用寿命。 固态硬盘就有使用寿命了,大概支持30w次的读写操作。 闪存使用的是电容进行存储,断电数据就没了。 器件之间传输bit数据在总线上是一个一个传输的,因为通过电压传输(电流不稳定),但是电压属于电势能,所以可以叠加互相干扰,这也就是硬盘,U盘

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std