Adaboost算法1、Adaboost算法简介Adaboost算法是Freund和Schapire根据在线分配算法提出的,他们详细分析了Adaboost算法错误率的上界,以及为了使强分类器达到错误率,算法所需要的最多迭代次数等相关问题。与Boosting算法不同的是,Adaboost算法不需要预先知道弱学习算法学习正确率的下限即弱分类器的误差,并且最后得到的强分类器的分类精度依赖于所有弱分类器的分类精度,这样可以深入挖掘弱分类器算法的能力。2、Adaboost算法基本原理Adaboost是一种迭代算法,其核心思想是针对同一个训练集训练不同的分类器(弱分类器),然后把这些弱分类器集合起来,构成一个更强的最终分类器(强分类器)。其算法本身是通过改变数据分布来实现的,它根据每次训练集之中每个样本的分类是否正确,以及上次的总体分类的准确率,来确定每个样本的权值。将修改过权值的新数据集送给下层分类器进行训练,最后将每次训练得到的分类器最后融合起来,作为最后的决策分类器。使用Adaboost分类器可以排除一些不必要的训练数据特征,并将关键放在关键的训练数据上面。Adaboost算法中不同的训练集是通过调整每个样本对应的权重来实现的。开始时,每个样本对应的权重是相同的,即其中n为样本个数,在此样本分布下训练出一弱分类器。对于分类错误的样本,加大其对应的权重;而对于分类正确的样本,降低其权重,这样分错的样本就被突出出来,从而得到一个新的样本分布。在新的样本分布下,再次对弱分类器进行训练,得到弱分类器。依次类推,经过T次循环,得到T个弱分类器,把这T个弱分类器按一定的权重叠加(boost)起来,得到最终想要的强分类器。Adaboost算法的具体步骤如下:设输入的n个训练样本为:1122{(,),(,),,(,)}nnxyxyxy,其中ix是输入的训练样本,{0,1}iy分别表示正样本和负样本,其中正样本数为l,负样本数m。nlm,具体步骤如下:⑴初始化每个样本的权重,()iwiDi;⑵对每个1,,tT(T为弱分类器的个数):①把权重归一化为一个概率分布,,,1titintjj②对每个特征f,训练一个弱分类器jh计算对应所有特征的弱分类器的加权错误率1()()njtijiiiwxhxy③选取最佳的弱分类器th(拥有最小错误率):t④按照这个最佳弱分类器,调整权重11,,itititww其中0i表示被正确地分类,1i,表示被错误地分类1ttt⑶最后的强分类器为:1111()()20TTttttthxhxotherwise,1logtt3、Adaboost算法应用随着Adaboost算法的发展,目前Adaboost算法广泛的应用于人脸检测、目标识别等领域,其中有在人脸识别、汽车识别、驾驶员眨眼识别的方面的应用和研究。Discete-Adaboost算法1、给定训练集:11,,,,NNxyxy,其中1,1iy,表示ix的正确的类别标签,1,,iN,()jigx表示第i副图像的第j个特征值2、训练集上样本的初始分布:11Dim3、寻找弱分类器th(1,,tT)⑴对于每个样本中的第j个特征,可以得到一个弱分类器jh,即可得到阈值j和方向jp,使得1()()NjtijiiiDxhxy达到最小,而弱分类器jh为:1()()1jjjjjpgxphxother其中jp决定不等式的方向,只有1两种情况。4、将所有特征(j)中挑选出一个具有最小误差t的弱分类器th。5、对所有的样本权重进行更新1expttitittDiyhxDiZ其中tZ是使11()1NtiiDx得归一化因子。6、经过T轮训练得到T个最优的弱分类器,此时组成一个强分类器;1TfinaltttHxsignhx在Adaboost算法的弱学习中,将产生错误率为12,T的弱分类器。如果每个错误率12t,则强分类器的总错误率t2te(1-)一切都从强分类器的错误率开始首先权值更新1exp()expexp()titittititiittttttyhxDiyhxyfxDiZmZmZ其中()()itttfxhx然后强分类器的错误率11()1()01()0101exp(())()iiiiiiiiittitifyHxtrainingerrorHelseNifyfxelseNyfxNDiZ 使这个错误率快速下降?()exp(())tttitiiZDiyhxtZ为归一化因子。转化为求tZ的最小值了!:():()()exp(())()exp()()exp()(1)exp()exp()iiiittititiitittitiyHxiyHxttttZDxyhxDxDx此时我们用贪心算法求出tZ的一个局部最小值对tZ中的t求导[此时将t固定](1)exp()exp()ttttttdZd令导数为零0ttdZd解出11ln()2ttt此时2(1)tttZ绘制tZ关于t的曲线图从这幅图上我们可以看出,当错误率越小或者越大(只要不在中点处徘徊)的时候tZ快速收敛到0。越小:说明错误越小的分类器能快速识别出正例。越大:说明错误越大的分类器也能快速识别出正例。1()()NjtijiiiDxhxy既然最大,只要我把弱分类器取反,这样错误率就是最小,这样还是收敛到0。从以上的证明,我们知道只要是弱分类器的错误率都取最小,于是我们就能组合得到一个强分类器。接下来我们就找出一个弱分类器1()hx错误率1很小。找T个联合起来就得到了强分类器finalHx!怎么找弱分类器?决策树ID3,C4.5,C5.0ID3生成树用(CIG类别属性增益法)C4.5生成树用(GainRatio增益比率法)修剪树用(Rulepost-pruning规则修剪)C5.0生成树用(Giniindex基尼指数)修剪树用(CRAT回归树修剪)然后给出YoavFreund论文中给出的寻找方法12(),()()jjjNgxgxgx排序12(),()()Njjjgxgxgx令阈值1g()()2iijjijxgx1()()0jjjjjpgxphxother,1()()NjtijiiiDxhxy