R语言进行集成学习算法:随机森林
创始人
2024-12-27 01:35:58
0
# 10.4 集成学习及随机森林 # 导入car数据集 car <- read.table("data/car.data",sep = ",") # 对变量重命名 colnames(car) <- c("buy","main","doors","capacity",                    "lug_boot","safety","accept") # 随机选取75%的数据作为训练集建立模型,25%的数据作为测试集用来验证模型 library(caret) library(ggplot2) library(lattice) # 构建训练集的下标集 ind <- createDataPartition(car$accept,times=1,p=0.75,list=FALSE)  # 构建测试集数据好训练集数据 carTR <- car[ind,] carTE <- car[-ind,] carTR<- within(carTR,accept <- factor(accept,levels=c("unacc","acc","good","vgood"))) carTE<- within(carTE,accept <- factor(accept,levels=c("unacc","acc","good","vgood")))   # 使用adabag包中的bagging函数实现bagging算法 #install.packages("adabag") library(adabag) bagging.model <- bagging(accept~.,data=carTR)  # 使用adabag包中的boosting函数实现boosting算法 boosting.model <- boosting(accept~.,data=carTR)  # 使用randomForest包中的randomForest函数实现随机森林算法 #install.packages("randomForest") library(randomForest) randomForest.model <- randomForest(accept~.,data=carTR,ntree=500,mtry=3)  # 预测结果,并构建混淆矩阵,查看准确率 # 构建result,存放预测结果 result <- data.frame(arithmetic=c("bagging","boosting","随机森林"),                      errTR=rep(0,3),errTE=rep(0,3)) for(i in 1:3){   # 预测结果   carTR_predict <- predict(switch(i,bagging.model,boosting.model,randomForest.model),                            newdata=carTR) # 训练集数据   carTE_predict <- predict(switch(i,bagging.model,boosting.model,randomForest.model),                            newdata=carTE) # 测试集数据   # 构建混淆矩阵   tableTR <- table(actual=carTR$accept,                    predict=switch(i,carTR_predict$class,carTR_predict$class,carTR_predict))   tableTE <- table(actual=carTE$accept,                    predict=switch(i,carTE_predict$class,carTE_predict$class,carTE_predict))   # 计算误差率   result[i,2] <- paste0(round((sum(tableTR)-sum(diag(tableTR)))*100/sum(tableTR),                               2),"%")   result[i,3] <- paste0(round((sum(tableTE)-sum(diag(tableTE)))*100/sum(tableTE),                               2),"%") } # 查看结果 result 

相关内容

热门资讯

9分钟辅助!扑克之星辅助,we... 9分钟辅助!扑克之星辅助,wepoker透视有吗(有挂详细)-哔哩哔哩1、进入游戏-大厅左侧-新手福...
技法辅助!免费吉祥填大坑有插件... 技法辅助!免费吉祥填大坑有插件吗(辅助)总是真的有辅助神器(哔哩哔哩)1、上手简单,内置详细流程视频...
绝活辅助!山西扣点点辅助下载(... 绝活辅助!山西扣点点辅助下载(辅助)本来是真的有辅助工具(哔哩哔哩)1)山西扣点点辅助下载辅助插件:...
十分钟辅助!wepoker看底... 十分钟辅助!wepoker看底牌,hhpoker有后台操控吗(有挂秘籍)-哔哩哔哩一、hhpoker...
模块辅助!新圣游脚本下载(辅助... 模块辅助!新圣游脚本下载(辅助)一贯真的有辅助教程(哔哩哔哩)1、点击下载安装,新圣游脚本下载脚本分...
一分钟辅助!wepoker破解... 一分钟辅助!wepoker破解版内购,sohoo竞技联盟辅助器(有挂规律)-哔哩哔哩一、sohoo竞...
攻略辅助!吉祥填大坑怎么用插件... 攻略辅助!吉祥填大坑怎么用插件(辅助)好像真的有辅助插件(哔哩哔哩)1、吉祥填大坑怎么用插件公共底牌...
四分钟辅助!fishpoker... 四分钟辅助!fishpoker透视,pokemmo手机版脚本免费(详细教程)-哔哩哔哩1、点击下载安...
步骤辅助!小闲川南宜宾辅助(辅... 步骤辅助!小闲川南宜宾辅助(辅助)总是有辅助技巧(哔哩哔哩)1、玩家可以在小闲川南宜宾辅助透视最简单...
第四分钟辅助!hhpoker有... 第四分钟辅助!hhpoker有没有辅助,德州之星扫描器(有挂教程)-哔哩哔哩运hhpoker有没有辅...