过拟合的问题
到现在为止,我们已经学习了几种不同的学习算法,包括线性回归和逻辑回归,它们能够有效地解决许多问题,但是当将它们应用到某些特定的机器学习应用时,会遇到**过拟合(over-fitting)**的问题,可能会导致它们效果很差。
可以使用一种**正则化(regularization)**的技术来改善或减少过度拟合的问题
在回归问题中
-
第一个模型是一个线性模型,欠拟合,不能很好地适应我们的训练集;
-
第三个模型是一个四次方的模型,过于强调拟合原始数据,而丢失了算法的本质:
当我们用第三个模型预测新数据,可以看出,若给出一个新的值使之预测,它将表现的很差,是过拟合,虽然能非常好地适应我们的训练集但在新输入变量进行预测时可能会效果不好;而中间的模型似乎是最合适的。
在分类问题中
就以多项式理解, x
的次数越高,拟合的越好,但相应的预测的能力就可能变差。
处理过拟合问题
- 丢弃一些不能帮助我们正确预测的特征。可以是手工选择保留哪些特征,或者使用一些模型选择的算法来帮忙(例如PCA)
- 正则化。 保留所有的特征,但是减少参数的大小(magnitude)
代价函数
我们从之前的事例可以看出,正是那些高次项导致了过拟合的产生,所以我们可以通过让这些高次项的系数接近于0,我们就能很好的拟合。
所以正则化的基本方法就是在一定程度上减小高次项系数即参数theta
的值
即在设定代价函数时,为高次项的系数设置一些惩罚,通过这样代价函数选择出的theta
对预测结果的影响就比之前要小许多。
但如果我们不知道要对哪一个参数进行惩罚,我们可以对所以特征进行惩罚,并且让代价函数最优化的软件来选择这些惩罚的程度。于是得到了一个较为简单的能防止过拟合问题的假设
其中λ
称为正则化参数(Regularization Parameter)。注:根据惯例,我们不对theta0
进行惩罚。
经过正则化处理的模型与原模型的可能对比如图:
如果选择的正则化参数λ
过大,则会把所有的参数都最小化了,导致模型变成 h(x) = theta0
,也就是上图中红色直线所示的情况,造成欠拟合。
对于正则化,我们要取一个合理的λ
的值,这样才能更好的应用正则化。 回顾一下代价函数,为了使用正则化,让我们把这些概念应用到到线性回归和逻辑回归中去,那么我们就可以让他们避免过度拟合了。
正则化线性回归
正则化线性回归的代价函数为:
如果我们要使用梯度下降法令这个代价函数最小化,因为我们未对theta0
进行正则化,所以梯度下降算法将分两种情形:
分类
L1正则化(Lasso回归)
损失函数基础上加上权重参数的绝对值
L2正则化(岭回归)
损失函数基础上加上权重参数的平方和
需要说明的是:L1 相比于 L2 会更容易获得稀疏解
WHY->Click