【Gradient Boosted Decision Tree】林轩田机器学习技术
GBDT之前实习的时候就听说应用很广,现在终于有机会系统的了解一下。
首先对比上节课讲的Random Forest模型,引出AdaBoost-DTree(D)

AdaBoost-DTree可以类比AdaBoost-Stump模型,就可以直观理解了
1)每轮都给调整sample的权重
2)获得gt(D,ut)
3)计算gt的投票力度alphat
最后返回一系列gt的线性组合。
weighted error这个比较难搞,有没有不用动原来的模型,通过输入数据上做文章就可以达到同样的目的呢?

回想bagging的weighted策略:每轮boostrapping的时候,样本的权重体现在copy个数上。
现在从一个更一般的角度来看,给定一个weighted u,如果对数据按照u的比例大小对样本进行sampling的动作,那么最后D中的数据也体现了weighted。
这样AdaBoost-DTree的原型就出来了:
1)AdaBoost方法
2)按照给定的权重对样本进行sampling的动作,生成每棵树的训练数据
3)训练每棵树
这种方法如果不限制树的高度,是容易产生autocracy的。原因是如果把所有的资料丢进去,容易全切开。
这里产生一个疑问:为什么random forest中每棵树就不会有这种完全切开全分开的情况,甚至在decision stump那个作业的时候,会不会有某个stump给全切开了。
1)个人感觉random forest样本、特征、分支条件(b(x))都是randomness的,完全分开的可能性极小极小
2)至于decision stump,如果真有个decision stump能一刀切开,那也就不用这么复杂的模型了

总的来说,每棵树要弱一些。
如果弱到不能再弱,树就只留下一层了,这时候decision tree就退化成了decision stump了。

接下来,林开始讲解AdaBoost方法的一些optimization view以及内在的insights,这里的一些推导大体思路记住就可以了。
AdaBoost的核心是每个样本的权重变化,所谓的insights也是从这里出发。

1)把之前讲授的AdaBoost样本权重迭代公式转换一下形式(重点是引入了alphat):
unt+1 = unt * exp(-yn * alphat * gt(xn))
2)根据修改后的迭代公式,给出了每个样本在T+1轮的权重通项公式:
unT+1 = 1/N * exp(- yn * Σt=1,T (alphat * gt(xn)) )
(这里有个地方在之前提到过,一般N个样本,每个样本的初始权重系那个灯,都是1/N)
综合上面两点,unT+1 与 前面T轮产生的所有gt对样本点xn的综合打分情况(Σt=1,T (alphat * gt(xn))) 有关系。

林在这里点出了一个insights:可以把voting score和margin联系起来,类比SVM中的margin概念。
1)把每个gt(xn)看成是xn的一种transform,前面的alphat看成是transformed之后的权重
2)这种形式很像hard-margin SVM中的margin
我们肯定是希望yn*(voting score)越大越好,因为这代表预测值跟实际值更靠近;因此我们可以得到unT+1有可能随着T增加而变小。
顺着这种思路,AdaBoost的大方向最起码应该是unT+1越小越好,那么Σn=1,N(unt)也应该是随着AdaBoost的迭代而逐步减小的。
因此,思路就是:预测的准 → yn*(voting score)越大越好 → ΣunT+1越小越好
于是,AdaBoost的优化目标函数就可以大概给出来了。

再次请出来我们的老朋友error0/1,对比一下AdaBoost又产生了一个bound住error0/1的上界的error measure,叫“exponential error measure”
如下图:

既然目标函数大概写出来了,下面就是怎么最小化这个目标函数了。
这个任务比较麻烦,因为是Σ套着exp再套着Σ,因此需要一些前人的智慧了。
模仿gradient descent的方法,假设前面已经AdaBoost完t-1轮了,现在要求的是一个函数gt(x)(或者称为h(x))。
再第t轮,我们沿着函数h(x)的方向走ita的步长,可以使得目标函数迅速往min的方向走。如下:

1)由于前面已经执行完了t-1轮,因此可以把式子化简一下,把一些项目合并成unt的函数形式
2)利用xn=0点的泰勒展开,进一步化简(这里为什么要用0这个位置的taylor展开呢,可以理解成h(x)只是沿着原来的Σ1,t-1(alphat*g'(xn)这个函数,挪动的了一小步;这一小步,就意味着变化很小,变化很小甚至接近0,因此就可以在0点taylor展开。不晓得这种理解是否正确,意会吧)
到此,我们利用前人的智慧已经把目标函数给大大简化了,要求的东西有俩:
1)h(x)是啥?
2)ita是啥?

这里的方法还是挺巧妙的
1)先提出来一个固定的Σunt,后面留出来的“变化的一项”
2)再分析下后面变化的这一项,如果要后面变化这一项最小,那么就是最小化Einu(h)(周边再配合上一些常系数)
因此,可以获得结论:在AdaBoost的过程中,算法A就是good gt了!
下面再看ita如何求。

核心在于EADA是怎么变成可对ita求导的形式的:
EADA = u1t*exp(-ita) + u2t*exp(ita)...
EADA1 = u1t*exp(-ita) + ut2t*0 ... (EADA1只考虑exp(-ita)的项,其余的补上0)
EADA2 = u1t*0 + u2t * exp(ita) ...(EADA2只考虑exp(+ita)的项,其余的补上0)
则,EADA = EADA1 + EADA1 = (Σunt) * ( (1-epson)exp(-ita) + epson*exp(ita) )
随后的求导步骤就是很自然的了,因此就验证了之前的结论,itat = sqrt( (1-epsont)/epsont) )就是最优的。前一次课直接给出了这个结论,并没有说为什么,这次算是给出了一个相对理论些的推导。
再往更一般的Gradient Boost推广。
推广的方式就是泛化error measure function,如下:

沿着这个思路,下面往regression的方向上平移一下。
大体的目标还是两个:
1)求解函数h(x)的形式
2)求解函数h(x)移动的幅度

先搞定h(x)的形式
regression一般用square error,直接上taylor:
1)前面一项是constant,因为yn都知道sn也都知道
2)第二项要对s求导 并在sn这点取导数值
这样,看起来貌似h(x)无穷大;这样不科学,于是要添加对于h(x)的惩罚项。

再经过penalize一番折腾之后,h终于有个像模像样的形式了:即regression with residuals。
接下来再解决移动幅度的问题。

一番云雨之后,alphat也求出来了,就是一个单变量的线性回归。
把前面的铺垫都做好了之后,简练地给出了GBDT的形式:

1)利用C&RT去学{x, yn-sn},保留这一轮学出来的树gt(x)
2)再求{gt(x), residual}线性回归,最小化目标函数求出来ita
3)更新sn
学习足够多次数后,返回组合的GBDT。
最后,林对几种经典的aggregation模型进行了汇总。

Random Forest: 代表bagging+强子模型
AdaBoost DTree 或 GBDT :代表AdaBoost+弱子模型

AdaBoost系列的方法:把弱的拼在一起,组成一个强的G(x);背后的insights可以理解为,利用很多弱弱的模型做了特征转换,转化后再合并在一起就变强了。
RF系列的方法:把本身很强的拼在一起,通过diversity达到regularization的效果(有的子模型往正的方向强,有的往负的方向强,多搞一些这样的模型就中和了彼此的overfitting,类似SVM large margin的效应)
【Gradient Boosted Decision Tree】林轩田机器学习技术的更多相关文章
- 【Kernel Logistic Regression】林轩田机器学习技术
最近求职真慌,一方面要看机器学习,一方面还刷代码.还是静下心继续看看课程,因为觉得实在讲的太好了.能求啥样搬砖工作就随缘吧. 这节课的核心就在如何把kernel trick到logistic regr ...
- 【Soft-Margin Support Vector Machine】林轩田机器学习技术
Hard-Margin的约束太强了:要求必须把所有点都分开.这样就可能带来overfiiting,把noise也当成正确的样本点了. Hard-Margin有些“学习洁癖”,如何克服这种学习洁癖呢? ...
- 【Kernal Support Vector Machine】林轩田机器学习技术
考虑dual SVM 问题:如果对原输入变量做了non-linear transform,那么在二次规划计算Q矩阵的时候,就面临着:先做转换,再做内积:如果转换后的项数很多(如100次多项式转换),那 ...
- (转载)林轩田机器学习基石课程学习笔记1 — The Learning Problem
(转载)林轩田机器学习基石课程学习笔记1 - The Learning Problem When Can Machine Learn? Why Can Machine Learn? How Can M ...
- 机器学习技法:11 Gradient Boosted Decision Tree
Roadmap Adaptive Boosted Decision Tree Optimization View of AdaBoost Gradient Boosting Summary of Ag ...
- 机器学习技法笔记:11 Gradient Boosted Decision Tree
Roadmap Adaptive Boosted Decision Tree Optimization View of AdaBoost Gradient Boosting Summary of Ag ...
- 【Decision Tree】林轩田机器学习技法
首先沿着上节课的AdaBoost-Stump的思路,介绍了Decision Tree的路数: AdaBoost和Decision Tree都是对弱分类器的组合: 1)AdaBoost是分类的时候,让所 ...
- 【Random Forest】林轩田机器学习技法
总体来说,林对于random forest的讲解主要是算法概况上的:某种程度上说,更注重insights. 林分别列举了Bagging和Decision Tree的各自特点: Random Fores ...
- 【Matrix Factorization】林轩田机器学习技法
在NNet这个系列中讲了Matrix Factorization感觉上怪怪的,但是听完第一小节课程就明白了. 林首先介绍了机器学习里面比较困难的一种问题:categorical features 这种 ...
随机推荐
- java——栈和队列 面试题
(1)栈的创建 (2)队列的创建 (3)两个栈实现一个队列 (4)两个队列实现一个栈 (5)设计含最小函数min()的栈,要求min.push.pop.的时间复杂度都是O(1) (6)判断栈的push ...
- NOIP2018学军中学游记(11.09~11.11)
前言 这篇博客记录的是我在\(NOIP2018\)提高组比赛中的经历. 这一次的\(NOIP\)是在学军中学举办的, 莫名感到一阵慌张. 但愿能有一个好成绩,不然就要\(AFO\)了... ... 说 ...
- Python 爬虫的工具列表
这个列表包含与网页抓取和数据处理的Python库 网络 通用 urllib -网络库(stdlib). requests -网络库. grab - 网络库(基于pycurl). pycurl - 网络 ...
- C++ Boost库简介
boost是一个准标准库,相当于STL的延续和扩充,它的设计理念和STL比较接近,都是利用泛型让复用达到最大化.不过对比STL,boost更加实用.STL集中在算法部分,而boost包含了不少工具类, ...
- scrollHeight, scrollTop, clientHeight
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 12、SpringBoot------activeMq的简单使用
开发工具:STS 前言: What is ActiveMq? ActiveMq:实现了Jms规范的一款Java 消息中间件. 消息中间件: 处理消息的一个消息机制,负责接收消息与转发. 用途: (1) ...
- leetcode第221题(最大正方形)的本地IDE实现及变形
问题描述: 在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积.PS:本文也对只包含0的最大正方形面积进行了运算 示例: 输入: 1 0 1 0 0 1 0 1 1 1 ...
- MappingException:class com.zsn.crm.Model.user not found whie looking for property user id
之前好好地运行 什么东西都没动过 再次运行突然报异常*****MappingException:class com.zsn.crm.Model.user not found whie looking ...
- Python学习之登陆认证
需求: 让用户输入用户名密码 认证成功后显示欢迎信息 输错三次后退出程序 可以支持多个用户登录 (提示,通过列表存多个账户信息) 用户3次认证失败后,退出程序,再次启动程序尝试登录时,还是锁定状态(提 ...
- php COM
查看php.ini中是否已经开启了com.allow_dcom = true 从php/ext/里面查找一下有没有这个php_com_dotnet.dll这个文件 如果没有网上下载个,一般都会有的吧应 ...