我有一个形状为 (30,480,640) 的 numpy ndarray,第 1 和第 2 轴代表位置(纬度和经度),第 0 轴包含实际数据点。我想在每个位置沿第 0 轴使用最频繁的值,其中是构造一个形状为(1,480,640)的新数组。即:
>>> data
array([[[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14],
[15, 16, 17, 18, 19]],
[[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14],
[15, 16, 17, 18, 19]],
[[40, 40, 42, 43, 44],
[45, 46, 47, 48, 49],
[50, 51, 52, 53, 54],
[55, 56, 57, 58, 59]]])
(perform calculation)
>>> new_data
array([[[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14],
[15, 16, 17, 18, 19]]])
数据点将包含负数和正数浮点数。我怎样才能进行这样的计算?非常感谢!
我尝试使用 numpy.unique,但我得到“TypeError: unique() got an unexpected keyword argument 'return_inverse'”。我正在使用 Unix 上安装的 numpy 版本 1.2.1,它不支持 return_inverse ..我也试过模式,但是处理如此大量的数据需要永远......那么有没有另一种方法来获得最频繁的值?再次感谢。