gpt4 book ai didi

python - TensorFlow Keras 在期望一个预测的同时返回多个预测

转载 作者:行者123 更新时间:2023-11-30 09:26:44 29 4
gpt4 key购买 nike

我正在学习 TensorFlow 和 LSTM,我想知道为什么当我训练它返回一个值时,我的预测输出有多个值。我的目标是在使用数组进行情感分析训练后获得 0 到 1 之间的单个值。

训练输入数据如下所示:

[[59, 21, ... 118, 194], ... [12, 110, ... 231, 127]]

所有输入数组的长度相同,并用 0 填充。训练目标数据如下所示:

[1.0, 0.5, 0.0, 1.0, 0.0 ...]

型号:

model = Sequential()
model.add(Embedding(input_length, 64, mask_zero=True))
model.add(LSTM(100))
model.add(Dense(1, activation=tf.nn.sigmoid))

为什么预测似乎一次评估每个单独的值而不是整个数组?

model.predict([192])
# Returns [[0.5491102]]
model.predict([192, 25])
# Returns [[0.5491102, 0.4923803]]
model.predict([192, 25, 651])
# Returns [[0.5491102, 0.4923803, 0.53853387]]

我不想取输出的平均值,因为输入数组中的值之间的关系对于情感分析很重要。如果我正在训练预测单个值,我不明白为什么不输出单个值。我是 TensorFlow、Keras 和分层神经网络的新手,所以我确信我错过了一些明显的东西。

最佳答案

当你写下:

model.predict([192, 25, 651])

如果您为模型提供三个输入样本,那么作为返回,您将获得三个输出,每个输入样本一个。相反,如果 [192, 25, 651] 您确实指的是一个输入样本,那么您可以将其包装在两个列表中:

model.predict([[[192, 25, 651]]])

原因:最外面的列表对应的是模型所有输入层的所有输入数据的列表,这里就是一个。第二个列表对应于第一个(也是唯一一个)输入层的数据,第三个列表对应于一个输入样本。列表输入就是这种情况,因为多输入(和多输出)Keras 模型应该将输入数组列表作为输入。一种更好的方法是使用 numpy 数组来代替:

model.predict(np.array([[192, 25, 651]]))

np.array([[192, 25, 651]]) 的形状为 (1,3),这意味着长度为 3 的一个样本。

关于python - TensorFlow Keras 在期望一个预测的同时返回多个预测,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53979199/

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