起步
熵的计算:
根据计算公式:
![1de8624be6c7e7b1cb6c2c052b0932d61d3ad5c0](https://yqfile.alicdn.com/1de8624be6c7e7b1cb6c2c052b0932d61d3ad5c0.png?x-oss-process=image/resize,w_1400/format,webp)
对应的 python 代码:
![da5e4ae0a67c638c8ff22918319d885f59418d7e](https://yqfile.alicdn.com/da5e4ae0a67c638c8ff22918319d885f59418d7e.png?x-oss-process=image/resize,w_1400/format,webp)
条件熵的计算:
根据计算方法:
![b904e3b21bc992d4dc8886e792baf8e4ddd80a7e](https://yqfile.alicdn.com/b904e3b21bc992d4dc8886e792baf8e4ddd80a7e.png?x-oss-process=image/resize,w_1400/format,webp)
对应的 python 代码:
![e82147b1a6a153fe4bdead8771c97fe550b70597](https://yqfile.alicdn.com/e82147b1a6a153fe4bdead8771c97fe550b70597.png?x-oss-process=image/resize,w_1400/format,webp)
其中参数 future_list 是某一特征向量组成的列表,result_list 是 label 列表。
信息增益:
根据信息增益的计算方法:
![783f4096d3a014ef4bb8c6338b9701b6db5aebd0](https://yqfile.alicdn.com/783f4096d3a014ef4bb8c6338b9701b6db5aebd0.png?x-oss-process=image/resize,w_1400/format,webp)
对应的python代码:
![b6afbcadce0cce9ba3b4f0b66d752a811949f9d1](https://yqfile.alicdn.com/b6afbcadce0cce9ba3b4f0b66d752a811949f9d1.png?x-oss-process=image/resize,w_1400/format,webp)
定义决策树的节点
作为树的节点,要有左子树和右子树是必不可少的,除此之外还需要其他信息:
![49a615c8be5999314c32aea0b79b334de6a69ca7](https://yqfile.alicdn.com/49a615c8be5999314c32aea0b79b334de6a69ca7.png?x-oss-process=image/resize,w_1400/format,webp)
树的节点会有两种状态,叶子节点中 results 属性将保持当前的分类结果。非叶子节点中, col 保存着该节点计算的特征索引,根据这个索引来创建左右子树。
has_calc_index 属性表示在到达此节点时,已经计算过的特征索引。特征索引的数据集上表现是列的形式,如数据集(不包含结果集):
![1241c86f064fb4d62825881caf2fe2951f9dafe8](https://yqfile.alicdn.com/1241c86f064fb4d62825881caf2fe2951f9dafe8.png?x-oss-process=image/resize,w_1400/format,webp)
有三条数据,三个特征,那么第一个特征对应了第一列 [1, 0, 0] ,它的索引是 0 。
递归的停止条件
本章将构造出完整的决策树,所以递归的停止条件是所有待分析的训练集都属于同一类:
![aee432d291fc2997700563bfe65a7dce91b74603](https://yqfile.alicdn.com/aee432d291fc2997700563bfe65a7dce91b74603.png?x-oss-process=image/resize,w_1400/format,webp)
从训练集中筛选最佳的特征:
![22f177641cf24ffc07fd84c5707c26187b6fe582](https://yqfile.alicdn.com/22f177641cf24ffc07fd84c5707c26187b6fe582.png?x-oss-process=image/resize,w_1400/format,webp)
因此计算节点就是调用 best_index = choose_best_future(node.data_set, node.labels, node.has_calc_index) 来获取最佳的信息增益的特征索引。
构造决策树
决策树中需要一个属性来指向树的根节点,以及特征数量。不需要保存训练集和结果集,因为这部分信息是保存在树的节点中的。
![6591ee9c0104386eefc264d483c4ab06c18e4de3](https://yqfile.alicdn.com/6591ee9c0104386eefc264d483c4ab06c18e4de3.png?x-oss-process=image/resize,w_1400/format,webp)
创建决策树:
这里需要递归来创建决策树:
![47a96ed7e9d988c252d20ec40628b868e16e6298](https://yqfile.alicdn.com/47a96ed7e9d988c252d20ec40628b868e16e6298.png?x-oss-process=image/resize,w_1400/format,webp)
根据信息增益的特征索引将训练集再划分为左右两个子树。
训练函数
也就是要有一个 fit 函数:
![317ad2493849481c69c1043f1654f15cd5cafd14](https://yqfile.alicdn.com/317ad2493849481c69c1043f1654f15cd5cafd14.png?x-oss-process=image/resize,w_1400/format,webp)
清理训练集
训练后,树节点中数据集和结果集等就没必要的,该模型只要 col 和 result 就可以了:
![b72c213ca146c03bedcc7ba729d8cc18662409b8](https://yqfile.alicdn.com/b72c213ca146c03bedcc7ba729d8cc18662409b8.png?x-oss-process=image/resize,w_1400/format,webp)
预测函数
提供一个预测函数:
![539b1d435250834edb960355bc58e62645dafae5](https://yqfile.alicdn.com/539b1d435250834edb960355bc58e62645dafae5.png?x-oss-process=image/resize,w_1400/format,webp)
测试
数据集使用前面《应用篇》中的向量化的训练集:
原文发布时间为:2017-12-18
本文作者:weapon