为TFliteconverter创建代表性数据集的正确方法是什么?

时间:2019-09-10 20:40:08

标签: tensorflow dataset tensorflow-lite

我正在尝试用tinyYOLO-V2的权重和激活来推断INT8。我可以使用TFliteConverter将权重转换为INT8。对于INT8激活,我必须给出代表性的数据集以估计比例因子。我创建此类数据集的方法似乎是错误的。

正确的程序是什么?

def rep_data_gen():
    a = []
    for i in range(160):
        inst = anns[i]
        file_name = inst['filename']
        img = cv2.imread(img_dir + file_name)
        img = cv2.resize(img, (NORM_H, NORM_W))
        img = img / 255.0
        img = img.astype('float32')
        a.append(img)
    a = np.array(a)
    print(a.shape) # a is np array of 160 3D images
    img = tf.data.Dataset.from_tensor_slices(a).batch(1)
    for i in img.take(BATCH_SIZE):
        print(i)
        yield [i]
# https://www.tensorflow.org/lite/performance/post_training_quantization
converter = tf.lite.TFLiteConverter.from_keras_model_file("./yolo.h5")
converter.optimizations = [tf.lite.Optimize.DEFAULT]
converter.target_ops = [tf.lite.OpsSet.TFLITE_BUILTINS_INT8]
converter.inference_input_type = [tf.int8]
converter.inference_output_type = [tf.int8]
converter.representative_dataset=rep_data_gen
tflite_quant_model = converter.convert()
  

ValueError:无法设置张量:得到类型为STRING的张量,但预期输入27为FLOAT32类型,名称:input_1

1 个答案:

答案 0 :(得分:0)

我使用您的代码读取数据集并发现错误:

img = img.astype('float32')应该

img = img.astype(np.float32)

希望这会有所帮助