最近复现别人的论文,才发现tf竟然就只有常用的一些loss, 并没有其他指标,例如P@1和MRR。在手工计算这些指标的过程中,发现了几个神奇的函数。
任务介绍
输入是各个候选的分值tensor_score,假设有每个样本对应5个候选,那么输入大小就是[batch_size, 5]。target指定了候选中实际匹配一个为1,其余为0,大小为[batch_size,1]
现在我们的目标是:得到5个候选从高到低的排序,并且把最高的取出来与target对比,若其target为1则正确,否则错误,计算P@1。然后取targer中值为1的候选,得到它的排名,计算MRR。
具体的计算公式如下:
P@1=1N