gpt4 book ai didi

python - LSTM 嵌入层形状错误

转载 作者:行者123 更新时间:2023-11-30 09:46:24 25 4
gpt4 key购买 nike

我有这样的网络架构:

model = Sequential()
model.add(Embedding(9761, 100, input_length=longest_period))
model.add(LSTM(30, dropout=0.2, recurrent_dropout=0.2))
model.add(Dense(1, activation='sigmoid'))
model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])

当我尝试拟合模型时:

res = model.fit(X_train_lsmt, np.array(y_train_lsmt), validation_split=0.25, epochs=2, batch_size=128, verbose=0)

我收到此错误:

ValueError: Error when checking model input: expected
embedding_3_input to have shape (None, 217) but got array
with shape (3133, 1)

我认为错误可能与单热编码y_train_lsmt有关,其形状为(3133,3)

[[ 0.1.0.]
[ 0.1.0.]
[ 0.0.1.]
...,
[ 1.0.0.]
[ 1.0.0.]
[0.1.0.]]

但我对此不确定。

更新:

我已经部分解决了添加 Flatten() 层的问题:

model = Sequential()
model.add(Embedding(9761, 100, input_length=stringa_piu_lunga))
model.add(LSTM(units=10, return_sequences=True))
model.add(Flatten())
model.add(Dense(3, activation='softmax'))
model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])

但现在我在模型评估过程中遇到了同样的错误:

score = model.evaluate(X_test_lsmt, y_train_lsmt, verbose=0)

最佳答案

你的代码看起来不错。将您的 y_train_lstm 更改为分类:

y_train_lstm = keras.utils.to_categorical(y_train_lstm)

或者将损失更改为稀疏_分类_熵:

model.compile(optimizer='adam',
loss='sparse_categorical_crossentropy',
metrics=['accuracy'])
<小时/>

已编辑:根据您的 github 存储库,评估将无法进行,因为您没有对 x_test_lstm 进行预处理。尝试:

X_test_lstm = sequence.pad_sequences(X_test_lstm, maxlen=longest_string)

关于python - LSTM 嵌入层形状错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51987877/

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