首页 > 代码库 > 机器学习中的过拟合问题
机器学习中的过拟合问题
机器学习中的过拟合问题
相关内容:
1、 R语言︱ROC曲线——分类器的性能表现评价
2、机器学习中的过拟合问题
3、R语言︱机器学习模型评估方案(以随机森林算法为例)
——————————————————————————
过拟合问题举例
右图在训练数据上拟合完美,但是预测第11个时候,
左图虽然拟合不完全,但是更合理;右图的-953,误差极大。
一、随机森林不会发生过拟合的原因
在建立每一棵决策树的过程中,有两点需要注意 -采样与完全分裂。首先是两个随机采样的过程,random forest对输入的数据要进行行、列的采样。对于行采样,采用有放回的方式,也就是在采样得到的样本集合中,可能有重复的样本。
假设输入样本为N个,那么采样的样本也为N个。这样使得在训练的时候,每一棵树的输入样本都不是全部的样本,使得相对不容易出现over-fitting。
然后进行列采样,从M个feature中,选择m个(m << M)。之后就是对采样之后的数据使用完全分裂的方式建立出决策树,这样决策树的某一个叶子节点要么是无法继续分裂的,要么里面的所有样本的都是指向的同一个分类。一般很多的决策树算法都一个重要的步骤 - 剪枝,但是这里不这样干,由于之前的两个随机采样的过程保证了随机性,所以就算不剪枝,也不会出现over-fitting。 按这种算法得到的随机森林中的每一棵都是很弱的,但是大家组合起来就很厉害了。
可以这样比喻随机森林算法:每一棵决策树就是一个精通于某一个窄领域的专家(因为我们从M个feature中选择m让每一棵决策树进行学习),这样在随机森林中就有了很多个精通不同领域的专家,对一个新的问题(新的输入数据),可以用不同的角度去看待它,最终由各个专家,投票得到结果。
机器学习中的过拟合问题