Python3机器学习实践:集成学习之LightGBM

light.png
本文为官方文档翻译,点击查看英文原版
LightGBM(Light Gradient Boosting Machine)是微软的开源分布式高性能Gradient Boosting框架,使用基于决策树的学习算法。下面介绍下此框架的优化。
1、速度、内存方面的优化

许多提升工具使用基于预排序的算法(近似直方图算法)(例如XGBoost中的默认算法)来进行决策树学习。这是一个比较简单的解决方案,但不容易优化。LightGBM使用基于直方图的算法,它将连续特征值存储到离散区间。这可以加快训练速度并减少了内存使用量。
1.1 直方图算法的优点

  • 降低计算分裂增益的成本
  1. 基于预排序的算法具有时间复杂性 O(训练样本的个数),计算直方图具有时间复杂度O(训练样本的个数),但这仅当在执行总结操作时发生;
  2. 构建完直方图后,基于直方图的算法具有时间复杂度O(某个特征不同值的个数),因为某个特征不同值的个数远小于训练样本的个数;
  • 使用直方图的相减进一步加速
  1. 在计算某个叶子节点的直方图时,通过它的父节点和它的相邻节点的直方图相减,得到;
  2. 根据上条可知,每次分裂仅需要为一个叶子节点构建直方图,另一个叶子节点的可以通过直方图的减法获得,成本较低;
  • 减少内存的使用
    用离散箱替换连续值。如果某个特征不同值的个数很小,可以使用小数据类型,例如uint8_t来存储训练数据,无需存储用于预排序特征值的其他信息

  • 降低并行学习的通信成本


2、针对稀疏特征优化

对于稀疏的特征只需要O(2 * 非零值的样本个数)的时间复杂度来构造直方图


3、优化树的生长策略来提高准确率

3.1 最好的叶子节点优先分裂(Leaf_wise)的决策树生成策
大多数决策树学习算法生成树的策略是以同样的深度生成树(Level_wise),生成树的示例见下图:

image

而LightGBM以Leaf_wise的方式生成。它将选择具有最大增益损失的叶子节点来分裂。当两种方式生成的树具有相等的叶子节点时,Leaf_wise策略生成的树会比Level_wise的拟合度更高。
对于样本较少的情况,Leaf_wise方式可能会导致过度拟合,因此LightGBM中利用参数max_depth来限制树的深度。Leaf_wise方式生成的树示例如下:

image

3.2 特征的最优分割点
通常使用独热编码来转换分类特征,但这种方法对于决策树的学习并不是有益的。特别是对于不同值较多的特征,独热编码后构建的树往往是不平衡的,并且需要非常大的深度才能获得较好的准确率。
事实上,最佳解决方案是通过将类别划分为2个子集。如果特征具有K个不同的值,就是在2^(k-1) - 1种情况里找到最优的分割点。对于回归树而言,有一种解决方案可以保证在O(k * log(k))的时间复杂度内找到最优分割点。
找到特征的最优分割点的基本思想是根据训练目标的相关性对类别进行重排序。 更具体的说,根据累加值(sum_gradient / sum_hessian)重新对(类别特征的)直方图进行排序,然后在排好序的直方图中寻找最优的分割点。


4、网络通信的优化

在LightGBM的并行学习中,它只需要使用一些聚合通信算法,如“All reduce”,“All gather”和“Reduce scatter”。LightGBM实现了最先进的state-of-art算法。这些聚合通信算法可以提供比点对点通信更好的性能。


5、并行学习中的优化

LightGBM提供以下并行学习算法的优化:特征并行、数据并行、投票并行。

5.1 特征并行
传统算法中的特征并行,主要是体现在找到最好的分割点,其步骤为:

  1. 垂直分区数据(不同的线程具有不同的数据集);
  2. 在本地数据集上找到最佳分割点,包括特征,阈值;
  3. 再进行各个划分的通信整合并得到最佳划分;
  4. 以最佳划分方法对数据进行划分,并将数据划分结果传递给其他线程;
  5. 其他线程对接受到的数据进一步划分;

传统特征并行的缺点:

  1. 计算成本较大,传统特征并行没有实现得到"split"(时间复杂度为“O(训练样本的个数)")的加速。当数据量很大的时候,难以加速;
  2. 需要对划分的结果进行通信整合,其额外的时间复杂度约为 “O(训练样本的个数/8)”(一个数据一个字节);

LightGBM中的并行特征

由于特征并行在训练样本的个数大的时候不能很好地加速,LightGBM做了以下优化:不是垂直分割数据,而是每个线程都拥有完整的全部数据。因此,LightGBM不需要为分割数据结果进行通信,因为每个线程都知道如何划分数据。并且训练样本的个数不会变大,因此这种方案是合理的。

LightGBM中实现特征并行的过程:

  1. 每个线程在本地数据集上找到最佳分割点,包括特征,阈值;
  2. 本地进行各个划分的通信整合并得到最佳划分;
  3. 执行最佳划分;

然而,该并行算法在数据量很大时仍然存在计算上的局限。因此,建议在数据量很大时使用数据并行。

5.2 数据并行

传统算法数据并行旨在并行化整个决策学习。数据并行的过程是:

  1. 水平划分数据;
  2. 线程以本地数据构建本地直方图;
  3. 将本地直方图整合成全局直方图;
  4. 在全局直方图中寻找最佳划分,然后执行此划分;

传统数据并行的缺点:通信成本高。如果使用点对点通信算法,则一台机器的通信成本约为O(#machine * #feature * #bin)。如果使用聚合通信算法(例如“All Reduce”),通信成本约为O(2 * #feature * #bin)。

LightGBM中的数据并行

LightGBM中通过下面方法来降低数据并行的通信成本:

  1. 不同于“整合所有本地直方图以形成全局直方图”的方式,LightGBM 使用分散规约(Reduce scatter)的方式对不同线程的不同特征(不重叠的)进行整合。 然后线程从本地整合直方图中寻找最佳划分并同步到全局的最佳划分中;
  2. LightGBM通过直方图的减法加速训练。 基于此,我们可以进行单叶子节点的直方图通讯,并且在相邻直方图上作减法;

通过上述方法,LightGBM 将数据并行中的通讯开销减少到O(0.5 * #feature * #bin)。

5.3 投票并行
投票并行进一步降低了数据并行中的通信成本,使其减少至常数级别。它使用两阶段投票来降低特征直方图的通信成本。


6、GPU支持

参见英文文档


7、支持的应用和度量

7.1 应用

  • 回归,目标函数是L2损失
  • 二进制分类,目标函数是logloss(对数损失)
  • 多分类
  • 交叉熵,目标函数是logloss,支持非二进制标签的训练
  • lambdarank,目标函数为基于NDCG的lambdarank

7.2 度量

  • L1 loss:绝对值损失
  • L2 loss:MSE,平方损失
  • Log loss:对数损失
  • 分类错误率
  • AUC(Area Under Curve):ROC曲线下的面积
  • NDCG(Normalized Discounted Cumulative Gain):归一化折损累积增益
  • MAP(Mean Average Precision):平均精度均值
  • 多类别对数损失
  • 多类别分类错误率
  • Fair损失
  • Huber损失
  • Possion:泊松回归
  • Quantile:分位数回归
  • MAPE(Mean Absolute Percent Error):平均绝对百分比误差
  • kullback_leibler:Kullback-Leibler divergence
  • gamma:negative log-likelihood for Gamma regression
  • tweedie:negative log-likelihood for Tweedie regression
  • 更多阅读原文

7.3 其他

  • 限制树的最大深度max_depth
  • DART:Dropouts meet Multiple Additive Regression Trees
  • L1 / L2正则化
  • 套袋
  • 随即选择列(特征)子集
  • Continued train with input GBDT model
  • Continued train with the input score file
  • Weighted training
  • Validation metric output during training
  • 交叉验证
  • Multi metrics
  • 提前停止(训练和预测)
  • Prediction for leaf index
  • 更多阅读原文
image
LightGBM实例

一、北京市Pm2.5回归预测
参数选择图

image

预测数据集结果对比图
image

二、成年人收入分类
参数选择图

image

预测数据集结果
image

实例代码LightGBM,扫描下方二维码或者微信公众号直接搜索”Python范儿“,关注微信公众号pythonfan, 获取更多实例和代码。

pythonfan.jpg

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容