【机器学习】集成学习——提升模型准确度的秘密武器

news2024/12/25 16:03:41

【机器学习】集成学习——提升模型准确度的秘密武器

1. 引言

集成学习(Ensemble Learning)是一种通过结合多个弱模型来提升整体预测准确性的技术。通过将多个模型的预测结果进行组合,集成学习在复杂任务中展现了极强的泛化能力。本文将探讨集成学习的主要方法,并通过代码示例演示如何应用这些方法来提升模型表现。

在这里插入图片描述

2. 什么是集成学习?

集成学习的核心思想是将多个模型(弱学习器)组合成一个更强大的模型。常见的集成学习方法包括:

  • Bagging(袋装法)
  • Boosting(提升法)
  • Stacking(堆叠法)

这些方法通过不同的策略组合模型,降低单个模型的误差,提高准确性和鲁棒性。

3. Bagging(袋装法)

3.1 Bagging 的原理

Bagging 通过对数据集进行多次有放回采样,训练多个模型,并将这些模型的预测结果进行平均或投票。它可以有效减少过拟合,特别适用于高方差模型,如决策树。

在这里插入图片描述

3.2 随机森林(Random Forest)

随机森林是 Bagging 的一种典型实现,它通过构建多个决策树,并结合它们的结果来进行预测。

python复制代码from sklearn.ensemble import RandomForestClassifier
from sklearn.model_selection import train_test_split
from sklearn.datasets import load_iris
from sklearn.metrics import accuracy_score

# 加载数据
iris = load_iris()
X_train, X_test, y_train, y_test = train_test_split(iris.data, iris.target, test_size=0.3, random_state=42)

# 创建随机森林模型
rf_model = RandomForestClassifier(n_estimators=100, random_state=42)
rf_model.fit(X_train, y_train)

# 预测与评估
y_pred = rf_model.predict(X_test)
print(f"随机森林准确率: {accuracy_score(y_test, y_pred)}")

4. Boosting(提升法)

4.1 Boosting 的原理

Boosting 的核心思想是通过迭代地训练多个弱学习器,每次调整上一次模型中错误分类的样本权重,从而提升模型的整体性能。与 Bagging 不同,Boosting 强调模型之间的顺序性。

4.2 梯度提升决策树(Gradient Boosting)

梯度提升决策树(GBDT)是一种流行的 Boosting 方法,适用于回归和分类任务。它通过最小化损失函数来优化模型。

python复制代码from sklearn.ensemble import GradientBoostingClassifier

# 创建梯度提升模型
gb_model = GradientBoostingClassifier(n_estimators=100, learning_rate=0.1, random_state=42)
gb_model.fit(X_train, y_train)

# 预测与评估
y_pred = gb_model.predict(X_test)
print(f"梯度提升准确率: {accuracy_score(y_test, y_pred)}")

在这里插入图片描述

4.3 XGBoost

XGBoost 是一种优化版的梯度提升算法,具有更快的计算速度和更高的预测精度。

python复制代码import xgboost as xgb
from sklearn.metrics import accuracy_score

# 转换数据格式为 DMatrix
dtrain = xgb.DMatrix(X_train, label=y_train)
dtest = xgb.DMatrix(X_test, label=y_test)

# 设置模型参数
params = {'objective': 'multi:softmax', 'num_class': 3, 'max_depth': 3, 'learning_rate': 0.1}
num_round = 100

# 训练模型
xgb_model = xgb.train(params, dtrain, num_round)

# 预测与评估
y_pred = xgb_model.predict(dtest)
print(f"XGBoost 准确率: {accuracy_score(y_test, y_pred)}")

5. Stacking(堆叠法)

5.1 Stacking 的原理

Stacking 通过将多个不同的模型组合在一起,通常会使用一个**元学习器(Meta-Learner)**来整合各个基础模型的预测结果。与 Bagging 和 Boosting 不同,Stacking 不要求模型类型相同,因此可以通过组合不同类型的模型(如决策树、逻辑回归、支持向量机等)来增强表现。

5.2 Stacking 示例

下面是使用 Stacking 的示例,通过将决策树、逻辑回归和支持向量机的预测结果结合在一起进行最终预测。

python复制代码from sklearn.ensemble import StackingClassifier
from sklearn.linear_model import LogisticRegression
from sklearn.svm import SVC
from sklearn.tree import DecisionTreeClassifier

# 创建基础模型
estimators = [
    ('dt', DecisionTreeClassifier()),
    ('svc', SVC(probability=True))
]

# 创建堆叠模型,使用逻辑回归作为元学习器
stacking_model = StackingClassifier(estimators=estimators, final_estimator=LogisticRegression())
stacking_model.fit(X_train, y_train)

# 预测与评估
y_pred = stacking_model.predict(X_test)
print(f"Stacking 准确率: {accuracy_score(y_test, y_pred)}")

在这里插入图片描述

6. 集成学习的优势

集成学习相比单一模型有以下几个优势:

  • 降低方差:通过结合多个模型,集成学习可以减少单一模型的方差,提升泛化能力。
  • 提高准确性:集成学习往往比单一模型具有更高的预测准确率。
  • 增强鲁棒性:集成模型对异常数据点的敏感性较低,更加稳健。

7. 集成学习的挑战

尽管集成学习有诸多优势,但它也有一些挑战:

  • 计算开销:集成学习涉及多个模型的训练,计算资源消耗较大。
  • 模型复杂性:集成学习的模型更加复杂,难以解释和调试。

在这里插入图片描述

8. 总结

集成学习是一种强大的技术,通过结合多个弱模型来提升整体预测准确性。本文介绍了三种常见的集成学习方法:Bagging、Boosting 和 Stacking,并通过代码示例展示了如何应用这些方法。在实际项目中,集成学习能有效提高模型的性能,特别是在数据复杂、模型表现有限的情况下。

9. 参考资料

  • XGBoost 官方文档

使用机器学习技术分析CSDN热榜

在这里插入图片描述

  • 机器学习上热榜太难了,最难的部分在于要找机器学习的图片,然后变成博客封面。建议CSDN减少对机器学习上热榜难度,只要标题是机器学习,不需要内容也能上热榜。
    img

你好,我是Qiuner. 为帮助别人少走弯路而写博客 这是我的 github https://github.com/Qiuner⭐ gitee https://gitee.com/Qiuner 🌹

如果本篇文章帮到了你 不妨点个吧~ 我会很高兴的 😄 (^ ~ ^) 。想看更多 那就点个关注吧 我会尽力带来有趣的内容 😎。

代码都在github或gitee上,如有需要可以去上面自行下载。记得给我点星星哦😍

如果你遇到了问题,自己没法解决,可以去我掘金评论区问。私信看不完,CSDN评论区可能会漏看 掘金账号 https://juejin.cn/user/1942157160101860 掘金账号

更多专栏:
  • 📊 一图读懂系列

  • 📝 一文读懂系列

  • ⚽ Uniapp

  • 🌟 持续更新

  • 🤩 Vue项目实战

  • 🚀 JavaWeb

  • 🎨 设计模式

  • 📡 计算机网络

  • 🎯 人生经验

  • 🔍 软件测试

掘金账号 CSDN账号

感谢订阅专栏 三连文章

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2186529.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于微信的乐室预约小程序+ssm(lw+演示+源码+运行)

摘 要 随着社会的发展,社会的方方面面都在利用信息化时代的优势。互联网的优势和普及使得各种系统的开发成为必需。 本文以实际运用为开发背景,运用软件工程原理和开发方法,它主要是采用java语言技术和mysql数据库来完成对系统的设计。整个…

深入探讨指令调优的局限性

深入探讨指令调优的局限性 摘要 指令调优(Instruction Tuning, IT)是通过使用指令-响应对训练大型语言模型(LLMs)的过程,已成为将基础预训练LLMs转化为开放领域对话代理的主要方法。尽管IT取得了显著的成功和广泛的应…

HUAWEI New4.9G 与 2.6G 无法正常切换问题处理案例

HUAWEI New4.9G 与 2.6G 无法正常切换问题处理案例 在某地市的 XX 音乐节保障准备期间,为确保活动期间的网络质量,现场新开了 4.9G HUAWEI 室外基站。在网络优化和测试中,发现UE无法实现从 2.6G 到 4.9G 的正常切换。虽然现场具备 4.9G信号覆…

算法与数据结构--二分查找

原理 简单说就是每次二分取中间值,然后将中间值与我们要找的值比较,如果比它大就移动左边界到其右侧,如果比它小就移动右边界到其左侧。直到中间值等于该值或者经过移动直至右边界在左边界左侧为止。 二.具体实现 public int searchInsert(…

数据结构 ——— 单链表oj题:反转链表

目录 题目要求 手搓一个简易链表 代码实现 题目要求 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表 手搓一个简易链表 代码演示: struct ListNode* n1 (struct ListNode*)malloc(sizeof(struct ListNode)); assert(n1);…

【重学 MySQL】五十三、MySQL数据类型概述和字符集设置

【重学 MySQL】五十三、MySQL数据类型概述和字符集设置 MySQL数据类型概述MySQL字符集设置注意事项 MySQL数据类型概述 MySQL是一个流行的关系型数据库管理系统,它支持多种数据类型,以满足不同数据处理和存储的需求。理解并正确使用这些数据类型对于提高…

已解决:org.springframework.web.HttpMediaTypeNotAcceptableException

文章目录 写在前面问题描述报错原因分析: 解决思路解决办法1. 确保客户端请求的 Accept 头正确2. 修改 Controller 方法的 produces 参数3. 配置合适的消息转换器4. 检查 Spring 配置中的媒体类型5. 其他解决方案 总结 写在前面 在开发过程中,Spring 框…

实验1 集成开发环境的使用及程序设计入门

1、求两点之间的距离 【问题描述】从键盘输入平面上已知两点的坐标A(x1,y1)、B(x2,y2),计算两点之间的距离。结果保留4位小数。 【输入形式】两个点的坐标 【输出形式】两点之间的距离 【样例输入】 0 0 3 4 【样例输出】 5.0000 #define _CRT_SECURE_NO_WARNI…

(C语言贪吃蛇)12.Linux线程概念引入及编程实现

目录 前言 Linux线程概念 解决方法 注意事项⚠️ 解决问题🔥 总结 前言 我们上节提出了两个死循环不能同时运行,导致我们无法控制贪吃蛇的运动方向,本节我们便来解决这个问题。 Linux线程概念 线程是一个进程内部的控制序列&#xff0c…

鸿蒙应用开发前置学习-TypeScript

注意:博主有个鸿蒙专栏,里面从上到下有关于鸿蒙next的教学文档,大家感兴趣可以学习下 如果大家觉得博主文章写的好的话,可以点下关注,博主会一直更新鸿蒙next相关知识 专栏地址: https://blog.csdn.net/qq_56760790/…

杭州电子科技大学《2019年+2023年861自动控制原理真题》 (完整版)

本文内容,全部选自自动化考研联盟的:《杭州电子科技大学861自控考研资料》的真题篇。后续会持续更新更多学校,更多年份的真题,记得关注哦~ 目录 2019年真题 2023年真题 Part1:2019年2023年完整版真题 2019年真题 2…

【Linux私房菜(九)之进程间通信】

文章目录 进程间通信介绍进程间通信的概念进程间通信的目的进程间通信的本质进程间通信的分类 管道什么是管道匿名管道匿名管道的原理pipe函数匿名管道使用步骤管道读写规则管道的特点管道的四种特殊情况管道的大小 命名管道命名管道的原理使用命令创建命名管道创建一个命名管道…

会声会影导出视频mp4格式哪个最高清,会声会影输出格式哪个清晰

调高分辨率后,mp4视频还是不清晰。哪怕全部使用4K级素材,仍然剪不出理想中的高画质作品。不是你的操作有问题,而是剪辑软件没选对。Corel公司拥有全球顶尖的图像处理技术,该公司研发的会声会影视频剪辑软件,在过去的20…

详解CSS中的伪元素

4.3 伪元素 可以把样式应用到文档树中根本不存在的元素上。 ::first-line 文本中的第一行 ::first-letter 文本中的第一个字母 ::after 元素之后添加 ::before 元素之前 代码&#xff1a; <!DOCTYPE html> <html> <head><meta charset"utf-8&q…

netty之Netty传输Java对象

前言 Netty在实际应用级开发中&#xff0c;有时候某些特定场景下会需要使用Java对象类型进行传输&#xff0c;但是如果使用Java本身序列化进行传输&#xff0c;那么对性能的损耗比较大。为此我们需要借助protostuff-core的工具包将对象以二进制形式传输并做编码解码处理。与直接…

无线物联网通信与智能家居

无线物联网通信技术与智能家居之间存在着密不可分的关系。无线物联网通信技术作为智能家居系统的核心支撑&#xff0c;为智能家居设备之间的互联互通提供了可能&#xff0c;从而实现了家居生活的智能化、便捷化和舒适化。 一、无线物联网通信技术在智能家居中的应用 1、传感器…

LabVIEW程序员从幼稚到成熟的标志是什么?

LabVIEW程序员从“幼稚”到“成熟”的转变标志主要体现在以下几个方面&#xff1a; 1. 系统性思维与架构设计 初学者通常会注重功能实现&#xff0c;常常直接编写功能模块&#xff0c;而忽略系统整体的架构设计。成熟的LabVIEW程序员则具备系统性思维&#xff0c;在开始编写代…

Ericsson EPSFB 通话掉话现象优化案例

Ericsson EPSFB 通话掉话现象优化案例 在移动通信网络中&#xff0c;用户体验的稳定性和通话质量至关重要。随着通信语言通话技术的发展&#xff0c;部分用户在通话时会遇到掉话现象&#xff0c;尤其是在采用EPSFB&#xff08;EvolvedPacket>System Fallback&#xff09;技术…

【WRF工具】cmip6-to-wrfinterm工具概述:生成WRF中间文件

cmip6-to-wrfinterm工具概述 cmip6-to-wrfinterm工具安装cmip6-to-wrfinterm工具使用快速启动&#xff08;Quick start&#xff09;情景1&#xff1a;MPI-ESM-1-2-HR&#xff08;默认&#xff09;&#xff1a;情景2&#xff1a;BCMM情景3&#xff1a;EC-Earth3 更改使用&#x…

SpringBoot框架下美容院管理系统的设计与实现

第二章 开发环境 对美容院管理系统进行开发&#xff0c;需要了解开发技术的理论与实际运用&#xff0c;对开发工具&#xff0c;尤其是数据库的使用方法需要进行掌握。 2.1 SpringBoot框架 SpringBoot框架的诞生是出于需要优化Spring框架的前提下&#xff0c;Spring框架随着时间…