GBDT

GBDT 的全称是 Gradient Boosting Decision Tree,先要理解GBDT中的Gradient Boosting 和Decision Tree分别是什么?

GBDT中的Decision Tree是CART回归树(不是分类树),无论是处理回归问题还是二分类以及多分类,GBDT使用的决策树通通都是都是CART回归树。为什么不用CART分类树呢?因为GBDT每次迭代要拟合的是梯度值,是连续值所以要用回归树。

GBDT的损失函数是误差平方和:
L(y_i,f(x_i))=\frac{1}{2}\sum_{i=1}^n(\hat y_i-y_i)^2=\frac{1}{2}\sum_{i =1}^n(f(x_i)-y_i)^2
我们对f(x_i)求偏导:
\frac{∂L(y_i,f(x_i)}{∂f(x_i)}=\sum_{i=1}^nf(x_i)-y_i
其中f(x_i)-y_i表示的是残差,也就是梯度值,所以说GBDT拟合的是残差。

GBDT算法步骤:
1、确定超参数:学习率、迭代次数、树的深度;
2、对每一个特征,根据其值,确定划分点;
3、划分点划分后的两个子数据集(因为是二叉的);
4、按照该划分点进行预测的结果,与真实标签之间的残差,进而计算残差平方和;
5、将两个子集的残差平方和相加,得到该划分点的残差平方和;
6、重复步骤2-5,确定每一个特征下所有划分点的残差平方和,并从中选择最小的残差平方和对应的特征的划分点,作为本次的划分点;
7、如果未达到设定的树的深度,对步骤6划分后的子集应用步骤2-6进行划分;
8、树的深度达到设定值后,完成一棵树桩;
9、根据该树桩预测的结果与真实标签之间的残差,作为下一次迭代的标签;
10、重复2-9进行迭代,直到达到设定迭代次数;
11、最终学习器为学习率与各个基学习器线性之和。初始基学习器可以不应用学习率。

我们通过例子来说明什么叫拟合残差?


GBDT例1


训练集

x \in [1,10],y \in [5,10]学习这个回归问题,考虑只用树桩作为基函数。
1、第1步求第一棵树桩T_1(x)
要先找到训练数据集的切分点:根据数据集中的x,考虑如下切分点:\{1.5, 2.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 9.5 \}
对于第1个切分点有子集R_1 = \{5.56 \}R_2 = \{5.7,5.91, 6.4,6.8,7.05,8.9,8.7,9,9.05\}
分别求S_1的平均数μ_1=5.56S_2的平均数μ_2=7.5
那么该切分点产生的残差为两个集合残差之和:R=\sum_{y1 \in S_1}(y_1-μ_1)^2+\sum_{y2 \in S_2}(y_2-μ_2)^2=0+15.72=15.72
同理,我们可以求出各个切分点对应的残差:


显然,当切分点为x=6.5时,其产生的残差最小,此时有集合:
R_1 = \{5.56,5.7,5.91,6.4, 6.8,7.05 \}μ_1=6.24
R_2 = \{8.9, 8.7, 9, 9.05 \}μ_2=8.91
有残差表:

以第一个残差为例:5.56-6.24=-0.68
那么有树f(x)=T_1(x)=\left\{ \begin{aligned} 6.24 , x \lt 6.5 \\ 8.91, x \geq6.5 \end{aligned} \right.
该树桩T_1(x)你和训练数据的平方误差损失为:L=\sum_{i=1}^{10} r_i^2=1.93

2、求第2个树桩T_2(x),然后这个残差表就层楼我们“新的数据集”,同样考虑划分点:\{1.5, 2.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 9.5 \},并求出各个划分点对应的残差,选择残差最小的作为最终划分点,此时有划分点x=3.5,那么其将残差数据集分成两部分
S_1 = \{-0.68, -0.54, -0.33 \}μ_1=-0.52
S_2 = \{0.16, 0.56, 0.81,-0.01, -0.21, 0.09, 0.14\}μ_2=0.22
那么有树桩T_2(x)=\left\{ \begin{aligned} -0.52 , x \lt 3.5 \\ 0.22, x \geq 3.5 \end{aligned} \right.

由切分点$x=3.5又可以更新残差表:


至此,有树f(x)=T_1(x)+T_2(x)=\left\{ \begin{aligned} 5.72 , x \lt 3.5 \ \ \ \ \ \ \ \ \ \ \\ 6.46 , 3.5 \leq x \lt 6.5 \\ 9.13, x \geq6.5 \ \ \ \ \ \ \ \ \ \ \end{aligned} \right.
此时,用树f(x)拟合训练数据得到平方损失误差为0.79.

3、由更新后的残差表,求第3棵树桩,每获得一个树桩,残差表更新一次,依次可求得多个树桩,直到树桩达到指定数目或残差小于某个设定值,停止迭代。将所有树桩串联起来即可得到训练后的结果f(x)=T_1(x)+T_2(x)+...+T_n(x)


GBDT例2


我们要根据年龄和体重预测身高,那么身高就是我们的标签列。第4条为我们要预测的。

1、参数设置:
学习率:learning_rate=0.1
迭代次数:n_trees=5
树的深度:max_depth=3,上面的例子中我们没有考虑树的深度,因为我们就一个特征。
2、第1棵树桩:T_0(x)=\frac{1.1+1.3+1.7+1.8}{4}=1.475
这个意思就是说我们把第1个基分类器设置为要拟合的均值,即给出任何年龄和体重该基分类器预测的都是1.475。我们难道不能对图1的数据集直接构建CART树吗?——显然是可以的,使用平均值更简单。

此时我们可以得到残差:


此时,f(x)=T1=1.45,其在训练集上的残差平方和为0.3275。

用T1的残差残差作为标签,产生了新的数据集:


2、迭代轮数m=1,2,…,M:
对图3的数据集构建CART回归树:
对年龄属性选择划分点[7,21,30]
age<7,S_1 = \{-0.375 \}


age>=7,S_2 = \{ -0.175, 0.225, 0.325 \}

该划分点的残差为:r=0+0.09+0.01+0.04=0.14

同理,我们可以得到各个特征下各个划分点对应的残差平方和,如下表:

选择残差平方和最小的即0.025,对应两个划分点,age=21和weight=60,我们随机选一个作为划分点,这里选择age=21。有树如下:



第1棵树

我们设定的树的深度max_depth=3,现在树的深度只有2,需要再进行一次划分,这次划分要对左右两个节点分别进行划分:


此时我们得到
T_1(x)=η*\sum_{j=1}^4y_iI(x)
=0.1*(-0.375+(-0.0175)+0.0225+0.0325)
那么f(x)=T_0(x)+T_1(x)

为什么要用学习率呢?这是Shrinkage的思想,如果每次都全部加上(学习率为1)很容易一步学到位导致过拟合。
所以,可以更新残差,作为下一类迭代的标记。
重复此步骤,直到 m>5 结束,最后生成5棵树。(加上f_0(x)一共是6个基学习器)

第2棵树

第3棵树

第4棵树

第5棵树

得到最后的强学习器:
f(x)=T_0(x)+T1(x)+...+T_6(x)

当我们输入年龄=25,体重=65给T_0,得到值1.475;
当我们输入年龄=25,体重=65给T_1,得到值0.225;
当我们输入年龄=25,体重=65给T_2,得到值0.2025;
...
最终预测结果:f(x)=1.475+0.1∗(0.225+0.2025+0.1823+0.164+0.1476)=1.56714

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容