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

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

时间:2024-05-17 23:30:31浏览次数:27  
标签:CARTmodel cp ## chaid 用户 CART 流失 电商 决策树

全文链接:http://tecdat.cn/?p=31644

原文出处:拓端数据部落公众号

借着二胎政策的开放与家庭消费升级的东风,母婴市场迎来了生机盎然的春天,尤其是母婴电商行业,近年来发展迅猛。用户获取和流失是一对相对概念,就好比一个水池,有进口,也有出口。我们不能只关心进口的进水速率,却忽略了出水口的出水速率。挽留一个老用户相比拉动一个新用户,在增加营业收入、产品周期维护方面都是有好处的。并且获得一个新用户的成本是留存一个老用户的5~6倍。

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

数据

image.png

   
查看可用数据源

image.png

用户名密码登陆

   

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

品牌表

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

image.png

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

Output

用户寿命(天) 是否流失

   
head(data)

image.png

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

建立决策树预测是否流失

   
CARTmodel = rpart
draw.tree(CARTmodel) 

image.png

绘制决策树

输出决策树cp值

   
printcp(CARTmodel)

image.png

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

   
cp= CARTmodel$cptable[which.min(CARTmodel$cptable[,"xerror"]),"CP"]
cp

prune(CARTmodel, cp= CARTmodel$cpCP"])  #剪枝

image.png

   

CARTmodel2 <- prune(CARTmo

image.png

对数据进行预测

   
(predict(CARTmodel2,datanew.test ))

summary(CARTmodel2)

image.png

计算混淆矩阵和准确度

   
tab=table(tree.pred,datanew.test$是否流失)#得到训练集混淆矩阵

(tab[1,1]+tab[2,2])/sum(tab)

image.png

mse

   

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

image.png

输出结果

   
CARTmodel2 

image.png

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

变量重要程度

   
CARTmodel$varmportance

image.png

预测用户寿命.天.

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

image.png

绘制决策树

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

输出决策树cp值

image.png

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

   
prune(CARTmodel, cp= CARTmodel$cptab

image.png

   
prune(CARTmodel

image.png

进行预测

   
predict(CARTmodel

image.png

输出结果

image.png

   
#mse

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

变量重要程度

image.png

随机森林

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

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

MSE误差

   

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

image.png

变量重要程度

image.png

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

image.png

混淆矩阵

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

image.png

   
#变量重要程度
importance(rf)

image.png

image.png

chaid树

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

image.png

   
plot(ct, mai

下载.png

image.png

ctree

是否流失

image.png

   
plot(ct,

image.png

混淆矩阵

   
table(predict(ct), datanew.train$是否流失)
   
##    
##       0   1
##   0  89   1
##   1  18 603

预测类别概率

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

image.png

   
将结果表写进数据库里
sqlSave(channel,resul

the-secret-to-great-health-1339038575-thumb-1536x1536.webp

最受欢迎的见解

1.PYTHON用户流失数据挖掘:建立逻辑回归、XGBOOST、随机森林、决策树、支持向量机、朴素贝叶斯模型和KMEANS聚类用户画像

2.R语言基于树的方法:决策树,随机森林

3.python中使用scikit-learn和pandas决策树

4.机器学习:在SAS中运行随机森林数据分析报告

5.R语言用随机森林和文本挖掘提高航空公司客户满意度

6.机器学习助推快时尚精准销售时间序列

7.用机器学习识别不断变化的股市状况——隐马尔可夫模型的应用

8.python机器学习:推荐系统实现(以矩阵分解来协同过滤)

9.python中用pytorch机器学习分类预测银行客户流失

标签:CARTmodel,cp,##,chaid,用户,CART,流失,电商,决策树
From: https://www.cnblogs.com/tecdat/p/18198891

相关文章

  • PPO-KL散度近端策略优化玩cartpole游戏
     其实KL散度在这个游戏里的作用不大,游戏的action比较简单,不像LM里的action是一个很大的向量,可以直接用surr1,最大化surr1,实验测试确实是这样,而且KL的系数不能给太大,否则惩罚力度太大,actionmodel和refmodel产生的action其实分布的差距并不太大 importgymimporttorchimp......
  • PPO近端策略优化玩cartpole游戏
     这个难度有些大,有两个policy,一个负责更新策略,另一个负责提供数据,实际这两个policy是一个东西,用policy1跑出一组数据给新的policy2训练,然后policy2跑数据给新的policy3训练,,,,直到policy(N-1)跑数据给新的policyN训练,过程感觉和DQN比较像,但是模型是actorcritic架构,on-policy转换成o......
  • 电商数仓—表
    0各表同步策略   1后台管理系统1.1商品1.1.1sku_info商品信息表字段名字段说明id商品库存id(itemlID)spu_id商品idprice价格sku_namesku名称sku_desc商品规格描述weight重量tm_id品牌(冗余)category3_id三级分类id(冗余)sku_......
  • DQN玩cartpole游戏
    importgymimporttorchimporttorch.nnasnnimporttorch.optimasoptimimportrandomimportpygameimportsysfromcollectionsimportdeque#定义DQN模型classDQN(nn.Module):def__init__(self):super(DQN,self).__init__()self.netwo......
  • 策略梯度玩 cartpole 游戏,强化学习代替PID算法控制平衡杆
     cartpole游戏,车上顶着一个自由摆动的杆子,实现杆子的平衡,杆子每次倒向一端车就开始移动让杆子保持动态直立的状态,策略函数使用一个两层的简单神经网络,输入状态有4个,车位置,车速度,杆角度,杆速度,输出action为左移动或右移动,输入状态发现至少要给3个才能稳定一会儿,给2个完全学不明白,......
  • 02-大厂电商设计解析之商品管理系统
    1雪花算法使用IdWorkeridWorker=newIdWorker(1,1);for(inti=0;i<10000;i++){longid=idWorker.nextId();System.out.println(id);}配置分布式ID生成器将IdWorker.java拷贝到util包在工程的resources下新增applicationContext-service.xml<!‐‐雪花ID生......
  • 01-电商商品中心解密:仅凭SKU真的足够吗?
    在电子商务系统中,SKU(StockKeepingUnit,库存单位)和SPU(StandardProductUnit,标准产品单位)是两种不同的概念,它们共同用于商品管理和库存控制。虽然理论上可以只使用SKU来管理商品,但在实际应用中,同时使用SPU和SKU有其明显的优势和必要性。SKU(库存单位)SKU是商品的具体型号或款式,每......
  • 【Python】Q-Learning处理CartPole-v1
    上一篇配置成功gym环境后,就可以利用该环境做强化学习仿真了。这里首先用之前学习过的qlearning来处理CartPole-v1模型。CartPole-v1是一个倒立摆模型,目标是通过左右移动滑块保证倒立杆能够尽可能长时间倒立,最长步骤为500步。模型控制量是左0、右1两个。模型状态量为下面四个:......
  • 生成带重复的笛卡尔乘积过程 Cartesian Product with Repetition
    目录WhatisCartesianProductwithRepetitionCodeDemoWhatisCartesianProductwithRepetition比如说有两个集合:\(\{1,2,3\}\)\(\{A,B,C\}\)想把他们组合成所有可能组合,比如,1AAA1AAB1AAC...这种组合可以称为"有重复的笛卡尔积"或"带重复的笛卡尔乘积"(Carte......
  • 实验一原型设计————电商系统
    一、实验题目:原型设计二、实验目的:掌握产品原型设计方法和相应工具使用。三、实验要求(1)对比分析墨刀、Axure、Mockplus等原型设计工具的各自的适用领域及优缺点(至少3条)。1.墨刀:适用领域:产品设计,项目管理,可以利用墨刀绘制流程图,明确项目流程和时间节点,提高项目执行效率。优......