数据预处理与特征工程(一)----归一化与标准化

数据预处理与特征工程(一)----归一化与标准化

相关数据集均放置在本人的csdn文件中,如有需要,可免费下载。内容来自老师上课的课件。侵删

一、数据挖掘的五大流程

  • 获取数据
  • 数据预处理 :数据预处理是从数据中检测,纠正或删除损坏,不准确或不适用于模型的记录的过程。可能面对的问题有:数据类型不同,比如有的是文字,有的是数字,有的含时间序列,有的连续,有的间断。也可能,数据的质量不行,有噪声,有异常,有缺失,数据出错,量纲不一,有重复,数据是偏态,数据量太大或太小。数据预处理的目的:让数据适应模型,匹配模型的需求
  • 特征工程: 特征工程是将原始数据转换为更能代表预测模型的潜在问题的特征的过程,可以通过挑选最相关的特征,提取特征以及创造特征来实现。其中创造特征又经常以降维算法的方式实现。可能面对的问题有:特征之间有相关性,特征和标签无关,特征太多或太小,或者干脆就无法表现出应有的数据现象或无法展示数据的真实面貌
    特征工程的目的:降低计算成本,提升模型上限。
  • 建模,测试模型并预测出结果
  • 上线,验证模型效果

二、数据的无量纲化

​ 在机器学习算法实践中,我们往往有着将不同规格的数据转换到同一规格,或不同分布的数据转换到某个特定分布的需求,这种需求统称为将数据“无量纲化”。譬如梯度和矩阵为核心的算法中,譬如逻辑回归,支持向量机,神经网络,无量纲化可以加快求解速度;而在距离类模型,譬如K近邻,K-Means聚类中,无量纲化可以帮我们提升模型精度,避免某一个取值范围特别大的特征对距离计算造成影响。(一个特例是决策树和树的集成算法们,对决策树我们不需要无量纲化,决策树可以把任意数据都处理得很好。)
​ 数据的无量纲化可以是线性的,也可以是非线性的。线性的无量纲化包括中心化(Zero-centered或者Meansubtraction)处理和缩放处理(Scale)。中心化的本质是让所有记录减去一个固定值,即让数据样本数据平移到某个位置。缩放的本质是通过除以一个固定值,将数据固定在某个范围之中,取对数也算是一种缩放处理。

三、归一化与标准化

MinMaxScaler

​ 当数据**(x)按照最小值中心化后,再按极差(最大值 - 最小值)缩放,数据移动了最小值个单位,并且会被收敛到[0,1]之间,而这个过程,就叫做数据归一化(Normalization),又称(Min-Max Scaling)**。注意,Normalization是归一化,不是正则化,真正的正则化是regularization,不是数据预处理的一种手段。归一化之后的数据服从正态分布。 MinMaxScaler有一个重要参数,feature_range,控制我们希望把数据压缩到的范围,默认是[0,1]。

数据预处理与特征工程(一)----归一化与标准化_第1张图片

StandardScaler

​ 当数据**(x)按均值(μ)中心化后,再按标准差(σ)缩放,数据就会服从为均值为0**,方差为1的正态分布(即标准正态分布),而这个过程,就叫做数据标准化(Standardization,又称Z-score normalization)
数据预处理与特征工程(一)----归一化与标准化_第2张图片

归一化与标准化的对比

​ 大多数机器学习算法中,会选择StandardScaler来进行特征缩放,因为MinMaxScaler对异常值非常敏感。在PCA,聚类,逻辑回归,支持向量机,神经网络这些算法中,StandardScaler往往是最好的选择。MinMaxScaler在不涉及距离度量、梯度、协方差计算以及数据需要被压缩到特定区间时使用广泛,比如数字图像处理中量化像素强度时,都会使用MinMaxScaler将数据压缩于[0,1]区间之中。建议先试试看StandardScaler,效果不好换MinMaxScaler

实例代码

  1. 导入库并准备好以下数据

    from sklearn.preprocessing import MinMaxScaler 
    data = [[-1, 2], [-0.5, 6], [0, 10], [1, 18]]
    
  2. 对以上数据使用数据归一化

    import pandas as pd
    pd.DataFrame(data)
    #实现归一化
    scaler = MinMaxScaler()                      #实例化
    scaler = scaler.fit(data)                    #fit,在这里本质是生成min(x)和max(x)
    result = scaler.transform(data)              #通过接口导出结果
    result
    
  3. 将归一化后的结果逆转:使用inverse_transform

    result_ = scaler.fit_transform(data)
    scaler.inverse_transform(result)
    
  4. ​ 使用MinMaxScaler的参数feature_range实现将数据归一化到[0,1]以外的范围中【5,10】

    data = [[-1, 2], [-0.5, 6], [0, 10], [1, 18]]
    scaler = MinMaxScaler(feature_range=[5,10])
    result = scaler.fit_transform(data)                 
    result
    
  5. 对以上数据进行标准化处理。

    from sklearn.preprocessing import StandardScaler
    data = [[-1, 2], [-0.5, 6], [0, 10], [1, 18]]
    scaler = StandardScaler()                           #实例化
    scaler.fit(data)
    
  6. 查看查看均值的属性mean_

    scaler.mean_   
    scaler.var_
    x_std = scaler.transform(data)
    x_std.mean()
    
  7. 查看方差的属性var

    x_std.std() 
    
  8. 使用inverse_transform逆转标准化

scaler.fit_transform(data)   
scaler.inverse_transform(x_std)  

你可能感兴趣的:(基础,机器学习)