【发布时间】:2017-10-25 19:55:24
【问题描述】:
我尝试在 scipy 中使用 stats.zscore() 并得到以下让我感到困惑的结果。
假设我有一个数组,我以 2 种不同的方式计算 z 分数:
>>> a = np.array([[1.0, 2.0], [3.0, 4.0]])
>>> a
array([[ 1., 2.],
[ 3., 4.]])
第一个结果:
>>> stats.zscore(a)
array([[-1., -1.],
[ 1., 1.]])
第二个结果:
>>> 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]])
上面的结果是不同的,但是如果我使用另一个数组,
>>> 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])
第一个结果:
>>> stats.zscore(c)
array([ 1.12724554, -1.2469956 , -0.05542642, 1.09231569, 1.16645923, -0.8558472 , 0.57858329, 0.67480514, -1.14879659, -1.33234306])
第二个结果:
>>> 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])
所以当我使用另一个数组时,结果变得相同。有人可以帮助我理解我在这方面做错了什么吗?谢谢!
【问题讨论】:
-
stats.zscore默认情况下沿轴 0 工作(它不会像 mean 和 std 函数那样展平整个数组)。它的行为本质上是(a - a.mean(axis=0)) / a.std(axis=0)。 -
(*它的行为 - 请原谅我的语法) - 尝试
stats.zscore(a, axis=None)以获得与二维数组的 NumPy 相同的结果。 -
@Alex:这看起来像是一个答案。 :)
-
@AlexRiley,谢谢,这就是答案!
标签: python numpy scipy statistics normalization