IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 周志华西瓜书学习笔记(三) -> 正文阅读

[数据结构与算法]周志华西瓜书学习笔记(三)

周志华西瓜书学习笔记(三)

决策树是一种基本的分类方法,根据数据的各种属性分类,如图就是一个决策树。

先介绍决策树中的概念:

根节点:就是树的最顶端,最开始的那个节点。在图中,“天气”就是一个根节点;

内部节点:就是树中间的那些节点,比如说“温度”、“湿度”、“刮风”

叶节点:就是树最底部的节点,也就是决策结果。

节点之间存在父子关系。比如根节点会有子节点,子节点会有自己的子子节点,但是到了叶节点就停止了,叶节点不存在子节点。

在这里插入图片描述

决策树通常有三个步骤:特征选择、决策树的生成、决策树的修剪。在特征选择中,我们其实有很多选择可以作为分类的依据,但问题是如何选取最好的那个值作为我们分类的依据。

ID3决策树

ID3决策树学习算法就是以信息增益为准则来选择划分属性,接下来先引出信息增益的定义:

  • 信息熵:信息熵是度量样本集合纯度最常用的一种指标。假定当前样本集合D中第k类样本所占的比例为 p k p_k pk?,则D的信息熵定义为:

? E n t ( D ) = ? ∑ k = 1 ∣ y ∣ p k ? l o g 2 p k Ent(D) = -\sum_{k=1}^{|y|}p_k·log_2p_k Ent(D)=?k=1y?pk??log2?pk?

? 显然Ent(D)的值越小,则D的纯度越高。当所有样本都只属于某一类,样本中没有其他类别的数据时,此时信息熵最小;相反如果样本中的数据平均归属于每一类别,所有类别占的比例都相同时,此时信息熵最大。

  • 信息增益:使用某种属性a来进行划分时所获得的的“纯度提升”

    ? G a i n ( D , a ) = E n t ( D ) ? ∑ v = 1 V ∣ D v ∣ ∣ D ∣ E n t ( D v ) Gain(D,a) = Ent(D) - \sum_{v=1}^V\frac{|D^v|}{|D|}Ent(D^v) Gain(D,a)=Ent(D)?v=1V?DDv?Ent(Dv)

    ? E n t ( D ) Ent(D) Ent(D) 是使用属性a进行分类之前的信息熵, ∑ v = 1 V ∣ D v ∣ ∣ D ∣ E n t ( D v ) \sum_{v=1}^V\frac{|D^v|}{|D|}Ent(D^v) v=1V?DDv?Ent(Dv)是分类之后每一个子节点上的信息熵,按照子节点中分到的样本个数占父节点个数的比值进行加权汇总后得到的信息熵,二者的差就是信息增益。

  • 构建方法:在所有的属性中,逐一作为分类标准,计算出各个属性的信息增益,选择有最大信息增益的属性作为分类标准。

不足ID3的信息增益准则对可取数值数目较多的属性有所偏好,为减少这种偏好可能带来的不利影响,提出C4.5决策树

C4.5决策树

  • 信息增益率: G a i n r a t i o ( D , a ) = G a i n ( D , a ) I V ( a ) Gain_ratio(D,a) = \frac{Gain(D,a)}{IV(a)} Gainr?atio(D,a)=IV(a)Gain(D,a)?,其中 I V ( a ) = ? ∑ v = 1 V ∣ D v ∣ D ? l o g 2 ∣ D v ∣ D IV(a)=-\sum_{v=1}^V\frac{|D^v|}{D}·log_2\frac{|D^v|}{D} IV(a)=?v=1V?DDv??log2?DDv?。计算的是信息增益占属性a信息熵的比重,可以类似为“优化率”。

  • 缺点:增益率准则对可取值数目较少的属性有所偏好。

因此C4.5的构造方法不是直接选择增益率最大的候选划分属性,而是先从划分属性中选出信息增益高于平均水平的属性,在从中选择增益率最高的。

CART决策树

  • 基尼系数: G i n i ( D ) = ∑ k = 1 ∣ y ∣ ∑ k ′ ≠ k p k p k ′ = 1 ? ∑ k = 1 ∣ y ∣ p k 2 Gini(D) = \sum_{k=1}^{|y|} \sum_{k'≠k}p_kp_k' = 1-\sum_{k=1}^{|y|}p_k^2 Gini(D)=k=1y?k?=k?pk?pk?=1?k=1y?pk2? ;

    G i n i i n d e x ( D , a ) = ∑ v = 1 V ∣ D v ∣ ∣ D ∣ G i n i ( D v ) Gini_index(D,a) = \sum_{v=1}^V\frac{|D^v|}{|D|}Gini(D^v) Ginii?ndex(D,a)=v=1V?DDv?Gini(Dv)。属性a的基尼系数也可以根据下属子节点分类数量占总量的权重加权

  • 构造方法:在候选属性集合A中,选择那个使得划分后基尼指数最小的属性作为最优划分属性。

剪枝处理

决策树很可能出现一个问题就是过拟合,而剪枝是决策树学习算法对付“过拟合”的主要手段。

决策树剪枝的基本策略有“预剪枝”(prepruning)和“后剪枝”(post-pruning)。预剪枝是指在决策树生成过程中,对每个结点在划分前先进行估计,若当前结点的划分不能带来决策树泛化性能提升,则停止划分并将当前结点标记为叶结点;后剪枝则是先从训练集生成-棵完整的决策树,然后自底向上地对非叶结点进行考察,若将该结点对应的子树替换为叶结点能带来决策树泛化性能提升,则将该子树替换为叶结点。

连续值与缺失值

  • 对连续值的情况,给定样本集D和连续属性a,假定a在D上出现了n个不同的取值,将这些值从小到大进行排序,记为 a 1 , a 2 . . . , a n {a^1,a^2...,a^n} a1,a2...,an。基于划分点t可将D分为子集 D t ? D_t^- Dt?? D t + D_t^+ Dt+?,其中 D t ? D_t^- Dt??包含那些在属性a上取值不大于t的样本,而 D t + D_t^+ Dt+?则包含那些在属性a上取值大于t的样本.显然,对相邻的属性取值 a i a^i ai a i + 1 a^{i+1} ai+1来说, t在区间[ a i a^i ai a i + 1 a^{i+1} ai+1)中取任意值所产生的划分结果相同。因此,对连续属性a,我们可考察包含n- 1个元素的候选划分点集合: T a = { a i + a i + 1 2 ∣ 1 ≤ i ≤ n ? 1 } T_a = \{\frac{a^i+a^{i+1}}{2}|1≤i≤n-1\} Ta?={2ai+ai+1?1in?1}。然后就可以像考察离散属性值一样考察划分点。

  • 对缺失值的情况,只需要将信息不缺失的数据先单独编成一个集合D’,将这个集合先分类,然后再将缺失的数据分配到每一个叶节点中,但是需要修改这些数据的权重。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

多变量决策树

在这里插入图片描述

对于正常的决策树,其边界都是平行于坐标轴的,这样效率不够高,因此要开始寻找能直接斜着的的边界,也就是非叶节点不再是仅对某个属性,而是对属性线性组合进行测试。如下图:
在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-23 11:03:36  更:2021-07-23 11:06:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/27 9:54:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计