R语言CART决策树、随机森林、chaid树预测母婴电商平台用户寿命、流失可视化

简介: R语言CART决策树、随机森林、chaid树预测母婴电商平台用户寿命、流失可视化

用户获取和流失是一对相对概念,就好比一个水池,有进口,也有出口。我们不能只关心进口的进水速率,却忽略了出水口的出水速率。挽留一个老用户相比拉动一个新用户,在增加营业收入、产品周期维护方面都是有好处的。并且获得一个新用户的成本是留存一个老用户的5~6倍。

我们最近有一个很棒的机会与一位伟大的客户合作,要求构建一个适合他们需求的用户流失预测算法。本课题着眼于利用决策树算法和随机森林模型,对用户进行预测,判断哪些客户会流失。数据的处理方法以及机器学习本身算法理论的学习和代码实现在各领域具有相同性,之后同学可以在其他感兴趣的领域结合数据进行分析,利用此课题所学知识举一反三。


数据


查看可用数据源


用户名密码登陆


channel <- odbcConnect("sa", uid="sa", pwd="12345")


品牌表

data<-sqlQuery(channel,"select * from  DataMeet1$")
 
head(data)


input:品牌 品牌 奶粉阶段(对应小孩年龄) 城市等级(1,2,3线城市)


Output

用户寿命(天) 是否流失

head(data)

转换数据,拟合决策树模型


建立决策树预测是否流失

CARTmodel = rpart
draw.tree(CARTmodel)

点击标题查阅往期内容


数据分享|R语言决策树和随机森林分类电信公司用户流失churn数据和参数调优、ROC曲线可视化


01

02

03

04


绘制决策树


输出决策树cp值

printcp(CARTmodel)


根据cp值对决策树进行剪枝

cp= CARTmodel$cptable[which.min(CARTmodel$cptable[,"xerror"]),"CP"]
cp
prune(CARTmodel, cp= CARTmodel$cpCP"])  #剪枝

CARTmodel2 <- prune(CARTmo

对数据进行预测


(predict(CARTmodel2,datanew.test ))
summary(CARTmodel2)

计算混淆矩阵和准确度

tab=table(tree.pred,datanew.test$是否流失)#得到训练集混淆矩阵
(tab[1,1]+tab[2,2])/sum(tab)

mse


mean((as.numeric(tree.pred) - as.numeric(datanew.test$是否流失))^2)


输出结果


CARTmodel2

将表写进数据库里
sqlSave(channel,result_lossnew11,


变量重要程度


CARTmodel$varmportance

预测用户寿命.天.


CARTmodel = rpart(用户寿命.天. ~


绘制决策树


决策树是一种机器学习的方法。决策树的生成算法有ID3, C4.5和CART等。决策树是一种树形结构,其中每个内部节点表示一个属性上的判断,每个分支代表一个判断结果的输出,最后每个叶节点代表一种分类结果。


输出决策树cp值


根据cp值对决策树进行剪枝

prune(CARTmodel, cp= CARTmodel$cptab

prune(CARTmodel


进行预测


predict(CARTmodel


输出结果


#mse
mean((as.numeric(tree.pred) - as.numeric(datanew.test$用户寿命.天.))^2)
## [1] 7713.91


变量重要程度


随机森林


随机森林是属于集成学习,其核心思想就是集成多个弱分类器以达到三个臭皮匠赛过诸葛亮的效果。

rf <- randomForest(datanew.train$用户寿命.天.  ~


MSE误差


mean(predict(rf)- datanew.train$用户寿命.天.  )^2
## [1] 0.007107568


变量重要程度

plot(d,center=TRUE,leaflab='none',


混淆矩阵


table(predict(rf), datanew.train$是否流失  )
##    
##       0   1
##   0  84  15
##   1  23 589

#变量重要程度
importance(rf)

chaid树


CHAID是一种高效的统计分箱技术,是商业上运用最成功的算法之一。通过统计检验方法,CHAID评估潜在预测变量的所有取值,合并对目标变量而言在统计意义上同质的取值成为一个分箱,保留那些有异质性的取值为单独的分箱,然后选择最佳的预测,成为决策树的第一个分支,因此每一个子节点都是同质的,此过程继续递推直至完成整个决策树。

plot(ct, mai

ctree

是否流失

plot(ct,

混淆矩阵

table(predict(ct), datanew.train$是否流失)


##    
##       0   1
##   0  89   1
##   1  18 603


预测类别概率


tr.pred = predict(ct, newdata=datanew.train, type="prob")
tr.pred

将结果表写进数据库里
sqlSave(channel,resul
相关文章
|
3月前
|
数据可视化 数据挖掘 API
【R语言实战】聚类分析及可视化
【R语言实战】聚类分析及可视化
|
3月前
|
数据采集 数据可视化
利用R语言进行因子分析实战(数据+代码+可视化+详细分析)
利用R语言进行因子分析实战(数据+代码+可视化+详细分析)
|
3月前
|
Web App开发 数据可视化 数据挖掘
利用R语言进行聚类分析实战(数据+代码+可视化+详细分析)
利用R语言进行聚类分析实战(数据+代码+可视化+详细分析)
|
3月前
|
机器学习/深度学习 数据可视化
R语言Stan贝叶斯回归置信区间后验分布可视化模型检验|附数据代码
R语言Stan贝叶斯回归置信区间后验分布可视化模型检验|附数据代码
|
3月前
|
移动开发 数据可视化
广义线性模型beta二项分布的淋巴结疾病风险预测可视化R语言2实例合集|附数据代码
广义线性模型beta二项分布的淋巴结疾病风险预测可视化R语言2实例合集|附数据代码
|
3月前
|
机器学习/深度学习 数据可视化
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为2
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为
|
4天前
|
机器学习/深度学习 数据采集
R语言逻辑回归、GAM、LDA、KNN、PCA主成分分类分析预测房价及交叉验证
上述介绍仅为简要概述,每个模型在实施时都需要仔细调整与优化。为了实现高度精确的预测,模型选择与调参是至关重要的步骤,并且交叉验证是提升模型稳健性的有效途径。在真实世界的房价预测问题中,可能还需要结合地域经济、市场趋势等宏观因素进行综合分析。
12 3
|
3月前
利用R语言进行典型相关分析实战
利用R语言进行典型相关分析实战
|
3月前
|
机器学习/深度学习 算法
R语言分类回归分析考研热现象分析与考研意愿价值变现
R语言分类回归分析考研热现象分析与考研意愿价值变现
|
3月前
|
数据可视化 定位技术
R语言贝叶斯INLA空间自相关、混合效应、季节空间模型、SPDE、时空分析野生动物数据可视化
R语言贝叶斯INLA空间自相关、混合效应、季节空间模型、SPDE、时空分析野生动物数据可视化

热门文章

最新文章