梯度提升技术

来自testwiki
imported>Efsauser2024年3月11日 (一) 04:01的版本
(差异) ←上一版本 | 最后版本 (差异) | 下一版本→ (差异)
跳转到导航 跳转到搜索

Template:NoteTA

梯度提升,亦稱作梯度增强,是一种用于回归分类问题的机器学习技术。其产生的预测模型是弱预测模型的集成,如采用典型的决策树作为弱预测模型,这时则为梯度提升树(Template:AbbrTemplate:Abbr)。像其他提升方法一样,它以分阶段的方式构建模型,但它通过允许对任意可微分损失函数进行优化作为对一般提升方法的推广。

梯度提升技術源自於Template:Link-en於1997年時將提升方法用於优化算法的观察[1]。随后Template:Link-en於1999年時提出了显式回归梯度增强算法[2][3]。Llew Mason、Jonathan Baxter、Peter Bartlett和Marcus Frean則針對梯度提升在一般的函数空间的運用進行研究,並於1999年在研討會發表之後[4],同年正式發表了论文[5]。該论文介绍了将提升算法看作“函数空间上的梯度下降迭代”算法的观点。也就是将其视为通过迭代地选择指向负梯度方向的函数(弱预测模型),来优化函数空间上的成本函数的算法。这种将提升视为函数梯度的观点,导致了提升算法被運用於回归和分类之外的其他机器学习和统计领域的後續发展。

非正式介绍

(本节遵循Li对梯度增强的说明[6]。)

与其他增强方法一样,梯度增强以迭代方式将弱的“学习器”组合为一个强学习器。最简单的解释是在最小二乘回归中,通过最小化均方误差 1ni(y^iyi)2 ,“教”模型F预测实数值y^=F(x)

在梯度提升的每个阶段 m, 1mM, 假设已经有一个不太完美的模型 Fm (最开始时只是一个预测输出变量 Template:Mvar 均值的模型)。 梯度提升算法通过在当前模型 Fm 增加一个新的估计量 Template:Mvar 得到一个更好的模型: Fm+1(x)=Fm(x)+h(x). 为了求得 h, 梯度提升基于以下观察:一个完美的 Template:Mvar 可以完美预测当前不完美模型Fm的残差,即满足,

Fm+1(x)=Fm(x)+h(x)=y

或者,等效地有,

h(x)=yFm(x).

因此,梯度提升通过拟合残差 yFm(x)得到 Template:Mvar 。和其他提升方法的变体一样, Fm+1 通过纠正 Fm的误差变得更完美。 这个想法可以扩展到均方误差损失之外的任意损失函数,甚至扩展到分类与排序问题,只要观察到以下一点:模型的残差 yFm(x)就是均方损失函数12(yF(x))2关于F(x)的负梯度。因此,梯度提升其实是一种 梯度下降算法,可以代入除了均方损失之外的不同的损失函数,得到不同的梯度。

算法

在许多有监督学习问题中,一个输出变量Template:Mvar和一个输入变量Template:Mvar通过联合概率分布P(x,y)描述 。给定训练集{(x1,y1),,(xn,yn)},目的是在所有具有给定形式的函数F(x)中找到一个F^(x)使某些指定损失函数L(y,F(x))的期望值达到最小:

F^=argminF𝔼x,y[L(y,F(x))].

梯度提升方法通过某一类中弱学习器(或称基学习器hi(x)带权重和的形式来表示对实值变量Template:Mvar做出估计的F^(x):

F^(x)=i=1Mγihi(x)+const.

根据经验风险最小化原理,该方法试图找到一个近似F^(x)可以最大程度地减少训练集上损失函数的平均值,即,最小化经验风险。它是从一个由常数函数组成的模型F0(x)开始 ,并以贪心的方式逐步扩展:

F0(x)=argminγi=1nL(yi,γ),
Fm(x)=Fm1(x)+argminhm[i=1nL(yi,Fm1(xi)+hm(xi))],

上式hm是基学习器。

不幸的是,通常在每个步骤中为任意损失函数Template:Mvar选择最佳函数Template:Mvar是计算上不可行的优化问题。因此,我们将方法局限于问题的简化版本。

这个想法是对这个最小化问题(函数梯度下降)应用梯度下降步骤。如果我们考虑连续情况,即是上的任意微分函数的集合 ,我们将根据以下方程式更新模型

Fm(x)=Fm1(x)γmi=1nFm1L(yi,Fm1(xi)),
γm=argminγi=1nL(yi,Fm1(xi)γFm1L(yi,Fm1(xi))),

式子中,对于i{1,..,m}是关于函数Fi求导,γm是步长。 但是在离散情况下,即如果是有限的,我们选择最接近Template:Mvar梯度的候选函数Template:Mvar ,然后可以根据上述等式通过线搜索来计算系数Template:Mvar。请注意,这种方法是一种启发式方法,因此不能给出给定问题的精确解决方案,而是一种近似方法。 在伪代码中,通用梯度增强方法是[2][7]Template:彩色框 头部 Input: training set {(xi,yi)}i=1n, a differentiable loss function L(y,F(x)), number of iterations Template:Mvar.

Algorithm:

  1. Initialize model with a constant value:
    F0(x)=argminγi=1nL(yi,γ).
  2. For Template:Mvar = 1 to Template:Mvar:
    1. Compute so-called pseudo-residuals:
      rim=[L(yi,F(xi))F(xi)]F(x)=Fm1(x)for i=1,,n.
    2. Fit a base learner (or weak learner, e.g. tree) hm(x) to pseudo-residuals, i.e. train it using the training set {(xi,rim)}i=1n.
    3. Compute multiplier γm by solving the following one-dimensional optimization problem:
      γm=argminγi=1nL(yi,Fm1(xi)+γhm(xi)).
    4. Update the model:
      Fm(x)=Fm1(x)+γmhm(x).
  3. Output FM(x).

Template:彩色框 底部

梯度树增强

梯度提升通常与固定大小的决策树 (尤其是CART树)一起用作基础学习者。 对于这种特殊情况,Friedman提出了对梯度增强方法的改进,以提高每个基础学习者的适应质量。

第m步的通用梯度提升将适合决策树hm(x)伪残留物。 让Jm是它的叶子数。 树将输入空间划分为Jm不相交的区域R1m,,RJmm并预测每个区域的恒定值。 使用指标符号 ,输出hm(x)输入x可以写为和:

hm(x)=j=1Jmbjm𝟏Rjm(x),

这里bjm是该区域中预测的值RjmTemplate:Efn

然后系数bjm乘以一些值γm ,使用线搜索进行选择,以最大程度地减少损失函数,并按以下方式更新模型:

Fm(x)=Fm1(x)+γmhm(x),γm=argminγi=1nL(yi,Fm1(xi)+γhm(xi)).

弗里德曼(Friedman)建议修改此算法,以便选择一个单独的最佳值γjm每个树的区域,而不是单个γm为整棵树。 他称修改后的算法为“ TreeBoost”。 系数bjm然后可以简单地丢弃树拟合过程中的数据,模型更新规则变为:

Fm(x)=Fm1(x)+j=1Jmγjm𝟏Rjm(x),γjm=argminγxiRjmL(yi,Fm1(xi)+γ).

树木大小

J (树中终端节点的数量)是该方法的参数,可以针对手头的数据集进行调整。 它控制模型中变量之间允许的最大交互级别。 用J=2 ( 决策树桩 ),不允许变量之间进行交互。 用J=3该模型可能包括多达两个变量之间的相互作用的影响,依此类推。

Hastie等人评论通常4J8对于提升效果很好,结果对选择J在这个范围内J=2不足以用于许多应用程序,并且J>10不太可能是必需的[7]

正则化

过于紧密地拟合训练集可能导致模型的泛化能力下降。 几种所谓的正则化技术通过限制拟合过程来减少这种过度拟合的效果。

一个自然的正则化参数是梯度提升迭代的次数M(即,当基础学习者是决策树时,模型中的树的数量)。M的增加会减少训练集上的误差,但将其设置得过高可能会导致过度拟合。 通常通过监视单独的验证数据集上的预测误差来选择M的最佳值。 除了控制M外,还使用其他几种正则化技术。

另一个正则化参数是树的深度。 该值越高,模型越可能适合训练数据。

收缩率

梯度增强方法的一个重要部分是通过收缩进行正则化,它包括如下修改更新规则:

Fm(x)=Fm1(x)+νγmhm(x),0<ν1,

哪里参数 ν被称为“学习率”。

根据经验发现,使用较小的学习率 (例如ν<0.1 )在不缩小(而不缩小)的情况下,极大地提高了模型的泛化能力ν=1[7]。然而,这是以在训练和查询期间增加计算时间为代价的:较低的学习率需要更多的迭代。

随机梯度增强

引入梯度增强后不久,Friedman在Breiman的bootstrap聚合 (“装袋”)方法的启发下 ,对该算法进行了较小的修改[3]。具体来说,他提出在算法的每次迭代中,基础学习者都应适合随机抽取的训练集的子样本,而无需替换。Template:Efn弗里德曼(Friedman)观察到,通过这种修改,梯度增强的精度有了显着提高。

子样本大小是某个常数f训练集的大小。 什么时候f=1 ,该算法是确定性的,并且与上述算法相同。 较小的值f将随机性引入算法中,并防止过度拟合 ,作为一种正则化 。 该算法也变得更快,因为回归树必须在每次迭代时都适合较小的数据集。弗里德曼[3]获得了0.5f0.8在中小型训练集上可获得良好的结果。 因此, f通常将其设置为0.5,这意味着训练集的一半用于构建每个基础学习者。

同样,像在装袋中一样,子采样允许通过评估那些在下一个基础学习者的构建中未使用的观察值的预测来定义预测性能改进的袋外误差 。 预算外的估计有助于避免需要独立的验证数据集,但通常会低估实际性能的提高和最佳迭代次数。 [8][9]

叶子中的观察数

梯度树增强实现通常还通过限制树的终端节点中的最小观察次数来使用正则化(此参数在R gbm软件包中命名为n.minobsinnode[8])。通过忽略导致导致节点包含少于此训练集实例数量的节点的任何拆分,在树构建过程中使用它。

施加此限制有助于减少叶子预测的差异。

惩罚树木的复杂性

用于梯度增强树的另一种有用的正则化技术是惩罚学习模型的模型复杂性。 [10] 模型复杂度可以定义为学习树中叶子的比例。 损失和模型复杂性的联合优化对应于后修剪算法,该算法可删除未能将损失降低阈值的分支。 其他种类的正规化,例如2还可以添加对叶子值的惩罚以避免过度拟合

用法

梯度提升可以用于学习排名 。 商业网络搜索引擎Yahoo [11]Yandex [12]在其机器学习的排名引擎中使用了梯度增强的变体。

名字

该方法有多种名称。弗里德曼(Friedman)将他的回归技术称为“梯度提升机”(GBM)。 [2] 梅森,巴克斯特等。将广义的算法抽象类描述为“功能梯度提升”[4][5]。弗里德曼(Friedman)等人。将梯度提升模型的进展描述为多重可加回归树(MART)[13];Elith等。将这种方法描述为“增强回归树”(BRT)[14]

R的一种流行的开源实现将其称为“通用提升模型”[8]。但是,使用BRT扩展这项工作的软件包。 [15] Salford Systems的商业实现使用名称“ Multiple Additive Regression Trees”(MART)和TreeNet,两者均为商标。   [ 需要引用 ]

参见

註解

Template:Notelist

参考文献

Template:Reflist

外部链接