【发布时间】:2018-12-27 16:33:19
【问题描述】:
最近,我一直致力于在带有 Tensorflow 后端的 Keras 中应用网格搜索交叉验证 (sklearn GridSearchCV) 进行超参数调整。我的模型调整好后 我正在尝试保存 GridSearchCV 对象以供以后使用,但没有成功。
超参数调优如下:
x_train, x_val, y_train, y_val = train_test_split(NN_input, NN_target, train_size = 0.85, random_state = 4)
history = History()
kfold = 10
regressor = KerasRegressor(build_fn = create_keras_model, epochs = 100, batch_size=1000, verbose=1)
neurons = np.arange(10,101,10)
hidden_layers = [1,2]
optimizer = ['adam','sgd']
activation = ['relu']
dropout = [0.1]
parameters = dict(neurons = neurons,
hidden_layers = hidden_layers,
optimizer = optimizer,
activation = activation,
dropout = dropout)
gs = GridSearchCV(estimator = regressor,
param_grid = parameters,
scoring='mean_squared_error',
n_jobs = 1,
cv = kfold,
verbose = 3,
return_train_score=True))
grid_result = gs.fit(NN_input,
NN_target,
callbacks=[history],
verbose=1,
validation_data=(x_val, y_val))
备注:create_keras_model 函数初始化并编译一个 Keras Sequential 模型。
执行交叉验证后,我尝试使用以下代码保存网格搜索对象 (gs):
from sklearn.externals import joblib
joblib.dump(gs, 'GS_obj.pkl')
我得到的错误如下:
TypeError: can't pickle _thread.RLock objects
请告诉我这个错误的可能原因是什么?
谢谢!
P.S.:joblib.dump 方法适用于保存使用的 GridSearchCV 对象 用于训练来自 sklearn 的 MLPRegressors。
【问题讨论】:
-
如果我的回答解决了您的问题,请告诉我。
标签: python scikit-learn keras save grid-search