以 TFIDF 作为输入的 LSTM,尺寸误差
LSTM with TFIDF as input, dimension error
我正在尝试 运行 以 TFIDF 作为输入的 LSTM,但出现错误。我有 11915 个维度的每个条目的 TFIDF
代码如下:
## Creating model
model=Sequential()
model.add(Bidirectional(LSTM(100, input_shape=(1, 11915),return_sequences=True)))
model.add(Dropout(0.3))
model.add(Dense(1,activation='sigmoid'))
model.build(input_shape=(1, 11915))
model.compile(loss='binary_crossentropy',optimizer='adam',metrics=['accuracy'])
print(model.summary())
错误如下
层 bidirectional_27 的输入 0 与层不兼容:预期 ndim=3,发现 ndim=2。已收到完整形状:[1, 11915]
我是这个领域的新手,非常感谢任何帮助。如果有人在这样的输入
上为 运行ning Bidirectional LSTM 编写虚拟代码,那将非常好
我的输入是10229*11915的tfidf。我想在 TFIDF 上使用 LSTM 作为输入进行假新闻检测
您想在 Bidirectional
层中指定您的 input_shape
:
model.add(Bidirectional(LSTM(100, return_sequences=True), input_shape=(1, 11915)))
这是一个完整的工作示例
# create fake data
n_sample = 10229
X = np.random.uniform(0,1, (n_sample,11915))
y = np.random.randint(0,2, n_sample)
# expand X to 3D
X = X.reshape(X.shape[0],1,X.shape[-1])
model=Sequential()
model.add(Bidirectional(LSTM(100, return_sequences=False), input_shape=(1, 11915)))
model.add(Dropout(0.3))
model.add(Dense(1, activation='sigmoid'))
model.compile(loss='binary_crossentropy',optimizer='adam',metrics=['accuracy'])
print(model.summary())
model.fit(X,y, epochs=3, batch_size=256)
出现此错误可能是因为您没有正确管理您的数据。还要注意正确定义第一层和 return_sequences=False 因为你的输出是 2D
我正在尝试 运行 以 TFIDF 作为输入的 LSTM,但出现错误。我有 11915 个维度的每个条目的 TFIDF
代码如下:
## Creating model
model=Sequential()
model.add(Bidirectional(LSTM(100, input_shape=(1, 11915),return_sequences=True)))
model.add(Dropout(0.3))
model.add(Dense(1,activation='sigmoid'))
model.build(input_shape=(1, 11915))
model.compile(loss='binary_crossentropy',optimizer='adam',metrics=['accuracy'])
print(model.summary())
错误如下 层 bidirectional_27 的输入 0 与层不兼容:预期 ndim=3,发现 ndim=2。已收到完整形状:[1, 11915]
我是这个领域的新手,非常感谢任何帮助。如果有人在这样的输入
上为 运行ning Bidirectional LSTM 编写虚拟代码,那将非常好我的输入是10229*11915的tfidf。我想在 TFIDF 上使用 LSTM 作为输入进行假新闻检测
您想在 Bidirectional
层中指定您的 input_shape
:
model.add(Bidirectional(LSTM(100, return_sequences=True), input_shape=(1, 11915)))
这是一个完整的工作示例
# create fake data
n_sample = 10229
X = np.random.uniform(0,1, (n_sample,11915))
y = np.random.randint(0,2, n_sample)
# expand X to 3D
X = X.reshape(X.shape[0],1,X.shape[-1])
model=Sequential()
model.add(Bidirectional(LSTM(100, return_sequences=False), input_shape=(1, 11915)))
model.add(Dropout(0.3))
model.add(Dense(1, activation='sigmoid'))
model.compile(loss='binary_crossentropy',optimizer='adam',metrics=['accuracy'])
print(model.summary())
model.fit(X,y, epochs=3, batch_size=256)
出现此错误可能是因为您没有正确管理您的数据。还要注意正确定义第一层和 return_sequences=False 因为你的输出是 2D