博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从零开始用Python构造决策树(附公式、代码)
阅读量:4046 次
发布时间:2019-05-25

本文共 952 字,大约阅读时间需要 3 分钟。

本文长度为700字建议阅读5分钟

本文介绍如何不利用第三方库,仅用python自带的标准库来构造一个决策树。



起步


熵的计算:


根据计算公式:



对应的 python 代码:



条件熵的计算:


根据计算方法:



对应的 python 代码:



其中参数 future_list 是某一特征向量组成的列表,result_list 是 label 列表。


信息增益:


根据信息增益的计算方法:



对应的python代码:



定义决策树的节点


作为树的节点,要有左子树和右子树是必不可少的,除此之外还需要其他信息:



树的节点会有两种状态,叶子节点中 results 属性将保持当前的分类结果。非叶子节点中, col 保存着该节点计算的特征索引,根据这个索引来创建左右子树。


has_calc_index 属性表示在到达此节点时,已经计算过的特征索引。特征索引的数据集上表现是列的形式,如数据集(不包含结果集):



有三条数据,三个特征,那么第一个特征对应了第一列 [1, 0, 0] ,它的索引是 0 。


递归的停止条件


本章将构造出完整的决策树,所以递归的停止条件是所有待分析的训练集都属于同一类:



从训练集中筛选最佳的特征:



因此计算节点就是调用 best_index = choose_best_future(node.data_set, node.labels, node.has_calc_index) 来获取最佳的信息增益的特征索引。


构造决策树


决策树中需要一个属性来指向树的根节点,以及特征数量。不需要保存训练集和结果集,因为这部分信息是保存在树的节点中的。



创建决策树:


这里需要递归来创建决策树:




根据信息增益的特征索引将训练集再划分为左右两个子树。


训练函数


也就是要有一个 fit 函数:



清理训练集


训练后,树节点中数据集和结果集等就没必要的,该模型只要 col 和 result 就可以了:



预测函数


提供一个预测函数:



测试


数据集使用前面《应用篇》中的向量化的训练集:


分享朋友圈 也是另一种赞赏

The more we share, The more we have

 

欢迎加入数据君高效数据分析社区


加我私人微信进入大数据干货群:tongyuannow 






目前100000+人已关注加入我们

       

       



转载地址:http://gezci.baihongyu.com/

你可能感兴趣的文章
Oracle DG failover 后恢复
查看>>
mysql 主从同步配置
查看>>
为什么很多程序员都选择跳槽?
查看>>
mongdb介绍
查看>>
mongdb安装使用
查看>>
mongdb在java中的应用
查看>>
区块链技术让Yotta企业云盘为行政事业服务助力
查看>>
Yotta企业云盘更好的为媒体广告业服务
查看>>
Yotta企业云盘助力旅游行业新发展
查看>>
Yotta企业云盘助力科技行业创高峰
查看>>
Yotta企业云盘更好地为教育行业服务
查看>>
Yotta企业云盘怎么帮助到能源化工行业
查看>>
企业云盘如何助力商业新发展
查看>>
医疗行业运用企业云盘可以带来什么样的提升
查看>>
教育数字智能化能为现有体系带来新的起点
查看>>
媒体广告业如何将内容资产进行高效地综合管理与利用
查看>>
能源化工要怎么管控核心数据
查看>>
媒体广告业如何运用云盘提升效率
查看>>
企业如何运用企业云盘进行数字化转型-实现新发展
查看>>
司法如何运用电子智能化加快现代化建设
查看>>