【機器學習】--整合演算法從初始到應用

LHBlog發表於2018-06-22

一、前述

整合思想就是讓很多個訓練器決定一個結果,目的:讓機器學習效果更好,單個不行,群毆走起。

二、具體

1、概述

 2、Bagging模型

全稱: bootstrap aggregation(說白了就是並行訓練一堆分類器),最典型的代表就是隨機森林啦。

隨機:資料取樣隨機,特徵選擇隨機

森林:很多個決策樹並行放在一起

構造樹模型:

由於二重隨機性,使得每個樹基本上都不會一樣,最終的結果也會不一樣。

樹模型:之所以要進行隨機,是要保證泛化能力,如果樹都一樣,那就沒意義了!

隨機森林優勢:
它能夠處理很高維度(feature很多)的資料,並且不用做特徵選擇
容易做成並行化方法,速度比較快
在訓練完後,它能夠給出哪些feature比較重要
可以進行視覺化展示,便於分析

 

理論上越多的樹效果會越好,但實際上基本超過一定數量就差不多上下浮動了

3、Boosting模型

典型代表:AdaBoost, Xgboost
Adaboost會根據前一次的分類效果調整資料權重
最終的結果:每個分類器根據自身的準確性來確定各自的權重,再合體
解釋:如果某一個資料在這次分錯了,那麼在下一次我就會給它更大的權重

Adaboost工作流程
每一次切一刀!
整合演算法
最終合在一起
弱分類器這就升級了!

4、Stacking模型
堆疊:很暴力,拿來一堆直接上(各種分類器都來了)
可以堆疊各種各樣的分類器(KNN,SVM,RF等等)
為了刷結果,不擇手段!
分階段:第一階段得出各自結果,第二階段再用前一階段結果訓練

 

堆疊在一起確實能使得準確率提升,但是速度是個問題
整合演算法是競賽與論文神器,當我們更關注於結果時不妨來試試!

相關文章