ARTICLE

标准化

标准化 (Standardization) 标准化,在统计学和数据分析领域,特指一种将原始数据进行线性变换(或称仿射变换)的方法,使其具有特定的属性。最常见的标准化形式被称为 Z-score 标准化 (Z-score Normalization),其目的是将一组数据重新缩放,使其平均值(mean)为 0,标准差(standard deviation)为 1。

浏览 51 更新 2025-10-26

标准化 (Standardization)

标准化,在统计学数据分析领域,特指一种将原始数据进行线性变换(或称仿射变换)的方法,使其具有特定的属性。最常见的标准化形式被称为 Z-score 标准化 (Z-score Normalization),其目的是将一组数据重新缩放,使其平均值(mean)为 0,标准差(standard deviation)为 1。

这个过程将每个原始数据点转换为一个"Z-score"(标准分数),该分数表示原始数据点与数据集平均值相差多少个标准差。标准化是一种核心的数据预处理技术,在许多统计分析和机器学习算法中至关重要。

标准化的目的与意义

在处理包含多个变量的数据集时,这些变量的单位和量纲往往各不相同。例如,一个数据集可能同时包含以千克为单位的体重和以厘米为单位的身高。这种尺度上的差异会对某些分析方法产生不成比例的影响。标准化的主要目的就是消除这种尺度差异,使得不同变量之间具有可比性。

  1. 消除量纲影响,实现可比性:标准化将所有变量转换到一个共同的、无量纲的尺度上。这使得我们可以公平地比较和权衡不同变量的重要性,例如在构建综合指数或进行多变量分析时。
  2. 满足算法要求:许多机器学习算法的性能会受到输入特征尺度的影响,特别是那些依赖于距离计算或假设数据中心化的算法。 \begin{itemize}
  3. 基于距离的算法:如K-Means 聚类支持向量机 (SVM)、K-近邻算法 (KNN) 等,如果特征尺度差异巨大,那么尺度较大的特征将在距离计算中占据主导地位,而尺度较小的特征则可能被忽略。
  4. 梯度下降法:在训练神经网络线性回归模型时,如果特征尺度不一,损失函数的等高线图可能会呈现为拉长的椭圆形,导致梯度下降的收敛速度变慢。标准化可以使等高线图更接近圆形,从而加速收敛。
  5. 主成分分析 (PCA):PCA 旨在寻找数据中方差最大的方向。如果不对数据进行标准化,方差最大的变量将会主导第一个主成分,这可能并不是我们所期望的结果。
  6. 正则化:在使用L1 正则化 (Lasso) 或L2 正则化 (Ridge) 的回归模型中,标准化可以确保惩罚项对所有系数的惩罚是公平的,而不会因为变量的天然尺度不同而产生偏见。 \end{itemize}
  7. 解释模型系数:在多元线性回归中,对自变量进行标准化后,回归系数的大小可以直接反映该变量对因变量的相对重要性。一个较大的(绝对值)标准化系数意味着该自变量每变化一个标准差,因变量将相应变化更多的标准差。

Z-score 标准化的数学公式

Z-score 标准化的计算公式非常直观。对于数据集 X X 中的每一个数据点 xi x_i ,其对应的 Z-score zi z_i 计算如下:

zi=xiμσz_i = \frac{x_i - \mu}{\sigma}

其中:

  • xi x_i 是原始数据集中的一个数据点。
  • μ \mu 是原始数据集的平均值(mean)。对于总体数据,μ \mu 是总体均值;对于样本数据,则使用样本均值 xˉ \bar{x}
  • σ \sigma 是原始数据集的标准差(standard deviation)。对于总体数据,σ \sigma 是总体标准差;对于样本数据,则使用样本标准差 s s

标准化数据的性质

经过 Z-score 标准化处理后的新数据集 Z={z1,z2,,zn} Z = \{z_1, z_2, \dots, z_n\} 具有以下重要性质:

  • 均值为 0mean(Z)=0 \text{mean}(Z) = 0
  • 标准差为 1std(Z)=1 \text{std}(Z) = 1
  • 不改变分布形状:标准化是一种线性变换,它只改变数据的中心位置和尺度,但不会改变数据点的相对顺序或分布的原始形状。例如,如果原始数据是右偏的,标准化后的数据仍然是右偏的。

计算示例

假设我们有一组学生的身高数据(单位:厘米):X={165,170,175,180,185} X = \{165, 170, 175, 180, 185\}

第一步:计算平均值 μ \mu

μ=165+170+175+180+1855=8755=175\mu = \frac{165 + 170 + 175 + 180 + 185}{5} = \frac{875}{5} = 175

第二步:计算标准差 σ \sigma 首先计算方差 σ2 \sigma^2

σ2=i=1n(xiμ)2n=(165175)2+(170175)2+(175175)2+(180175)2+(185175)25\sigma^2 = \frac{\sum_{i=1}^{n}(x_i - \mu)^2}{n} = \frac{(165-175)^2 + (170-175)^2 + (175-175)^2 + (180-175)^2 + (185-175)^2}{5}
σ2=(10)2+(5)2+02+52+1025=100+25+0+25+1005=2505=50\sigma^2 = \frac{(-10)^2 + (-5)^2 + 0^2 + 5^2 + 10^2}{5} = \frac{100 + 25 + 0 + 25 + 100}{5} = \frac{250}{5} = 50

然后计算标准差 σ \sigma

σ=507.071\sigma = \sqrt{50} \approx 7.071

第三步:对每个数据点进行标准化

\begin{align*} \[ z_1 &= \frac{165 - 175}{7.071} \approx -1.414 \\ \] \[ z_2 &= \frac{170 - 175}{7.071} \approx -0.707 \\ \] \[ z_3 &= \frac{175 - 175}{7.071} = 0 \\ \] \[ z_4 &= \frac{180 - 175}{7.071} \approx 0.707 \\ \] \[ z_5 &= \frac{185 - 175}{7.071} \approx 1.414 \] \end{align*}

新的标准化数据集为 Z{1.414,0.707,0,0.707,1.414} Z \approx \{-1.414, -0.707, 0, 0.707, 1.414\} 。我们可以验证,这组新数据的均值约为 0,标准差约为 1。

与其他缩放方法的比较

标准化常常与另一种数据缩放技术——归一化 (Normalization)——相提并论。虽然两者都旨在调整数据尺度,但它们的方法和适用场景有所不同。

归一化 (Min-Max Scaling)

  • 公式x=xmin(X)max(X)min(X) x' = \frac{x - \min(X)}{\max(X) - \min(X)}
  • 范围:将数据严格缩放到一个固定的区间,通常是 [0,1] [0, 1]
  • 离群值的敏感性:非常敏感。一个极端的最大值或最小值会严重压缩其他数据点的范围。
  • 适用场景:当数据需要被限定在特定边界内时,如图像处理中的像素值,或者在不假设数据分布的算法(如 KNN)中。

\begin{table}[h] \centering \begin{tabular}{|l|l|l|} \hline 特性 \& 标准化 (Standardization) \& 归一化 (Normalization) \\ \hline 目的 \& 中心化数据(均值为0),并统一尺度(标准差为1) \& 将数据缩放到特定区间(如 [0,1] [0, 1] ) \\ \hline 输出范围 \& 没有固定范围,可以是任何实数 \& 固定的,通常为 [0,1] [0, 1] \\ \hline 对离群值敏感度 \& 较低,因为均值和标准差对离群值的鲁棒性高于最大/最小值 \& 很高,因为计算依赖于最大值和最小值 \\ \hline 假设 \& 适用于接近正态分布的数据,但非强制 \& 对数据分布没有特定假设 \\ \hline \end{tabular} \caption{标准化与归一化的对比} \end{table}

应用和注意事项

  1. 训练集与测试集:在机器学习实践中,如果需要对数据进行标准化,一个至关重要的原则是:必须使用从 训练集 计算出的均值和标准差来同时转换训练集和测试集(以及任何未来的新数据)。如果在测试集上重新计算均值和标准差,会导致数据泄露 (Data Leakage),模型在评估时的表现会过于乐观,而无法真实反映其在未知数据上的泛化能力。
  2. 选择合适的缩放方法:选择标准化还是归一化并没有绝对的规则。一般而言,如果数据近似服从正态分布,或者所使用的算法(如 PCA、带正则化的回归)假设数据是零中心的,那么标准化是更好的选择。如果数据分布不规则,或者算法对输入范围有要求,归一化可能更合适。
  3. 解释性:虽然标准化有助于模型训练,但它可能会降低结果的直接可解释性。例如,一个标准化后的身高值-1.414并不如原始值165厘米直观。因此,在向非专业人士解释模型结果时,可能需要将预测结果或系数转换回原始尺度。