如何将Keras训练模型导出用于Tensorflow服务

如何将Keras训练模型导出用于Tensorflow服务

Tensorflow Serving是将机器学习模型引入生产的最明显和最好的解决方案。带来的好处包括:

  • 一个预先构建的rest api,速度非常快,由谷歌支持
  • 不同模型和模型版本的源代码控制和访问
  • 在所有平台上服务模型的标准化方法。

但是,因为它是新的,所以缺少了很多东西,比如文档和对其他流行库(如keras)的文档支持。Keras与服务于Tensorflow完全兼容,唯一的挑战是保存模型,使服务于Tensorflow的方式能够使用它。

因此,为了简单起见,我选择使用keras来训练一个简单的模型,并将其导出为适合于Tensorflow服务的格式。

XOR预测例子

1、下载代码

首先克隆Repo以获取代码

git clone https://github.com/brianalois/xor_keras_tensorflow_serving.git

确保您的环境是在github页面上要求的环境,readme有说明。

2、代码

导入你的依赖关系! !

import tensorflow as tf

from keras import backend as K

from tensorflow.python.saved_model import builder as saved_model_builder

from tensorflow.python.saved_model import tag_constants, signature_constants, signature_def_utils_impl

from keras.models import Sequential

from keras.layers.core import Dense, Dropout, Activation

from keras.optimizers import SGD

import numpy as np

设置Tensorflow会话

sess = tf.Session()

K.set_session(sess)

K.set_learning_phase(0)

设置变量

模型版本:将更改导出的模型目录的名称

epoch:训练周期数越多,时间越长。5000是个不错的数字,但可能需要一些时间来训练。100适合快速测试。

model_version = "2"

epoch = 100

加载数据

这就是我选择XOR示例的原因,因为数据非常容易获取

X = np.array([

[0,0],

[0,1],

[1,0],

[1,1]

])

Y = np.array([[0],[1],[1],[0]])

建立模型

model = Sequential()

model.add(Dense(8, input_dim=2))

model.add(Activation('tanh'))

model.add(Dense(1))

model.add(Activation('sigmoid'))

sgd = SGD(lr=0.1)

编译和拟合模型

model.compile(loss='binary_crossentropy', optimizer=sgd)

model.fit(X, Y, batch_size=1, nb_epoch=epoch)

获取 Tensorflow Serving输入和输出变量

x = model.input

y = model.output

prediction_signature = tf.saved_model.signature_def_utils.predict_signature_def({"inputs": x}, {"prediction":y})

测试tf serving 的预测签名是否有效

valid_prediction_signature = tf.saved_model.signature_def_utils.is_valid_signature(prediction_signature)

if(valid_prediction_signature == False):

raise ValueError("Error: Prediction signature not valid!")

构建和配置模型

builder = saved_model_builder.SavedModelBuilder('./'+model_version)

legacy_init_op = tf.group(tf.tables_initializer(), name='legacy_init_op')

builder.add_meta_graph_and_variables(

sess, [tag_constants.SERVING],

signature_def_map={

signature_constants.DEFAULT_SERVING_SIGNATURE_DEF_KEY:prediction_signature,

},

legacy_init_op=legacy_init_op)

保存模型

builder.save()

这里非常简单,现在应该可以看到目录中有一个文件夹,它的名称是2。

注意:

对于那些熟悉Tensorflow服务的人,有预测、分类和回归操作。对于每个模型,都需要以特定的方式保存模型。预测是最容易理解的,这也是我开始它的原因。但是,分类和回归很难找到如何使用keras的方法。

相关推荐