首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何保存/加载优化的GPy回归模型

如何保存/加载优化的GPy回归模型
EN

Stack Overflow用户
提问于 2020-10-27 23:33:25
回答 2查看 230关注 0票数 3

我正在尝试保存我的优化高斯进程模型,以便在不同的脚本中使用。我目前的想法是利用GPy内置的to_dictfrom_dict函数将模型信息存储在json文件中。大致是这样的:

代码语言:javascript
运行
复制
import GPy
import numpy as np
import json

X = np.random.uniform(-3.,3.,(20,1))
Y = np.sin(X) + np.random.randn(20,1)*0.05
kernel = GPy.kern.RBF(input_dim=1, variance=1., lengthscale=1.)

m = GPy.models.GPRegression(X, Y, kernel)

m.optimize(messages=True)
m.optimize_restarts(num_restarts = 10)

jt = json.dumps(m.to_dict(save_data=False), indent=4)
with open("j-test.json", 'w') as file:
    file.write(jt)

这一步没有问题,但是我在尝试使用以下命令加载模型信息时遇到了问题:

代码语言:javascript
运行
复制
with open("j-test.json", 'r') as file:
    d = json.load(file)  # d is a dictionary

m2 = GPy.models.GPClassification.from_dict(d, data=None)

这给了我一个断言错误,因为“数据不是None”--至少我是这么认为的。

我对GPy和jsons的使用都是新手,所以我真的不确定我在哪里走错了路。我试着查看了文档,但文档有点模糊,我找不到它的用法示例。是否有我遗漏的步骤/概念?另外,这是存储和重新加载模型的最佳方式吗?在这方面的任何帮助都将非常感谢!谢谢!

EN

Stack Overflow用户

回答已采纳

发布于 2020-10-27 23:44:52

模块pickle在这里是你的朋友!

代码语言:javascript
运行
复制
import pickle
with open('save.pkl', 'wb') as file:
    pickle.dump(m, file)

您可以在将来的脚本中使用以下命令回调它:

代码语言:javascript
运行
复制
with open('save.pkl', 'rb') as file:
    loaded_model = pickle.load(file)
票数 3
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64557786

复制
相关文章

相似问题

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