次のような ndarray がある場合:
>>> a = np.arange(27).reshape(3,3,3)
>>> a
array([[[ 0, 1, 2],
[ 3, 4, 5],
[ 6, 7, 8]],
[[ 9, 10, 11],
[12, 13, 14],
[15, 16, 17]],
[[18, 19, 20],
[21, 22, 23],
[24, 25, 26]]])
次を使用して、特定の軸に沿って最大値を取得できることを知っていますnp.max(axis=...)
。
>>> a.max(axis=2)
array([[ 2, 5, 8],
[11, 14, 17],
[20, 23, 26]])
または、次の最大値に対応するその軸に沿ったインデックスを取得できます。
>>> indices = a.argmax(axis=2)
>>> indices
array([[2, 2, 2],
[2, 2, 2],
[2, 2, 2]])
私の質問 - 配列indices
と配列が与えられた場合、a
配列が返す配列を再現する洗練された方法はありa.max(axis=2)
ますか?
これはおそらくうまくいくでしょう:
import itertools as it
import numpy as np
def apply_mask(field,indices):
data = np.empty(indices.shape)
#It seems highly likely that there is a more numpy-approved way to do this.
idx = [range(i) for i in indices.shape]
for idx_tup,zidx in zip(it.product(*idx),indices.flat):
data[idx_tup] = field[idx_tup+(zidx,)]
return data
しかし、それはかなりハック/非効率的です。また、「最後の」軸以外の軸でこれを使用することもできません。これを機能させるための numpy 関数 (または魔法の numpy インデックス作成の使用) はありますか? ナイーブa[:,:,a.argmax(axis=2)]
は機能しません。
更新:
以下も機能するようです(そして少し良いです):
import numpy as np
def apply_mask(field,indices):
data = np.empty(indices.shape)
for idx_tup,zidx in np.ndenumerate(indices):
data[idx_tup] = field[idx_tup+(zidx,)]
return data
argmax(axis=...)
1つの配列のデータに基づいてインデックスを抽出し(通常は を使用)、それらのインデックスを使用して他の(同等の形状の)配列の束からデータを引き出したいため、これを行いたいと思います。私はこれを達成するための別の方法を受け入れています (たとえば、ブール値のマスクされた配列を使用します)。ただし、これらの「インデックス」配列を使用して得られる「安全性」が気に入っています。これにより、3D フィールドを通る 2D の「スライス」のように見える新しい配列を作成するための適切な数の要素があることが保証されます。