绘制单个和投票回归预测#

投票回归器是一个集成元估计器,它拟合多个基回归器,每个回归器都在整个数据集上拟合。然后它对单个预测进行平均以形成最终预测。我们将使用三个不同的回归器来预测数据:GradientBoostingRegressorRandomForestRegressorLinearRegression)。然后,以上 3 个回归器将用于 VotingRegressor

最后,我们将绘制所有模型做出的预测以进行比较。

我们将使用糖尿病数据集,该数据集包含从糖尿病患者队列中收集的 10 个特征。目标是基线一年后疾病进展的定量指标。

# Authors: The scikit-learn developers
# SPDX-License-Identifier: BSD-3-Clause

import matplotlib.pyplot as plt

from sklearn.datasets import load_diabetes
from sklearn.ensemble import (
    GradientBoostingRegressor,
    RandomForestRegressor,
    VotingRegressor,
)
from sklearn.linear_model import LinearRegression

训练分类器#

首先,我们将加载糖尿病数据集并初始化梯度提升回归器、随机森林回归器和线性回归。接下来,我们将使用这 3 个回归器来构建投票回归器

X, y = load_diabetes(return_X_y=True)

# Train classifiers
reg1 = GradientBoostingRegressor(random_state=1)
reg2 = RandomForestRegressor(random_state=1)
reg3 = LinearRegression()

reg1.fit(X, y)
reg2.fit(X, y)
reg3.fit(X, y)

ereg = VotingRegressor([("gb", reg1), ("rf", reg2), ("lr", reg3)])
ereg.fit(X, y)
VotingRegressor(estimators=[('gb', GradientBoostingRegressor(random_state=1)),
                            ('rf', RandomForestRegressor(random_state=1)),
                            ('lr', LinearRegression())])
在 Jupyter 环境中,请重新运行此单元格以显示 HTML 表示或信任笔记本。
在 GitHub 上,HTML 表示无法呈现,请尝试使用 nbviewer.org 加载此页面。


进行预测#

现在我们将使用每个回归器进行前 20 个预测。

xt = X[:20]

pred1 = reg1.predict(xt)
pred2 = reg2.predict(xt)
pred3 = reg3.predict(xt)
pred4 = ereg.predict(xt)

绘制结果#

最后,我们将可视化 20 个预测。红色星号显示由 VotingRegressor 做出的平均预测。

plt.figure()
plt.plot(pred1, "gd", label="GradientBoostingRegressor")
plt.plot(pred2, "b^", label="RandomForestRegressor")
plt.plot(pred3, "ys", label="LinearRegression")
plt.plot(pred4, "r*", ms=10, label="VotingRegressor")

plt.tick_params(axis="x", which="both", bottom=False, top=False, labelbottom=False)
plt.ylabel("predicted")
plt.xlabel("training samples")
plt.legend(loc="best")
plt.title("Regressor predictions and their average")

plt.show()
Regressor predictions and their average

脚本总运行时间:(0 分钟 1.164 秒)

相关示例

普通最小二乘法示例

普通最小二乘法示例

使用堆叠组合预测器

使用堆叠组合预测器

使用 AdaBoost 的决策树回归

使用 AdaBoost 的决策树回归

梯度提升回归

梯度提升回归

由 Sphinx-Gallery 生成的图库