2 回答

TA贡献1911条经验 获得超7个赞
您可以调整 from_tensor_slices 以使其保持为 2 个元素的元组,并且第一个元素本身就是一个元组。
工作示例:
import numpy as np
import tensorflow as tf
input_1 = tf.keras.Input(shape=(10,))
dense_1 = tf.keras.layers.Dense(4)(input_1)
input_2 = tf.keras.Input(shape=(10,))
dense_2 = tf.keras.layers.Dense(4)(input_2)
x = tf.keras.layers.Concatenate()([dense_1, dense_2])
y = tf.keras.layers.Dense(2)(x)
model = tf.keras.Model([input_1, input_2], y)
model.summary()
dataset_size = 16
batch_size = 4
input_1_values = np.random.random((dataset_size, 10))
input_2_values = np.random.random((dataset_size, 10))
output_values = np.random.random((dataset_size, 2))
dataset = tf.data.Dataset.from_tensor_slices(((input_1_values, input_1_values), output_values))
dataset = dataset.repeat().shuffle(buffer_size=4).batch(batch_size)
steps = 10
model.compile(optimizer="adam", loss="binary_crossentropy")
model.fit(dataset, epochs=1, steps_per_epoch=steps)
将数据集合并为单个数据集的另一种选择也可能是使用zip 方法

TA贡献1807条经验 获得超9个赞
我发现没有必要使用“for”循环。我可以通过仅使用 Keras 来避免使用“for”循环,同时我仍然可以使用多个 Xes,但不再使用 tf.data.Dataset:
Steps = 1000;
Epochs = round(Steps/(Dsize/Bsize));
Lline = 10;
Lafte = round(Epochs/Lline);
if Lafte==0: Lafte=1;
#Train: Loop
L = Model.evaluate(x=[Inp1,Inp2], y=Exp, steps=round(Dsize/Bsize), batch_size=Bsize,
verbose=0);
print(f"Initavg batch loss: {L:.9f}");
Model.fit(x=[Inp1,Inp2], y=Exp, epochs=Epochs, batch_size=Bsize, shuffle=True,
verbose=0, callbacks=[callback()]);
添加回答
举报