梯度提升技術
梯度提升,亦稱作梯度增強,是一種用於回歸和分類問題的機器學習技術。其產生的預測模型是弱預測模型的集成,如採用典型的決策樹作為弱預測模型,這時則為梯度提升樹(GBT或GBDT)。像其他提升方法一樣,它以分階段的方式構建模型,但它通過允許對任意可微分損失函數進行優化作為對一般提升方法的推廣。
梯度提升技術源自於Leo Breiman於1997年時將提升方法用於優化算法的觀察[1]。隨後Jerome H. Friedman於1999年時提出了顯式回歸梯度增強算法[2][3]。Llew Mason、Jonathan Baxter、Peter Bartlett和Marcus Frean則針對梯度提升在一般的函數空間的運用進行研究,並於1999年在研討會發表之後[4],同年正式發表了論文[5]。該論文介紹了將提升算法看作「函數空間上的梯度下降迭代」算法的觀點。也就是將其視為通過迭代地選擇指向負梯度方向的函數(弱預測模型),來優化函數空間上的成本函數的算法。這種將提升視為函數梯度的觀點,導致了提升算法被運用於回歸和分類之外的其他機器學習和統計領域的後續發展。
非正式介紹
[編輯](本節遵循Li對梯度增強的說明[6]。)
與其他增強方法一樣,梯度增強以迭代方式將弱的「學習器」組合為一個強學習器。最簡單的解釋是在最小二乘回歸中,通過最小化均方誤差 ,「教」模型預測實數值。
在梯度提升的每個階段 , , 假設已經有一個不太完美的模型 (最開始時只是一個預測輸出變量 y 均值的模型)。 梯度提升算法通過在當前模型 增加一個新的估計量 h 得到一個更好的模型: . 為了求得 , 梯度提升基於以下觀察:一個完美的 h 可以完美預測當前不完美模型的殘差,即滿足,
或者,等效地有,
- .
因此,梯度提升通過擬合殘差 得到 h 。和其他提升方法的變體一樣, 通過糾正 的誤差變得更完美。 這個想法可以擴展到均方誤差損失之外的任意損失函數,甚至擴展到分類與排序問題,只要觀察到以下一點:模型的殘差 就是均方損失函數關於的負梯度。因此,梯度提升其實是一種 梯度下降算法,可以代入除了均方損失之外的不同的損失函數,得到不同的梯度。
算法
[編輯]在許多有監督學習問題中,一個輸出變量y和一個輸入變量x通過聯合概率分布描述 。給定訓練集,目的是在所有具有給定形式的函數中找到一個使某些指定損失函數的期望值達到最小:
- .
梯度提升方法通過某一類中弱學習器(或稱基學習器)帶權重和的形式來表示對實值變量y做出估計的:
- .
根據經驗風險最小化原理,該方法試圖找到一個近似可以最大程度地減少訓練集上損失函數的平均值,即,最小化經驗風險。它是從一個由常數函數組成的模型開始 ,並以貪心的方式逐步擴展:
- ,
- ,
上式是基學習器。
不幸的是,通常在每個步驟中為任意損失函數L選擇最佳函數h是計算上不可行的優化問題。因此,我們將方法局限於問題的簡化版本。
這個想法是對這個最小化問題(函數梯度下降)應用梯度下降步驟。如果我們考慮連續情況,即是上的任意微分函數的集合 ,我們將根據以下方程式更新模型
式子中,對於是關於函數求導,是步長。 但是在離散情況下,即如果是有限的,我們選擇最接近L梯度的候選函數h ,然後可以根據上述等式通過線搜索來計算係數γ。請注意,這種方法是一種啟發式方法,因此不能給出給定問題的精確解決方案,而是一種近似方法。 在偽代碼中,通用梯度增強方法是[2][7]:
Input: training set a differentiable loss function number of iterations M.
Algorithm:
- Initialize model with a constant value:
- For m = 1 to M:
- Compute so-called pseudo-residuals:
- Fit a base learner (or weak learner, e.g. tree) to pseudo-residuals, i.e. train it using the training set .
- Compute multiplier by solving the following one-dimensional optimization problem:
- Update the model:
- Compute so-called pseudo-residuals:
- Output
梯度樹增強
[編輯]梯度提升通常與固定大小的決策樹 (尤其是CART樹)一起用作基礎學習者。 對於這種特殊情況,Friedman提出了對梯度增強方法的改進,以提高每個基礎學習者的適應質量。
第m步的通用梯度提升將適合決策樹偽殘留物。 讓是它的葉子數。 樹將輸入空間劃分為不相交的區域並預測每個區域的恆定值。 使用指標符號 ,輸出輸入x可以寫為和:
這裡是該區域中預測的值[a]。
然後係數乘以一些值 ,使用線搜索進行選擇,以最大程度地減少損失函數,並按以下方式更新模型:
弗里德曼(Friedman)建議修改此算法,以便選擇一個單獨的最佳值每個樹的區域,而不是單個為整棵樹。 他稱修改後的算法為「 TreeBoost」。 係數然後可以簡單地丟棄樹擬合過程中的數據,模型更新規則變為:
樹木大小
[編輯](樹中終端節點的數量)是該方法的參數,可以針對手頭的數據集進行調整。 它控制模型中變量之間允許的最大交互級別。 用 ( 決策樹樁 ),不允許變量之間進行交互。 用該模型可能包括多達兩個變量之間的相互作用的影響,依此類推。
Hastie等人評論通常對於提升效果很好,結果對選擇在這個範圍內不足以用於許多應用程序,並且不太可能是必需的[7]。
正則化
[編輯]過於緊密地擬合訓練集可能導致模型的泛化能力下降。 幾種所謂的正則化技術通過限制擬合過程來減少這種過度擬合的效果。
一個自然的正則化參數是梯度提升迭代的次數M(即,當基礎學習者是決策樹時,模型中的樹的數量)。M的增加會減少訓練集上的誤差,但將其設置得過高可能會導致過度擬合。 通常通過監視單獨的驗證數據集上的預測誤差來選擇M的最佳值。 除了控制M外,還使用其他幾種正則化技術。
另一個正則化參數是樹的深度。 該值越高,模型越可能適合訓練數據。
收縮率
[編輯]梯度增強方法的一個重要部分是通過收縮進行正則化,它包括如下修改更新規則:
哪裡參數 被稱為「學習率」。
根據經驗發現,使用較小的學習率 (例如 )在不縮小(而不縮小)的情況下,極大地提高了模型的泛化能力 )[7]。然而,這是以在訓練和查詢期間增加計算時間為代價的:較低的學習率需要更多的迭代。
隨機梯度增強
[編輯]引入梯度增強後不久,Friedman在Breiman的bootstrap聚合 (「裝袋」)方法的啟發下 ,對該算法進行了較小的修改[3]。具體來說,他提出在算法的每次迭代中,基礎學習者都應適合隨機抽取的訓練集的子樣本,而無需替換。[b]弗里德曼(Friedman)觀察到,通過這種修改,梯度增強的精度有了顯着提高。
子樣本大小是某個常數訓練集的大小。 什麼時候 ,該算法是確定性的,並且與上述算法相同。 較小的值將隨機性引入算法中,並防止過度擬合 ,作為一種正則化 。 該算法也變得更快,因為回歸樹必須在每次迭代時都適合較小的數據集。弗里德曼[3]獲得了在中小型訓練集上可獲得良好的結果。 因此, 通常將其設置為0.5,這意味着訓練集的一半用於構建每個基礎學習者。
同樣,像在裝袋中一樣,子採樣允許通過評估那些在下一個基礎學習者的構建中未使用的觀察值的預測來定義預測性能改進的袋外誤差 。 預算外的估計有助於避免需要獨立的驗證數據集,但通常會低估實際性能的提高和最佳迭代次數。 [8][9]
葉子中的觀察數
[編輯]梯度樹增強實現通常還通過限制樹的終端節點中的最小觀察次數來使用正則化(此參數在R gbm
軟件包中命名為n.minobsinnode
[8])。通過忽略導致導致節點包含少於此訓練集實例數量的節點的任何拆分,在樹構建過程中使用它。
施加此限制有助於減少葉子預測的差異。
懲罰樹木的複雜性
[編輯]用於梯度增強樹的另一種有用的正則化技術是懲罰學習模型的模型複雜性。 [10] 模型複雜度可以定義為學習樹中葉子的比例。 損失和模型複雜性的聯合優化對應於後修剪算法,該算法可刪除未能將損失降低閾值的分支。 其他種類的正規化,例如還可以添加對葉子值的懲罰以避免過度擬合 。
用法
[編輯]梯度提升可以用於學習排名 。 商業網絡搜索引擎Yahoo [11]和Yandex [12]在其機器學習的排名引擎中使用了梯度增強的變體。
名字
[編輯]該方法有多種名稱。弗里德曼(Friedman)將他的回歸技術稱為「梯度提升機」(GBM)。 [2] 梅森,巴克斯特等。將廣義的算法抽象類描述為「功能梯度提升」[4][5]。弗里德曼(Friedman)等人。將梯度提升模型的進展描述為多重可加回歸樹(MART)[13];Elith等。將這種方法描述為「增強回歸樹」(BRT)[14]。
R的一種流行的開源實現將其稱為「通用提升模型」[8]。但是,使用BRT擴展這項工作的軟件包。 [15] Salford Systems的商業實現使用名稱「 Multiple Additive Regression Trees」(MART)和TreeNet,兩者均為商標。 [ 需要引用 ]
參見
[編輯]註解
[編輯]- ^ Note: in case of usual CART trees, the trees are fitted using least-squares loss, and so the coefficient for the region is equal to just the value of output variable, averaged over all training instances in .
- ^ Note that this is different from bagging, which samples with replacement because it uses samples of the same size as the training set.
參考文獻
[編輯]- ^ Breiman, L. Arcing The Edge (PDF). Statistics Department, University of California, Berkeley. June 1997 [2019-11-12]. (原始內容存檔 (PDF)於2020-05-09).
- ^ 2.0 2.1 2.2 Friedman, J. H. Greedy Function Approximation: A Gradient Boosting Machine (PDF). February 1999 [2019-11-12]. (原始內容存檔 (PDF)於2019-11-01).
- ^ 3.0 3.1 3.2 Friedman, J. H. Stochastic Gradient Boosting (PDF). March 1999 [2019-11-12]. (原始內容存檔 (PDF)於2014-08-01).
- ^ 4.0 4.1 Mason, L.; Baxter, J.; Bartlett, P. L.; Frean, Marcus. Boosting Algorithms as Gradient Descent (PDF). S.A. Solla and T.K. Leen and K. Müller (編). Advances in Neural Information Processing Systems 12. MIT Press: 512–518. 1999 [2022-09-10]. (原始內容存檔 (PDF)於2019-12-22).
- ^ 5.0 5.1 Mason, L.; Baxter, J.; Bartlett, P. L.; Frean, Marcus. Boosting Algorithms as Gradient Descent in Function Space (PDF). May 1999 [2019-11-12]. (原始內容 (PDF)存檔於2018-12-22).
- ^ Cheng Li. A Gentle Introduction to Gradient Boosting (PDF). [2019-11-12]. (原始內容存檔 (PDF)於2018-10-24).
- ^ 7.0 7.1 7.2 Hastie, T.; Tibshirani, R.; Friedman, J. H. 10. Boosting and Additive Trees. The Elements of Statistical Learning: Data Mining, Inference, and Prediction. 2nd. New York: Springer. 2009: 337–384. ISBN 978-0-387-84857-0. (原始內容存檔於2009-11-10).
- ^ 8.0 8.1 8.2 Ridgeway, Greg. Generalized Boosted Models: A guide to the gbm package (PDF). 2007. (原始內容存檔 (PDF)於2020-02-10).
- ^ Learn Gradient Boosting Algorithm for better predictions (with codes in R). [2019-11-12]. (原始內容存檔於2019-08-13).
- ^ Tianqi Chen. Introduction to Boosted Trees (頁面存檔備份,存於網際網路檔案館)
- ^ Cossock, David and Zhang, Tong (2008). Statistical Analysis of Bayes Optimal Subset Ranking 網際網路檔案館的存檔,存檔日期2010-08-07., page 14.
- ^ Yandex corporate blog entry about new ranking model "Snezhinsk" (頁面存檔備份,存於網際網路檔案館) (in Russian)
- ^ Friedman, Jerome. Multiple Additive Regression Trees with Application in Epidemiology. Statistics in Medicine. 2003, 22 (9): 1365–1381. PMID 12704603. doi:10.1002/sim.1501.
- ^ Elith, Jane. A working guide to boosted regression trees. Journal of Animal Ecology. 2008, 77 (4): 802–813. PMID 18397250. doi:10.1111/j.1365-2656.2008.01390.x.
- ^ Elith, Jane. Boosted Regression Trees for ecological modeling (PDF). CRAN. CRAN. [31 August 2018]. (原始內容存檔 (PDF)於2020-07-25).