决策树信息增益

2024-06-02 10:32
文章标签 信息 决策树 增益

本文主要是介绍决策树信息增益,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

决策树和集成算法都是树模型

决策树:从根节点一步步走到叶子节点,所有的数据都会落到叶子节点,既可以做分类也可以做回归。

一颗树有三种节点组成,根节点,中间几点,叶子节点。根节点是第一个选择节点,也是最重要的一个选择特征。叶子节点是存放最终的结果。

决策树的训练和测试

训练是建立一棵树。

测试是让数据从根节点走到叶子节点。

如何切分特征:

通过一种衡量标准,计算在不同特征下的值。选择最好的一个作为根节点。

信息增益:g(D,A)=H(D)-H(D|A)  是集合D的信息熵-在特征A条件的信息熵

 

决策树的三种算法:

       1.ID3      信息增益

       2.C4.5     信息增益率

       3.CART   基尼系数    

CART分为回归树和分类树,回归树是平方误差。 分类树是基尼系数,作为sklearn默认选择。

决策树减枝原因:容易出现过拟合,只要树足够大,能够把所有的数据分开。

减枝分为预剪枝和后剪枝。

预剪枝:在建立树的过程中进行剪枝。---实用

后剪枝:在建立决策树以后剪枝。

 

剪枝策略:

预剪枝策略:限制树的深度,叶子节点的个数,信息增益量的大小等。

后剪枝策略:通过一定的衡量标准,比如叶子节点个数越多,损失越大。

 

决策树的优缺点:

优点

1.容易理解和解释。

2.不需要很多的数据,不需要归一化。

 

缺点:

1.过拟和

2.决策树不稳定,数据小的变化可能导致产生不同的树。

改进方法:

1.CART剪纸

2.随机森林

 

随机森林

随机森林是一种集成方法,通过随机采样样本和随机选取特征生成多颗树,产生多个分类器,通过投票表决的方式产生最终的结果。

随机森林的特点:两个特点又放回的采样,采样样本和采样特征。

 

随机森林的特点:

1.具有极高的准确率

2.能够运行在大数据集上

3.能够处理高维的样本,不需要降维。

4.能够评估各个特征在分类问题上的重要性

5.对于缺失值也有很好的效果。

 

 

 

 

 

 

 

这篇关于决策树信息增益的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

使用Python检查CPU型号并弹出警告信息

《使用Python检查CPU型号并弹出警告信息》本教程将指导你如何编写一个Python程序,该程序能够在启动时检查计算机的CPU型号,如果检测到CPU型号包含“I3”,则会弹出一个警告窗口,感兴趣的小... 目录教程目标方法一所需库步骤一:安装所需库步骤二:编写python程序步骤三:运行程序注意事项方法二

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

Linux命令(11):系统信息查看命令

系统 # uname -a # 查看内核/操作系统/CPU信息# head -n 1 /etc/issue # 查看操作系统版本# cat /proc/cpuinfo # 查看CPU信息# hostname # 查看计算机名# lspci -tv # 列出所有PCI设备# lsusb -tv

【小迪安全笔记 V2022 】信息打点9~11

第9天 信息打点-CDN绕过篇&漏洞回链8接口探针&全网扫指&反向件 知识点: 0、CDN知识-工作原理及阻碍 1、CDN配置-域名&区域&类型 2、CDN绕过-靠谱十余种技战法 3、CDN绑定-HOSTS绑定指向访问 CDN 是构建在数据网络上的一种分布式的内容分发网。 CDN的作用是采用流媒体服务器集群技术,克服单机系统输出带宽及并发能力不足的缺点,可极大提升系统支持的并发流数目,减少或避

Weex入门教程之4,获取当前全局环境变量和配置信息(屏幕高度、宽度等)

$getConfig() 获取当前全局环境变量和配置信息。 Returns: config (object): 配置对象;bundleUrl (string): bundle 的 url;debug (boolean): 是否是调试模式;env (object): 环境对象; weexVersion (string): Weex sdk 版本;appName (string): 应用名字;