姓名:郑红 学号:17101223385
本文转自http://developer.51cto.com/art/201712/560689.htm
【嵌牛导读】:本章介绍如何不利用第三方库,仅用python自带的标准库来构造一个决策树
【嵌牛鼻子】:Python 决策树
【嵌牛提问】:怎么构造决策树?
【嵌牛正文】:起步
本章介绍如何不利用第三方库,仅用python自带的标准库来构造一个决策树。
熵的计算公式:
![](https://img.haomeiwen.com/i7882785/0033cfc76ba536c7.jpeg)
对应的 python 代码:
![](https://img.haomeiwen.com/i7882785/0e14b436e26a9f2c.png)
条件熵的计算
根据计算方法:
![](https://img.haomeiwen.com/i7882785/95eac1b34da8f4ec.jpeg)
对应的 python 代码:
![](https://img.haomeiwen.com/i7882785/6871955d0d0dffae.png)
其中参数 future_list 是某一特征向量组成的列表,result_list 是 label 列表。
信息增益
根据信息增益的计算方法:
![](https://img.haomeiwen.com/i7882785/6728f4082f59b80a.jpeg)
对应的python代码:
..
![](https://img.haomeiwen.com/i7882785/d6c69cb7173c61cb.png)
定义决策树的节点
作为树的节点,要有左子树和右子树是必不可少的,除此之外还需要其他信息:
![](https://img.haomeiwen.com/i7882785/c8af9c48af7c2b3d.png)
树的节点会有两种状态,叶子节点中 results 属性将保持当前的分类结果。非叶子节点中, col 保存着该节点计算的特征索引,根据这个索引来创建左右子树。
has_calc_index 属性表示在到达此节点时,已经计算过的特征索引。特征索引的数据集上表现是列的形式,如数据集(不包含结果集):
![](https://img.haomeiwen.com/i7882785/42462fc195215e86.png)
有三条数据,三个特征,那么第一个特征对应了第一列 [1, 0, 0] ,它的索引是 0 。
递归的停止条件
本章将构造出完整的决策树,所以递归的停止条件是所有待分析的训练集都属于同一类:
![](https://img.haomeiwen.com/i7882785/f3316ce5773a9c18.png)
从训练集中筛选最佳的特征
![](https://img.haomeiwen.com/i7882785/9361846a5ae4d790.png)
因此计算节点就是调用 best_index = choose_best_future(node.data_set, node.labels, node.has_calc_index) 来获取最佳的信息增益的特征索引。
构造决策树
决策树中需要一个属性来指向树的根节点,以及特征数量。不需要保存训练集和结果集,因为这部分信息是保存在树的节点中的。
![](https://img.haomeiwen.com/i7882785/089d2b9bbea1c597.png)
创建决策树
这里需要递归来创建决策树:
![](https://img.haomeiwen.com/i7882785/17cb5580dc5ba205.png)
![](https://img.haomeiwen.com/i7882785/798174c3b9f5dbfe.png)
根据信息增益的特征索引将训练集再划分为左右两个子树。
训练函数
也就是要有一个 fit 函数:
![](https://img.haomeiwen.com/i7882785/7d9d122ac57a3805.png)
清理训练集
训练后,树节点中数据集和结果集等就没必要的,该模型只要 col 和 result 就可以了:
![](https://img.haomeiwen.com/i7882785/cb3265ec339a1ae8.png)
预测函数
提供一个预测函数:
![](https://img.haomeiwen.com/i7882785/09ffa0ffad5be1db.png)
测试
数据集使用前面《应用篇》中的向量化的训练集:
![](https://img.haomeiwen.com/i7882785/4b1548dc9271c8f7.png)
网友评论