我正在尝试解决以下问题:
我有来自许多设备的时间序列数据。每个设备记录的长度为 3000。捕获的每个数据点都有 4 个测量值。所以我的数据是成形的(设备记录的数量,3000、4)。
我正在尝试生成一个长度为 3000 的向量,其中每个数据点是 3 个标签(y1、y2、y3)之一,所以我想要的输出暗淡是(设备记录数,3000、1)。我已经标记了用于训练的数据。
我正在尝试为此使用 LSTM 模型,因为“随着时间序列数据移动时的分类”似乎是 RNN 类型的问题。
我的网络设置如下:
model = Sequential()
model.add(LSTM(3, input_shape=(3000, 4), return_sequences=True))
model.add(LSTM(3, activation = 'softmax', return_sequences=True))
model.summary()
总结如下:
Model: "sequential_23"
_________________________________________________________________
Layer (type) Output Shape Param #
=================================================================
lstm_29 (LSTM) (None, 3000, 3) 96
_________________________________________________________________
lstm_30 (LSTM) (None, 3000, 3) 84
=================================================================
Total params: 180
Trainable params: 180
Non-trainable params: 0
_________________________________________________________________
在输出空间中一切看起来都很好,因为我可以使用每个单元的结果来确定我的三个类别中的哪一个属于那个特定的时间步(我认为)。
但我只有 180 个可训练参数,所以我猜我做错了什么。
有人可以帮我理解为什么我的可训练参数这么少吗?我是否误解了如何设置这个 LSTM?我只是在担心什么吗?
那 3 个单位是否意味着我只有 3 个 LSTM“块”?并且它只能回顾 3 个观察结果?
守着一只汪
相关分类