• 集成学习—boosting和bagging


    集成~bagging~权值~组合~抽样~样例~基本~并行

    一、简介

     集成学习通过构建并结合多个学习器来完成学习任务,常可获得比单一学习器显著优越的泛化性能

     根据个体学习器的生成方式,目前的集成学习方法大致可分为两大类

      个体学习器间存在强依赖关系、必须串行生成的序列化方法

      个体学习器间不存在强依赖关系、可同时生成的并行化方法

     前者的代表是Boosting,后者的代表是Bagging和“随机森林”

    二、bagging与boosting的概念及区别

     首先介绍Bootstraping,即自助法:它是一种有放回的抽样方法(可能抽到重复的样本)

     1、Bagging (bootstrap aggregating)

      Bagging即套袋法,其算法过程如下:

       A)从原始样本集中抽取训练集,每轮从原始样本集中使用Bootstraping的方法抽取n个训练样本(在训练集中,有些样本可能被多次抽取到,而有些样本可能一次都没有被抽中),共进行k轮抽取,得到k个训练集(k个训练集相互独立)

       B)每次使用一个训练集得到一个模型,k个训练集共得到k个模型(注:根据具体问题采用不同的分类或回归方法,如决策树、神经网络等)

       C)对分类问题:将上步得到的k个模型采用投票的方式得到分类结果;对回归问题,计算上述模型的均值作为最后的结果

     2、Boosting

      Boosting是一族可将弱学习器提升为强学习器的算法

      关于Boosting的两个核心问题:

      1)在每一轮如何改变训练数据的权值或概率分布?

       通过提高那些在前一轮被弱分类器分错样例的权值,减小前一轮分对样本的权值,而误分的样本在后续受到更多的关注

      2)通过什么方式来组合弱分类器?

       通过加法模型将弱分类器进行线性组合,比如AdaBoost通过加权多数表决的方式,即增大错误率小的分类器的权值,同时减小错误率较大的分类器的权值

       而提升树通过拟合残差的方式逐步减小残差,将每一步生成的模型叠加得到最终模型

     3、Bagging,Boosting二者之间的区别

      1)样本选择上:

       Bagging:训练集是在原始集中有放回选取的,从原始集中选出的各轮训练集之间是独立的

       Boosting:每一轮的训练集不变,只是训练集中每个样例在分类器中的权重发生变化,而权值是根据上一轮的分类结果进行调整

      2)样例权重:

       Bagging:使用均匀取样,每个样例的权重相等

       Boosting:根据错误率不断调整样例的权值,错误率越大则权重越大

      3)基学习器:

       Bagging:所有基学习器的权重相等.

       Boosting:每个基学习器都有相应的权重,对于分类误差小的分类器会有更大的权重

      4)并行计算:

       Bagging:各个预测函数可以并行生成

       Boosting:各个预测函数只能顺序生成,因为后一个模型参数需要前一轮模型的结果

  • 相关阅读:
    VS2008 Pocket PC 2003 SE仿真程序上网设置
    http请求头content-type详解
    gitLab介绍以及常用指令
    vue-cli + webpack 项目搭建
    uni-app中分页器(uni-pagination)的使用
    关于vue给对象动态添加属性页面不会动态更新的问题
    uni-app取消原生头部导航栏
    uni-app中原生头部导航栏图标事件的监听
    uni-app中原生头部导航栏图标的添加
    uni-app背景图片的引用问题
  • 原文地址:https://www.cnblogs.com/always-fight/p/10660148.html
Copyright © 2020-2023  润新知