有没有一种直接的方法可以使用调用 NumPy 的输出argmax
或argmin
在 ND 数组的单个维度上定义该数组的索引?
这可能最好用一个例子来解释。考虑以下随时间变化的 2D 温度读数网格示例:
>>> import numpy as np
>>> times = np.array([0, 20])
>>> temperature_map_t0 = np.array([[10, 12, 14], [23, 40, 50]])
>>> temperature_map_t1 = np.array([[20, 12, 15], [23, 10, 12]])
>>> temperature_map = np.dstack([temperature_map_t0, temperature_map_t1])
和包含相应压力读数的相同形状的 ND 阵列:
>>> pressure_map = np.random.rand(*temperature_map.shape)
我们可以找到每个位置的最高温度:
>>> top_temperatures = temperature_map.max(axis=2)
>>> top_temperatures
array([[20, 12, 15],
[23, 40, 50]])
以及它们发生的时间:
>>> times = times[temperature_map.argmax(axis=2)]
>>> times
array([[20, 0, 20],
[ 0, 0, 0]])
但是我们怎样才能temperature_map.argmax(axis=2)
找到相应的压力呢?
>>> pressures_at_top_temperatures = pressures[ ???? ]
换句话说 - 使用该维度的argmin
orargmax
索引折叠 ND 数组的单个维度的索引语法是什么?