要保持tf.keras.predict
和tf.data.Dataset
之间的示例索引对应,可以使用enumerate()
函数来追踪索引,并在预测时将索引添加到输出中。以下是一个示例代码:
import tensorflow as tf
import numpy as np
# 创建一个示例的输入数据集
x = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
y = np.array([10, 20, 30])
dataset = tf.data.Dataset.from_tensor_slices((x, y))
# 构建一个简单的模型
model = tf.keras.Sequential([
tf.keras.layers.Dense(10, activation='relu'),
tf.keras.layers.Dense(1)
])
# 定义一个生成器函数,用于包装数据集并追踪索引
def gen():
for i, (x, y) in enumerate(dataset):
yield i, x, y
# 使用生成器函数创建一个新的数据集
indexed_dataset = tf.data.Dataset.from_generator(gen, output_signature=(tf.TensorSpec(shape=(), dtype=tf.int32),
tf.TensorSpec(shape=(3,), dtype=tf.int32),
tf.TensorSpec(shape=(), dtype=tf.int32)))
# 预测并保持索引对应
predictions = []
for i, x, y in indexed_dataset:
prediction = model.predict(tf.expand_dims(x, 0))
predictions.append((i, prediction))
# 打印预测结果
for i, prediction in predictions:
print(f"Example {i}: {prediction}")
在上述代码中,我们首先创建了一个示例数据集dataset
,其中包含三个输入样本和三个对应的标签。然后,我们定义了一个生成器函数gen()
,它通过enumerate()
函数来追踪索引,并将索引、输入样本和标签作为生成器的输出。接下来,我们使用from_generator()
方法来创建一个新的数据集indexed_dataset
,其中每个示例都包含了索引、输入样本和标签。
在预测阶段,我们遍历indexed_dataset
并使用model.predict
进行预测。我们将预测结果和示例的索引存储在predictions
列表中。最后,我们按照示例的索引顺序打印预测结果。
通过这种方式,我们可以保持tf.keras.predict
和tf.data.Dataset
之间的示例索引对应。
下一篇:保持Three.js纹理的宽高比