python numpy数组 行相同_在Python / numpy的分配相同的数组索引一次

I want to find a fast way (without for loop) in Python to assign reoccuring indices of an array.

This is the desired result using a for loop:

import numpy as np

a=np.arange(9, dtype=np.float64).reshape((3,3))

# The array indices: [2,3,4] are identical.

Px = np.uint64(np.array([0,1,1,1,2]))

Py = np.uint64(np.array([0,0,0,0,0]))

# The array to be added at the array indices (may also contain random numbers).

x = np.array([.1,.1,.1,.1,.1])

for m in np.arange(len(x)):

a[Px[m]][Py[m]] += x

print a

%[[ 0.1 1. 2.]

%[ 3.3 4. 5.]

%[ 6.1 7. 8.]]

When I try to add x to a at the indices Px,Py I obviously do not get the same result (3.3 vs. 3.1):

a[Px,Py] += x

print a

%[[ 0.1 1. 2.]

%[ 3.1 4. 5.]

%[ 6.1 7. 8.]]

Is there a way to do this with numpy? Thanks.

解决方案

Yes, it can be done, but it is a little tricky:

# convert yourmulti-dim indices to flat indices

flat_idx = np.ravel_multi_index((Px, Py), dims=a.shape)

# extract the unique indices and their position

unique_idx, idx_idx = np.unique(flat_idx, return_inverse=True)

# Aggregate the repeated indices

deltas = np.bincount(idx_idx, weights=x)

# Sum them to your array

a.flat[unique_idx] += deltas

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值