关于xgboost的原理网络上的资源不多,大多数还停留在应用层面,本文经过学习陈天奇博士的PPT地址和xgboost导读和实战 地址,但愿对xgboost原理进行深刻理解。python
说到xgboost,不得不说gbdt。了解gbdt能够看我这篇文章 地址,gbdt不管在理论推导仍是在应用场景实践都是至关完美的,但有一个问题:第n颗树训练时,须要用到第n-1颗树的(近似)残差。从这个角度来看,gbdt比较难以实现分布式(ps:虽然难,依然是能够的,换个角度思考就行),而xgboost从下面这个角度着手
注:红色箭头指向的l即为损失函数;红色方框为正则项,包括L一、L2;红色圆圈为常数项。
利用泰勒展开三项,作一个近似,咱们能够很清晰地看到,最终的目标函数只依赖于每一个数据点的在偏差函数上的一阶导数和二阶导数。git
(1)定义树的复杂度
对于f的定义作一下细化,把树拆分红结构部分q和叶子权重部分w。下图是一个具体的例子。结构函数q把输入映射到叶子的索引号上面去,而w给定了每一个索引号对应的叶子分数是什么。
定义这个复杂度包含了一棵树里面节点的个数,以及每一个树叶子节点上面输出分数的L2模平方。固然这不是惟一的一种定义方式,不过这必定义方式学习出的树效果通常都比较不错。下图还给出了复杂度计算的一个例子。
注:方框部分在最终的模型公式中控制这部分的比重
在这种新的定义下,咱们能够把目标函数进行以下改写,其中I被定义为每一个叶子上面样本集合 github
这一个目标包含了TT个相互独立的单变量二次函数。咱们能够定义算法
最终公式能够化简为网络
经过对求导等于0,能够获得数据结构
而后把最优解代入获得:分布式
(2)打分函数计算示例ide
Obj表明了当咱们指定一个树的结构的时候,咱们在目标上面最多减小多少。咱们能够把它叫作结构分数(structure score)函数
(3)枚举不一样树结构的贪心法学习
贪心法:每一次尝试去对已有的叶子加入一个分割
对于每次扩展,咱们仍是要枚举全部可能的分割方案,如何高效地枚举全部的分割呢?我假设咱们要枚举全部x < a 这样的条件,对于某个特定的分割a咱们要计算a左边和右边的导数和。
咱们能够发现对于全部的a,咱们只要作一遍从左到右的扫描就能够枚举出全部分割的梯度和GL和GR。而后用上面的公式计算每一个分割方案的分数就能够了。
观察这个目标函数,你们会发现第二个值得注意的事情就是引入分割不必定会使得状况变好,由于咱们有一个引入新叶子的惩罚项。优化这个目标对应了树的剪枝, 当引入的分割带来的增益小于一个阀值的时候,咱们能够剪掉这个分割。你们能够发现,当咱们正式地推导目标的时候,像计算分数和剪枝这样的策略都会天然地出现,而再也不是一种由于heuristic(启发式)而进行的操做了。
在实际的业务场景下,咱们每每须要自定义损失函数。这里给出一个官方的 连接 地址
因为Xgboost的参数过多,使用GridSearch特别费时。这里能够学习下这篇文章,教你如何一步一步去调参。地址
任务:二分类,存在样本不均衡问题(scale_pos_weight能够必定程度上解读此问题)
【Python】
【R】
(1)objective [ default=reg:linear ] 定义学习任务及相应的学习目标,可选的目标函数以下:
(2)’eval_metric’ The choices are listed below,评估指标:
(3)lambda [default=0] L2 正则的惩罚系数
(4)alpha [default=0] L1 正则的惩罚系数
(5)lambda_bias 在偏置上的L2正则。缺省值为0(在L1上没有偏置项的正则,由于L1时偏置不重要)
(6)eta [default=0.3]
为了防止过拟合,更新过程当中用到的收缩步长。在每次提高计算以后,算法会直接得到新特征的权重。 eta经过缩减特征的权重使提高计算过程更加保守。缺省值为0.3
取值范围为:[0,1]
(7)max_depth [default=6] 数的最大深度。缺省值为6 ,取值范围为:[1,∞]
(8)min_child_weight [default=1]
孩子节点中最小的样本权重和。若是一个叶子节点的样本权重和小于min_child_weight则拆分过程结束。在现行回归模型中,这个参数是指创建每一个模型所须要的最小样本数。该成熟越大算法越conservative
取值范围为: [0,∞]
更多关于Xgboost学习地址