使用sklearn学习决策树(Decision Tree)

决策树模型

  决策树(decision tree)是一种基本的分类与回归方法。
  分类决策树模型是一种描述对实例进行分类的树形结构。决策树由结点(node)和有向边(directed edge)组成。结点有两种类型:内部结点(internal node)和叶结点(leaf node)。内部结点表示一个特征或属性,叶结点表示一个类。
  用决策树分类,从根结点开始,对实例的某一特征进行测试,根据测试结果,将实例分配到其子结点;这时,每一个子结点对应着该特征的一个取值。如此递归地对实例进行测试并分配,直至达到叶结点。最后将实例分到叶结点的类中。

     用于预测一个人是否肥胖或不肥胖的决策树

决策树学习

  决策树学习算法包括3部分:特征选择、树的生成和树的剪枝。常用的算法有ID3、 C4.5和CART。
  1、特征选择的目的在于选取对训练数据能够分类的特征。特征选择的关键是其准则。常用的准则如下:
  (1)样本集合D对特征A的信息增益(ID3)
  (2)样本集合D对特征A的信息增益比(C4.5)
  (3)样本集合D的基尼指数(CART)
  2.决策树的生成。通常使用信息增益最大、信息增益比最大或基尼指数最小作为特征选择的准则。决策树的生成往往通过计算信息增益或其他指标,从根结点开始,递归地产生决策树。这相当于用信息增益或其他准则不断地选取局部最优的特征,或将训练集分割为能够基本正确分类的子集。
   3.决策树的剪枝。由于生成的决策树存在过拟合问题,需要对它进行剪枝,以简化学到的决策树。决策树的剪枝,往往从已生成的树上剪掉一些叶结点或叶结点以上的子树,并将其父结点或根结点作为新的叶结点,从而简化生成的决策树。

使用Scikit-learn进行决策树分类
import numpy as np
from sklearn.datasets import load_iris
from sklearn import tree
import matplotlib.pyplot as plt

iris=load_iris()
print(iris.feature_names)
print(iris.target_names)

#划分数据集
removed =[0,50,100]
new_target = np.delete(iris.target,removed)
new_data = np.delete(iris.data,removed, axis=0)

#训练分类器
clf = tree.DecisionTreeClassifier() # 定义决策树分类器
clf=clf.fit(new_data,new_target)
prediction = clf.predict(iris.data[removed])

print("Original Labels",iris.target[removed])
print("Labels Predicted",prediction)

#绘制决策树
plt.figure(figsize=(15, 10))
tree.plot_tree(clf, feature_names=iris.feature_names, filled=True)
plt.show()

在这里插入图片描述
参考链接https://www.askpython.com/python/examples/decision-trees

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
sklearn是一个Python的机器学习库,里面包含了很多机器学习算法的实现。其中,决策树是一个常用的分类和回归算法,在sklearn中有完整的决策树实现。 使用sklearn决策树案例的步骤如下: 1. 导入必要的库和数据集:首先需要导入sklearn库中的decisiontree模块,以及其他可能需要的库,如numpy和pandas。然后,将准备好的数据集加载到程序中。 2. 数据预处理:对于决策树模型,数据需要进行一定的预处理。这包括对数据进行缺失值处理、特征选择、特征缩放等。可以使用sklearn中的preprocessing模块提供的函数进行处理。 3. 构建决策树模型:使用sklearn中的DecisionTreeClassifier来构建决策树模型。可以设置树的深度、最小叶节点数、最小拆分样本数等参数。 4. 拟合模型:将准备好的训练数据传入fit函数进行模型拟合。模型会根据传入的数据进行训练,学习到数据的特征和标签之间的关系。 5. 预测和评估:使用训练好的模型对测试数据进行预测,得到预测结果。可以使用sklearn中的predict函数来进行预测。然后,通过与真实标签进行比较,可以使用准确性、精确度、召回率等指标评估模型的性能。 6. 可视化决策树:如果希望可视化决策树,可以使用sklearn中的export_graphviz函数生成Graphviz格式的决策树图形,然后使用Graphviz库进行展示。 总结来说,使用sklearn决策树案例需要导入库和数据集、预处理数据、构建模型、拟合模型、预测和评估模型,最后可以选择性地对决策树进行可视化。通过这个过程,我们可以使用决策树算法来解决分类和回归问题,并对模型性能进行评估和可视化展示。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值