XGBoost中的DART树提升器详解
2025-07-07 09:02:55作者:秋阔奎Evelyn
概述
在机器学习领域,XGBoost是一个强大的梯度提升框架,而DART(Dropouts meet Multiple Additive Regression Trees)是XGBoost中一种特殊的树提升器。本文将深入解析DART的工作原理、特性以及使用方法。
DART的背景
传统XGBoost通常结合大量回归树和小学习率进行训练。这种情况下,早期添加的树对模型影响较大,而后期添加的树影响较小。DART借鉴了深度神经网络中的dropout技术,将其应用于提升树模型,在某些场景下能取得更好的效果。
DART的核心思想
DART通过在训练过程中随机"丢弃"(dropout)一些树来解决过拟合问题:
- 防止那些仅用于修正微小错误的"琐碎树"影响模型
- 引入随机性增强模型鲁棒性
- 通过规范化技术保持预测的稳定性
工作原理
在训练的第m轮中:
- 随机选择k棵树进行丢弃
- 设D为被丢弃树的叶子分数总和
- 新树的叶子分数为Fₘ = ηF̃ₘ
- 目标函数为:
\mathrm{Obj} = \sum_{j=1}^n L(y_j, \hat{y}_j^{m-1} - D_j + \tilde{F}_m) + \Omega(\tilde{F}_m) - 使用缩放因子来平衡D和Fₘ的过度影响
关键参数详解
DART继承了gbtree的基本参数(如eta、gamma、max_depth等),并新增了以下特有参数:
采样类型(sample_type)
uniform(默认):均匀随机丢弃树weighted:按权重比例丢弃树
规范化类型(normalize_type)
tree(默认):新树与每棵被丢弃树权重相同forest:新树与被丢弃树的总权重相同
丢弃率(rate_drop)
- 范围:[0.0, 1.0]
- 控制每轮丢弃树的比例
跳过丢弃概率(skip_drop)
- 范围:[0.0, 1.0]
- 跳过丢弃的概率,此时与普通gbtree行为相同
使用注意事项
- 训练速度可能比gbtree慢,因为随机丢弃会阻止使用预测缓冲区
- 由于随机性,早期停止可能不太稳定
- 预测时必须指定ntree_limit参数
示例代码
import xgboost as xgb
# 读取数据
dtrain = xgb.DMatrix('demo/data/agaricus.txt.train')
dtest = xgb.DMatrix('demo/data/agaricus.txt.test')
# 设置DART参数
param = {
'booster': 'dart',
'max_depth': 5,
'learning_rate': 0.1,
'objective': 'binary:logistic',
'silent': True,
'sample_type': 'uniform',
'normalize_type': 'tree',
'rate_drop': 0.1,
'skip_drop': 0.5
}
# 训练模型
num_round = 50
bst = xgb.train(param, dtrain, num_round)
# 进行预测(必须指定ntree_limit)
preds = bst.predict(dtest, ntree_limit=num_round)
适用场景
DART特别适合以下情况:
- 数据量相对较小,容易过拟合
- 需要更强的正则化效果
- 模型性能达到平台期,需要突破
总结
DART为XGBoost提供了一种创新的正则化方法,通过引入dropout技术增强了模型的泛化能力。虽然训练过程可能稍慢且不太稳定,但在特定场景下能带来显著的性能提升。理解其工作原理和参数配置,可以帮助开发者更好地利用这一强大工具。
登录后查看全文
热门项目推荐
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00
项目优选
收起
deepin linux kernel
C
26
9
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
420
3.22 K
Ascend Extension for PyTorch
Python
230
261
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
689
330
暂无简介
Dart
685
160
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
React Native鸿蒙化仓库
JavaScript
266
326
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.22 K
666
仓颉编译器源码及 cjdb 调试工具。
C++
136
869