机器学习集成学习——GBDT(Gradient Boosting Decision Tree 梯度提升决策树)算法

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

系列文章目录

机器学习神经网络——Adaboost分离器算法

机器学习之SVM分类器介绍——核函数、SVM分类器的使用

机器学习的一些常见算法介绍【线性回归岭回归套索回归弹性网络】

文章目录

系列文章目录

前言

一、GBDT(Gradient Boosting Decision Tree) 梯度提升决策树简介

1.1、集成学习

1.2、Boosting

1.3、AdaBoost

1.4、Gradient Boosting

1.5、 决策树与CART

二、GBDT算法的案例解读

2.1、使用梯度提升算法和决策树分类器对手写数字数据进行对比分析

2.2、GBDT算法参数的介绍

2.3、GBDT适用范围

总结


前言

本文主要介绍GBDT算法以及使用梯度提升算法和决策树分类器对手写数字数据进行对比分析的案例介绍

一、GBDT(Gradient Boosting Decision Tree) 梯度提升决策树简介

DTDecision Tree决策树GB是Gradient Boosting是一种学习策略GBDT的含义就是用Gradient Boosting的策略训练出来的DT模型

在前几年深度学习还没有大行其道之前GBDT在各种竞赛是大放异彩。一是效果确实挺不错。二是即可以用于分类也可以用于回归。三是可以筛选特征

1.1、集成学习

集成学习就是将多个弱的学习器结合起来组成一个强的学习器。
这就涉及到先产生一组‘个体学习器’再用一个策略将它们结合起来。

个体学习器可以选择决策树神经网络。

集成时可以所有个体学习器属于同一类算法全是决策树或全是神经网络也可以来自不同的算法。

结合策略例如分类问题可以用投票法少数服从多数。
之所以用这种集成的思想是因为单独用一个算法时效果往往不容易达到很好但如果多个个体算法结合在一起取长补短整体效果就会比单独一个要强。

当然集成并不是不管怎么选择学习器怎么组合都一定会获得更好的效果最好的情况是每个学习器都不是特别差并且要具有一定的多样性否则可能集成后的会没有效果或者起负作用。

这就是集成学习的一个核心问题如何生成准确性又不是很差并且还能保证多样性的个体学习器呢

目前主要有两种生成方式

  • Boosting个体学习器间存在强依赖关系必须串行生成。
  • Bagging随机森林个体之间不存在强依赖关系可并行生成。

1.2、Boosting

Boosting 的思想,三个臭皮匠顶一个诸葛亮:

给定初始训练数据由此训练出第一个基学习器
根据基学习器的表现对样本进行调整在之前学习器做错的样本上投入更多关注
用调整后的样本训练下一个基学习器
重复上述过程 T 次将 T 个学习器加权结合。
简单讲就是每次训练单个弱学习器时都将上一次分错的数据权重提高一点再进行当前单个弱学习器的学习。这样越往后执行训练出的单个弱学习器就会越在意那些容易分错权重高的点。当执行 M 次后通过加权求和的方式组合成一个最终的学习器。

Boosting模型可以抽象为一个前向加法模型additive model:
根据 Boosting 的定义它有三个基本要素

  • 基学习器
  • 组合方式
  • 目标函数

1.3、AdaBoost

Boosting 的代表是 Adaboost。

• 第 1 行初始化样本权重分布此时每个数据的权重是一样的所以是 1/m
以分类问题为例最初令每个样本的权重都相等对于第 t 次迭代操作我们就根据这些权重来选取样本点进而训练分类器 C_t。
• 第 2 行进入 for 循环 T 次即基学习器的个数为 T 个
• 第 3 行根据具有当前权重分布 D_t 的数据集学习出 h_t
前一个分类器分错的样本会被用来训练下一个分类器。
h_t 是分量分类器 C_t 给出的对任一样本点 xi 的标记+1或-1h_t(xi) = yi 时样本被正确分类。
• 第 4 行计算当前学习器的误差
• 第 5 行如果误差大于 0.5就停止
AdaBoost 方法中使用的分类器可能很弱比如出现很大错误率但只要它的分类效果比随机好一点比如两类问题分类错误率略小于0.5就能够改善最终得到的模型。
• 第 6 行计算当前学习器的权重 α_t
权值是关于误差的表达式当下一次分类器再次错分这些点之后会提高整体的错误率这样就导致分类器权值变小进而导致这个分类器在最终的混合分类器中的权值变小也就是说Adaboost算法让正确率高的分类器占整体的权值更高让正确率低的分类器权值更低从而提高最终分类器的正确率。
• 第 7 行得到下一时刻的权重分布 D_t1.
如果某个样本点已经被准确地分类那么在构造下一个训练集中它被选中的概率就被降低相反如果某个样本点没有被准确地分类那么它的权重就得到提高。通过这样的方式AdaBoost 方法能“聚焦于”那些较难分更富信息的样本上。

此算法的案例可以参考本篇博客

机器学习神经网络——Adaboost分离器算法

1.4、Gradient Boosting

AdaBoost每一轮基学习器训练过后都会更新样本权重再训练下一个学习器最后将所有的基学习器加权组合。AdaBoost使用的是指数损失这个损失函数的缺点是对于异常点非常敏感因而通常在噪音比较多的数据集上表现不佳。Gradient Boosting在这方面进行了改进使得可以使用任何损失函数 (只要损失函数是连续可导的)这样一些比较robust的损失函数就能得以应用使模型抗噪音能力更强。
和Adaboost不同Gradient Boosting 在迭代的时候选择梯度下降的方向来保证最后的结果最好。
算法将负梯度作为残差值来学习基本模型h(x).

1.5、 决策树与CART

1976年-1986年J.R.Quinlan给出ID3算法原型并进行了总结确定了决策树学习的理论。这可以看做是决策树算法的起点。1993Quinlan将ID3算法改进成C4.5算法称为机器学习的十大算法之一。ID3算法的另一个分支是CART(Classification adn Regression Tree, 分类回归决策树)用于预测。这样决策树理论完全覆盖了机器学习中的分类和回归两个领域。

 决策树
决策树(decision tree)一般都是自上而下的来生成的。每个决策或事件即自然状态都可能引出两个或多个事件导致不同的结果把这种决策分支画成图形很像一棵树的枝干故称决策树。

决策树利用如下图所示的树结构进行决策每一个非叶子节点是一个判断条件每一个叶子节点是结论。从跟节点开始经过多次判断得出结论。

决策树的构建是数据逐步分裂的过程构建的步骤如下:

  • 步骤1将所有的数据看成是一个节点进入步骤2
  • 步骤2从所有的数据特征中挑选一个数据特征对节点进行分割进入步骤3
  • 步骤3生成若干孩子节点对每一个孩子节点进行判断如果满足停止分裂的条件进入步骤4否则进入步骤2
  • 步骤4设置该节点是子节点其输出的结果为该节点数量占比最大的类别。

从上述步骤可以看出决策生成过程中有三个重要的问题

  • 1数据如何分割
  • 2如何选择分裂的属性
  • 3什么时候停止分裂

决策树decision tree算法基于特征属性进行分类其主要的优点模型具有可读性计算量小分类速度快。

二、GBDT算法的案例解读

2.1、使用梯度提升算法和决策树分类器对手写数字数据进行对比分析

#使用梯度提升算法和决策树分类器对手写数字数据进行对比分析
import numpy as np
#导入sklearn内置数据集 
from sklearn.datasets import load_digits
#导入手写数字数据
digits = load_digits()
#以图片形式显示前100号手写数字
import matplotlib.pyplot as plt
plt.figure(1, figsize=(3.5,3.5),facecolor='white') 
for i in range(10): 
    for j in range(10):
        ax= plt.subplot(10,10,10*i+j+1)
        #设置子图的位置
        ax.set_xticks([])
        #隐藏横坐标
        #隐藏纵坐标
        ax.set_yticks([])
        plt.imshow(digits.images[9*i+j],cmap=plt.cm.gray_r,interpolation="nearest")
plt.show()
#导入sklearn中的模型验证类 
from sklearn.model_selection import train_test_split
#使用train test_split函数自动分割训练数据集和测试数据集
x_train,x_test,y_train,y_test = train_test_split(digits.data,digits.target,test_size=0.3)
#导入sklearn模块中的决策树分类器类 
from sklearn.tree import DecisionTreeClassifier
#定义一个决策树分类器对象
dtc = DecisionTreeClassifier()
dtc.fit(x_train,y_train)
#导入sklearn模块中的梯度提升分类器类 
from sklearn.ensemble import GradientBoostingClassifier
#定义一个梯度提升决策树分类器对象
gbc = GradientBoostingClassifier(n_estimators=30,learning_rate=0.1)
gbc.fit(x_train,y_train)
print("单棵决策树在训练集上的性能%.3f"%dtc.score(x_train,y_train))
print("单棵决策树在测试集上的性能%.3f"%dtc.score(x_test,y_test))
print("GBDT(T-30)在训练集上的性能%.3f"%gbc.score(x_train,y_train))
print("GBDT(T-30)在测试集上的性能%.3f"%gbc.score(x_test,y_test))
#观察弱分类器数量对分类准确度的影响
#弱分类器的最大值
T_max =39
gbc_train_scores=[] 
gbc_test_scores=[] 
for i in range(1,T_max+1):
    gbc = GradientBoostingClassifier(n_estimators=i,learning_rate=0.1)
    gbc.fit(x_train,y_train)
    gbc_train_scores.append(gbc.score(x_train,y_train))
    gbc_test_scores.append(gbc.score(x_test,y_test))
#绘制测试结果
import matplotlib.pyplot as plt
#解决图形中的中文显示乱码
plt.rcParams['font.sans-serif']=['SimHei']
plt.matplotlib.rcParams['axes.unicode_minus']=False 
plt.figure()
#解决图形中的坐标轴负号显示问题
plt.plot(range(1,T_max+1),gbc_train_scores,color='r',label='训练集')
plt.plot(range(1,T_max+1),gbc_test_scores,color='g',label='测试集')
plt.title("基学习器数量对GBDT性能的影响")
plt.xlabel("基分类器数量")
plt.ylabel("准确率")
plt.xlim(1,T_max)
plt.legend()
plt.show()

运行结果

aba7884f7a4e44b8b8b400f9653adb65.png

单棵决策树在训练集上的性能1.000
单棵决策树在测试集上的性能0.822
GBDT(T-30)在训练集上的性能0.999
GBDT(T-30)在测试集上的性能0.928

47b638bfbd434d2ba7c114dafdf23960.png

案例二

# 导入GBDT分类器模型
from sklearn.ensemble import GradientBoostingClassifier
# 定义一个GBDT分类器模型设置参数
gbdt = GradientBoostingClassifier(n_estimators=100, learning_rate=0.1, max_depth=3)
# 训练模型
gbdt.fit(X_train, y_train)
# 使用训练好的模型进行预测
y_pred = gbdt.predict(X_test)
# 输出预测结果
print(y_pred)

第一行导入了sklearn库中的GBDT分类器模型。

第二行定义了一个GBDT分类器模型其中n_estimators表示迭代次数learning_rate表示学习率max_depth表示决策树的最大深度。

第三行使用训练数据集进行模型训练。

第四行使用训练好的模型对测试数据集进行预测。

第五行输出预测结果。

案例三

# 导入GBDT分类器模型
from sklearn.ensemble import GradientBoostingClassifier
# 定义一个GBDT分类器模型设置参数
gbdt = GradientBoostingClassifier(n_estimators=100, learning_rate=0.1, max_depth=3, min_samples_split=2, min_samples_leaf=1, max_features=None)
# 训练模型
gbdt.fit(X_train, y_train)
# 使用训练好的模型进行预测
y_pred = gbdt.predict(X_test)
# 输出预测结果
print(y_pred)

在这个例子中我们使用了n_estimators=100进行了100次迭代使用了learning_rate=0.1来调整每个决策树的权重使用了max_depth=3限制了每个决策树的最大深度使用了min_samples_split=2和min_samples_leaf=1来限制了节点和叶子节点的最小样本数使用了max_features=None考虑了所有特征。

2.2、GBDT算法参数的介绍

GBDT类在scikit-learn库中有多个参数以下是其中一些主要参数的说明

- n_estimators指定迭代次数即决策树的个数。默认为100。

- learning_rate指定学习率用于调整每个决策树的权重。学习率越小模型越稳定但需要更多的迭代次数才能达到较好的结果。默认为0.1。

- max_depth指定每个决策树的最大深度。默认为3。

- min_samples_split指定一个节点在被分割之前所需的最小样本数。默认为2。

- min_samples_leaf指定一个叶子节点所需的最小样本数。默认为1。

- max_features指定每个节点在进行分割时所考虑的特征数量。默认为None表示考虑所有的特征。

2.3、GBDT适用范围

GBDT既可以用于分类模型也可以用于回归模型。在分类模型中GBDT通过训练多个决策树来预测样本的类别每个决策树的输出是概率值或者类别标签。在回归模型中GBDT通过训练多个决策树来预测目标变量的值每个决策树的输出是一个实数值。

一个分类模型的例子是通过GBDT算法预测信用卡交易是否为欺诈。一个回归模型的例子是通过GBDT算法预测房价。

总结

以上就是今天的内容~

最后欢迎大家点赞收藏⭐转发
如有问题、建议请您在评论区留言哦。

 

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: 机器学习