我使用Keras2.0.2FunctionalAPI (Tensorflow 1.0.1)来实现一个网络,它需要几个输入并产生两个输出a和b。我需要使用cosine_proximity丢失来训练网络,这样b才是a的标签。我该怎么做?
在这里分享我的密码。最后一行model.fit(..)是有问题的部分,因为我没有标记数据本身。标签是由模型本身产生的。
from keras.models import Model
from keras.layers import Input, LSTM
from keras import losses
shared_lstm = LSTM(dim)
q1 = Input(shape=(..,.. ), name='q1')
q2 = Input(shape=(..,.. ), name='q2')
a = shared_lstm(q1)
b = shared_lstm(q2)
model = Model(inputs=[q1,q2], outputs=[a, b])
model.compile(optimizer='adam', loss=losses.cosine_proximity)
model.fit([testq1, testq2], [?????])发布于 2017-04-08 19:35:50
你可以先定义一个假的真实标签。例如,将其定义为输入数据大小的一维数组。
现在是损失函数。你可以按下面的方式写。
def my_cosine_proximity(y_true, y_pred):
a = y_pred[0]
b = y_pred[1]
# depends on whether you want to normalize
a = K.l2_normalize(a, axis=-1)
b = K.l2_normalize(b, axis=-1)
return -K.mean(a * b, axis=-1) + 0 * y_true我将y_true乘以零,并将其相加,这样Theano就不会给出丢失的输入警告/错误。
你应该在正常情况下调用你的fit函数,也就是包括你的假真实标签.
model.compile('adam', my_cosine_proximity) # 'adam' used as an example optimizer
model.fit([testq1, testq2], fake_y_true)https://stackoverflow.com/questions/43299274
复制相似问题