在xgboost中使用自定义损失函数有两种不同的准则。
如果预测概率“ p” = Sigmoid(z)
2。在https://xgboost.readthedocs.io/en/latest/tutorials/custom_metric_obj.html 1中,梯度为w.r.t'p'
哪个是正确的?
答案 0 :(得分:1)
为使此情况尽可能通用,您需要计算总损耗函数的斜率,以改变当前的预测值。通常,损失函数的形式为$ L = \ sum_ {i = 1} ^ {N} \ ell(y_ {i},\ hat {y_ {i}})$,其中$ y_ {i} $是$ i ^ {th} $数据点的标签,$ \ hat {y_ {i}} $是您的预测(在二进制分类的情况下,您可以选择定义它,使$ y_ {i} $为二进制标签和$ \ hat {y_ {i}} $是分类器分配给作为类别之一的标签的概率)。
然后,您需要计算$ \ frac {\ partial \ ell} {\ hat {y_ {i}}} \ big | {y {i}}} $