我有一个相对简单的问题,如果不使用循环就无法解决。我很难找出这个问题的正确标题。假设我们有两个 numpy 数组:
array_1 = np.array([[0, 1, 2],
[3, 3, 3],
[3, 3, 4],
[3, 6, 2]])
array_2 = np.array([[0, 0, 0],
[1, 1, 1],
[2, 2, 2],
[3, 3, 3],
[4, 4, 4],
[5, 5, 5],
[6, 6, 6]])
array_1
array_2
表示我们想要的行的索引sum
。因此,例如,数组中的4
第 行应包含与array_1中的所有 s 具有相同行索引的所有行的总和。result
array_2
3
在代码中更容易理解:
result = np.empty(array_2.shape)
for i in range(array_1.shape[0]):
for j in range(array_1.shape[1]):
index = array_1[i, j]
result[index] = result[index] + array_2[i]
结果应该是:
[[ 0 0 0]
[ 0 0 0]
[ 3 3 3]
[10 10 10]
[ 2 2 2]
[ 0 0 0]
[ 3 3 3]]
我尝试使用np.einsum
,但我需要将数组中的两个元素都用作索引,并将其行用作索引,所以我不确定np.einsum
这里是否是最佳路径。
这是我在图形中遇到的问题。array_1
表示三角形的顶点索引并array_2
表示法线,其中行的索引对应于顶点的索引