当前位置: 首页 > news >正文

【机器学习(二十二)】零代码开发之LightGBM算法-Sentosa_DSML社区版

文章目录

  • 一、算法概念
  • 二、算法原理
    • (一)Histogram
    • (二)GOSS
      • 1、信息增益
      • 2、近似误差
    • (三)EFB
  • 三、算法优缺点
    • (一)优点
    • (二)缺点
  • 四、LightGBM分类任务实现
    • (一)数据加载和样本分区
    • (二)模型训练
    • (三)模型评估和模型可视化
  • 五、LightGBM回归任务实现
    • (一)数据加载和样本分区
    • (二)模型训练
    • (三)模型评估和模型可视化
  • 六、总结

一、算法概念

什么是LightGBM?
  LightGBM属于Boosting集合模型中的一种,LightGBM和XGBoost一样是对GBDT的高效实现。LightGBM在很多方面会比XGBoost表现更为优秀。LightGBM有以下优势:更快的训练效率、低内存使用、更高的准确率、支持并行化学习、可处理大规模数据。
  LightGBM继承了XGBoost的许多优点,包括对稀疏数据的优化、并行训练、支持多种损失函数、正则化、bagging(自助采样)和早停机制。然而,二者之间的主要区别在于树的构建方式。LightGBM并不像大多数其他实现那样逐层生长树,而是采用逐叶生长的方式。它每次选择可以最大化减少损失的叶子节点进行扩展。
在这里插入图片描述
  此外,LightGBM并不像XGBoost或其他常见的实现那样使用基于排序的决策树学习算法,该算法在排序后的特征值中寻找最佳的分割点。相反,LightGBM实现了一种高度优化的基于直方图的决策树学习算法,在效率和内存使用上具有显著优势。
  LightGBM在XGBoost的基础上引入了三项关键技术,使得其在保持较高精度的同时加速了算法运行。这三项技术分别是直方图算法(Histogram)、基于梯度的单侧采样(GOSS)和互斥特征捆绑(EFB)。
  Histogram通过将连续特征值离散化为直方图,减少寻找最佳分割点的复杂度,降低计算成本和内存占用;
  GOSS通过在训练过程中优先保留梯度较大的样本,减少计算量;
  EFB则通过将互斥的特征捆绑在一起,减少特征维度,提升训练速度。
  通过这三项算法的引入,LightGBM生成一个叶子节点需要的计算复杂度大幅度降低,从而极大节约了计算时间。

二、算法原理

(一)Histogram

  LightGBM 使用的直方图算法的核心思想是将连续的浮点数特征离散化为k个离散值。将原本可能无限取值的特征分割成较少的区间(分桶),直方图中的每一个“桶”(bin)对应一个特征区间,记录该区间内样本的累计统计量,如梯度累加和样本数量。在特征选择时,不需要再逐个遍历所有样本的具体特征值,而是根据直方图的统计结果,直接在离散值的基础上进行遍历。通过比较各个桶中的累计统计量,可以快速找到能够带来最大增益的分割点。
  算法流程如下图所示:
在这里插入图片描述
  首先,外层循环遍历树的深度,从1到最大深度d,对每个当前层的节点,获取对应的数据索引 usedRows;然后,对于每个特征k,构建直方图H,直方图H的作用是将连续的浮点特征值离散化到不同的区间(桶)中,便于后续进行增益计算。;其次,遍历每条数据,更新直方图中的值(针对每个特征)。遍历当前节点的样本,对于每个样本,根据其特征值将其放入对应的直方图桶中,同时更新该桶的统计值,直方图汇总了该节点样本在不同特征值区间的分布情况。;接下来,在直方图H上,遍历所有离散的区间,计算每个区间的分割增益,找出所有叶节点中增益最大的分割点为最优分割点,将该最优分割点对应的叶节点的数据分割成两批。;最后,根据最优分割点,更新rowSet和nodeSet,准备下一层的分裂操作,直到达到最大深度或满足停止条件为止。

(二)GOSS

  GOSS算法的核心思想是通过优先选择大梯度的样本进行训练,因为大梯度的数据对模型的改进有更大的贡献,而小梯度的数据通过采样来减少计算量,并调整它们的权重以平衡影响。
在这里插入图片描述
  GOSS 算法的核心流程如下:首先,根据样本点的梯度绝对值对它们进行降序排序,并选取梯度较大的前a%样本作为大梯度样本集;然后从剩余的梯度较小的样本中随机采样出 b(1−a)% 的小梯度样本。将大梯度样本和小梯度样本合并后,对小梯度样本赋予权重,使用这些样本训练新的弱学习器(如决策树)。重复上述步骤,直到达到指定的迭代次数或模型收敛。

1、信息增益

  GOSS 算法中的增益计算公式用于衡量特征的分裂点是否最优。通过GOSS采样后,特征 j j j在分裂点 d d d的增益计算公式如下所示:
V ~ j ( d ) = 1 n ( ( ∑ x i ∈ A l g i + 1 − a b ∑ x i ∈ B i g i ) 2 n l j ( d ) + ( ∑ x i ∈ A r g i + 1 − a b ∑ x i ∈ B r g i ) 2 n r j ( d ) ) \tilde{V}_j(d)=\frac{1}{n}\left(\frac{(\sum_{x_i\in A_l}g_i+\frac{1-a}{b}\sum_{x_i\in B_i}g_i)^2}{n_l^j(d)}+\frac{(\sum_{x_i\in A_r}g_i+\frac{1-a}{b}\sum_{x_i\in B_r}g_i)^2}{n_r^j(d)}\right) V~j(d)=n1(nlj(d)(xiAlgi+b1axiBigi)2+nrj(d)(xiArgi+b1axiBrgi)2)
  其中,
   ∙ \bullet n n n是总样本数。
   ∙ \bullet A l A_l Al A r A_r Ar分别表示在分裂点 d d d左右的样本集合。
   ∙ \bullet B l B_l Bl B r B_r Br分别表示从梯度较小的样本中随机采样得到的样本,分别为左右的样本集合。
   ∙ \bullet g i g_i gi是样本 i i i的梯度。
   ∙ \bullet n l j ( d ) n_l^j(d) nlj(d) n r j ( d ) n_r^j(d) nrj(d)分别表示在分裂点 d d d左右的样本数。
   ∙ \bullet a a a b b b是大梯度和小梯度样本的采样比例。
   ∙ \bullet 1 − a b \frac {1- a}b b1a是对小梯度样本权重的调整因子。
  这个公式的作用是将大梯度和小梯度样本分别处理后,结合权重调整,确保即使经过采样,增益计算仍然保持精度。

2、近似误差

  GOSS 中的近似误差表示为:
E ( d ) ≤ C a , b 2 ln ⁡ 1 / δ ⋅ max ⁡ { 1 n l j ( d ) , 1 n r j ( d ) } + 2 D C a , b ln ⁡ 1 / δ n \mathcal{E}(d)\leq C_{a,b}^2\ln1/\delta\cdot\max\left\{\frac{1}{n_l^j(d)},\frac{1}{n_r^j(d)}\right\}+2DC_{a,b}\sqrt{\frac{\ln1/\delta}{n}} E(d)Ca,b2ln1/δmax{nlj(d)1,nrj(d)1}+2DCa,bnln1/δ
  该公式用于衡量在给定分裂点 d d d时,增益近似误差的上界。
  其中
   ∙ \bullet n n n是样本总数。
   ∙ \bullet D D D表示树的深度。
   ∙ \bullet E ( d ) \mathcal{E}(d) E(d)是在分裂点 d d d的增益近似误差。
   ∙ \bullet C a , b C_{a, b} Ca,b是依赖于采样比例 a a a b b b的常数。
   ∙ \bullet δ \delta δ是一个置信参数,表示置信水平的倒数。
   ∙ \bullet n l j ( d ) n_l^j( d) nlj(d) n r j ( d ) n_r^j(d) nrj(d)分别是分裂点 d d d左右的样本数。
  这个公式表达了误差上界与分裂点两侧样本数量 n l j ( d ) n_l^j(d) nlj(d) n r j ( d ) n_r^j(d) nrj(d)之间的关系。随着分裂点两侧样本数的增加,误差的上界会变小,确保增益估计的准确性。

(三)EFB

  在处理高维特征数据的时候,容易出现数据稀疏问题,存在有些特征之间是互斥的,这样造成了没有必要的计算开销。稀疏性提供了一种能够在不明显降低模型性能的情况下减少特征数量的可能,通过观察这种互斥关系,可以将这些特征捆绑起来,将多个互斥特征合并为一个新的特征,减少特征的数量,从而有效地在不损失信息的前提下显著降低模型的计算复杂度,减少存储开销。
  主要解决的两个问题是:
  1 如何确定哪些特征应该捆绑在一起;
  2 如何把互斥特征对进行捆绑。

  对于问题1,特征捆绑算法的流程如下图所示:
在这里插入图片描述
  特征捆绑算法的核心流程为:首先,构建一个特征冲突图 G,其中每个特征节点的边表示该特征与其他特征在某些数据点上的冲突。其次,按照特征在图中的冲突程度对特征进行排序。最后,将排序后的特征列表进行遍历。如果某个特征可以与当前的捆绑包产生较少的冲突,则将其添加到已有的捆绑包中;否则,创建一个新的捆绑。此外,为了提高效率,提出了一个更简单的排序策略,不需要构建完整的冲突图。改为按特征的非零值数量进行排序,因为更多非零值意味着更高的冲突概率。

  对于问题二,需要一种把互斥特征对进行捆绑的方法,算法流程如下所示:
在这里插入图片描述
  通过合并多个互斥的特征,将它们的分箱索引组合在一起,减少存储和计算的复杂性。这对于互斥特征(如互斥的类别特征)特别有用,因为它们不会在同一条数据中同时非零,因此可以被合并到一个更紧凑的分箱表示中,可以通过向特征的原始值添加偏移量来完成。例如,特征A的取值在[0,10],特征 B 取值 [0, 20],让特征B的每个取值都加一个偏置量10,使得B的值范围变为 [10, 30],这样就把特征1和特征2分开,A 和 B 可以合并为一个新的特征,其值范围为 [0, 30],避免值的冲突,合并后能够有效降低训练复杂度。

三、算法优缺点

(一)优点

  1、LightGBM具有高效的训练和预测速度,采用的Histogram算法能够实现并行计算的线性加速。
  2、由于使用了Histogram等算法,LightGBM能够减少内存消耗,适用于内存有限的环境。
  3、LightGBM通过优化算法和特征选择等方法提高了模型的准确性。

(二)缺点

  1、容易过拟合
  2、LightGBM 的特征并行算法在数据量很大时,仍然存在计算上的局限。

四、LightGBM分类任务实现

(一)数据加载和样本分区

  首先,利用文本读入算子读取数据,对数据进行读入。
在这里插入图片描述
  其次,连接样本分区算子划分数据的训练集和测试集,选择训练集测试机划分比例为8:2
在这里插入图片描述
  利用类型算子设置Feature列和Label列。
在这里插入图片描述

(二)模型训练

  连接LightGBM分类算子
在这里插入图片描述
  参数配置如下图所示:

  右击算子,点击运行,得到LightGBM分类模型,如下所示:
在这里插入图片描述

(三)模型评估和模型可视化

  模型后可接评估算子,对模型的分类结果进行评估。模型后也可接任意个数据处理算子,再接图表分析算子或数据写出算子,形成算子流执行。评估算子流如下图所示:
在这里插入图片描述
  评估算子执行完成后,得到训练集和测试集评估结果如下:
在这里插入图片描述
在这里插入图片描述
  连接混淆矩阵进行模型评估
在这里插入图片描述
  混淆矩阵算子执行完成后,得到训练集和测试集混淆矩阵结果如下:
在这里插入图片描述
在这里插入图片描述
  右键预览可查看模型的运行结果,如下图所示:
在这里插入图片描述
在这里插入图片描述
  也可以查看模型信息,得到模型特征重要性图等
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五、LightGBM回归任务实现

(一)数据加载和样本分区

  利用数据读入的算子读取数据
在这里插入图片描述
  其次,连接样本分区算子对数据集划分训练集和测试集。
在这里插入图片描述
  连接类型算子设置数据的标签列和特征列
在这里插入图片描述

(二)模型训练

  连接LightGBM回归算子,设置模型参数,点击应用,并右键执行。
在这里插入图片描述
  可以训练完成后可以得到LightGBM回归模型,右键即可查看模型信息和预览模型结果。
在这里插入图片描述

(三)模型评估和模型可视化

  连接评估算子对模型进行评估
在这里插入图片描述
  得到训练集和测试集的评估结果,如下所示:
在这里插入图片描述
在这里插入图片描述
  右键点击模型信息,可以看到模型特征重要性图,残差直方图等结果,如下所示:
在这里插入图片描述
在这里插入图片描述

六、总结

  相比传统代码方式,利用Sentosa_DSML社区版完成机器学习算法的流程更加高效和自动化,传统方式需要手动编写大量代码来处理数据清洗、特征工程、模型训练与评估,而在Sentosa_DSML社区版中,这些步骤可以通过可视化界面、预构建模块和自动化流程来简化,有效的降低了技术门槛,非专业开发者也能通过拖拽和配置的方式开发应用,减少了对专业开发人员的依赖。
  Sentosa_DSML社区版提供了易于配置的算子流,减少了编写和调试代码的时间,并提升了模型开发和部署的效率,由于应用的结构更清晰,维护和更新变得更加容易,且平台通常会提供版本控制和更新功能,使得应用的持续改进更为便捷。

  Sentosa数据科学与机器学习平台(Sentosa_DSML)是力维智联完全自主知识产权的一站式人工智能开发部署应用平台,可同时支持零代码“拖拉拽”与notebook交互式开发,旨在通过低代码方式帮助客户实现AI算法模型的开发、评估与部署,结合完善的数据资产化管理模式与开箱即用的简捷部署支持,可赋能企业、城市、高校、科研院所等不同客户群体,实现AI普惠、化繁为简。
  Sentosa_DSML产品由1+3个平台组成,以数据魔方平台(Sentosa_DC)为主管理平台,三大功能平台包括机器学习平台(Sentosa_ML)、深度学习平台(Sentosa_DL)和知识图谱平台(Sentosa_KG)。力维智联凭借本产品入选“全国首批人工智能5A等级企业”,并牵头科技部2030AI项目的重要课题,同时服务于国内多家“双一流”高校及研究院所。
  为了回馈社会,矢志推动全民AI普惠的实现,不遗余力地降低AI实践的门槛,让AI的福祉惠及每一个人,共创智慧未来。为广大师生学者、科研工作者及开发者提供学习、交流及实践机器学习技术,我们推出了一款轻量化安装且完全免费的Sentosa_DSML社区版软件,该软件包含了Sentosa数据科学与机器学习平台(Sentosa_DSML)中机器学习平台(Sentosa_ML)的大部分功能,以轻量化一键安装、永久免费使用、视频教学服务和社区论坛交流为主要特点,同样支持“拖拉拽”开发,旨在通过零代码方式帮助客户解决学习、生产和生活中的实际痛点问题。
  该软件为基于人工智能的数据分析工具,该工具可以进行数理统计与分析、数据处理与清洗、机器学习建模与预测、可视化图表绘制等功能。为各行各业赋能和数字化转型,应用范围非常广泛,例如以下应用领域:
  金融风控:用于信用评分、欺诈检测、风险预警等,降低投资风险;
  股票分析:预测股票价格走势,提供投资决策支持;
  医疗诊断:辅助医生进行疾病诊断,如癌症检测、疾病预测等;
  药物研发:进行分子结构的分析和药物效果预测,帮助加速药物研发过程;
  质量控制:检测产品缺陷,提高产品质量;
  故障预测:预测设备故障,减少停机时间;
  设备维护:通过分析机器的传感器数据,检测设备的异常行为;
  环境保护:用于气象预测、大气污染监测、农作物病虫害防止等;
  客户服务:通过智能分析用户行为数据,实现个性化客户服务,提升用户体验;
  销售分析:基于历史数据分析销量和价格,提供辅助决策;
  能源预测:预测电力、天然气等能源的消耗情况,帮助优化能源分配和使用;
  智能制造:优化生产流程、预测性维护、智能质量控制等手段,提高生产效率。

  欢迎访问Sentosa_DSML社区版的官网https://sentosa.znv.com/,免费下载体验。同时,我们在B站、CSDN、知乎、博客园等平台有技术讨论博客和应用案例分享,欢迎广大数据分析爱好者前往交流讨论。

  Sentosa_DSML社区版,重塑数据分析新纪元,以可视化拖拽方式指尖轻触解锁数据深层价值,让数据挖掘与分析跃升至艺术境界,释放思维潜能,专注洞察未来。
社区版官网下载地址:https://sentosa.znv.com/
社区版官方论坛地址:http://sentosaml.znv.com/
B站地址:https://space.bilibili.com/3546633820179281
CSDN地址:https://blog.csdn.net/qq_45586013?spm=1000.2115.3001.5343
知乎地址:https://www.zhihu.com/people/kennethfeng-che/posts
博客园地址:https://www.cnblogs.com/KennethYuen


http://www.mrgr.cn/news/61856.html

相关文章:

  • springboot和vue配置https请求
  • 剖析 Claim-Check 模式:以小传大,赋能分布式系统与微服务
  • LeetCode -Hot100 - 53. 最大子数组和
  • DNS协议漏洞利用实验_hust计算机网络安全实验
  • js实现md5加密
  • 建立时间和保持时间
  • ssm014基于JSP的乡镇自来水收费系统+jsp(论文+源码)_kaic
  • 需求挖掘时,深入访谈5大技巧!
  • 【话题】Midjourney与未来设计:AI绘画工具能否取代人类创造力?
  • Nature子刊丨可再生能源对电力系统天气脆弱性的影响
  • Java面试经典 150 题.P27. 移除元素(002)
  • 【C++】C++预编译头文件、基准测试benchmark
  • QT相机连接与拍照
  • threejs 实现灯光照射模型有阴影
  • MyBatis 读取全局变量
  • 好用的透明加密软件有哪些
  • yolov8训练及测试(ubuntu18.04、tensorrt、ros)
  • 反射机制(简单版)
  • Nature: 一种基于宏基因组序列空间生成无参考的蛋白质家族的计算方法
  • 算法日记 13 day 二叉树
  • 【Java】继承
  • 【名单】科大睿智祝贺企业通过DCMM认证最新公示名单
  • 指令集架构(ISA)
  • 教你详细使用Spring框架中编程式事务
  • Vue3 学习笔记(十二)侦听器详解
  • 管家婆财贸ERP BB060.销售订单导入+BB067.销售订单修改BOM类型