numpy.nanmedian#
- numpy.nanmedian(a, axis=None, out=None, overwrite_input=False, keepdims=<no value>)[源代码]#
计算指定轴上的中位数,同时忽略 NaN 值。
返回数组元素的中位数。
- 参数:
- aarray_like
输入数组或可以转换为数组的对象。
- axis{int, sequence of int, None}, 可选
计算中位数的轴或多个轴。默认值是计算数组展平版本的中位数。自 1.9.0 版本起支持轴序列。
- outndarray, 可选
放置结果的备选输出数组。它必须具有与预期输出相同的形状和缓冲区长度,但如有必要,将强制转换输出的类型。
- overwrite_inputbool, 可选
如果为 True,则允许使用输入数组 a 的内存进行计算。输入数组将通过调用
median
进行修改。当您不需要保留输入数组的内容时,这将节省内存。将输入视为未定义的,但它可能会被完全或部分排序。默认值为 False。如果 overwrite_input 为True
且 a 尚未是ndarray
,则会引发错误。- keepdimsbool, 可选
如果将其设置为 True,则将结果中被缩减的轴保留为大小为 1 的维度。使用此选项,结果将正确地广播到原始 a。
如果这不是默认值,它将传递(在空数组的特殊情况下)给底层数组的
mean
函数。如果数组是子类,并且mean
没有 kwarg keepdims,则会引发 RuntimeError。
- 返回:
- medianndarray
一个包含结果的新数组。如果输入包含整数或小于
float64
的浮点数,则输出数据类型为np.float64
。否则,输出的数据类型与输入的数据类型相同。如果指定了 out,则返回该数组。
另请参阅
备注
给定一个长度为
N
的向量V
,V
的中位数是V
的排序副本V_sorted
的中间值 - 即当N
为奇数时为V_sorted[(N-1)/2]
,当N
为偶数时为V_sorted
的两个中间值的平均值。示例
>>> import numpy as np >>> a = np.array([[10.0, 7, 4], [3, 2, 1]]) >>> a[0, 1] = np.nan >>> a array([[10., nan, 4.], [ 3., 2., 1.]]) >>> np.median(a) np.float64(nan) >>> np.nanmedian(a) 3.0 >>> np.nanmedian(a, axis=0) array([6.5, 2. , 2.5]) >>> np.median(a, axis=1) array([nan, 2.]) >>> b = a.copy() >>> np.nanmedian(b, axis=1, overwrite_input=True) array([7., 2.]) >>> assert not np.all(a==b) >>> b = a.copy() >>> np.nanmedian(b, axis=None, overwrite_input=True) 3.0 >>> assert not np.all(a==b)