gpt4 book ai didi

tensorflow - 训练后量化后加载模型时出现问题

转载 作者:行者123 更新时间:2023-12-02 12:44:33 32 4
gpt4 key购买 nike

我已经训练了一个模型并将其转换为 .tflite 模型。我已经使用以下方法完成了训练后量化:

import tensorflow as tf
converter = tf.lite.TFLiteConverter.from_saved_model(saved_model_dir)
converter.optimizations = [tf.lite.Optimize.OPTIMIZE_FOR_SIZE]
tflite_quant_model = converter.convert()

但是当我尝试在 RaspberryPi 上使用模型进行推理时,出现以下错误

Traceback (most recent call last):
File "tf_lite_test.py", line 8, in <module>
interpreter = tf.lite.Interpreter(model_path="converted_from_h5_model_with_quants.tflite")
File "/home/pi/.local/lib/python3.5/site-packages/tensorflow/lite/python/interpreter.py", line 46, in __init__
model_path))
ValueError: Didn't find op for builtin opcode 'CONV_2D' version '2'
Registration failed.

当我将模型转换为 tflite 而不应用任何训练后量化时,我没有收到任何错误。这是我用来隐藏模型而不应用训练后量化的代码。

import tensorflow as tf
converter = tf.lite.TFLiteConverter.from_saved_model(saved_model_dir)
tflite_quant_model = converter.convert()

这是我的模型:

model = tf.keras.models.Sequential([
tf.keras.layers.Conv2D(32, (3,3), activation='relu', input_shape=(IMG_SHAPE, IMG_SHAPE, 3)),
tf.keras.layers.MaxPooling2D(2, 2),

tf.keras.layers.Conv2D(64, (3,3), activation='relu'),
tf.keras.layers.MaxPooling2D(2,2),

tf.keras.layers.Conv2D(128, (3,3), activation='relu'),
tf.keras.layers.MaxPooling2D(2,2),

tf.keras.layers.Dropout(0.5),
tf.keras.layers.Flatten(),
tf.keras.layers.Dense(64, activation='relu'),
tf.keras.layers.Dense(3, activation='softmax')
])

如何应用训练后量化并加载模型而不会出现此错误?

最佳答案

也许您需要重建 tflite 运行时。这个型号可能太旧了,无法使用。请参阅此处的说明:https://www.tensorflow.org/lite/guide/build_rpi

关于tensorflow - 训练后量化后加载模型时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56722720/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com