楼主: CDA网校
974 0

[数据挖掘新闻] R语言函数报错继续执行方法——CDA人工智能学院 [推广有奖]

管理员

大师

64%

还不是VIP/贵宾

-

威望
3
论坛币
33543 个
通用积分
3105.4819
学术水平
260 点
热心指数
268 点
信用等级
235 点
经验
195577 点
帖子
5156
精华
19
在线时间
3714 小时
注册时间
2019-9-13
最后登录
2024-5-23

初级热心勋章

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
CDA人工智能学院致力于以优质的人工智能在线教育资源助力学员的DT职业梦想!课程内容涵盖数据分析机器学习深度学习人工智能tensorFlowPyTorch、知识图谱等众多核心技术及行业案例,让每一个学员都可以在线灵活学习,快速掌握AI时代的前沿技术。PS:私信我即可获取CDA会员1个月免费试听机会

今天我把这些问题的细节做了一些改善,重新做了模型,发觉模型结果比我预想中的要棒!!主要修改如下:

1、将邻居矩阵从2维扩充为35维;(据我测算,一般为整个数据集中用户数的5%最佳,50维出现了一些空值)

2、将欧氏距离上限标准化去掉,这样能更有效的匹配到相似度更高的用户。

后续在执行推荐算法的过程中发现,一个一个计算每一个用户的推荐产品太傻,我需要来一个循环语句来执行推荐算法!

过程中主要问题如下:

1、并不是所有用户都有相似用户,在执行语句中会报错——这里我需要一个语句能识别报错并跳过继续执行;

2、如何把所有执行的结果放入一个矩阵,并且识别是哪一个用户——这里需要一个空矩阵将用户ID和结果装入。

最终代码编写如下:

#组建初始化空矩阵

R<-matrix(0,9,1)  

#循环运行推荐程序并将结果并入到空矩阵
for (i in 1:nrow(S))

#循环执行推荐程序
    try({

#将ID放到结果之前
      R1=cbind(c(rep(i,3),UserBasedRecommender(i,RECOMMENDER_NUM,M,S,N)))

#将ID和结果一起并入空矩阵
      R<-cbind(R,R1)
    }
    ,silent = T)

#删除结果矩阵1,2行以及第一列
c<-R[-1,-1][-1,]


write.csv(c,file = 'hnjbtj1.csv')

结果如下:




扫码关注CDA公众号,即可获取最新版数据分析题库大全CDA免费精品课70+


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:人工智能 R语言 CDA Tensor 推荐算法

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-24 09:56