Adaboost算法原理分析和简单实例讲解

目录

转载说明

一、AdaBoost简介

二、AdaBoost算法过程

三、AdaBoost实例讲解

三、AdaBoost的优点和缺点

转载说明

本篇博客转载自:https://blog.****.net/guyuealian/article/details/70995333

通过本篇博文的确让我对AdaBoost的求解流程更清楚了,但是个人觉得原博主在讲例子的时候,不应该先给出3个弱分类器。因为AdaBoost每一个弱分类器有一个承前启后的作用:由前一个弱分类器分类结果更新训练样本的权重,然后使用更新过的样本权重训练当前弱分类器,这主要体现在当前弱分类器的损失函数计算上面,前一个分类器中分类错误的样本就会占据较大的损失值,继而影响当前弱分类器的训练偏重。然后当前弱分类器的分类结果又继续更新训练样本的权重,传递给下一个弱分类器训练。……,原博主的例子中每一轮的迭代重点强调了训练样本权重的更新和每个弱分类器在强分类器中权重的计算,未体现每个弱分类器的训练过程。当然这只是一个简单示例喽,我们在实际使用中稍做注意即可。

一、AdaBoost简介

Boosting, 也称为增强学习或提升法,是一种重要的集成学习技术, 能够将预测精度仅比随机猜度略高的弱学习器增强为预测精度高的强学习器,这在直接构造强学习器非常困难的情况下,为学习算法的设计提供了一种有效的新思路和新方法。其中最为成功应用的是,Yoav Freund和Robert Schapire在1995年提出的AdaBoost算法。

AdaBoost是英文"Adaptive Boosting"(自适应增强)的缩写,它的自适应在于:前一个基本分类器被错误分类的样本的权值会增大,而正确分类的样本的权值会减小,并再次用来训练下一个基本分类器。同时,在每一轮迭代中,加入一个新的弱分类器,直到达到某个预定的足够小的错误率或达到预先指定的最大迭代次数才确定最终的强分类器。

Adaboost算法可以简述为三个步骤:

  1. 初始化训练数据的权值分布。如果有N个样本,则每一个训练样本最开始时都被赋予相同的权值:1/N。
  2. 训练弱分类器。具体训练过程中,如果某个样本点已经被准确地分类,那么在构造下一个训练集中,它的权值就被降低;相反,如果某个样本点没有被准确地分类,那么它的权值就得到提高。然后,权值更新过的样本集被用于训练下一个分类器,整个训练过程如此迭代地进行下去。
  3. 将各个训练得到的弱分类器组合成强分类器。各个弱分类器的训练过程结束后,加大分类误差率小的弱分类器的权重,使其在最终的分类函数中起着较大的决定作用,而降低分类误差率大的弱分类器的权重,使其在最终的分类函数中起着较小的决定作用。换言之,误差率低的弱分类器在最终分类器中占的权重较大,否则较小。
     

在Adaboost算法中,每训练完一个弱分类器都就会调整权重,上一轮训练中被误分类的点的权重会增加,在本轮训练中,由于权重影响,本轮的弱分类器将更有可能把上一轮的误分类点分对,如果还是没有分对,那么分错的点的权重将继续增加,下一个弱分类器将更加关注这个点,尽量将其分对。这样,达到“你分不对的我来分”,下一个分类器主要关注上一个分类器没分对的点,每个分类器都各有侧重

Adaboost算法原理分析和简单实例讲解

二、AdaBoost算法过程

给定训练数据集:Adaboost算法原理分析和简单实例讲解,其中Adaboost算法原理分析和简单实例讲解用于表示训练样本的类别标签,i=1,...,N。Adaboost的目的就是从训练数据中学习一系列弱分类器或基本分类器,然后将这些弱分类器组合成一个强分类器。

相关符号定义:

Adaboost算法原理分析和简单实例讲解

Adaboost的算法流程如下:

Adaboost算法原理分析和简单实例讲解

 

Adaboost算法原理分析和简单实例讲解

Adaboost算法原理分析和简单实例讲解

相关说明:

Adaboost算法原理分析和简单实例讲解

 综合上面的推导,可得样本分错与分对时,其权值更新的公式为:

Adaboost算法原理分析和简单实例讲解

1、鉴于很多网友反应,归一化常数Adaboost算法原理分析和简单实例讲解是怎么来的,这个我就不做推导,直接给个截图吧:

截图来自:https://blog.****.net/m0_37407756/article/details/67637400

Adaboost算法原理分析和简单实例讲解

三、AdaBoost实例讲解

 例:给定如图所示的训练样本,弱分类器采用平行于坐标轴的直线,用Adaboost算法的实现强分类过程。

Adaboost算法原理分析和简单实例讲解

Adaboost算法原理分析和简单实例讲解

 数据分析:

将这10个样本作为训练数据,根据 X 和Y 的对应关系,可把这10个数据分为两类,图中用“+”表示类别1,用“O”表示类别-1。本例使用水平或者垂直的直线作为分类器,图中已经给出了三个弱分类器,即:

Adaboost算法原理分析和简单实例讲解

初始化:

首先需要初始化训练样本数据的权值分布,每一个训练样本最开始时都被赋予相同的权值:wi=1/N,这样训练样本集的初始权值分布D1(i):

令每个权值w1i = 1/N = 0.1,其中,N = 10,i = 1,2, ..., 10,然后分别对于t= 1,2,3, ...等值进行迭代(t表示迭代次数,表示第t轮),下表已经给出训练样本的权值分布情况:

Adaboost算法原理分析和简单实例讲解

第1次迭代t=1:

初始的权值分布D1为1/N(10个数据,每个数据的权值皆初始化为0.1), D1=[0.1,  0.1, 0.1, 0.1, 0.1, 0.1,0.1, 0.1, 0.1, 0.1]

在权值分布D1的情况下,取已知的三个弱分类器h1、h2和h3中误差率最小的分类器作为第1个基本分类器H1(x)(三个弱分类器的误差率都是0.3,那就取第1个吧)

Adaboost算法原理分析和简单实例讲解

在分类器H1(x)=h1情况下,样本点“5 7 8”被错分,因此基本分类器H1(x)的误差率为

Adaboost算法原理分析和简单实例讲解

可见,被误分类样本的权值之和影响误差率e,误差率e影响基本分类器在最终分类器中所占的权重α。

Adaboost算法原理分析和简单实例讲解

然后,更新训练样本数据的权值分布,用于下一轮迭代,对于正确分类的训练样本“1 2 3 4 6 9 10”(共7个)的权值更新为:

Adaboost算法原理分析和简单实例讲解

这样,第1轮迭代后,最后得到各个样本数据新的权值分布:D2=[1/14,1/14,1/14,1/14,1/6,1/14,1/6,1/6,1/14,1/14]

由于样本数据“5 7 8”被H1(x)分错了,所以它们的权值由之前的0.1增大到1/6;反之,其它数据皆被分正确,所以它们的权值皆由之前的0.1减小到1/14,下表给出了权值分布的变换情况:

Adaboost算法原理分析和简单实例讲解

可得分类函数:f1(x)= α1H1(x) = 0.4236H1(x)。此时,组合一个基本分类器sign(f1(x))作为强分类器在训练数据集上有3个误分类点(即5 7 8),此时强分类器的训练错误为:0.3。

第二次迭代t=2:

在权值分布D2的情况下,再取三个弱分类器h1、h2和h3中误差率最小的分类器作为第2个基本分类器H2(x):
① 当取弱分类器h1=X1=2.5时,此时被错分的样本点为“5 7 8”:误差率e=1/6+1/6+1/6=3/6=1/2;
② 当取弱分类器h2=X1=8.5时,此时被错分的样本点为“3 4 6”:误差率e=1/14+1/14+1/14=3/14;
③ 当取弱分类器h3=X2=6.5时,此时被错分的样本点为“1 2 9”:误差率e=1/14+1/14+1/14=3/14;

Adaboost算法原理分析和简单实例讲解

因此,取当前最小的分类器h2作为第2个基本分类器H2(x)

Adaboost算法原理分析和简单实例讲解

显然,H2(x)把样本“3 4 6”分错了,根据D2可知它们的权值为D2(3)=1/14,D2(4)=1/14, D2(6)=1/14,所以H2(x)在训练数据集上的误差率:

Adaboost算法原理分析和简单实例讲解

这样,第2轮迭代后,最后得到各个样本数据新的权值分布: D3=[1/22,1/22,1/6,1/6,7/66,1/6,7/66,7/66,1/22,1/22]

下表给出了权值分布的变换情况:

Adaboost算法原理分析和简单实例讲解

可得分类函数:f2(x)=0.4236H1(x) + 0.6496H2(x)。此时,组合两个基本分类器sign(f2(x))作为强分类器在训练数据集上有3个误分类点(即3 4 6),此时强分类器的训练错误为:0.3。

第三次迭代t=3:

在权值分布D3的情况下,再取三个弱分类器h1、h2和h3中误差率最小的分类器作为第3个基本分类器H3(x):
① 当取弱分类器h1=X1=2.5时,此时被错分的样本点为“5 7 8”:误差率e=7/66+7/66+7/66=7/22;
② 当取弱分类器h2=X1=8.5时,此时被错分的样本点为“3 4 6”:误差率e=1/6+1/6+1/6=1/2=0.5;
③ 当取弱分类器h3=X2=6.5时,此时被错分的样本点为“1 2 9”:误差率e=1/22+1/22+1/22=3/22;

Adaboost算法原理分析和简单实例讲解

因此,取当前最小的分类器h3作为第3个基本分类器H3(x):

Adaboost算法原理分析和简单实例讲解

这样,第3轮迭代后,得到各个样本数据新的权值分布为: D4=[1/6,1/6,11/114,11/114,7/114,11/114,7/114,7/114,1/6,1/38]

下表给出了权值分布的变换情况:

Adaboost算法原理分析和简单实例讲解

可得分类函数:f3(x)=0.4236H1(x) + 0.6496H2(x)+0.9229H3(x)。此时,组合三个基本分类器sign(f3(x))作为强分类器,在训练数据集上有0个误分类点。至此,整个训练过程结束。

整合所有分类器,可得最终的强分类器为:

Adaboost算法原理分析和简单实例讲解

这个强分类器Hfinal对训练样本的错误率为0!

注:本例原博客附有matlab实现代码,这里就不贴出了。

三、AdaBoost的优点和缺点

优点:

     (1)Adaboost提供一种框架,在框架内可以使用各种方法构建子分类器。可以使用简单的弱分类器,不用对特征进行筛选,也不存在过拟合的现象。(Adaboost 算法的原理与推导

     (2)Adaboost算法不需要弱分类器的先验知识,最后得到的强分类器的分类精度依赖于所有弱分类器。无论是应用于人造数据还是真实数据,Adaboost都能显著的提高学习精度。

     (3)Adaboost算法不需要预先知道弱分类器的错误率上限,且最后得到的强分类器的分类精度依赖于所有弱分类器的分类精度,可以深挖分类器的能力。Adaboost可以根据弱分类器的反馈,自适应地调整假定的错误率,执行的效率高。

     (4)Adaboost对同一个训练样本集训练不同的弱分类器,按照一定的方法把这些弱分类器集合起来,构造一个分类能力很强的强分类器,即“三个臭皮匠赛过一个诸葛亮”。

缺点:

     在Adaboost训练过程中,Adaboost会使得难于分类样本的权值呈指数增长,训练将会过于偏向这类困难的样本,导致Adaboost算法易受噪声干扰。此外,Adaboost依赖于弱分类器,而弱分类器的训练时间往往很长。