《机器学习》从入门到实战——决策树

embedded/2025/1/11 19:15:56/

目录

一、简介

二、基本结构

三、构建过程

四、API接口解析

1、决策树--分类

(1)、接口调用方法

(2)、参数解析

2、决策树--回归

(1)、接口调用方法

(2)、参数解析

五、代码实践

1、决策树--分类

结果展示:

2、决策树--回归

结果展示: 


一、简介

决策树是一种常用的机器学习算法,广泛应用于分类和回归任务。它通过递归地将数据集划分为更纯的子集,构建树状结构来进行决策。每个内部节点表示一个特征或属性的测试,每个分支代表一个可能的测试结果,而每个叶节点则代表一个类别(分类任务)或一个值(回归任务)。

决策树通过对训练样本的学习,并建立分类规则,然后依据分类规则,对新样本数据进行分类预测,属于有监督学习。

二、基本结构

  • 节点

    • 根节点:树的起始点,包含整个数据集。

    • 内部节点:表示一个特征或属性的测试,根据测试结果将数据划分到不同的子节点。

    • 叶节点:表示最终的决策结果(类别或值)。

  • 分支:从一个节点到另一个节点的路径,表示一个特征测试的结果。

  • 划分准则:用于选择最佳特征进行划分的准则,常见的准则有信息增益、信息增益比、基尼指数等。

三、构建过程

决策树的构建过程通常包括以下步骤:

  • 特征选择:从所有特征中选择一个最佳特征作为当前节点的划分标准。常用的特征选择方法有:

    • 信息增益(ID3算法):选择信息增益最大的特征。

    • 信息增益比(C4.5算法):对信息增益进行归一化处理,避免偏向取值较多的特征。

    • 基尼指数(CART算法):选择基尼指数最小的特征。

  • 节点划分:根据选择的特征将数据集划分为若干子集,每个子集对应一个分支。

  • 递归构建:对每个子集递归地重复上述过程,直到满足停止条件(如节点中的样本属于同一类别、样本数小于阈值、树的深度达到预设值等)。

  • 剪枝:为了防止过拟合,可以对生成的决策树进行剪枝,去掉一些不必要的分支。

四、API接口解析

1、决策树--分类

(1)、接口调用方法
from sklearn.tree import DecisionTreeClassifier# 创建决策树分类器
clf = DecisionTreeClassifier()# 训练模型
clf.fit(X_train, y_train)# 预测
y_pred = clf.predict(X_test)
(2)、参数解析
参数名说明
criterion衡量分割质量的函数。
可选值:
"gini":基尼系数(默认)。
"entropy":信息增益。
splitter选择分割策略。
可选值:
"best":选择最佳分割(默认)。
"random":随机选择分割。
max_depth树的最大深度。
如果不设置,树会一直生长直到所有叶子节点纯净或达到其他停止条件。
min_samples_split分割内部节点所需的最小样本数。
默认是 2。
min_samples_leaf叶子节点所需的最小样本数。
默认是 1。
min_weight_fraction_leaf叶子节点所需的最小权重比例(基于样本权重)。
默认是 0。
max_features寻找最佳分割时考虑的最大特征数。
可以是整数、浮点数或 "auto""sqrt""log2" 等。
默认是 "auto"(即所有特征)。
random_state随机种子,用于控制随机性(如 splitter="random" 时)。
max_leaf_nodes最大叶子节点数。
如果不设置,则不限制叶子节点数。
min_impurity_decrease如果分割导致不纯度的减少大于该值,则进行分割。
默认是 0。
class_weight类别权重,用于处理不平衡数据集。
可以是 "balanced" 或字典形式。默认是 None
ccp_alpha用于最小代价复杂度剪枝的正则化参数。
默认是 0(不剪枝)。

2、决策树--回归

(1)、接口调用方法
from sklearn.tree import DecisionTreeRegressor# 创建决策树回归器
clf = DecisionTreeRegressor()# 训练模型
clf.fit(X_train, y_train)# 预测
y_pred = clf.predict(X_test)
(2)、参数解析
参数名说明
criterion衡量分割质量的函数。
可选值:
"squared_error":均方误差(默认)。
"friedman_mse":改进的均方误差。
"absolute_error":绝对误差。
"poisson":泊松偏差。
splitter选择分割策略。
可选值:
"best":选择最佳分割(默认)。
"random":随机选择分割。
max_depth树的最大深度。
如果不设置,树会一直生长直到所有叶子节点纯净或达到其他停止条件。
min_samples_split分割内部节点所需的最小样本数。
默认是 2。
min_samples_leaf叶子节点所需的最小样本数。
默认是 1。
min_weight_fraction_leaf叶子节点所需的最小权重比例(基于样本权重)。
默认是 0。
max_features寻找最佳分割时考虑的最大特征数。
可以是整数、浮点数或 "auto""sqrt""log2" 等。
默认是 "auto"(即所有特征)。
random_state随机种子,用于控制随机性(如 splitter="random" 时)。
max_leaf_nodes最大叶子节点数。
如果不设置,则不限制叶子节点数。
min_impurity_decrease如果分割导致不纯度的减少大于该值,则进行分割。
默认是 0。
ccp_alpha用于最小代价复杂度剪枝的正则化参数。
默认是 0(不剪枝)。

五、代码实践

1、决策树--分类

import pandas as pd
import matplotlib.pyplot as plt
from sklearn.metrics import confusion_matrix
from sklearn.model_selection import train_test_split
from sklearn import tree
from sklearn import metrics
from sklearn.tree import plot_tree# 绘制混淆矩阵函数
def cm_plot(y, yp):cm = confusion_matrix(y, yp)  # 计算混淆矩阵plt.matshow(cm, cmap=plt.cm.Blues)  # 使用蓝色调绘制混淆矩阵plt.colorbar()  # 添加颜色条for x in range(len(cm)):for y in range(len(cm)):# 在每个单元格中标注数值plt.annotate(cm[x, y], xy=(x, y), horizontalalignment='center', verticalalignment='center')plt.ylabel('True label')  # 设置y轴标签plt.xlabel('Predicted label')  # 设置x轴标签return pltdatas = pd.read_excel('./data/电信客户流失数据.xlsx')
data = datas.iloc[:,:-1]
target = datas.iloc[:,-1]"""划分数据集"""
data_train,data_test,target_train,target_test = \
train_test_split(data,target,test_size=0.2,random_state=42)
dtr = tree.DecisionTreeClassifier(criterion='gini',max_depth=10,min_samples_leaf=5,random_state=42)
dtr.fit(data_train,target_train)'''训练集混淆矩阵'''
# 训练集预测
train_predict = dtr.predict(data_train)
metr = metrics.classification_report(target_train,train_predict)'''测试集混淆矩阵'''
test_predicted = dtr.predict(data_test)
metr1 = metrics.classification_report(target_test,test_predicted)
print(metr1)
cm_plot(target_test,test_predicted).show()
dtr.score(data_test,target_test)# 绘制决策树
fig,ax = plt.subplots(figsize=(32,32))
plot_tree(dtr,filled=True,ax=ax)
plt.show()
结果展示:

 

2、决策树--回归

from sklearn.tree import DecisionTreeRegressor
import numpy as np
from sklearn import metricsfrom sklearn.model_selection import train_test_split
data = np.loadtxt('../data/fangjia.txt')
x = data[:,:-1]
y = data[:,-1]
# 划分数据集
train_x,test_x,train_y,test_y = train_test_split(x,y,test_size=0.3,random_state=1)reg = DecisionTreeRegressor(max_depth=10,min_samples_leaf=1,min_samples_split=3,ccp_alpha=0.03,max_features="auto",random_state=42)
reg = reg.fit(train_x,train_y)
y_pr = reg.predict(test_x)
# print(y_pr)
print("R² Score:", metrics.r2_score(test_y, y_pr))
结果展示: 

 


http://www.ppmy.cn/embedded/153098.html

相关文章

计算机网络之---数据传输与比特流

数据传输的概念 数据传输是指将数据从一个设备传输到另一个设备的过程。传输过程涉及将高层协议中的数据(如包、帧等)转化为比特流,在物理介质上传输。 比特流的概念 比特流是数据传输中最基本的单位,它是由0和1组成的连续比特…

Swift UI开发指南:修饰器特性(modifiers)

SwiftUI开发指南:修饰器特性(Modifiers) 什么是修饰器?修饰器的特性示例:改变文本颜色代码:效果: 常用修饰器列表修饰器的最佳实践总结 在SwiftUI中,修饰器(modifiers&am…

[免费]微信小程序(高校就业)招聘系统(Springboot后端+Vue管理端)【论文+源码+SQL脚本】

大家好,我是java1234_小锋老师,看到一个不错的微信小程序(高校就业)招聘系统(Springboot后端Vue管理端),分享下哈。 项目视频演示 【免费】微信小程序(高校就业)招聘系统(Springboot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项目介绍…

【大模型入门指南 07】量化技术浅析

【大模型入门指南】系列文章: 【大模型入门指南 01】深度学习入门【大模型入门指南 02】LLM大模型基础知识【大模型入门指南 03】提示词工程【大模型入门指南 04】Transformer结构【大模型入门指南 05】LLM技术选型【大模型入门指南 06】LLM数据预处理【大模型入门…

Spring Boot项目中增加MQTT对接

在Spring Boot项目中增加MQTT对接,通常涉及以下几个步骤: 一、搭建MQTT服务器 首先,你需要搭建一个MQTT服务器(Broker)。这可以通过多种方式实现,例如使用Docker来部署EMQX或Mosquitto等MQTT Broker。 以…

javaEE初阶————多线程初阶(1)

多线程初阶———— 1,认识线程 1.1 概念 1)线程是什么 线程就是一个“执行流”,可以理解为程序执行的最小单位; 可以看成轻量级的进程; 2)为啥要有线程 “并发编程” 的需要,但是我们不…

一个基于Spring Boot的简单网吧管理系统

一个基于Spring Boot的简单网吧管理系统的案例代码。这个系统包括用户管理、电脑管理、上机记录管理等功能。代码结构清晰,适合初学者学习和参考。 1. 项目结构 src/main/java/com/example/netbarmanagement├── controller│ ├── ComputerController.jav…

Data/Code/Algorithm

前段时间很久没更在忙考研的事情,现在初试过了也算是一阶段的学习尘埃落定 有时间和心力和探索更多未知的世界和新奇的领域 我在小红书上刷到帖子推荐了几部计算机专业学生必看的纪录片 个人认为这是一个了解计算机新领域的好时机,所以最近陆陆续续也…