gpt4 book ai didi

python - numpy - 沿轴的点积之和

转载 作者:行者123 更新时间:2023-11-30 22:41:56 24 4
gpt4 key购买 nike

我有一个 A x B 数组和另一个 D x A x A 数组,并且正在尝试想出有效的方法来计算沿 D 轴的两个数组的点积之和(这样结果将是 A x B 数组)。最明显的方法是使用 for 循环:

result = np.zeros(first_array.shape)
for d in range(0,second_array.shape[0]):
result = result + np.dot(second_array[d], first_array)
print result

我想知道在 numpy 中是否有更有效的计算方法。我读过一点np.einsum但不幸的是,我不完全了解它在这种情况下是否能够提供帮助。

最佳答案

In [436]: np.einsum('ijk,km->jm',np.ones((2,3,3)),np.ones((3,4)))
Out[436]:
array([[ 6., 6., 6., 6.],
[ 6., 6., 6., 6.],
[ 6., 6., 6., 6.]])
In [437]: _.shape
Out[437]: (3, 4)

您的表示为(k在第一个的最后一个和第二个的第二个到最后一个之间共享):

In [438]: np.einsum('jk,km->jm',np.ones((3,3)),np.ones((3,4)))
Out[438]:
array([[ 3., 3., 3., 3.],
[ 3., 3., 3., 3.],
[ 3., 3., 3., 3.]])

i 添加到第一个数组与其 3d 形状相匹配。但是从结果中省略它会告诉einsum对其值求和。没有求和

In [439]: np.einsum('ijk,km->ijm',np.ones((2,3,3)),np.ones((3,4))).shape
Out[439]: (2, 3, 4)

关于python - numpy - 沿轴的点积之和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42319805/

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