首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法为CatBoostRegressor调优超参数

无法为CatBoostRegressor调优超参数
EN

Stack Overflow用户
提问于 2021-08-27 09:14:34
回答 1查看 703关注 0票数 0

我正试图使CatBoostRegressor适合我的模型。当我为基线模型执行K折叠CV时,一切都很好。但是当我使用Optuna进行超参数调优时,它做了一些非常奇怪的事情。它运行第一次试用,然后抛出以下错误:

代码语言:javascript
复制
[I 2021-08-26 08:00:56,865] Trial 0 finished with value: 0.7219653113910736 and parameters: 
{'model__depth': 2, 'model__iterations': 1715, 'model__subsample': 0.5627211605250965, 
'model__learning_rate': 0.15601805222619286}. Best is trial 0 with value: 0.7219653113910736. 
[W 2021-08-26 08:00:56,869] 

Trial 1 failed because of the following error: CatBoostError("You 
can't change params of fitted model.")
Traceback (most recent call last):

我对XGBRegressor和LGBM使用了类似的方法,它们工作得很好。那么,为什么我会收到CatBoost错误呢?

以下是我的代码:-

代码语言:javascript
复制
cat_cols = [cname for cname in train_data1.columns if 
train_data1[cname].dtype == 'object']
num_cols = [cname for cname in train_data1.columns if 
train_data1[cname].dtype in ['int64', 'float64']]


from sklearn.preprocessing import StandardScaler
num_trans = Pipeline(steps = [('impute', SimpleImputer(strategy = 
                             'mean')),('scale', StandardScaler())])
cat_trans = Pipeline(steps = [('impute', SimpleImputer(strategy = 
                             'most_frequent')), ('encode', 
                         OneHotEncoder(handle_unknown = 'ignore'))])

from sklearn.compose import ColumnTransformer

preproc = ColumnTransformer(transformers = [('cat', cat_trans, 
                           cat_cols), ('num', num_trans, num_cols)])


from catboost import CatBoostRegressor
cbr_model = CatBoostRegressor(random_state = 69, 
                             loss_function='RMSE', 
                             eval_metric='RMSE', 
                             leaf_estimation_method ='Newton', 
                             bootstrap_type='Bernoulli', task_type = 
                             'GPU')

pipe = Pipeline(steps = [('preproc', preproc), ('model', cbr_model)])


import optuna
from sklearn.metrics import mean_squared_error

def objective(trial):
    model__depth = trial.suggest_int('model__depth', 2, 10)
    model__iterations = trial.suggest_int('model__iterations', 100, 
                                          2000)
    model__subsample = trial.suggest_float('model__subsample', 0.0, 
                                           1.0)
    model__learning_rate =trial.suggest_float('model__learning_rate', 
                                              0.001, 0.3, log = True)

    params = {'model__depth' : model__depth,
              'model__iterations' : model__iterations,
              'model__subsample' : model__subsample, 
              'model__learning_rate' : model__learning_rate}

    pipe.set_params(**params)
    pipe.fit(train_x, train_y)
    pred = pipe.predict(test_x)

    return np.sqrt(mean_squared_error(test_y, pred))

cbr_study = optuna.create_study(direction = 'minimize')
cbr_study.optimize(objective, n_trials = 10)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-05 17:14:47

显然,CatBoost有这样一种机制,您必须为每一次试验创建新的CatBoost模型对象。I在Github上就这一问题提出了一个问题,他们说它是为了保护长期培训的结果而实现的。,这对我来说毫无意义!

到目前为止,这个问题的唯一解决办法是您必须为每一次试验创建新的CatBoost模型!

如果使用Pipeline方法和Optuna,另一种更明智的方法是在optuna函数中定义最终管道实例和模型实例。然后再次定义函数外部的最终管道实例。

这样你就不必定义50个实例,如果你使用50个试验!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68950922

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档