当前位置: 首页 > 面试题库 >

请问GBDT和XGBoosts的区别是什么?

邢鸿博
2023-03-14
本文向大家介绍请问GBDT和XGBoosts的区别是什么?相关面试题,主要包含被问及请问GBDT和XGBoosts的区别是什么?时的应答技巧和注意事项,需要的朋友参考一下

首先介绍一下boosting思想,每次训练单个弱分类器时,都将上一次分错的数据权重提高一点再进行当前单个弱分类器的学习,这样往后执行,训练出来的单个弱分类器就会越在意那些容易分错的点,最终通过加权求和的方式组合成一个最终的学习器

gradent boosting 是boosting的一种,每一次构建单个学习器时,是在之前建立的模型的损失函数的梯度下降方向, GB与Adaboost的区别在于:

AdaBoost是通过提升错分数据点的权重来定位模型的不足。

Gradient Boosting是通过算梯度(gradient)来定位模型的不足 。

主要思想是,每一次建立单个学习器时,是在之前建立的模型的损失函数的梯度下降方向,损失函数越大,说明模型越容易出错,如果我们的模型能够让损失函数持续的下降,则说明我们的模型在不停的改进,而最好的方式就是让损失函数在其梯度方向上下降。

GBDT=GB+DT(decision tree),即基分类器为决策树时,这里的决策树是回归树

Xgboost 是GB算法的高效实现,其中基分类器除了可以使CART也可以是线性分类器

 

几大区别:

传统GBDT以CART作为基分类器,xgboost还支持线性分类器,这个时候xgboost相当于带L1和L2正则化项的逻辑斯帝回归或者线性回归 传统GBDT在优化时只用到了一阶导数,而xgboost对代价函数进行了二阶泰勒展开,用到了一阶和二阶导数 xgboost加入了正则项,防止过拟合 shrinkage,相当于学习率,在每完成一次html" target="_blank">迭代后,会乘上这个系数,削减每棵树的影响 列抽样,借鉴随机森林的做法,支持列抽样,不仅能降低过拟合,还能减少计算

 类似资料:
  • 本文向大家介绍AdaBoost和GBDT的区别,AdaBoost和GBDT的区别?相关面试题,主要包含被问及AdaBoost和GBDT的区别,AdaBoost和GBDT的区别?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: AdaBoost通过调整错分的数据点的权重来改进模型,而GBDT是从负梯度的方向去拟合改进模型。 AdaBoost改变了训练数据的权值,即样本的概率分布,减少上一轮被正

  • 本文向大家介绍随机森林和 GBDT 的区别?相关面试题,主要包含被问及随机森林和 GBDT 的区别?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: 1)随机森林采用的bagging思想,而GBDT采用的boosting思想。这两种方法都是Bootstrap思想的应用,Bootstrap是一种有放回的抽样方法思想。虽然都是有放回的抽样,但二者的区别在于:Bagging采用有放回的均匀取样,而

  • 本文向大家介绍请问error和exception有什么区别?相关面试题,主要包含被问及请问error和exception有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 考察点:异常 error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。 exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。

  • 请问打包和分发的区别是什么? 我在学习Electron的时候,我有看到 electron-builder 是打包工具; electron-forge 是打包/分发工具。 请问打包和分发的区别是什么呢?

  • 本文向大家介绍请问EJB与JAVA BEAN的区别是什么?相关面试题,主要包含被问及请问EJB与JAVA BEAN的区别是什么?时的应答技巧和注意事项,需要的朋友参考一下 考察点:EJB 参考回答: Java Bean 是可复用的组件,对Java Bean并没有严格的规范,理论上讲,任何一个Java类都可以是一个Bean。但通常情况下,由于Java Bean是被容器所创建(如Tomcat)的,所以

  • 本文向大家介绍请问,hibernate的 save() 和persist() 方法分别是做什么的?有什么区别?相关面试题,主要包含被问及请问,hibernate的 save() 和persist() 方法分别是做什么的?有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 考察点:session   Hibernate的对象有三种状态:瞬时态(transient)、持久态(persistent)