【发布时间】:2020-12-29 10:48:47
【问题描述】:
我有一个大小为 (450,552,30) 的 3D 向量,其中 450 = x 维度,552 = y 维度,30 = 时间步长。本质上,二维对象的延时。我知道有可能的 convLSTM 和 LSTM CNN,但我想将这些数据扁平化为一维 LSTM 模型进行测试。
为了简单起见,让我们采用这样的二维数组
a = np.array([[1,2,3],[4,5,6],[7,8,9]])
然后让我们将它与第三维连接几次:
a = np.expand_dims(a,axis=-1)
b = a
b = np.concatenate((b,a),axis=-1)
b = np.concatenate((b,a),axis=-1)
b = np.concatenate((b,a),axis=-1)
print(b.shape)
(3,3,4)
这样 b 就是相同的数据 (a),将其自身连接起来,作为对我希望实现的全尺寸数据的一种小规模练习。如果我这样做:
b.flatten()
array([1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6,
6, 6, 7, 7, 7, 7, 8, 8, 8, 8, 9, 9, 9, 9])
这并没有给我我正在寻找的答案。我正在寻找更多:
array([[1,1,1,1],[2,2,2,2],[3,3,3,3],[4,4,4,4], ..., [9,9,9,9]])
满量程输出的尺寸应为 (450 * 552, 30)。而不是 (450 * 552 * 30,)。有没有一种优雅的方式来做到这一点?
【问题讨论】:
标签: python arrays numpy reshape flatten