在推荐场景中, 我们可以把user
对item
的行为, 用评分矩阵
表示.
为用户集合,
为item集合, 以商品为例.
比如说用户u1对商品p1加购物车, 那就令
, 用户u1对商品p2做出购买行为, 那就令
.
问题定义
在真实场景中, 用户只会对部分item做出反馈, 所以矩阵是非常稀疏的.
推荐的task就是预测出用户可能感兴趣的未见商品.
我们假设用户喜欢某个商品是因为用户的特征偏好与该商品的特征能够吻合起来.
那这些特征是什么呢? 以音乐推荐为例, 见图1
figure 1 音乐推荐中, latent space 的一种假设
这些特征我们不必人为定义, 可以引入latent space
的假定, 有
个潜在的特征.
用户对每个特征都有一个偏好程度, 用矩阵
表示, 每个物品都有一个特征的吻合程度, 用
表示,所以我们的任务就是求出这两个矩阵, 然后对
进行补全, 找出得分高的未见商品推荐给用户.
figure 矩阵分解示意,
.
求解方法
式1 为目标函数. 求解方法通常为 alternating least squares (ALS), 交替最小二乘法.