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)
所以当我使用另一个数组时,结果变得相同。有人可以帮助我理解我在这方面做错了什么吗?谢谢!
由于没有人添加答案并且它似乎是正确的,我将在此处发布 Alex Riley 的答案。
试试这个以获得相同的二维数组结果。
from scipy import stats
stats.zscore(a, axis=None)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
16489 次 |
| 最近记录: |