Как добавить фокусную потерю к пользовательской целевой функции lightgbm & xgboost - PullRequest
0 голосов
/ 19 марта 2019

вот моя обычная целевая функция , Я бы хотел добавить «фокусные потери» к lightgbm。

############### мой код
from numpy import log
def grad_func(y_true,y_pred):
   if y_true==1:
        return -0.5*(2y_pred - 2)log(y_pred) - 0.5(-y_pred + 1)**2/y_pred
   if y_true==0:
        return 0.5y_pred**2/(-y_pred + 1) - 1.0y_predlog(-y_pred + 1)

def hess_func(y_true,y_pred):
    if y_true==1:
         return -1.0log(y_pred) - (2.0y_pred - 2.0)/y_pred + 0.5*(y_pred - 1)2/y_pred2
    if y_true==0:
         return 0.5y_pred**2/(y_pred - 1)**2 - 2.0y_pred/(y_pred - 1) - 1.0*log(-y_pred + 1)

def focal_loss(y_true,y_pred):
    gamma=2.0
    alpha=0.5
    y_true=y_true.tolist()
    y_pred=y_pred.tolist()
    grad=[]
    hess=[]
    for i in range(len(y_true)):
    if y_pred[i]==0:
       y_pred[i]=y_pred[i]+1e-12 ## avoid that the y_pred==0
#and can not be divided

    grad.append(grad_func(y_true[i],y_pred[i]))
    hess.append(hess_func(y_true[i],y_pred[i]))
    return np.array(grad),np.array(hess)

Этобудет работать, но всегда работает как thie введите описание изображения здесь

...