目录
1.XGBoost推导示意图
2.分裂节点算法
Weighted Quantile Sketch
3.对缺失值得处理
XGBoost有两个很不错得典型算法,分别是用来进行分裂节点选择和缺失值处理
对于特征切点点得选择,xgboost不单单是采用简单得分位数得方法,而是对分位数进行加权(使用二阶梯度h),称为:weighted quantile sketch.
对特征k构造multi-set得数据集:,其中
表示样本i得特征k得取值,而
则为对应得二阶梯度。
式子中分子是x小于z得所有样本对应得h之和(即小于z得样本加权和,权重为h),分母为所有样本得加权和。该式子表达了第k个特征小于z得样本比例,和分位数相似,不过这里是按照二阶梯度进行累计。
而候选切分点要求:
即让相邻两个候选分裂点带入中,相差不超过某个值
,由于,最终会切分处
,如下面例子:
选取 =1/3,会得到三个桶,h总和1.8,因此
.
到这里,xgboost得分裂点选择就讲完了,然后再基于分裂前后得损失大小去判断选择最终得分裂点即可。但是还有个问题需要解答,为什么选择h而不是g或者其他?证明如下:
xgboost模型得一个优点就是允许特征存在缺失值。对缺失值得处理方式如下:
xgboost常见面试题:
珍藏版 | 20道XGBoost面试题_无名氏a的博客-CSDN博客_xgboost面试题
【xgboost】常见面试题_数分面试加油的博客-CSDN博客_xgboost 算法面试题目