我想使用 lgb.Dataset 对 LightGBM 模型进行交叉验证并使用early_stopping_rounds。以下方法对 XGBoost 的xgboost.cv没有问题。我不喜欢在 GridSearchCV 中使用 Scikit Learn 的方法,因为它不支持提前停止或 lgb.Dataset。
import lightgbm as lgb
from sklearn.metrics import mean_absolute_error
dftrainLGB = lgb.Dataset(data = dftrain, label = ytrain, feature_name = list(dftrain))
params = {'objective': 'regression'}
cv_results = lgb.cv(
params,
dftrainLGB,
num_boost_round=100,
nfold=3,
metrics='mae',
early_stopping_rounds=10
)
任务是做回归,但是下面的代码会抛出错误:
Supported target types are: ('binary', 'multiclass'). Got 'continuous' instead.
LightGBM 是否支持回归,还是我提供了错误的参数?