使用 scipy 和 numpy 中的函数计算 z-score

iTS*_*iTS 8 python statistics numpy normalization scipy

我尝试在 scipy 中使用 stats.zscore() 并得到以下结果让我感到困惑。

假设我有一个数组,我以两种不同的方式计算 z 分数:

>>> a = np.array([[1.0, 2.0], [3.0, 4.0]])
>>> a
array([[ 1.,  2.],
       [ 3.,  4.]])
Run Code Online (Sandbox Code Playgroud)

第一个结果:

>>> stats.zscore(a)               
array([[-1., -1.],
       [ 1.,  1.]])
Run Code Online (Sandbox Code Playgroud)

第二个结果:

>>> mean = np.mean(a)
>>> mean
2.5
>>> std = np.std(a)
>>> std
1.1180339887498949
>>> b = (a-mean)/std
>>> b
array([[-1.34164079, -0.4472136 ],
       [ 0.4472136 ,  1.34164079]])
Run Code Online (Sandbox Code Playgroud)

上面的结果是不同的,但是如果我使用另一个数组,

>>> c = np.array([ 0.7972,  0.0767,  0.4383,  0.7866,  0.8091,  0.1954, 0.6307, 0.6599,  0.1065,  0.0508])
>>> c
array([ 0.7972,  0.0767,  0.4383,  0.7866,  0.8091,  0.1954,  0.6307, 0.6599,  0.1065,  0.0508])
Run Code Online (Sandbox Code Playgroud)

第一个结果:

>>> stats.zscore(c)
array([ 1.12724554, -1.2469956 , -0.05542642,  1.09231569,  1.16645923, -0.8558472 ,  0.57858329,  0.67480514, -1.14879659, -1.33234306])
Run Code Online (Sandbox Code Playgroud)

第二个结果:

>>> mean = np.mean(c)
>>> mean
0.45511999999999986
>>> std = np.std(c)
>>> std
0.30346538451691657
>>> b = (c-mean)/std
>>> b
array([ 1.12724554, -1.2469956 , -0.05542642,  1.09231569,  1.16645923, -0.8558472 ,  0.57858329,  0.67480514, -1.14879659, -1.33234306])

    
Run Code Online (Sandbox Code Playgroud)

所以当我使用另一个数组时,结果变得相同。有人可以帮助我理解我在这方面做错了什么吗?谢谢!

Gra*_*art 5

由于没有人添加答案并且它似乎是正确的,我将在此处发布 Alex Riley 的答案。

试试这个以获得相同的二维数组结果。

from scipy import stats

stats.zscore(a, axis=None)
Run Code Online (Sandbox Code Playgroud)