【Python机器学习专栏】集成学习中的Bagging与Boosting

简介: 【4月更文挑战第30天】本文介绍了集成学习中的两种主要策略:Bagging和Boosting。Bagging通过自助采样构建多个基学习器并以投票或平均法集成,降低模型方差,增强稳定性。在Python中可使用`BaggingClassifier`实现。而Boosting是串行学习,不断调整基学习器权重以优化拟合,适合弱学习器。Python中可利用`AdaBoostClassifier`等实现。示例代码展示了如何在实践中运用这两种方法。

在机器学习的领域中,集成学习是一种强大的技术,它通过构建并组合多个学习器(或称为“基学习器”)来完成学习任务。集成学习的主要目标是提高学习系统的泛化能力,即模型在新数据上的表现。其中,Bagging和Boosting是两种最流行的集成学习策略。本文将详细介绍这两种策略的原理、特点及其在Python中的应用。

一、Bagging

Bagging,即装袋法,是一种并行式的集成学习策略。它的基本思想是通过对原始数据集进行自助采样(Bootstrap Sampling),得到若干个不同的子集,并在每个子集上训练一个基学习器。由于采样是随机的,因此每个子集都会有所不同,这会导致每个基学习器学习到不同的知识。最后,通过投票法或平均法将这些基学习器的预测结果进行组合,得到最终的预测结果。

Bagging的主要优点包括:

能够降低模型的方差,提高模型的稳定性。由于每个基学习器都是在不同的数据集上训练的,因此它们之间的相关性较低,通过组合可以降低整体模型的方差。
对噪声和异常值具有较好的鲁棒性。由于每个基学习器都是在不同的数据集上训练的,因此即使某些数据集包含噪声或异常值,也不会对整个模型的性能产生太大影响。
在Python中,可以使用sklearn库中的BaggingClassifier或BaggingRegressor类来实现Bagging策略。以下是一个简单的示例:

python
from sklearn.ensemble import BaggingClassifier
from sklearn.tree import DecisionTreeClassifier
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score

加载数据集

iris = load_iris()
X, y = iris.data, iris.target

划分训练集和测试集

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

定义基学习器(这里使用决策树)

base_estimator = DecisionTreeClassifier(random_state=42)

使用BaggingClassifier进行集成

bagging_clf = BaggingClassifier(base_estimator=base_estimator, n_estimators=10, random_state=42)

训练模型

bagging_clf.fit(X_train, y_train)

预测测试集并计算准确率

y_pred = bagging_clf.predict(X_test)
print("Accuracy:", accuracy_score(y_test, y_pred))
二、Boosting

Boosting,即提升法,是一种串行式的集成学习策略。它的基本思想是通过迭代的方式,不断从错误中学习并调整每个基学习器的权重,以使得整个集成学习器能够更好地拟合训练数据。在Boosting中,每个基学习器都是基于前一个基学习器的预测结果进行训练的,因此它们之间存在依赖关系。

Boosting的主要优点包括:

能够提高模型的泛化能力。通过不断从错误中学习并调整基学习器的权重,Boosting能够使得整个集成学习器更好地拟合训练数据,从而提高模型的泛化能力。
对弱学习器具有较好的适应性。Boosting并不要求每个基学习器都具有很强的学习能力,只要它们能够在一定程度上正确分类样本,就可以通过Boosting的方式组合成一个强学习器。
在Python中,sklearn库提供了多种Boosting算法的实现,如AdaBoostClassifier、GradientBoostingClassifier等。以下是一个使用AdaBoostClassifier的示例:

python
from sklearn.ensemble import AdaBoostClassifier
from sklearn.tree import DecisionTreeClassifier
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score

加载数据集

iris = load_iris()
X, y = iris.data, iris.target

划分训练集和测试集

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

定义基学习器(这里使用决策树)

base_estimator = DecisionTreeClassifier(max_depth=1, random_state=42)

使用AdaBoostClassifier进行集成

ada_clf = AdaBoostClassifier(base_estimator=base_estimator, n_estimators=50, random_state=42)

训练模型

ada_clf.fit(X_train, y_train)

相关文章
|
9天前
|
机器学习/深度学习 人工智能 算法
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
手写数字识别系统,使用Python作为主要开发语言,基于深度学习TensorFlow框架,搭建卷积神经网络算法。并通过对数据集进行训练,最后得到一个识别精度较高的模型。并基于Flask框架,开发网页端操作平台,实现用户上传一张图片识别其名称。
30 0
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
|
11天前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
27 2
|
13天前
|
机器学习/深度学习 数据采集 搜索推荐
利用Python和机器学习构建电影推荐系统
利用Python和机器学习构建电影推荐系统
31 1
|
13天前
|
机器学习/深度学习 算法 PyTorch
用Python实现简单机器学习模型:以鸢尾花数据集为例
用Python实现简单机器学习模型:以鸢尾花数据集为例
36 1
|
19天前
|
机器学习/深度学习 数据采集 算法
Python机器学习:Scikit-learn库的高效使用技巧
【10月更文挑战第28天】Scikit-learn 是 Python 中最受欢迎的机器学习库之一,以其简洁的 API、丰富的算法和良好的文档支持而受到开发者喜爱。本文介绍了 Scikit-learn 的高效使用技巧,包括数据预处理(如使用 Pipeline 和 ColumnTransformer)、模型选择与评估(如交叉验证和 GridSearchCV)以及模型持久化(如使用 joblib)。通过这些技巧,你可以在机器学习项目中事半功倍。
24 3
|
24天前
|
机器学习/深度学习 人工智能 算法
机器学习基础:使用Python和Scikit-learn入门
机器学习基础:使用Python和Scikit-learn入门
29 1
|
30天前
|
机器学习/深度学习 算法 Java
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
|
1月前
|
机器学习/深度学习 人工智能 算法
机器学习基础:使用Python和Scikit-learn入门
【10月更文挑战第12天】本文介绍了如何使用Python和Scikit-learn进行机器学习的基础知识和入门实践。首先概述了机器学习的基本概念,包括监督学习、无监督学习和强化学习。接着详细讲解了Python和Scikit-learn的安装、数据处理、模型训练和评估等步骤,并提供了代码示例。通过本文,读者可以掌握机器学习的基本流程,并为深入学习打下坚实基础。
23 1
|
1月前
|
机器学习/深度学习 API 计算机视觉
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(下)
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(下)
26 2
|
1月前
|
机器学习/深度学习 存储 算法
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(上)
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(上)
31 1