SPSS Modeler 集成学习算法之同质集成(第十五章)

2023-10-12 04:10

本文主要是介绍SPSS Modeler 集成学习算法之同质集成(第十五章),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

前面小编和大家一起学习了若干分类器,一般情况下,我们在训练集上构建单个分类器解决问题。而对于集成学习算法,可以组合若干个基分类器,从而提升分类器的预测性能。通俗说,就是三个臭皮匠赛过诸葛亮。

如果基分类器的数量趋于无穷多,那么集成分类器的错误率是否会等于0呢?
不会,因为集成分类器错误率趋于0需要达到以下条件:
(1)基分类器的错误率要低于0.5%;
(2)基分类器之间相互独立。
一般的,我们是基于同一数据集进行分类器的训练,很难满足分类器间相互独立的条件。在实际中,只能尽量保证分类器之间不存在强相关的情况。当所有基分类器完全相关时,组合分类器的性能不会有任何改善。

同质集成:指所有基分类器都是由同一种算法所产生的。
同质集成学习方法:Bagging,Boosting,随机森林。

一、Bagging

Boostrap AGGregatING,也称为袋装法,是最为经典的并行集成算法。

1.1 过程:对原始训练数据集进行有放回的重复抽样达到目的。

1.2 结果输出
① 分类任务:少数服从多数的原则集成多个分类器结果。(出现平票情况,可以利用准确率进行分类器加权或直接从平票结果中随机选择一个)
② 回归任务:对多个分类器的预测值求平均作为最终的预测结果。

1.3 步骤:分类任务为例
(1)输入:
包含n个样本的训练数据集D;
基分类器算法f;
设定基分类器构建个数N。
(2)for i in 1:N do。
(3)从初始数据集D中有放回的抽取n个样本,生成自助训练集Di。
(4)基于训练集Di,训练获得基分类器fi。
(5)end for 。
(6)输出。
各个基分类器是独立生成的,因此可以使用并行的方法提高效率。Bagging算法主要用于降低方差,同时对噪声样本具有较强的抗干扰能力,因此能够减少模型过拟合的风险。
SPSS Modeler中,Bagging作为提高模型稳定性的选项。

二、Boosting

最为经典的串行集成算法。

2.1 过程:下一个分类器将根据上一个分类器的预测结果对样本的权重进行调整,对于错判样本将给予更大的权重,从而使得新的分类器更加关注错误样本的预测。

2.2 步骤:分类任务为例,AdaBoost算法
(1)输入:
包含n个样本的训练数据集D;
基分类器算法f;
设定基分类器构建个数N。
(2)初始化样本权重w1。
(3)for i in 1:N do。
(4)从初始数据集D中基于样本权重wi有放回的抽取n个样本,生成训练集Di。
(5)基于训练集Di,训练获得基分类器fi。
(6)计算基分类器fi的加权误差zi。
(7)if zi >0.5 then。
(8)重新初始化样本权重wi。
(9)返回步骤(4)。
(10)end if。
(11)计算分类器权重。
(12)更新下一轮的抽样权重。
(13)end for。
(14)输出。
Boosting算法主要用于降低偏差,通过对错分样本赋予“更高”的权重,Boosting能够通过集成实现更高的准确度。由于其对异常点更加敏感,因此在某些情况下更容易出现过拟合的情况。
SPSS Modeler中,Bagging作为模型准确性的选项。

三、随机森林

如果决策树的最终输出是一棵树,那么随机森林的最终输出就是一片森林。
在Modeler中,随机森林的基分类器是CART算法。
过程:
实际上,随机森林方法将在Bagging算法上更进一步,首先随机森林算法采取与Bagging同样的测量生成N个不同的自助训练数据集。接着,对每个自助训练数据集,在树生长的过程中将引入随机因素。
决策树:在所有的m个属性变量中选择最优变量。
随机森林:先从m个属性变量中随机选择d(d≤m)个变量生成变量子集V,再在变量子集V中选择最优的划分变量。一般地,子集的个数可以选择d=log2 m +1。d越小,各个基分类器的关联性就越低,当d=1时,意味着每个节点都是采用随机方式进行选择。
袋外样本:OOB,out of bag,由于采用重采样生成自助样本集,则某些样本可能没有被选入,这些没有被选入的样本称为袋外样本。
可以使用袋外样本作为验证集及测试集,无须事先对数据集进行划分。
SPSS Modeler的“随机树”节点中,预测准确性就是袋外估计的预测结果。

这篇关于SPSS Modeler 集成学习算法之同质集成(第十五章)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/193141

相关文章

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事