我有一个形状为(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()获得了意外的关键字参数'return_inverse'”错误消息。 我正在使用在Unix上安装的numpy版本1.2.1,并且它不支持return_inverse..我还尝试过mode,但它需要处理如此大量的数据而花费很长时间...那么有没有替代方法可以获取最频繁出现的值? 再次感谢。