当前位置:   article > 正文

❤机器学习正则化算法的总结。耗时10个小时完成。❤

❤机器学习正则化算法的总结。耗时10个小时完成。❤

  ❤纯   干   货~❤

目录

纯干货

1、L1 正则化(Lasso 正则化)

2、L2 正则化(岭正则化)

3、弹性网络正则化(Elastic Net 正则化)

4、Dropout 正则化(用于神经网络)

5、贝叶斯Ridge和Lasso回归

贝叶斯Ridge回归

贝叶斯Lasso回归

6、早停法(Ear

7、数据增强


 正则化是一种用于降低机器学习模型过拟合风险的技术。当模型过度拟合训练数据时,它会在新样本上表现不佳。所以为了解决这个问题,我们必须要引入正则化算法。

正则化通过在模型的损失函数中添加一个正则项(惩罚项)来实现。这个正则项通常基于模型参数的大小,以限制模型参数的数量或幅度。主要有两种常见的正则化算法:L1正则化和L2正则化。

  • L1正则化(Lasso)L1正则化添加了模型参数的绝对值之和作为正则项。它倾向于使一些参数变为零,从而达到特征选择的效果。所以,L1正则化可以用于自动选择最重要的特征,并减少模型复杂度。

  • L2正则化(Ridge)L2正则化添加了模型参数的平方和作为正则项。它倾向于使所有参数都较小,但没有明确地将某些参数设置为零。L2正则化对异常值更加鲁棒,并且可以减少模型的过度依赖单个特征的情况。

正则化通过控制模型参数的大小来限制模型的复杂度,从而避免过拟合。在损失函数中引入正则项后,模型的优化目标变为最小化损失函数和正则项之和。

今天要探究的是这7各部分,大家请看~

  • L1 正则化

  • L2 正则化

  • 弹性网络正则化

  • Dropout 正则化

  • 贝叶斯Ridge和Lasso回归

  • 早停法

  • 数据增强

1、L1 正则化(Lasso 正则化)

L1正则化(也称为Lasso正则化)是一种用于控制机器学习模型复杂度的技术。

通过向损失函数添加L1范数项来实现正则化,鼓励模型产生稀疏权重,即将一些特征的权重调整为0。

公式:

L1正则化在优化过程中有两个关键特点:

1、由于正则化项中包含绝对值操作,导致损失函数不可导。因此,在求解最小化损失函数时,需要使用其他方法(如坐标下降、梯度下降等)。

2、正则化项的存在促使部分特征的权重变为0,从而实现特征选择和模型简化。

咱们看一个简单案例,使用了sklearn库中的Lasso类来实现L1正则化的模型:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.linear_model import Lasso
  4. # 生成示例数据
  5. np.random.seed(42)
  6. X = np.linspace(-5, 5, num=100).reshape(-1, 1)
  7. y = 2 * X + np.random.normal(0, 1, size=(100, 1))
  8. # 创建Lasso模型对象
  9. lasso = Lasso(alpha=0.1) # 设置alpha参数,控制正则化强度
  10. # 拟合数据
  11. lasso.fit(X, y)
  12. # 绘制优化复杂图形
  13. fig, ax = plt.subplots()
  14. ax.scatter(X, y, color="blue", label="Data")
  15. ax.plot(X, lasso.predict(X), color="red", linewidth=2, label="L1 Regularization")
  16. # 在图中绘制L1正则化项的等高线
  17. beta_0 = np.linspace(-10, 10, 100)
  18. beta_1 = np.linspace(-10, 10, 100)
  19. B0, B1 = np.meshgrid(beta_0, beta_1)
  20. Z = np.zeros_like(B0)
  21. for i in range(len(beta_0)):
  22. for j in range(len(beta_1)):
  23. lasso.coef_ = np.array([B0[i,j], B1[i,j]])
  24. Z[i,j] = np.sum(np.abs(lasso.coef_))
  25. ax.contour(B0, B1, Z, levels=20, colors="black", alpha=0.5)
  26. ax.set_xlabel("X")
  27. ax.set_ylabel("y")
  28. ax.set_title("L1 Regularization with Contour Plot")
  29. ax.legend()
  30. plt.show()

除了绘制原始数据点和经过L1正则化的拟合线外,我们还使用等高线图形展示了L1正则化项。通过等高线图,可以更加直观地看到正则化项对权重的影响,以及如何促使模型产生稀疏权重。

2、L2 正则化(岭正则化)

L2正则化(也称为岭正则化)是一种用于控制机器学习模型复杂度的技术。

它通过向损失函数添加L2范数项来实现正则化,鼓励模型产生平滑权重,即将特征的权重调整为较小的值。

公式:

L2正则化在优化过程中的2个关键特点:

1、正则化项中包含平方操作,使得损失函数可导。因此,在求解最小化损失函数时,可以使用常见的梯度下降等优化算法。

2、正则化项的存在使得特征权重趋向于较小的值,从而避免了过拟合问题。

先看一个案例,使用sklearn库中的Ridge类来实现L2正则化的模型:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.linear_model import Ridge
  4. # 生成示例数据
  5. np.random.seed(42)
  6. X = np.linspace(-5, 5, num=100).reshape(-1, 1)
  7. y = 2 * X + np.random.normal(0, 1, size=(100, 1))
  8. # 创建Ridge模型对象
  9. ridge = Ridge(alpha=0.1) # 设置alpha参数,控制正则化强度
  10. # 拟合数据
  11. ridge.fit(X, y)
  12. # 绘制优化复杂图形
  13. fig, ax = plt.subplots()
  14. ax.scatter(X, y, color="blue", label="Data")
  15. ax.plot(X, ridge.predict(X), color="red", linewidth=2, label="L2 Regularization")
  16. # 在图中绘制L2正则化项的等高线
  17. beta_0 = np.linspace(-10, 10, 100)
  18. beta_1 = np.linspace(-10, 10, 100)
  19. B0, B1 = np.meshgrid(beta_0, beta_1)
  20. Z = np.zeros_like(B0)
  21. for i in range(len(beta_0)):
  22. for j in range(len(beta_1)):
  23. ridge.coef_ = np.array([B0[i,j], B1[i,j]])
  24. Z[i,j] = np.sum(ridge.coef_ ** 2)
  25. ax.contour(B0, B1, Z, levels=20, colors="black", alpha=0.5)
  26. ax.set_xlabel("X")
  27. ax.set_ylabel("y")
  28. ax.set_title("L2 Regularization with Contour Plot")
  29. ax.legend()
  30. plt.show()

除了绘制原始数据点和经过L2正则化的拟合线外,我们还使用等高线图形展示了L2正则化项。通过等高线图,可以更加直观地看到正则化项对权重的影响,以及如何促使模型产生平滑权重。

3、弹性网络正则化(Elastic Net 正则化)

弹性网络正则化是一种用于线性回归模型的正则化方法,结合了L1和L2正则化的特点。

可以在具有大量特征的数据集上处理多重共线性问题,并选择相关特征。

弹性网络正则化通过加权L1范数和L2范数来控制正则化项的大小。L1范数在某些情况下会产生稀疏解(即部分系数为零),而L2范数鼓励系数的平滑性。

因此,弹性网络正则化可以综合利用L1和L2正则化的优势。

弹性网络正则化的损失函数可以表示为:

下面是使用Python的scikit-learn库来拟合弹性网络回归模型:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.linear_model import ElasticNet
  4. # 生成一些样本数据
  5. np.random.seed(42)
  6. n_samples = 100
  7. X = np.linspace(-3, 3, n_samples)
  8. y = 0.5 * X + np.random.normal(scale=0.5, size=n_samples)
  9. # 创建并拟合弹性网络模型
  10. enet = ElasticNet(alpha=0.5, l1_ratio=0.7)
  11. enet.fit(X.reshape(-1, 1), y)
  12. # 绘制原始数据和拟合曲线
  13. plt.scatter(X, y, color='b', label='Original data')
  14. plt.plot(X, enet.predict(X.reshape(-1, 1)), color='r', linewidth=2, label='Elastic Net')
  15. plt.xlabel('X')
  16. plt.ylabel('y')
  17. plt.legend()
  18. plt.title('Elastic Net Regression')
  19. plt.show()

代码中生成了一些具有噪声的样本数据,并使用弹性网络模型进行拟合。

通过绘制原始数据和拟合曲线,可以更好地理解弹性网络正则化在回归问题中的应用。

案例中只是一个简单的示例,实际使用时需要调整参数和改进模型以适应具体问题。

4、Dropout 正则化(用于神经网络)

Dropout 正则化是一种用于神经网络的正则化方法

通过在训练过程中随机将一部分神经元的输出设置为零,从而减少神经网络中的过拟合现象。

Dropout 正则化可以提高模型的泛化能力,并防止神经元之间过度依赖。

Dropout 正则化的原理是,在训练期间以概率  随机地将一部分神经元的输出设置为零,称为“丢弃”。丢弃的方式是对每个神经元引入一个二进制的随机变量 ,取值为 0 或 1,表示该神经元是否被丢弃。在前向传播和反向传播过程中,丢弃的神经元及其连接会被忽略。

在训练过程中,Dropout 正则化的损失函数可以表示为:

在测试阶段,不再进行丢弃操作,而是将所有神经元的输出乘以概率 P。通过这种方式,Dropout 正则化可以减少神经元之间的依赖性,提高模型的鲁棒性。

下面使用Python的tensorflow库来构建一个具有Dropout正则化的简单神经网络:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. import tensorflow as tf
  4. # 生成一些样本数据
  5. np.random.seed(42)
  6. n_samples = 100
  7. X = np.linspace(-3, 3, n_samples)
  8. y = 0.5 * X + np.random.normal(scale=0.5, size=n_samples)
  9. # 构建神经网络模型
  10. model = tf.keras.models.Sequential([
  11. tf.keras.layers.Dense(16, activation='relu', input_shape=(1,)),
  12. tf.keras.layers.Dropout(0.5),
  13. tf.keras.layers.Dense(1)
  14. ])
  15. # 编译和拟合模型
  16. model.compile(optimizer='adam', loss='mean_squared_error')
  17. model.fit(X, y, epochs=50, batch_size=16, verbose=0)
  18. # 绘制原始数据和拟合曲线
  19. plt.scatter(X, y, color='b', label='Original data')
  20. plt.plot(X, model.predict(X), color='r', linewidth=2, label='Dropout Regularization')
  21. plt.xlabel('X')
  22. plt.ylabel('y')
  23. plt.legend()
  24. plt.title('Neural Network with Dropout Regularization')
  25. plt.show()

上述代码生成了一些具有噪声的样本数据,并构建了一个简单的具有Dropout正则化的神经网络模型。通过绘制原始数据和拟合曲线,可以更好地理解Dropout正则化在神经网络中的应用。

5、贝叶斯Ridge和Lasso回归

贝叶斯Ridge回归和Lasso回归是两种基于贝叶斯统计思想的回归算法模型。它们都是经典的线性回归的扩展,可以用于特征选择和解决过拟合问题。

贝叶斯Ridge回归

贝叶斯Ridge回归通过引入正则化项来控制模型的复杂度,同时利用贝叶斯推断方法进行参数估计。其优化目标是最小化损失函数和正则化项的和。

贝叶斯Ridge回归的目标函数如下所示:

贝叶斯Ridge回归的核心思想是将权重参数视为一个随机变量,并使用贝叶斯推断对其进行估计。

通过引入先验分布p(W),根据贝叶斯定理可以得到后验分布P(W|X,y)。然后,可以通过采样或其他方法来估计权重参数的分布,从而得到预测结果。

贝叶斯Ridge回归的优点是可以灵活地处理不同类型的数据和噪声,并且可以用作特征选择方法。缺点是计算复杂度较高,需要进行概率推断。

贝叶斯Lasso回归

贝叶斯Lasso回归也是一种基于贝叶斯统计思想的回归模型。它与贝叶斯Ridge回归类似,但使用的是L1范数正则化项。

贝叶斯Lasso回归的目标函数如下所示:

贝叶斯Lasso回归通过最小化损失函数和L1范数正则化项来实现稀疏性。L1范数倾向于将一些权重参数设为0,从而实现特征选择。

贝叶斯Lasso回归的优点是可以自动进行特征选择,并且能够处理高维数据。缺点是计算复杂度较高,需要进行概率推断。

以贝叶斯Ridge回归为例,使用Python代码实现:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.linear_model import BayesianRidge
  4. # 生成示例数据集
  5. np.random.seed(42)
  6. X = np.random.rand(100, 1) * 10
  7. y = 2 * X[:, 0] + np.random.randn(100)
  8. # 创建贝叶斯Ridge回归模型对象
  9. model = BayesianRidge()
  10. # 拟合模型
  11. model.fit(X, y)
  12. # 绘制原始数据和拟合曲线
  13. fig, ax = plt.subplots()
  14. ax.scatter(X, y, color='blue', label='Original data')
  15. # 生成用于预测的新样本点
  16. x_new = np.linspace(0, 10, 100).reshape(-1, 1)
  17. # 预测新样本点的输出值
  18. y_pred, y_std = model.predict(x_new, return_std=True)
  19. # 绘制拟合曲线及置信区间
  20. ax.plot(x_new, y_pred, color='red', label='Fitted curve')
  21. ax.fill_between(x_new.flatten(), y_pred - y_std, y_pred + y_std, color='pink',
  22. alpha=0.5, label='Confidence interval')
  23. ax.set_xlabel('X')
  24. ax.set_ylabel('y')
  25. ax.set_title('Bayesian Ridge Regression')
  26. ax.legend()
  27. plt.show()

6、早停法(Ear

早停法(Early Stopping)是一种用于防止模型过拟合的正则化技术。它通过在训练过程中监测验证误差,并根据验证误差的变化来确定何时停止训练模型,以避免过拟合。

早停法采用以下步骤:

  1. 将数据集划分为训练集和验证集。

  2. 初始化模型参数。

  3. 在每个训练迭代中,计算训练误差并更新模型参数。

  4. 在每个训练迭代后,计算验证误差。

  5. 如果验证误差开始上升,则停止训练,并使用具有最低验证误差的模型参数作为最终模型。

公式:

早停法的目标是在验证误差开始上升之前找到最佳模型,即训练误差和验证误差同时达到较小值的点。

下面是一个Python实现的案例:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.model_selection import train_test_split
  4. from sklearn.linear_model import LinearRegression
  5. # 生成示例数据
  6. np.random.seed(42)
  7. X = np.linspace(-5, 5, num=100).reshape(-1, 1)
  8. y = 2 * X + np.random.normal(0, 1, size=(100, 1))
  9. # 划分训练集和验证集
  10. X_train, X_val, y_train, y_val = train_test_split(X, y, test_size=0.2, random_state=42)
  11. # 创建线性回归模型对象
  12. model = LinearRegression()
  13. # 记录训练误差和验证误差
  14. train_errors = []
  15. val_errors = []
  16. # 拟合数据并记录误差
  17. for i in range(1, len(X_train)):
  18. model.fit(X_train[:i], y_train[:i])
  19. y_train_pred = model.predict(X_train[:i])
  20. y_val_pred = model.predict(X_val)
  21. train_errors.append(np.mean((y_train_pred - y_train[:i]) ** 2))
  22. val_errors.append(np.mean((y_val_pred - y_val) ** 2))
  23. # 绘制优化复杂图形
  24. fig, ax = plt.subplots()
  25. ax.plot(train_errors, label="Train Error")
  26. ax.plot(val_errors, label="Validation Error")
  27. best_epoch = np.argmin(val_errors)
  28. ax.axvline(x=best_epoch, linestyle="--", color="red", label="Early Stopping")
  29. ax.set_xlabel("Epoch")
  30. ax.set_ylabel("Mean Squared Error")
  31. ax.set_title("Early Stopping")
  32. ax.legend()
  33. plt.show()

代码证,使用了线性回归模型,并在每个训练迭代中记录了训练误差和验证误差。通过绘制训练误差和验证误差的曲线,以及早停法的标记点,可以更加直观地观察到模型的优化过程和选择最佳模型时的判定点。

这样,使用优化复杂的图形可以更好地理解早停法算法模型的效果。

7、数据增强

数据增强正则化是一种常用的正则化技术,它通过对训练数据进行随机变换或扩充来增加数据集的多样性。这种方法可以帮助模型更好地泛化,并减轻过拟合问题。

数据增强正则化的步骤如下:

1、对训练数据进行一系列随机的变换操作,例如旋转、平移、缩放、裁剪等。

2、将变换后的样本添加到原始训练数据集中。

3、使用经过增强的数据集进行模型训练。

数据增强正则化的目标是通过增加数据集的多样性,使模型能够更好地适应不同的输入情况,并提高其泛化能力。

由于数据增强正则化是一种基于随机变换的方法,没有明确的公式表达。

代码示例:

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. from sklearn.datasets import make_moons
  4. from sklearn.linear_model import LogisticRegression
  5. # 生成示例数据集
  6. np.random.seed(42)
  7. X, y = make_moons(n_samples=200, noise=0.1)
  8. # 创建Logistic回归模型对象
  9. model = LogisticRegression()
  10. # 绘制原始数据分布
  11. fig, ax = plt.subplots()
  12. ax.scatter(X[:, 0], X[:, 1], c=y, cmap="bwr", edgecolors='k')
  13. ax.set_xlabel("X1")
  14. ax.set_ylabel("X2")
  15. ax.set_title("Original Data Distribution")
  16. # 数据增强
  17. n_transforms = 50
  18. augmented_X = []
  19. augmented_y = []
  20. for i in range(n_transforms):
  21. transformed_X = X + np.random.normal(0, 0.05, size=X.shape)
  22. augmented_X.append(transformed_X)
  23. augmented_y.append(y)
  24. augmented_X = np.concatenate(augmented_X, axis=0)
  25. augmented_y = np.concatenate(augmented_y, axis=0)
  26. # 绘制经过数据增强后的数据分布
  27. fig, ax = plt.subplots()
  28. ax.scatter(augmented_X[:, 0], augmented_X[:, 1], c=augmented_y, cmap="bwr", edgecolors='k')
  29. ax.set_xlabel("X1")
  30. ax.set_ylabel("X2")
  31. ax.set_title("Data Distribution after Augmentation")
  32. # 使用经过增强的数据进行模型训练
  33. model.fit(augmented_X, augmented_y)
  34. # 绘制决策边界
  35. x_min, x_max = X[:, 0].min() - 0.5, X[:, 0].max() + 0.5
  36. y_min, y_max = X[:, 1].min() - 0.5, X[:, 1].max() + 0.5
  37. xx, yy = np.meshgrid(np.arange(x_min, x_max, 0.02),
  38. np.arange(y_min, y_max, 0.02))
  39. Z = model.predict(np.c_[xx.ravel(), yy.ravel()])
  40. Z = Z.reshape(xx.shape)
  41. fig, ax = plt.subplots()
  42. ax.contourf(xx, yy, Z, alpha=0.8, cmap="bwr")
  43. ax.scatter(X[:, 0], X[:, 1], c=y, cmap="bwr", edgecolors='k')
  44. ax.set_xlabel("X1")
  45. ax.set_ylabel("X2")
  46. ax.set_title("Decision Boundary")
  47. plt.show()

在代码示例中,我们使用了make_moons函数生成了一个月亮形状的二分类数据集。然后,通过对原始数据进行随机的高斯扰动(np.random.normal),生成了多个变换后的样本,并将这些样本添加到原始数据集中。最后,使用经过增强的数据集训练了Logistic回归模型,并绘制了决策边界。

通过增强后的数据集,模型能够更好地捕捉到数据的不同特征和变化,使得模型能够更好地区分两个类别。而绘制的决策边界显示了模型在增强后的数据上学到的决策规则。

这种可视化方法有助于理解数据增强正则化的作用,以及如何通过引入多样性来改善模型的泛化能力。

实际应用中可能需要根据具体情况进行调整或使用其他数据增强技术。同时,数据增强正则化算法模型有许多变体和技巧,可以根据具体任务和需求进行调整和改进。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/791153
推荐阅读
相关标签
  

闽ICP备14008679号