TensorFlow:DNNRegressor,如何保存模型进行预测



我是TensorFlow的新手,正在尝试将我的scikit-learn模型转换为TensorFlow符号,但我发现它过于复杂。

在scikit-learn中,您只需调用model.dump("ModelName.pkl")来保存模型,然后调用joblib.load("ModelName.pkl")即可再次使用它。我正在尝试用TensorFlow做类似的事情,但是我收到以下错误:

Traceback (most recent call last):
File "/Users/user0/Desktop/IPML_Model/tensorflow_model_train.py", line 39, in <module>
saver = tf.train.Saver()
File "/Library/Python/2.7/site-packages/tensorflow/python/training/saver.py", line 1139, in __init__
self.build()
File "/Library/Python/2.7/site-packages/tensorflow/python/training/saver.py", line 1161, in build
raise ValueError("No variables to save")
ValueError: No variables to save

我想做的只是用get_training_data()训练模型,保存它,然后加载它,以便我可以调用predict。这是我所拥有的:

def get_training_data():
X, y = preprocess_data()
X_train, _, y_train, _ = train_test_split(X, y, test_size=0.2, random_state=123)
feature_set = {f: tf.constant(X_train[f]) for f in features}
label_set = tf.constant(y_train)
return feature_set, label_set
# Start a session
sess = tf.Session()
# Initialize a DNNRegressor model
feature_cols = [real_valued_column(k) for k in features]
dnn_regressor = DNNRegressor(feature_columns=feature_cols, hidden_units=[50, 50], label_dimension=7, model_dir=os.getcwd())
# Train the model
dnn_regressor.fit(input_fn=lambda: get_training_data(), steps=5000)
# Save the model
saver = tf.train.Saver()
saver.save(sess, "dnnregressor.ckpt")

我可以在拟合后dnnregressor上调用predict,这不需要"变量",但我想先保存模型,然后调用预测。什么是最简单,最少的方法?

当您调用以下内容时,模型将保存在model_dir中:

dnn_regressor = DNNRegressor(feature_columns=feature_cols, hidden_units=[50, 50], label_dimension=7, model_dir=os.getcwd())

现在,在inference期间,您再次调用上述内容,它将从model_dir加载模型,然后调用dnn_regressor.predict()函数。

最新更新