当前位置: 首页 > article >正文

【机器学习】机器学习的基本分类-监督学习-岭回归(Ridge Regression)

岭回归是一种针对多重共线性问题的回归方法,通过对线性回归模型引入 L_2​ 正则化项,限制模型系数的大小,从而提高模型的泛化能力。


1. 背景问题

在普通最小二乘(OLS)回归中,损失函数是最小化残差平方和:

\text{OLS Loss} = \sum_{i=1}^n (y_i - \hat{y}_i)^2

其中,预测值 \hat{y}_i = \beta_0 + \beta_1x_{i1} + \beta_2x_{i2} + \cdots + \beta_px_{ip}​。

多重共线性
  • 如果特征之间存在强烈的相关性(即多重共线性),会导致普通线性回归的解不稳定:
    1. 矩阵 X^T X 的条件数很大或接近奇异。
    2. 回归系数 β 对训练数据的噪声极为敏感,导致模型泛化能力差。

2. 岭回归的改进

引入 L_2​ 正则化

岭回归在 OLS 损失函数中添加了一个惩罚项,限制回归系数的平方和:

\text{Ridge Loss} = \sum_{i=1}^n (y_i - \hat{y}_i)^2 + \lambda \sum_{j=1}^p \beta_j^2

  • \lambda > 0 是正则化强度的超参数,控制惩罚的大小:
    • \lambda = 0,等同于普通最小二乘回归。
    • 当 \lambda \to \infty,所有回归系数趋近于 0。
优化目标

最小化目标函数:

\min_\beta \left\{ \| y - X\beta \|_2^2 + \lambda \| \beta \|_2^2 \right\}

其中:

  • \| y - X\beta \|_2^2​ 是残差平方和。
  • \| \beta \|_2^2 = \sum_{j=1}^p \beta_j^2​ 是 L_2 范数。

 3. 岭回归的解

岭回归的闭式解为:

\beta = (X^T X + \lambda I)^{-1} X^T y

  • X^T X + \lambda I 是一个正定矩阵,确保了逆矩阵的存在,即使 X^T X 接近奇异。
  • I 是单位矩阵。

相比于 OLS 解 \beta = (X^T X)^{-1} X^T y,岭回归通过 \lambda IX^T X 加入平滑,提高了数值稳定性。


4. 优缺点

优点
  1. 解决多重共线性:通过正则化减少模型对特征噪声的敏感性。
  2. 稳定性:模型更加稳定,预测结果更鲁棒。
  3. 控制过拟合:引入正则化,有效降低复杂模型的过拟合风险。
缺点
  1. 特征选择能力弱:岭回归不会将特征系数缩减为 0,因此不适合用于特征筛选(相比于 Lasso 回归)。
  2. 对 λ 的依赖:正则化参数需要通过交叉验证调优。

5. 实现代码

以下是 Python 中使用 scikit-learn 的实现示例:

from sklearn.linear_model import Ridge
from sklearn.model_selection import train_test_split
from sklearn.datasets import make_regression
from sklearn.metrics import mean_squared_error

# 生成数据
X, y = make_regression(n_samples=100, n_features=5, noise=10, random_state=42)

# 数据集划分
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 创建岭回归模型
ridge = Ridge(alpha=1.0)  # alpha 即正则化参数 λ
ridge.fit(X_train, y_train)

# 预测
y_pred = ridge.predict(X_test)

# 评价
print("MSE:", mean_squared_error(y_test, y_pred))
print("回归系数:", ridge.coef_)

输出结果 

MSE: 121.64571508040383
回归系数: [60.80641691 96.97650095 59.85083263 54.82588222 35.69887237]

6. 岭回归的应用场景

  1. 金融领域:解决变量间高度相关的问题,如资产定价模型。
  2. 基因数据分析:处理特征数量远大于样本数量的高维数据。
  3. 时间序列预测:对相关变量的噪声进行平滑处理。

7. 岭回归与其他方法的比较

方法正则化类型优点缺点
普通回归简单直观、无偏估计对多重共线性敏感
岭回归L_2​ 范数稳定性高,解决共线性问题无法特征选择
LassoL_1​ 范数可稀疏化系数(特征选择)存在一定的偏差
ElasticNetL_1 + L_2​ 范数综合岭回归和 Lasso 的优点需要调节两个正则化参数

8. 超参数调优

正则化参数 λ(在 scikit-learn 中为 alpha)是岭回归中的核心超参数,常用的调优方法是交叉验证

from sklearn.linear_model import RidgeCV
from sklearn.model_selection import train_test_split
from sklearn.datasets import make_regression

# 生成数据
X, y = make_regression(n_samples=100, n_features=5, noise=10, random_state=42)

# 数据集划分
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 设置不同的 λ 值
alphas = [0.1, 1.0, 10.0, 100.0]

# 交叉验证选择最佳 λ
ridge_cv = RidgeCV(alphas=alphas, cv=5)  # 5 折交叉验证
ridge_cv.fit(X_train, y_train)

# 最佳正则化参数
print("最佳 λ:", ridge_cv.alpha_)

输出结果

最佳 λ: 0.1

岭回归通过引入 L_2 正则化,有效解决了多重共线性和过拟合问题,适合在高维和相关性强的数据集中使用。


http://www.kler.cn/a/428593.html

相关文章:

  • 快手SDK接入错误处理经验总结(WebGL方案)
  • Alluxio 联手 Solidigm 推出针对 AI 工作负载的高级缓存解决方案
  • LabVIEW太赫兹二维扫描成像系统
  • c语言的分支与循环
  • 基于STM32的智能门锁安防系统(开源)
  • C语言之图像文件的属性
  • 4.1模块化技术之函数,本地类
  • Flink 核心知识总结:窗口操作、TopN 案例及架构体系详解
  • 如何使用 Python 实现链表的反转?
  • C++_关于异常处理throw-try-catch
  • MATLAB 非重叠点云提取算法(92)
  • C++的一些经典算法
  • java 服务端tcp方式接收和推送数据到c++或者qt(亲测可用)
  • 机器学习经典算法
  • C# 的GDI风车控件
  • FFmpeg+Nginx+VLC打造M3U8M3U8点播
  • STM32MX 配置CANFD收发通讯
  • Java 并发舞台:多线程小精灵的奇幻冒险之旅
  • 第二十二天 TensorFlow基础
  • Android 常用倒计时技术和实现方式
  • element UI的Cascader 级联选择器在树形列表中编辑使用
  • 使用Excel的COUNTIFS和SUMIFS函数进行高级数据分析
  • 面向对象系统的分析和设计
  • QNX的安全文件策略:SECPOL
  • Linux学习——4_DNS域名解析服务器
  • Leetcode Hot 100【堆】215. 数组中的第K个最大元素