【问题标题】:Train a model using lstm and keras使用 lstm 和 keras 训练模型
【发布时间】:2018-01-30 18:20:32
【问题描述】:

我有这样的输入数据:

x_train = [
    [0,0,0,1,-1,-1,1,0,1,0,...,0,1,-1],
    [-1,0,0,-1,-1,0,1,1,1,...,-1,-1,0]
    ...
    [1,0,0,1,1,0,-1,-1,-1,...,-1,-1,0]
]
y_train = [1,1,1,0,-1,-1,-1,0,1...,0,1]

它是一个数组,每个数组的大小为 83。 y_train 是每个数组的标签。 所以len(x_train) 等于len(y_train)。 我从 keras 和 theano 后端使用以下代码对此类数据进行训练:

def train(x, y, x_test, y_test):
    x_train = np.array(x)
    y_train = np.array(y)
    print x_train.shape
    print y_train.shape
    model = Sequential()
    model.add(Embedding(x_train.shape[0], output_dim=256))
    model.add(LSTM(128))
    model.add(Dropout(0.5))
    model.add(Dense(1, activation='sigmoid'))
    model.compile(loss='binary_crossentropy',
            optimizer='rmsprop',
            metrics=['accuracy'])
    model.fit(x_train, y_train, batch_size=16)
    score = model.evaluate(x_test, y_test, batch_size=16)
    print score

但我的网络不适合,结果是:

Epoch 1/10
1618/1618 [==============================] - 4s - loss: -1.6630 - acc: 0.0043     
Epoch 2/10
1618/1618 [==============================] - 4s - loss: -2.5033 - acc: 0.0012         
Epoch 3/10
1618/1618 [==============================] - 4s - loss: -2.6150 - acc: 0.0012         
Epoch 4/10
1618/1618 [==============================] - 4s - loss: -2.6297 - acc: 0.0012         
Epoch 5/10
1618/1618 [==============================] - 4s - loss: -2.5731 - acc: 0.0012            
Epoch 6/10
1618/1618 [==============================] - 4s - loss: -2.6042 - acc: 0.0012         
Epoch 7/10
1618/1618 [==============================] - 4s - loss: -2.6257 - acc: 0.0012          
Epoch 8/10
1618/1618 [==============================] - 4s - loss: -2.6303 - acc: 0.0012         
Epoch 9/10
1618/1618 [==============================] - 4s - loss: -2.6296 - acc: 0.0012         
Epoch 10/10
1618/1618 [==============================] - 4s - loss: -2.6298 - acc: 0.0012         
283/283 [==============================] - 0s     
[-2.6199024279631482, 0.26501766742328875]

我想做这个训练并取得好成绩。

【问题讨论】:

  • 你只训练了 10 个短时期。如果你训练更多会发生什么?
  • @JonasAdler 即使有 100 个 epoch,我也会得到相同的结果。
  • @JonasAdler 我怎样才能只用 tensorflow 做这个训练?

标签: python keras theano lstm keras-layer


【解决方案1】:

负损失应该引发巨大的危险信号。损失应该始终是一个正数,接近于零。你说你是

y_train = [1,1,1,0,-1,-1,-1,0,1...,0,1]

由于您的损失是binary_crossentropy,我必须假设目标是 2 类分类问题。当您查看 y 值时,您有 -1、0 和 1。这表明 3 个类。大问题,你应该只有1和0。您需要更正您的数据。我对数据一无所知,所以我无法将其浓缩为两个类。 -1 是负损失的原因。 sigmoid 激活基于 0-1 范围内的 CDF,因此您的类必须适合此函数的任一端。


编辑

根据下面 cmets 中的描述,我建议使用 3 类结构。以下是转换为分类值的输出数据示例

from keras.utils import to_categorical

y_train = np.random.randint(-1,2,(10))

print(y_train)

[-1  0 -1 -1 -1  0 -1  1  1  0]

print(to_categorical(y_train,num_classes=3))

[[ 0.  0.  1.]
 [ 1.  0.  0.]
 [ 0.  0.  1.]
 [ 0.  0.  1.]
 [ 0.  0.  1.]
 [ 1.  0.  0.]
 [ 0.  0.  1.]
 [ 0.  1.  0.]
 [ 0.  1.  0.]
 [ 1.  0.  0.]]

现在每个可能的输出都存储在单独的列中。您可以看到如何为 -1,0 和 1 分配二进制值,即-1 = [0. 0. 1.]0 = [1. 0. 0.]1 = [0. 1. 0.]

现在你只需要更新损失函数、输出节点的数量和输出层上的激活

model.add(Dense(3, activation='softmax'))
model.compile(loss='categorical_crossentropy',
        optimizer='rmsprop',
        metrics=['accuracy'])

【讨论】:

  • 感谢您的回答。我的数据中的 1、0、-1 表示某些指标的增加不变和减少,y 是这 83 个指标在一个指标上的结果。我的意思是指标 x 的增加和指标 y 和 z 的减少以及度量 t 没有改变,m 对特定单个度量的影响如何。我应该使用哪个损失函数?
  • 我得到了答案我应用了你的笔记并将我的 y_train 转换为分类数据并且不更改我的输入。使用RMSprop 作为我的优化器,使用0.5 作为learning rate 以及上面我的代码中的所有其他选项,我得到损失率 9 !!!准确率 45%
猜你喜欢
  • 1970-01-01
  • 2018-01-08
  • 2019-11-25
  • 1970-01-01
  • 1970-01-01
  • 2019-02-28
  • 1970-01-01
  • 2019-05-10
  • 1970-01-01
相关资源
最近更新 更多