解决深度学习中Conv1D层输出长度小于2的错误:ValueError: One of the dimensions in the output is <= 0 due to downsampling
解决深度学习中Conv1D层输出长度小于2的错误:ValueError: One of the dimensions in the output is <= 0 due to downsampling
在使用Keras构建CNN模型时,使用Conv1D层可能会遇到一个常见的错误:'ValueError: One of the dimensions in the output is <= 0 due to downsampling in conv1d_1. Consider increasing the input size. Received input shape [None, 1, 64] which would produce output shape with a zero or negative value in a dimension.'
这个错误是由于在第一个Conv1D层中使用了太小的卷积核(3),导致输出的长度小于2,无法进行下采样操作。
解决方法
有两种主要的方法可以解决这个问题:
-
增加输入数据的长度: 尝试增加输入数据的长度,例如,可以通过将数据窗口扩展到更长的时间范围来增加输入序列的长度。
-
减少卷积核大小: 尝试减少卷积核大小,例如,可以将卷积核大小从3减少到2。
示例代码
import pandas as pd
import numpy as np
# 加载数据
data = pd.read_excel('E:\pythonProject5\深度学习\新建 XLS 工作表.xls')
# 提取每日开盘价、收盘价、最高价和最低价
open_prices = data['开盘'].values
close_prices = data['收盘'].values
high_prices = data['最高'].values
low_prices = data['最低'].values
# 将价格数据转换为二维数组
prices = np.array([open_prices, close_prices, high_prices, low_prices])
prices = np.transpose(prices)
from keras.models import Sequential
from keras.layers import Conv1D, MaxPooling1D, Flatten, Dense, Dropout
# 定义CNN模型
model = Sequential()
model.add(Conv1D(64, 3, activation='relu', input_shape=(prices.shape[1], 1)))
model.add(MaxPooling1D(2))
# 将卷积核大小改为2
model.add(Conv1D(32, 2, activation='relu'))
model.add(MaxPooling1D(2))
model.add(Flatten())
model.add(Dense(64, activation='relu'))
model.add(Dropout(0.5))
model.add(Dense(1, activation='linear'))
model.summary()
# 将数据转换为三维数组
prices = np.expand_dims(prices, axis=2)
# 将数据输入模型
features = model.predict(prices)
# 提取特征
features = np.squeeze(features)
通过增加输入数据长度或减少卷积核大小,可以有效地解决'ValueError: One of the dimensions in the output is <= 0 due to downsampling'错误。
原文地址: https://www.cveoy.top/t/topic/oZUd 著作权归作者所有。请勿转载和采集!