CART算法原理及Python实践

2024-09-02 19:04
文章标签 python 算法 实践 原理 cart

本文主要是介绍CART算法原理及Python实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、CART算法原理

CART(Classification And Regression Trees)算法是一种用于分类和回归任务的决策树学习技术。它采用贪心策略递归地划分数据集,以构建一棵二叉决策树。CART算法的原理可以概括为以下几个关键步骤:

1. 特征选择与数据划分

特征选择:CART算法在每次划分时,会选择最优的特征及其对应的划分点(对于连续特征)或划分值(对于离散特征)。对于分类任务,通常使用基尼指数(Gini Index)作为划分标准;对于回归任务,则使用均方误差(MSE)作为划分标准。基尼指数越小或均方误差越小,表示划分后的数据子集越纯或越接近真实值。

数据划分:根据选定的最优特征和划分点/值,将数据集划分为两个子集。这两个子集将作为新生成的子节点的训练数据集。

2. 递归构建决策树

从根节点开始,CART算法递归地对每个节点进行上述的特征选择和数据划分操作,直到满足停止条件。常见的停止条件包括:节点中的样本个数小于预定的阈值、节点样本的基尼指数小于预定的阈值(分类树)、没有更多特征可以选择等。

递归过程中,每个非叶子节点都会生成两个子节点,从而构建出一棵二叉决策树。

3. 剪枝处理

为了避免过拟合,CART算法会对生成的决策树进行剪枝处理。剪枝的目的是简化决策树的复杂度,提高其对未知数据的预测能力。

CART算法通常采用后剪枝技术,即首先生成一棵完全生长的决策树,然后从树的底端开始,逐步剪去一些子树,直到满足某个停止条件(如损失函数最小)。剪枝过程中,会计算剪枝前后的损失函数变化量,选择使得损失函数最小的剪枝策略。

4. 决策树的应用

构建完成的CART决策树可以用于分类或回归任务。对于分类任务,决策树会根据输入的特征值,沿着决策树的路径进行遍历,直到达到一个叶子节点,该叶子节点对应的类别即为预测结果。

对于回归任务,决策树同样会根据输入的特征值进行遍历,但叶子节点对应的是一个具体的数值预测结果。

总的来说,CART算法通过递归地构建二叉决策树,并结合剪枝技术来提高模型的泛化能力,是一种非常有效且广泛应用的机器学习算法。

二、CART算法的Python实践

在Python中,使用CART算法的一个非常方便的方式是通过scikit-learn库,它提供了DecisionTreeClassifier(用于分类)和DecisionTreeRegressor(用于回归)两个类,这两个类都实现了CART算法。下面我将给出这两个类的简单使用示例。

1、分类任务(使用DecisionTreeClassifier)

首先,你需要安装scikit-learn库(如果你还没有安装的话):

pip install scikit-learn

然后,你可以使用以下代码进行CART分类树的实践:

from sklearn.datasets import load_iris

from sklearn.model_selection import train_test_split

from sklearn.tree import DecisionTreeClassifier

from sklearn import tree

import matplotlib.pyplot as plt

# 加载数据集

iris = load_iris()

X = iris.data

y = iris.target

# 划分训练集和测试集

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

# 创建决策树分类器实例

clf = DecisionTreeClassifier(criterion='gini', random_state=42)  # 使用基尼指数作为划分标准

# 训练模型

clf.fit(X_train, y_train)

# 预测测试集

y_pred = clf.predict(X_test)

# 评估模型(这里只是简单示例,你可以使用更复杂的评估方法)

accuracy = clf.score(X_test, y_test)

print(f'Accuracy: {accuracy}')

# 可视化决策树(可选)

plt.figure(figsize=(20,10))

tree.plot_tree(clf, filled=True, feature_names=iris.feature_names, class_names=iris.target_names)

plt.show()

2、回归任务(使用DecisionTreeRegressor)

对于回归任务,你可以使用DecisionTreeRegressor类,它的使用方式与DecisionTreeClassifier非常相似,只是目标变量y是连续的而不是离散的。

这里是一个简单的回归任务示例,但请注意,scikit-learn并没有内置用于回归任务的标准数据集,所以我们这里只是演示如何构建和训练模型:

import numpy as np

from sklearn.model_selection import train_test_split

from sklearn.tree import DecisionTreeRegressor

# 假设我们有以下简单的回归数据集(实际使用中,你需要从真实数据源加载数据)

X = np.array([[1], [2], [3], [4], [5], [6], [7], [8], [9], [10]])

y = np.array([2.7, 3.2, 3.8, 5.1, 5.9, 7.1, 7.9, 8.8, 9.2, 10.1])

# 划分训练集和测试集

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

# 创建决策树回归器实例

regressor = DecisionTreeRegressor(random_state=42)

# 训练模型

regressor.fit(X_train, y_train)

# 预测测试集

y_pred = regressor.predict(X_test)

# 评估模型(这里你可以使用MSE、RMSE等回归评估指标)

from sklearn.metrics import mean_squared_error

mse = mean_squared_error(y_test, y_pred)

print(f'MSE: {mse}')

# 注意:由于决策树回归器的可视化比较复杂,这里不展示可视化代码。

# 如果你需要可视化决策树,可以考虑使用`export_graphviz`函数将树导出为DOT格式,然后用Graphviz软件查看。在上面的示例中,我们使用了scikit-learn提供的数据集(对于分类)和自定义的简单数据集(对于回归)来演示如何使用CART算法进行分类和回归任务。在实际应用中,你需要从真实的数据源中加载数据,并进行适当的数据预处理和特征工程。

这篇关于CART算法原理及Python实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130798

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal