sklearn基础--『预处理』之 数据缩放

数据的预处理 是数据分析,或者机器学习训练前的重要步骤。

通过数据预处理,可以

  • 提高数据质量,处理数据的缺失值、异常值和重复值等问题,增加数据的准确性和可靠性
  • 整合不同数据,数据的来源和结构可能多种多样,分析和训练前要整合成一个数据集
  • 提高数据性能,对数据的值进行变换,规约等(比如无量纲化),让算法更加高效

本篇介绍的数据缩放处理,主要目的是消除数据的不同特征之间的量纲差异,使得每个特征的数值范围相同。这样可以避免某些特征对模型的影响过大,从而提高模型的性能。

1. 原理

数据缩放有多种方式,其中有一种按照最小值-最大值缩放 的算法是最常用的。

其主要步骤如下:

  1. 计算数据列的最小值(min)和最大值(max
  2. 对数据列中的每个值进行最小-最大缩放,即将其转换为 **0,1区间 **之内的一个值

缩放公式为: n e w _ d a t a = d a t a − m i n m a x − m i n new\_data = \frac{data -min}{max-min} new_data=max−mindata−min

实现缩放的代码如下:

python 复制代码
# 数据缩放的实现原理

data = np.array([10, 20, 30, 40, 50])
min = np.min(data)
max = np.max(data)

data_new = (data - min) / (max-min)

print("处理前: {}".format(data))
print("处理后: {}".format(data_new))

# 运行结果
处理前: [10 20 30 40 50]
处理后: [0.   0.25 0.5  0.75 1.  ]

数值被缩放到 **0,1区间 **之内。

这个示例只是为了演示缩放的过程,实际场景中最好使用scikit-learn库中的函数。

scikit-learn中的minmax_scale函数是封装好的数据缩放函数。

python 复制代码
from sklearn import preprocessing as pp

data = np.array([10, 20, 30, 40, 50])
pp.minmax_scale(data, feature_range=(0, 1))

# 运行结果
array([0.  , 0.25, 0.5 , 0.75, 1.  ])

使用scikit-learn中的minmax_scale函数得到的结果是一样的,数据也被压缩到 **0,1区间 **之内。

所以 数据缩放 的这个操作有时也被称为归一化

不过,数据缩放 不一定非得把数据压缩到 **0,1区间 **之内,

通过调整feature_range参数,可以把数据压缩到任意的区间。

python 复制代码
# 压缩到[0, 1]
print(pp.minmax_scale(data, feature_range=(0, 1)))

# 压缩到[-1, 1]
print(pp.minmax_scale(data, feature_range=(-1, 1)))

# 压缩到[0, 5]
print(pp.minmax_scale(data, feature_range=(0, 5)))

# 运行结果
[0.   0.25 0.5  0.75 1.  ]
[-1.  -0.5  0.   0.5  1. ]
[0.   1.25 2.5  3.75 5.  ]

2. 作用

数据缩放的作用主要有:

2.1. 统一数据尺度

通过缩放处理 ,将不同量纲、不同尺度、不同单位的数据转换成一个统一的尺度,

避免由于数据量纲不一致而导致的数据分析结果失真或误导。

2.2. 增强数据可比性

通过缩放处理 ,将不同量纲、不同尺度、不同单位的数据转换成一个统一的尺度,使得不同数据之间的比较更加方便和有意义。

例如,在评价多个样本的性能时,如果采用不同的量纲、不同尺度、不同单位进行比较,会导致比较结果不准确甚至误导。

通过统一的缩放处理之后,可以消除这种影响,使得比较结果更加准确可信。

2.3. 增强数据稳定性

通过缩放处理 ,将数据的数值范围调整到一个相对较小的区间内,

增加数据的稳定性,避免由于数据分布范围过大或过小而导致的分析误差或计算误差。

2.4. 提高算法效率和精度

通过缩放处理 ,使得一些计算算法的效率和精度得到提高。

例如,在神经网络算法中,如果输入数据的尺度过大或过小,会导致算法训练时间过长或过短,同时也会影响算法的精度和稳定性。

而缩放处理之后,就可以使算法的训练时间和精度得到优化。

3. 总结

scikit-learn库中,处理数据缩放不是只有上面的最小值-最大值缩放

还可用StandardScaler进行标准化缩放;用RobustScaler实现尺度缩放和平移等等。

进行数据缩放时,需要注意 一点,就是缩放处理对异常值 非常敏感,

如果数据中存在极大或者极小的异常值 时,有可能会破坏原始数据本身。

所以,缩放处理前,最好把异常值过滤掉。

相关推荐
学习3人组22 分钟前
机器学习KNeighborsClassifier实现手写数字识别
人工智能·机器学习
数智工坊24 分钟前
周志华《Machine Learning》学习笔记--第四章--决策树
笔记·学习·机器学习
m沐沐24 分钟前
【机器学习】NLP---用 Python+TF-IDF 给《红楼梦》自动提取关键词
人工智能·python·机器学习·自然语言处理·nlp·中文分词·tf-idf
威尔逊·柏斯科·希伯理27 分钟前
机器学习第二天(KNN)
人工智能·机器学习
lqqjuly29 分钟前
优化理论:梯度方法、约束优化与机器学习优化
人工智能·机器学习
m沐沐29 分钟前
【机器学习】Python 实现垃圾邮件分类(随机森林 + 可视化 + 特征重要性)
人工智能·python·随机森林·机器学习·分类·pycharm·回归算法
Hali_Botebie38 分钟前
【光流】自动驾驶光流任务 DeFlow: Decoder of Scene Flow Network in Autonomous Driving
人工智能·机器学习·自动驾驶
yingjie1101 小时前
Scanpy 单细胞转录组分析完整流程(上):从原始数据到细胞聚类
机器学习·数据挖掘·聚类
zhangfeng11331 小时前
超算中心 高性能计算 htc命令module use的作用
人工智能·机器学习
Rocky Ding*1 小时前
深入浅出完整解析AIGC时代中GAN(Generative Adversarial Network)系列模型核心基础知识(下篇)
论文阅读·人工智能·深度学习·机器学习·aigc·gan·ai-native