我有以下一个网络架构(下面只显示网络的相关部分)
vocab_dimension = 1500
embed_dimension = 10
x = [Input(shape=(None, ), name='input', dtype='int32'),
Input(shape=(None, ), name='weights'),
Input(shape=(None, ), name='neg_examples', dtype='int32')]
embedding_layer = Embedding(input_dim=vocab_dimension, output_dim=embed_dimension)
def _weighted_sum(x):
return K.sum(x[0] * K.expand_dims(x[1], -1), axis=1, keepdims=True)
weighted_sum = Lambda(_weighted_sum, name='weighted_sum')
item_vecs = embedding_layer(x[2])
user_vecs = weighted_sum([embedding_layer(x[0]), x[1]])
这里的问题是我不想将权重作为输入传递,但我想“学习”它们,就像在注意力层中一样。
我知道可以通过这种方式创建注意力层
attention_probs = Dense(h, activation='softmax', name='attention_probs')(x[0])
weighted_sum = Lambda(_weighted_sum)([x[0], attention_probs])
h
等于输入长度的维度,我将其设置为 5。但是,如果执行上述操作,则会出现以下错误
TypeError: unsupported operand type(s) for +: 'NoneType' and 'int'
我认为这与输入参数的尺寸有关,但我不确定如何解决这个问题。