
R語言使用boosting方法對數據分類與交叉驗證
數據分類說明
與bagging方法類似,boosting算法也是先獲得簡單的分類器,然后通過調整錯分樣本的權重逐步改進分類器,使得后續分類器能夠學習前一輪分類器,adabag實現了AdaBoost.M1和SAMME兩個算法,因此用戶能夠使用adabag包實施集成學習。
數據分類操作
導入包
library(rpart)
library(adabag)
調用adabag包的boosting函數分類器:
churn.boost = boosting(churn ~ .,data = trainset,mfinal = 10,coeflearn = "Freund",boos = FALSE,control = rpart.control(maxdepth = 3))
使用boosting訓練模型對測試數據集進行分類預測:
churn.boost.pred = predict.boosting(churn.boost,newdata = testset)
基于預測結果生成分類表:
churn.boost.pred$confusion
Observed Class
Predicted Class yes no
no 41 858
yes 100 19
根據分類結果計算平均誤差:
churn.boost.pred$error
[1] 0.0589391
數據分類原理
boosting算法的思想是通過對弱分類器(單一決策樹)的“逐步優化”,使之成為強分類器。假定當前在訓練集中存在n個點,對其權重分別賦值Wj(0<= j < n),在迭代的學習過程中(假定迭代次數為m),我們將根據每次迭代的分類結果,不斷調整這些點的權重,如果當前這些點分類是正確的,則調低其權值,否則,增加樣例點的權值。這樣,當整個迭代過程結束時,算法將得到m個合適的模型,最終,通過對每棵決策樹加權平均得到最后的預測結果,權值b由每棵決策樹的分類質量決定。
bagging和boosting都采用了集成學習的思想,即將多個弱分類器組成強分類器,兩者的不同在于,bagging是組合獨立的模型,而boosting則通過在迭代的過程學習的過程中盡可能用正確的分類模型來降低預測誤差。與bagging類似,用戶也需要指定用于分類的模型的公式與分類數據集,用戶還要自己指定諸如迭代次數(mfinal),權重更新系數(coeflearn)、觀測值權重(boos)以及rpart的控制方法(單一決策樹)等參數,本例中迭代次數為設置為10,采用Freund(AdaBoost.M1算法實現的方法)作為系數(coeflearn),設置boos的值是“false”,最大深度為3。
交叉驗證說明
adabag包支持對boosting方法的交叉驗證,該功能可以通過boosting.cv實現。
交叉驗證操作
獲得boosting方法交叉驗證后的最小估計錯誤:
調用boosting.cv對訓練數據集實施交叉驗證:
churn.boost.cv = boosting.cv(churn ~ .,v = 10,data = trainset,mfinal = 5,control=rpart.control(cp = 0.01))
從boosting結果生成混淆矩陣
churn.boost.cv$confusion
Observed Class
Predicted Class yes no
no 103 1936
yes 239 37
得到boosting的平均誤差:
churn.boost.cv$error
[1] 0.06047516
交叉驗證原理
函數參數v值設置為10,mfinal的值設置為5,boosting算法會執行一個5次迭代的10折交叉驗證,另外可以設置參數進行rpart的匹配控制。我們將復雜度參數設置為0.01。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25