在Keras 2.0中使用合并层(lambda/函数)?

我正在尝试将这个模型移植到Keras v2,但我在处理以下函数时遇到了问题:

  def __call__(self, sent1, sent2):        def _outer(AB):            att_ji = K.batch_dot(AB[1], K.permute_dimensions(AB[0], (0, 2, 1)))            return K.permute_dimensions(att_ji, (0, 2, 1))        return merge([self.model(sent1), self.model(sent2)], mode=_outer,                     output_shape=(self.max_length, self.max_length))

根据文档,mode 是:

字符串或lambda/函数。如果是字符串,必须是以下之一:’sum’, ‘mul’, ‘concat’, ‘ave’, ‘cos’, ‘dot’, ‘max’。如果是lambda/函数,它应该接受一个张量列表作为输入,并返回一个单一的张量。

在新的Keras版本中,模式为函数/lambda时的等效函数是什么,以避免以下警告:

UserWarning: The `merge` function is deprecated and will be removed after 08/2017. Use instead layers from `keras.layers.merge`, e.g. `add`, `concatenate`, etc.  return merge([attention, sentence], mode=_normalize_attention, output_shape=(self.max_length, self.nr_hidden))

回答:

这似乎是一种奇怪的模型实现方式……(至少在keras 2中是这样的…)

看起来你应该使用带有自定义函数的lambda层。

def __call__(self, sent1, sent2):    def _outer(AB): #自定义函数        att_ji = K.batch_dot(AB[1], K.permute_dimensions(AB[0], (0, 2, 1)))            return K.permute_dimensions(att_ji, (0, 2, 1))    return Lambda(_outer,                   output_shape=(self.max_length,self.max_length))([                                           self.model(sent1),                                            self.model(sent2)])

如果self.model(sent)返回由keras层创建的张量,这应该可以工作。


现在,关于实际的合并层,在keras 2中你有以下层:

  • Concatenate(axis=…)(listOfTensors)
  • Add()(listOfTensors)
  • Multiply()(listOfTensors)
  • 以及其他,包括Dot层,它“可能”与那个函数执行相同的操作。

如果使用dot层:

return Dot()([self.model(sent1),self.model(sent2)])

这需要测试。Keras中的Dot和batch dot是容易混淆的东西。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注