gpt4 book ai didi

python - 在 tf.metrics.mean_cosine_distance 上使用哪个 dim?

转载 作者:太空宇宙 更新时间:2023-11-04 00:22:50 25 4
gpt4 key购买 nike

我对哪个 dim 通常指的是 Tensorflow 中的哪个实际维度感到困惑,但具体来说,在使用 tf.metrics.mean_cosine_distance

给定

x = [
[1, 2, 3, 4, 5],
[0, 2, 3, 4, 5],
]

我想按列计算距离。也就是说,哪个维度解析为(伪代码):

mean([
cosine_distance(x[0][0], x[1][0]),
cosine_distance(x[0][1], x[1][1]),
cosine_distance(x[0][2], x[1][2]),
cosine_distance(x[0][3], x[1][3]),
cosine_distance(x[0][4], x[1][4]),
])

最佳答案

它沿着 dim 0 为您的输入 x。一旦您将输入 x 构建为 numpy 数组,就可以很直观地看到这一点。

In [49]: x_arr = np.array(x, dtype=np.float32)

In [50]: x_arr
Out[50]:
array([[ 1., 2., 3., 4., 5.],
[ 0., 2., 3., 4., 5.]], dtype=float32)


# compute (mean) cosine distance between `x[0]` & `x[1]`
# where `x[0]` can be considered as `labels`
# while `x[1]` can be considered as `predictions`
In [51]: cosine_dist_axis0 = tf.metrics.mean_cosine_distance(x_arr[0], x_arr[1], 0)

这个 dim 对应于 NumPy 术语中的名称 axis。例如,一个简单的 sum 操作可以沿着 axis 0 完成,例如:

In [52]: x_arr
Out[52]:
array([[ 1., 2., 3., 4., 5.],
[ 0., 2., 3., 4., 5.]], dtype=float32)

In [53]: np.sum(x_arr, axis=0)
Out[53]: array([ 1., 4., 6., 8., 10.], dtype=float32)

当您计算 tf.metrics.mean_cosine_distance 时,您实际上是在计算向量 labelspredictions 沿 dim 0 之间的余弦距离 (然后取平均值)如果你的输入是形状 (n, ) 其中 n 是每个向量的长度(即标签中的条目数/预测)

但是,如果您将 labelspredictions 作为列向量 传递,则 tf.metrics.mean_cosine_distance必须沿 dim 1

计算

示例:

如果你的输入labelprediction是列向量,

# if your `label` is a column vector
In [66]: (x_arr[0])[:, None]
Out[66]:
array([[ 1.],
[ 2.],
[ 3.],
[ 4.],
[ 5.]], dtype=float32)

# if your `prediction` is a column vector
In [67]: (x_arr[1])[:, None]
Out[67]:
array([[ 0.],
[ 2.],
[ 3.],
[ 4.],
[ 5.]], dtype=float32)

然后,tf.metrics.mean_cosine_distance 必须沿 dim 1

计算
# inputs
In [68]: labels = (x_arr[0])[:, None]
In [69]: predictions = (x_arr[1])[:, None]

# compute mean cosine distance between them
In [70]: cosine_dist_dim1 = tf.metrics.mean_cosine_distance(labels, predictions, 1)

这个 tf.metrics.mean_cosine_distance 或多或少与 scipy.spatial.distance.cosine 做同样的事情,但它也采用 mean

对于您的示例案例:

In [77]: x
Out[77]: [[1, 2, 3, 4, 5], [0, 2, 3, 4, 5]]

In [78]: import scipy

In [79]: scipy.spatial.distance.cosine(x[0], x[1])
Out[79]: 0.009132

关于python - 在 tf.metrics.mean_cosine_distance 上使用哪个 dim?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48529169/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com