【问题标题】:Unable to save TensorFlow Keras LSTM model to SavedModel format无法将 TensorFlow Keras LSTM 模型保存为 SavedModel 格式
【发布时间】:2019-11-05 22:24:03
【问题描述】:

系统信息:

操作系统平台和发行版(例如,Linux Ubuntu 16.04):Windows 10

TensorFlow 安装自(源代码或二进制文件):pip installed

TensorFlow 版本(使用下面的命令):v2.0.0-rc2-26-g64c3d382ca 2.0.0

Python 版本:3.7.1

错误:

无法将 TensorFlow Keras LSTM 模型保存为 SavedModel 格式以导出到 Google Cloud 存储桶。

错误信息:

ValueError:试图保存一个函数 b'__inference_lstm_2_layer_call_fn_36083',它引用了一个符号张量 Tensor("dropout/mul_1:0", shape=(None, 1280), dtype=float32) 这不是一个简单的常量。这不受支持。

代码:

import tensorflow as tf
import os
import cv2
import numpy as np
import matplotlib.pyplot as plt
import tqdm
import datetime
from sklearn.preprocessing import LabelBinarizer 

model = tf.keras.Sequential([
    tf.keras.layers.Masking(mask_value=0.),
    tf.keras.layers.LSTM(512, dropout=0.5, recurrent_dropout=0.5),
    tf.keras.layers.Dense(256, activation='relu'),
    tf.keras.layers.Dropout(0.5),
    tf.keras.layers.Dense(len(LABELS), activation='softmax')
])

model.compile(loss='categorical_crossentropy',
              optimizer='rmsprop',
              metrics=['accuracy', 'top_k_categorical_accuracy'])

test_file = 'C:/.../testlist01.txt'
train_file = 'C:/.../trainlist01.txt'

with open(test_file) as f:
    test_list = [row.strip() for row in list(f)]

with open(train_file) as f:
    train_list = [row.strip() for row in list(f)]
    train_list = [row.split(' ')[0] for row in train_list]


def make_generator(file_list):
    def generator():
        np.random.shuffle(file_list)
        for path in file_list:
            full_path = os.path.join(BASE_PATH, path).replace('.avi', '.npy')

            label = os.path.basename(os.path.dirname(path))
            features = np.load(full_path)

            padded_sequence = np.zeros((SEQUENCE_LENGTH, 1280))
            padded_sequence[0:len(features)] = np.array(features)

            transformed_label = encoder.transform([label])
            yield padded_sequence, transformed_label[0]
    return generator

train_dataset = tf.data.Dataset.from_generator(make_generator(train_list),
                 output_types=(tf.float32, tf.int16),
                 output_shapes=((SEQUENCE_LENGTH, 1280), (len(LABELS))))
train_dataset = train_dataset.batch(16).prefetch(tf.data.experimental.AUTOTUNE)

valid_dataset = tf.data.Dataset.from_generator(make_generator(test_list),
                 output_types=(tf.float32, tf.int16),
                 output_shapes=((SEQUENCE_LENGTH, 1280), (len(LABELS))))
valid_dataset = valid_dataset.batch(16).prefetch(tf.data.experimental.AUTOTUNE)

model.fit(train_dataset, epochs=17, validation_data=valid_dataset)

BASE_DIRECTORY = 'C:\\...\\saved_model\\LSTM\\1\\';
tf.saved_model.save(model, BASE_DIRECTORY)

【问题讨论】:

    标签: python keras lstm tensorflow2.0


    【解决方案1】:

    除了戴帽子的家伙的回答:

    .h5 部分足以告诉 keras 将其存储为 keras 模型保存。

    model.save('path_to_saved_model/model.h5') 
    

    应该可以解决问题。

    【讨论】:

      【解决方案2】:

      尝试使用 Keras API 保存它,而不是 SavedModel API。见Save and serialize models with Keras: Export to SavedModel

      model.save('path_to_saved_model', save_format='tf')
      

      这应该将模型保存为 SavedModel 格式。

      【讨论】:

      • 这仍然会产生相同的错误: ValueError: Attempted to save a function b'__inference_lstm_2_layer_call_fn_20869' 它引用了一个符号张量 Tensor("dropout/mul_1:0", shape=(None, 1280), dtype =float32) 这不是一个简单的常数。这不受支持。
      【解决方案3】:

      我认为有一个错误,您需要将 dropout 设置为 0 才能使函数 tf.saved_model.savemodel.save(.., save_format='tf') 工作

      【讨论】:

        【解决方案4】:

        这似乎是 TensorFlow 2.0 和 2.1 的一个错误,将我的 TensorFlow 升级到 v2.2 后,它工作正常。

        【讨论】:

          猜你喜欢
          • 2020-09-26
          • 1970-01-01
          • 1970-01-01
          • 2021-01-07
          • 1970-01-01
          • 1970-01-01
          • 2019-11-19
          • 1970-01-01
          • 2021-06-25
          相关资源
          最近更新 更多