推荐系统中的矩阵分解

在推荐场景中, 我们可以把useritem的行为, 用评分矩阵 R R | U | × | P | 表示.
U 为用户集合, P 为item集合, 以商品为例.
比如说用户u1对商品p1加购物车, 那就令 R u 1 , p 1 = 3 , 用户u1对商品p2做出购买行为, 那就令 R u 1 , p 2 = 5 .

问题定义

在真实场景中, 用户只会对部分item做出反馈, 所以矩阵是非常稀疏的.
推荐的task就是预测出用户可能感兴趣的未见商品.
我们假设用户喜欢某个商品是因为用户的特征偏好与该商品的特征能够吻合起来.
那这些特征是什么呢? 以音乐推荐为例, 见图1
这里写图片描述
figure 1 音乐推荐中, latent space 的一种假设

这些特征我们不必人为定义, 可以引入latent space的假定, 有 k 个潜在的特征.
用户对每个特征都有一个偏好程度, 用矩阵 Q 表示, 每个物品都有一个特征的吻合程度, 用 P 表示,所以我们的任务就是求出这两个矩阵, 然后对 R 进行补全, 找出得分高的未见商品推荐给用户.


figure 矩阵分解示意, R ^ = Q P T .

求解方法

(1) min Q , P u , i ( R u , i Q u P i T ) 2 + λ | | Q u | | 2 + λ | | P i | | 2

式1 为目标函数. 求解方法通常为 alternating least squares (ALS), 交替最小二乘法.

参考

  1. 网易云音乐的歌单推荐算法是怎样的? - nick lee的回答 - 知乎

猜你喜欢

转载自blog.csdn.net/chuchus/article/details/80911925