npair_loss

paddle.fluid.layers.npair_loss(anchor, positive, labels, l2_reg=0.002)[源代码]

Npair Loss Layer

参考阅读 Improved Deep Metric Learning with Multi class N pair Loss Objective

NPair损失需要成对的数据。NPair损失分为两部分:第一部分是对嵌入向量进行L2正则化;第二部分是每一对数据的相似性矩阵的每一行和映射到ont-hot之后的标签的交叉熵损失的和。

参数:
  • anchor (Variable) - 锚点图像的嵌入Tensor,形状为[batch_size, embedding_dims]的2-D Tensor。数据类型:float32和float64。
  • positive (Variable) - 正例图像的嵌入Tensor,形状为[batch_size, embedding_dims]的2-D Tensor。数据类型:float32和float64。
  • labels (Variable) - 标签向量,形状为[batch_size]的1-DTensor。数据类型:float32、float64和int64。
  • l2_reg (float) - 嵌入向量的L2正则化系数,默认:0.002。

返回: Tensor。经过npair loss计算之后的结果,是一个值。

返回类型:Variable

代码示例

import paddle.fluid as fluid
import numpy as np
anchor = fluid.layers.data(
          name = 'anchor', shape = [18, 6], dtype = 'float32', append_batch_size=False)
positive = fluid.layers.data(
          name = 'positive', shape = [18, 6], dtype = 'float32', append_batch_size=False)
labels = fluid.layers.data(
          name = 'labels', shape = [18], dtype = 'float32', append_batch_size=False)

res = fluid.layers.npair_loss(anchor, positive, labels, l2_reg = 0.002)
place = fluid.CPUPlace()
exe = fluid.Executor(place)
exe.run(fluid.default_startup_program())
a = np.random.rand(18, 6).astype("float32")
p = np.random.rand(18, 6).astype("float32")
l = np.random.rand(18).astype("float32")
output = exe.run(feed={"anchor": a, "positive": p, "labels": l}, fetch_list=[res])
print(output)