卷积神经网络中卷积核大小与输入大小之间的关系

我在Keras中使用了一个Conv1D层,卷积核大小为3,步长为1。当我尝试处理输入大小为5时会出现以下错误,但在输入大小为6时一切正常。

InvalidArgumentError (see above for traceback): Computed output size would be negative:-1 [input_size: 0, effective_filter_size: 3, stride: 1]

我原以为大小为3的卷积核至少需要大小为3的输入。

编辑:这是模型,输入大小是可变的,我的问题出现在输入大小为5时。

model = Sequential()model.add(Conv1D(    input_shape=(None, 4),    filters=64,    kernel_size=3,    activation='relu'))model.add(Conv1D(    filters=32,    kernel_size=3,    activation='relu'))model.add(Conv1D(    filters=16,    kernel_size=2,    activation='relu'))model.add(GlobalMaxPooling1D())model.add(Dense(number_of_classes))model.add(Softmax(axis=-1))model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])

回答:

为了确保输出特征图的大小与输入特征图相同,您需要使用’same’填充来填充输入。

model.add(Conv1D(    input_shape=(None, 4),    filters=64,    kernel_size=3,    activation='relu',    padding='same'))

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注