np.mean(a, # 必须是数组
axis=None,
dtype=None,
out=None,
keepdims=<class 'numpy._globals._NoValue'>)
mean()函数的功能是求取平均值,经常操作的参数是axis,以m*n的矩阵为例:
例子:
>>> a = np.array([[1, 2], [3, 4]])
>>>> a
array([[1, 2],
[3, 4]])
>>> np.mean(a)
2.5
>>> np.mean(a, axis=0) # axis=0,计算每一列的均值
array([ 2., 3.])
>>> np.mean(a, axis=1) # 计算每一行的均值
array([ 1.5, 3.5])
也可以用a.mean(1)
来代替np.mean(a, axis=1)
,这样子更简洁。
在out=None的情况下,返回的就是你要的平均值。否则,返回一个对平均值的引用。
算术平均值是沿轴的元素总合除以元素的数量。既然是除法,就涉及到一个精确度的问题。
对于浮点输入,平均值的计算使用与输入相同的精度计算,这可能会导致结果不准确,特别是对于float32来说。为了缓解这个问题,我们可以使用dtype关键字指定更高精度的累加器,
>>> a = np.zeros((2, 512*512), dtype=np.float32)
>>> a[0, :] = 1.0
>>> a[1, :] = 0.1
>>> np.mean(a)
0.54999924