nce_loss()的Tensorflow num_classes参数

问题描述 投票:2回答:1

我对噪声对比估计的理解是我们从单词嵌入(负样本)中采样一些向量,然后计算每个向量的对数似然。然后我们想要最大化目标词的概率和每个负样本词的对数似然之间的差异(所以如果我对此正确,我们希望优化损失函数,使其接近1尽可能)。

我的问题是:

num_classes函数的nce_loss参数的目的是什么?我最好的猜测是传入类的数量,以便Tensorflow知道我们绘制的负样本的分布大小,但这可能没有意义,因为我们可以从变量本身推断分布的大小。否则,我想不出为什么我们需要知道类的总数可能的原因,特别是如果语言模型仅输出k + 1个预测(负样本大小+目标词的1)。

tensorflow nlp word2vec word-embedding language-model
1个回答
0
投票

你的猜测是正确的。 num_classes参数用于从对数均匀(Zipfian)分布中对负标签进行采样。

这是link to the source code

# Sample the negative labels.
#   sampled shape: [num_sampled] tensor
#   true_expected_count shape = [batch_size, 1] tensor
#   sampled_expected_count shape = [num_sampled] tensor
if sampled_values is None:
  sampled_values = candidate_sampling_ops.log_uniform_candidate_sampler(
      true_classes=labels,
      num_true=num_true,
      num_sampled=num_sampled,
      unique=True,
      range_max=num_classes)

range_max=num_classes参数基本上定义了此分布的形状以及采样值的范围 - [0, range_max)。请注意,无法从标签中准确推断出此范围,因为特定的小批量只能包含较小的单词ID,这会显着扭曲分布。

© www.soinside.com 2019 - 2024. All rights reserved.