python - Tensorflow: `batch_size` 或 `steps` 输入数据需要 `Tensor` 或 `NumPy`

标签 python tensorflow keras

考虑以下 TensorFlow 代码:

import numpy as np
import tensorflow as tf

import tensorflow_datasets as tfds

mnist_dataset, mnist_info = tfds.load(name = 'mnist', with_info=True, as_supervised=True)

mnist_train, mnist_test = mnist_dataset['train'], mnist_dataset['test']

num_validation_samples = 0.1 * mnist_info.splits['train'].num_examples
num_validation_samples = tf.cast(num_validation_samples, tf.int64)

num_test_samples = mnist_info.splits['test'].num_examples
num_test_samples = tf.cast(num_test_samples, tf.int64)

def scale(image, label):
    image = tf.cast(image, tf.float32)
    image /= 255.
    return image, label

scaled_train_and_validation_data = mnist_train.map(scale)
test_data = mnist_test.map(scale)

BUFFER_SIZE = 10_000

shuffled_train_and_validation_data = scaled_train_and_validation_data.shuffle(BUFFER_SIZE)

validation_data = shuffled_train_and_validation_data.take(num_validation_samples)
train_data = shuffled_train_and_validation_data.skip(num_validation_samples)

BATCH_SIZE = 100
train_data = train_data.batch(BATCH_SIZE)
validation_data = validation_data.batch(num_validation_samples) # Single batch, having size equal to number of validation samples
test_data = test_data.batch(num_test_samples)

validation_inputs, validation_targets = next(iter(validation_data))

input_size = 784 # One for each pixel of the 28 * 28 image
output_size = 10
hidden_layer_size = 50 # Arbitrary chosen

model = tf.keras.Sequential([
    tf.keras.layers.Flatten(input_shape=(28,28,1)),
    tf.keras.layers.Dense(hidden_layer_size, activation='relu'), # First hidden layer
    tf.keras.layers.Dense(hidden_layer_size, activation='relu'),
    tf.keras.layers.Dense(output_size, activation='softmax')
])

model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])
NUM_EPOCHS = 5
model.fit(train_data, epochs = NUM_EPOCHS, validation_data=(validation_inputs, validation_targets), verbose=2)

运行它时 tf 给出错误:

ValueError: batch_size or steps is required for Tensor or NumPy input data.

当在 fit() 的调用中添加 batch_size 时:

model.fit(train_data, batch_size = BATCH_SIZE, epochs = NUM_EPOCHS, validation_data=(validation_inputs, validation_targets), verbose=2)

然后它提示:

ValueError: The batch_size argument must not be specified for the given input type. Received input: , batch_size: 100

这里有什么错误?

最佳答案

错误发生是因为 tf.Dataset提供给 Model.fit 的参数 validation_data ,但 Keras 不知道要验证多少步。要解决此问题,您只需设置参数 validation_steps 即可。例如:

model.fit(train_data,
    batch_size=BATCH_SIZE,
    epochs=NUM_EPOCHS,
    validation_data=(validation_inputs, validation_targets),
    validation_steps=10)

关于python - Tensorflow: `batch_size` 或 `steps` 输入数据需要 `Tensor` 或 `NumPy`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58752538/

相关文章:

python - 基于 pandas 数据框中的 2 列对多列进行排序

python - 匹配不需要的链接

python - 更大的批量大小减少训练时间

tensorflow - 如何访问 Huggingface 预训练 BERT 模型的特定层?

python - 在 TensorFlow Functional API 中保存和加载具有相同图表的多个模型

tensorflow - 关于 Keras 框架下自编码器模型中的解码器层定义

python - Keras和VGG训练: why do I "lose" training and validation examples following model. Predict_generator

Python ZipFile 模块缓慢提取受密码保护的 zip

python - 类型错误 : '_curses.curses window' object is not callable

Numpy 和删除具有相同值的行的最佳方法