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

相关文章

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

SpringBoot集成SOL链的详细过程

《SpringBoot集成SOL链的详细过程》Solanaj是一个用于与Solana区块链交互的Java库,它为Java开发者提供了一套功能丰富的API,使得在Java环境中可以轻松构建与Solana... 目录一、什么是solanaj?二、Pom依赖三、主要类3.1 RpcClient3.2 Public

SpringBoot3集成swagger文档的使用方法

《SpringBoot3集成swagger文档的使用方法》本文介绍了Swagger的诞生背景、主要功能以及如何在SpringBoot3中集成Swagger文档,Swagger可以帮助自动生成API文档... 目录一、前言1. API 文档自动生成2. 交互式 API 测试3. API 设计和开发协作二、使用

SpringBoot如何集成Kaptcha验证码

《SpringBoot如何集成Kaptcha验证码》本文介绍了如何在Java开发中使用Kaptcha生成验证码的功能,包括在pom.xml中配置依赖、在系统公共配置类中添加配置、在控制器中添加生成验证... 目录SpringBoot集成Kaptcha验证码简介实现步骤1. 在 pom.XML 配置文件中2.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06