机器学习基石
- 1 -- The Learning Problem
- 2 -- Learning to Answer Yes/No
- 3 -- Types of Learning
- 4 -- Feasibility of Learning
- 5 -- Training versus Testing
- 6 -- Theory of Generalization
- 7 -- The VC Dimension
- 8 -- Noise and Error
- 9 -- Linear Regression
- 10 -- Logistic Regression
- 11 -- Linear Models for Classification
- 12 -- Nonlinear Transformation
- 13 -- Hazard of Overfitting
- 14 -- Regularization
- 15 -- Validation
- 16 -- Three Learning Principles
机器学习技法
- 1 -- Linear Support Vector Machine
- 2 -- Dual Support Vector Machine
- 3 -- Kernel Support Vector Machine
- 4 -- Soft-Margin Support Vector Machine
- 5 -- Kernel Logistic Regression
- 6 -- Support Vector Regression
- 7 -- Blending and Bagging
- 8 -- Adaptive Boosting
- 9 -- Decision Tree
- 10 -- Random Forest
- 11 -- Gradient Boosted Decision Tree
- 12 -- Neural Network
- 13 -- Deep Learning
- 14 -- Radial Basis Function Network
- 15 -- Matrix Factorization
- 16(完结) -- Finale
15 -- Validation
上节课我们主要讲了为了避免 overfitting,可以使用 regularization 方法来解决。在之前的上加上一个 regularizer,生成,将其最小化,这样可以有效减少模型的复杂度,避免过拟合现象的发生。那么,机器学习领域还有许多选择,如何保证训练的模型具有良好的泛化能力?本节课将介绍一些概念和方法来解决这个选择性的问题。
一、Model Selection Problem
机器学习模型建立的过程中有许多选择,例如对于简单的二元分类问题,首先是算法 A 的选择,有 PLA,pocket,linear regression,logistic regression 等等;其次是迭代次数 T 的选择,有 100,1000,10000 等等;之后是学习速率的选择,有 1,0.01,0.0001 等等;接着是模型特征转换的选择,有 linear,quadratic,poly-10,Legendre-poly-10 等等;然后是正则化 regularizer 的选择,有 L2,L1 等等;最后是正则化系数的选择,有 0,0.01,1 等等。不同的选择搭配,有不同的机器学习效果。我们的目标就是找到最合适的选择搭配,得到一个好的矩 g,构建最佳的机器学习模型。
假设有 M 个模型,对应有,即有 M 个 hypothesis set,演算法为,共 M 个。我们的目标是从这 M 个 hypothesis set 中选择一个模型,通过演算法对样本集 D 的训练,得到一个最好的矩,使其最小。所以,问题的关键就是机器学习中如何选择到最好的矩。
考虑有这样一种方法,对 M 个模型分别计算使最小的矩 g,再横向比较,取其中能使最小的模型的矩:
但是足够小并不能表示模型好,反而可能表示训练的矩发生了过拟合,泛化能力很差。而且这种“模型选择+学习训练”的过程,它的 VC Dimension 是,模型复杂度增加。总的来说,泛化能力差,用来选择模型是不好的。
另外一种方法,如果有这样一个独立于训练样本的测试集,将 M 个模型在测试集上进行测试,看一下的大小,则选取最小的模型作为最佳模型:
这种测试集验证的方法,根据 finite-bin Hoffding 不等式,可以得到:
由上式可以看出,模型个数 M 越少,测试集数目越大,那么越小,即越接近于。
下面比较一下之前讲的两种方法,第一种方法使用作为判断基准,使用的数据集就是训练集 D 本身;第二种方法使用作为判断基准,使用的是独立于训练集 D 之外的测试集。前者不仅使用 D 来训练不同的,而且又使用 D 来选择最好的,那么对未知数据并不一定泛化能力好。举个例子,这相当于老师用学生做过的练习题再来对学生进行考试,那么即使学生得到高分,也不能说明他的学习能力强。所以最小化的方法并不科学。而后者使用的是独立于 D 的测试集,相当于新的考试题能更好地反映学生的真实水平,所以最小化更加理想。
但是,我们拿到的一都是训练集 D,测试集是拿不到的。所以,寻找一种折中的办法,我们可以使用已有的训练集 D 来创造一个验证集 validation set,即从 D 中划出一部分作为验证集。D 另外的部分作为训练模型使用,独立开来,用来测试各个模型的好坏,最小化,从而选择最佳的。
二、Validation
从训练集 D 中抽出一部分 K 个数据作为验证集,对应的 error 记为。这样做的一个前提是保证独立同分布(iid)于 P(x,y),也就是说的选择是从 D 中平均随机抽样得到的,这样能够把与联系起来。D 中去除后的数据就是供模型选择的训练数据,其大小为 N-k。从中选择最好的矩,记为。
假如 D 共有 1000 个样本,那么可以选择其中 900 个,剩下的 100 个作为。使用训练模型,得到最佳的,使用对进行验证,得到如下 Hoffding 不等式:
假设有 M 种模型 hypothesis set,的数量为 K,那么从每种模型 m 中得到一个在上表现最好的矩,再横向比较,从 M 个矩中选择一个最好的作为我们最终得到的模型。
现在由于数量为 N 的总样本 D 的一部分 K 作为验证集,那么只有 N-k 个样本可供训练。从中得到最好的,而总样本 D 对应的最好的矩为。根据之前的 leraning curve 很容易知道,训练样本越多,得到的模型越准确,其 hypothesis 越接近 target function,即 D 的比的要小:
所以,我们通常的做法是通过来选择最好的矩对应的模型,再对整体样本集 D 使用该模型进行训练,最终得到最好的矩。
总结一下,使用验证集进行模型选择的整个过程为:先将 D 分成两个部分,一个是训练样本,一个是验证集。若有 M 个模型,那么分别对每个模型在上进行训练,得到矩,再用对每个进行验证,选择表现最好的矩,则该矩对应的模型被选择。最后使用该模型对整个 D 进行训练,得到最终的。下图展示了整个模型选择的过程:
不等式关系满足:
下面我们举个例子来解释这种模型选择的方法的优越性,假设有两个模型:一个是 5 阶多项式,一个是 10 阶多项式。通过不使用验证集和使用验证集两种方法对模型选择结果进行比较,分析结果如下:
图中,横坐标表示验证集数量 K,纵坐标表示大小。黑色水平线表示没有验证集,完全使用进行判断基准,那么更好一些,但是这种方法的比较大,而且与 K 无关。黑色虚线表示测试集非常接近实际数据,这是一种理想的情况,其很小,同样也与 K 无关,实际中很难得到这条虚线。红色曲线表示使用验证集,但是最终选取的矩是,其趋势是随着 K 的增加,它对应的先减小再增大,当 K 大于一定值的时候,甚至会超过黑色水平线。蓝色曲线表示也使用验证集,最终选取的矩是,其趋势是随着 K 的增加,它对应的先缓慢减小再缓慢增大,且一直位于红色曲线和黑色直线之下。从此可见,蓝色曲线对应的方法最好,符合我们之前讨论的使用验证集进行模型选择效果最好。
这里提一点,当 K 大于一定的值时,红色曲线会超过黑色直线。这是因为随着 K 的增大,增大,但可供模型训练的在减小,那得到的不具有很好的泛化能力,即对应的会增大,甚至当 K 增大到一定值时,比模型更差。
那么,如何设置验证集 K 值的大小呢?根据之前的分析:
当 K 值很大时,,但是与相差很大;当 K 值很小是,,但是与可能相差很大。所以有个折中的办法,通常设置。值得一提的是,划分验证集,通常并不会增加整体时间复杂度,反而会减少,因为减少了。
三、Leave-One-Out Cross Validation
假如考虑一个极端的例子,k=1,也就是说验证集大小为 1,即每次只用一组数据对进行验证。这样做的优点是,但是与可能相差很大。为了避免与相差很大,每次从 D 中取一组作为验证集,直到所有样本都作过验证集,共计算 N 次,最后对验证误差求平均,得到,这种方法称之为留一法交叉验证,表达式为:
这样求平均的目的是为了让尽可能地接近。
下面用一个例子图解留一法的过程:
如上图所示,要对二维平面上的三个点做拟合,上面三个图表示的是线性模型,下面三个图表示的是常数模型。对于两种模型,分别使用留一交叉验证法来计算,计算过程都是每次将一个点作为验证集,其他两个点作为训练集,最终将得到的验证误差求平均值,就得到了和,比较两个值的大小,取值小对应的模型即为最佳模型。
接下来,我们从理论上分析 Leave-One-Out 方法的可行性,即是否能保证的矩足够好?假设有不同的数据集 D,它的期望分布记为,则其可以通过推导,等于的平均值。由于 N-1 近似为 N,的平均值也近似等于的平均值。具体推导过程如下:
最终我们得到的结论是的期望值和的期望值是相近的,这代表得到了比较理想的,Leave-One-Out 方法是可行的。
举一个例子,使用两个特征:Average Intensity 和 Symmetry 加上这两个特征的非线性变换(例如高阶项)来进行手写数字识别。平面特征分布如下图所示:
Error 与特征数量的关系如下图所示:
从图中我们看出,随着特征数量的增加,不断减小,先减小再增大,虽然是不断减小的,但是它与的差距越来越大,发生了过拟合,泛化能力太差。而与的分布基本一致,能较好地反映的变化。所以,我们只要使用 Leave-One-Out 方法得到使最小的模型,就能保证其足够小。下图是分别使用和进行训练得到的分类曲线:
很明显可以看出,使用发生了过拟合,而分类效果更好,泛化能力强。
四、V-Fold Cross Validation
接下来我们看看 Leave-One-Out 可能的问题是什么。首先,第一个问题是计算量,假设 N=1000,那么就需要计算 1000 次的,再计算其平均值。当 N 很大的时候,计算量是巨大的,很耗费时间。第二个问题是稳定性,例如对于二分类问题,取值只有 0 和 1 两种,预测本身存在不稳定的因素,那么对所有的计算平均值可能会带来很大的数值跳动,稳定性不好。所以,这两个因素决定了 Leave-One-Out 方法在实际中并不常用。
针对 Leave-One-Out 的缺点,我们对其作出了改进。Leave-One-Out 是将 N 个数据分成 N 分,那么改进措施是将 N 个数据分成 V 份(例如 V=10),计算过程与 Leave-One-Out 相似。这样可以减少总的计算量,又能进行交叉验证,得到最好的矩,这种方法称为 V-折交叉验证。其实 Leave-One-Out 就是 V-折交叉验证的一个极端例子。
所以呢,一般的 Validation 使用 V-折交叉验证来选择最佳的模型。值得一提的是 Validation 的数据来源也是样本集中的,所以并不能保证交叉验证的效果好,它的模型一定好。只有样本数据越多,越广泛,那么 Validation 的结果越可信,其选择的模型泛化能力越强。
五、总结
本节课主要介绍了 Validation 验证。先从如何选择一个好的模型开始切入,例如使用、都是不太好的,最终使用来进行模型选择。然后详细介绍了 Validation 的过程。最后,介绍了 Leave-One-Out 和 V-Fold Cross 两种验证方法,比较它们各自的优点和缺点,实际情况下,V-Fold Cross 更加常用。
注明:
文章中所有的图片均来自台湾大学林轩田《机器学习基石》课程
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论