5

我受过训练CatBoostClassifier来解决我的分类任务。现在我需要保存模型并在另一个应用程序中使用它进行预测。为此,我通过方法保存模型并通过save_model方法恢复它load_model

但是,每次调用predict恢复的模型时,都会出现错误:

CatboostError: There is no trained model to use predict(). Use fit() to train model. Then use predict().

所以看起来我需要再次训练我的模型,而我需要恢复预训练模型并将其仅用于预测。

我在这里做错了什么?我应该使用一种特殊的方式来加载模型进行预测吗?

我的训练过程是这样的:

model = CatBoostClassifier(
    custom_loss=['Accuracy'],
    random_seed=42,
    logging_level='Silent',
    loss_function='MultiClass')

model.fit(
    x_train, 
    y_train,
    cat_features=None,
    eval_set=(x_validation, y_validation),
    plot=True)

...

model.save("model.cbm")

我使用以下代码恢复模型:

model = CatBoostClassifier(
    custom_loss=['Accuracy'],
    random_seed=42,
    logging_level='Silent',
    loss_function='MultiClass')
model.load_model("model.cbm")

...


predict = self.model.predict(inputs)
4

2 回答 2

12
# After you train the model using fit(), save like this - 
model.save_model('model_name')    # extension not required.

# And then, later load - 
from catboost import CatBoostClassifier
model = CatBoostClassifier()      # parameters not required.
model.load_model('model_name')

# Now, try predict().
于 2019-04-20T13:36:50.730 回答
0

几个小时后,我意外地找到了解决方案。模型加载在外部 python 模块中实现,然后导入 Jupyter Notebook。原来我只需要重新启动 Jupyter 内核。

于 2018-08-18T04:44:42.117 回答