tensorflow - 如何将保存的模型转换或加载到 TensorFlow 或 Keras 中?

标签 tensorflow keras deep-learning tensorflow2.0

我使用 tensorflow keras 创建了一个模型,并定义了一个回调来在每个 epoch 之后保存模型。它工作并将模型保存为 pb 格式,但我无法将其再次加载到 keras 中,因为 keras 只接受 h5 格式。

我有两个问题:

  • 除了 tensorflow 服务,我如何将我保存的模型加载到 keras/tensorflow 中?
  • 如何在每个时期后以 h5 格式保存 keras 模型?

我的回调和保存模型:

from tensorflow.keras.callbacks import ModelCheckpoint

cp_callback = ModelCheckpoint(filepath=checkpoint_path, save_freq= 'epoch', verbose=1 )

regressor.compile(optimizer = 'adam', loss = 'mean_squared_error')
regressor.fit(X_train, y_train, epochs = 10, batch_size = 32, callbacks=[cp_callback])

我保存的模型结构:

saved_trained_10_epochs
├── assets
├── saved_model.pb
└── variables
    ├── variables.data-00000-of-00001
    └── variables.index

更新

我尝试如下使用 latest_checkpoint 但出现以下错误:

from tensorflow.train import latest_checkpoint

loaded_model = latest_checkpoint(checkpoint_path)
loaded_model.summary()

错误:

---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-57-76a8ebe4f259> in <module>
----> 1 loaded_model.summary()

AttributeError: 'NoneType' object has no attribute 'summary'

在重新创建模型之后:

loaded_regressor = Sequential()

loaded_regressor.add(LSTM(units = 180, return_sequences = True, input_shape = (X_train.shape[1], 3)))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(LSTM(units = 180, return_sequences = True))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(LSTM(units = 180, return_sequences = True))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(LSTM(units = 180, return_sequences = True))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(LSTM(units = 180, return_sequences = True))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(LSTM(units = 180))
loaded_regressor.add(Dropout(0.2))

loaded_regressor.add(Dense(units = 1))

loaded_regressor.compile(optimizer = 'adam', loss = 'mean_squared_error')
loaded_regressor.load_weights(latest_checkpoint(checkpoint_path))

错误:

---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-30-c344f1759d01> in <module>
     22 
     23 loaded_regressor.compile(optimizer = 'adam', loss = 'mean_squared_error')
---> 24 loaded_regressor.load_weights(latest_checkpoint(checkpoint_path))

/usr/local/lib/python3.6/dist-packages/tensorflow/python/keras/engine/training.py in load_weights(self, filepath, by_name)
    160         raise ValueError('Load weights is not yet supported with TPUStrategy '
    161                          'with steps_per_run greater than 1.')
--> 162     return super(Model, self).load_weights(filepath, by_name)
    163 
    164   @trackable.no_automatic_dependency_tracking

/usr/local/lib/python3.6/dist-packages/tensorflow/python/keras/engine/network.py in load_weights(self, filepath, by_name)
   1375             format.
   1376     """
-> 1377     if _is_hdf5_filepath(filepath):
   1378       save_format = 'h5'
   1379     else:

/usr/local/lib/python3.6/dist-packages/tensorflow/python/keras/engine/network.py in _is_hdf5_filepath(filepath)
   1670 
   1671 def _is_hdf5_filepath(filepath):
-> 1672   return (filepath.endswith('.h5') or filepath.endswith('.keras') or
   1673           filepath.endswith('.hdf5'))
   1674 

AttributeError: 'NoneType' object has no attribute 'endswith'

最佳答案

tf.keras 模型使用 tf.keras.models.load_model 加载,这应该可以正常工作,因为 tf.keras 支持读取/编写多种格式,包括 tensorflow 检查点。

关于tensorflow - 如何将保存的模型转换或加载到 TensorFlow 或 Keras 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58685572/

相关文章:

python - tensorflow 相对于 numpy 的一般计算优势

tensorflow - 使用 Vanilla Numpy 进行 LSTM 计算

python - 内部错误 : GPU sync failed in Google Colab

python - 实现余弦相似度损失给出了与 Tensorflow 不同的答案

machine-learning - Keras:验证错误是停止标准或验证准确性的一个很好的衡量标准吗?

tensorflow - TypeError : Inputs to a layer should be tensors. 得到:<PrefetchDataset 形状:

python - 在图形创建时跟踪张量形状

python - 使用 Tensorflow,使用神经网络进行 2 类分类

python - tensorflow :过滤器与内核和步幅

python - 为什么我们在 tensorflow 的损失函数中需要 `int64` 作为 MNIST 标签?