如何用ALS算法实现用户音乐打分预测

发布时间:2021-12-18 17:38:26 作者:柒染
来源:亿速云 阅读:155

如何用ALS算法实现用户音乐打分预测,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

ALS算法介绍

ALS算法是基于模型的推荐算法,基本思想是对稀疏矩阵进行模型分解,评估出缺失项的值,以此来得到一个基本的训练模型。然后依照此模型可以针对新的用户和物品数据进行评估。ALS是采用交替的最小二乘法来算出缺失项的,交替的最小二乘法是在最小二乘法的基础上发展而来的。

从协同过滤的分类来说,ALS算法属于User-Item CF,也叫做混合CF,它同时考虑了User和Item两个方面。

我们通过音乐打分这个案例介绍下交替最小二乘法的原理,首先拿到的原始数据是每个听众对每首歌的评分矩阵A,这个评分可能是非常稀疏的,因为不是每个用户都听过所有的歌,也不是每个用户都会对每首歌评分。

如何用ALS算法实现用户音乐打分预测

ALS矩阵分解会把矩阵A分解成两个矩阵的相乘,分别是X矩阵和Y矩阵,

矩阵A=矩阵X和矩阵Y的转秩的乘积

x的列表示和Y的横表示可以称之为ALS中的因子,这个因子是有隐含定义的,这里假设有3个因子,分别是性格、教育程度、爱好。A矩阵经过ALS分解出的X、Y矩阵可以分别表示成:

如何用ALS算法实现用户音乐打分预测

(上图为x矩阵)

如何用ALS算法实现用户音乐打分预测

(上图为Y矩阵)

数据经过这样的拆解就很容易做用户对音乐的评分预测。比如有听众6,他从没听过“红豆“这首歌,但是我们可以拿到听众6在矩阵分解中X矩阵的向量M,这时候只有把向量M和”红豆“在Y矩阵中的对应向量N相乘,就能预测出听众6对于”红豆“这首歌的评分。

ALS在PAI实验

现在在PAI上面对ALS算法案例进行实验。整体流程只需要包含输入数据源和ALS矩阵分解组件即可。本案例已经集成于PAI-STUDIO首页模板:

如何用ALS算法实现用户音乐打分预测

创建后如图:

如何用ALS算法实现用户音乐打分预测

1.数据源

输入数据源包含4个字段

如何用ALS算法实现用户音乐打分预测

2.ALS矩阵分解

需要设置3个对应字段,

如何用ALS算法实现用户音乐打分预测

参数名称参数描述取值范围是否必选,默认值
userColNameuser列名列的类型必须是bigint,可以不连续编号必选
itemColNameitem列名列的类型必须是bigint,可以不连续编号必选
rateColName打分列名列的类型必须是数值类型必选
numFactors因子数正整数可选,默认值100
numIter迭代数正整数可选,默认值10
lambda正则化系数浮点数可选,默认值0.1
implicitPref是否采用隐式偏好模型布尔型可选,默认值false
alpha隐式偏好系数浮点数,大于0可选,默认值40

3.结果分析

本案例中会输出2张表,对应ALS算法介绍中说的X矩阵和Y矩阵。

X矩阵表如图:

如何用ALS算法实现用户音乐打分预测

Y矩阵表如图:

如何用ALS算法实现用户音乐打分预测

比如要预测user1对音乐item994556636的评分,只要将下方两个向量相乘即可

看完上述内容,你们掌握如何用ALS算法实现用户音乐打分预测的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

推荐阅读:
  1. elasticsearch 打分插件
  2. elasticsearch 打分精度

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

als

上一篇:如何进行Spring源码剖析AOP实现原理

下一篇:如何进行springboot配置templates直接访问的实现

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》