pandas学习(四)--数据的归一化

来源:互联网 发布:美术教学网络系统 编辑:程序博客网 时间:2024/05/14 03:59

欢迎加入python学习交流群 667279387

Pandas学习(一)–数据的导入
pandas学习(二)–双色球数据分析
pandas学习(三)–NAB球员薪资分析
pandas学习(四)–数据的归一化

归一化方法有两种形式,一种是把数变为(0,1)之间的小数,一种是把有量纲表达式变为无量纲表达式。主要是为了数据处理方便提出来的,把数据映射到0~1范围之内处理。

常见归一化算法

1、min-max标准化(Min-Max Normalization)

也称为离差标准化,是对原始数据的线性变换,使结果值映射到[0 - 1]之间。转换函数如下:

x^=xxminxmaxxmin
其中max为样本数据的最大值,min为样本数据的最小值。这种方法有个缺陷就是当有新数据加入时,可能导致max和min的变化,需要重新定义。

2、Z-score标准化方法

这种方法给予原始数据的均值(mean)和标准差(standard deviation)进行数据的标准化。经过处理的数据符合标准正态分布,即均值为0,标准差为1,转化函数为:

x^=xμσ

其中为μ所有样本数据的均值,σ为所有样本数据的标准差。该种归一化方式要求原始数据的分布可以近似为高斯分布,否则处理的效果会变差。

pandas归一化方法

1、min-max标准化

import numpy as npimport pandas as pdnp.random.seed(1)df = pd.DataFrame(np.random.randn(4, 4) * 4 + 3)print(df)"""          0         1         2         30  9.497381  0.552974  0.887313 -1.2918741  6.461631 -6.206155  9.979247 -0.0448282  4.276156  2.002518  8.848432 -5.2405633  1.710331  1.463783  7.535078 -1.399565"""df_norm = (df - df.min()) / (df.max() - df.min())print(df_norm)"""          0         1         2         30  1.000000  0.823413  0.000000  0.7599861  0.610154  0.000000  1.000000  1.0000002  0.329499  1.000000  0.875624  0.0000003  0.000000  0.934370  0.731172  0.739260"""df_norm2=df.apply(lambda x: (x - np.min(x)) / (np.max(x) - np.min(x)))print(df_norm2)"""          0         1         2         30  1.000000  0.823413  0.000000  0.7599861  0.610154  0.000000  1.000000  1.0000002  0.329499  1.000000  0.875624  0.0000003  0.000000  0.934370  0.731172  0.739260"""

2、Z-score标准化方法

import numpy as npimport pandas as pdnp.random.seed(1)df = pd.DataFrame(np.random.randn(4, 4) * 4 + 3)print(df)"""          0         1         2         30  9.497381  0.552974  0.887313 -1.2918741  6.461631 -6.206155  9.979247 -0.0448282  4.276156  2.002518  8.848432 -5.2405633  1.710331  1.463783  7.535078 -1.399565"""df_norm = (df - df.mean()) / (df.std())print(df_norm)"""          0         1         2         30  1.213741  0.287871 -1.454237  0.3121661  0.295115 -1.481492  0.777218  0.8664402 -0.366215  0.667324  0.499679 -1.4429063 -1.142640  0.526297  0.177340  0.264301"""df_norm2 = df.apply(lambda x: (x - np.mean(x)) / (np.std(x)))print(df_norm2)"""         0         1         2         30  1.401507  0.332405 -1.679208  0.3604581  0.340769 -1.710680  0.897454  1.0004792 -0.422869  0.770560  0.576980 -1.6661253 -1.319407  0.607716  0.204774  0.305188"""

比较好奇为啥上面df.std()和np.std()算出来的值不一样,估计哪里有点不一样的地方,还需要研究研究。下面做了一个简单的实验,不知道df.std()具体是怎么算的。

import numpy as npimport pandas as pddata = [(1, 2), (3, 4)]df = pd.DataFrame(data)print(df)"""   0  10  1  21  3  4"""df_std1 = df.std(axis=0)print(df_std1)"""0    1.4142141    1.414214"""df_std2 = df.apply(lambda x: np.std(x), axis=0)print(df_std2)"""0    1.01    1.0"""

经过后续学习这篇帖子找到了答案:
https://stackoverflow.com/questions/24984178/different-std-in-pandas-vs-numpy

import numpy as npimport pandas as pddata = [(1, 2), (3, 4)]df = pd.DataFrame(data)print(df)"""   0  10  1  21  3  4"""df_std1 = df.std(axis=0)print(df_std1)"""0    1.4142141    1.414214"""df_std2 = df.apply(lambda x: np.std(x,ddof=1), axis=0)print(df_std2)"""0    1.4142141    1.414214"""

ddof : int, optional
Means Delta Degrees of Freedom. The divisor used in calculations is N - ddof, where N represents the number of elements. By default ddof is zero.
这个是numpy对ddof的解释。

简单点说np.std()计算的是标准差,df.std()计算的是标准差的无偏估计

参考资料
1、https://stackoverflow.com/questions/12525722/normalize-data-in-pandas
2、https://stackoverflow.com/questions/26414913/normalize-columns-of-pandas-data-frame
3、https://en.wikipedia.org/wiki/Unbiased_estimation_of_standard_deviation

欢迎加入python学习交流群 667279387

原创粉丝点击