如何利用隐语义模型在图数据库中构建推荐系统
什么是推荐系统?
推荐系统是基于现有数据来预测个人选择偏好的任意评分系统。推荐系统被用于视频流、在线购物以及社交媒体等各种服务。通常情况下,系统会根据用户对某件商品评分的预测来进行推荐。推荐系统可以分为两个方面,即利用信息和预测模型。
图 1(图片由作者提供)。这个示例数据集包括两个用户:爱丽丝和鲍勃,两部电影:玩具总动员和钢铁侠,还有三个评分记录(实线部分)。每个用户和电影都用它们的属性作为标签。
内容过滤 vs 协同过滤
内容过滤和协同过滤是最主要的两种推荐方法,它们的区别是预测时所需的信息有所不同。图一显示了一组电影评分数据和一些针对用户和电影的标签。注意,这里的用户对电影的评分数据从图结构中获得:用户和电影是图的顶点,评分是图的边。在本例中,内容过滤方法利用电影和用户的标签属性。通过查询标签,我们得知爱丽丝是漫威电影的超级粉丝,而《钢铁侠》是一部漫威电影,因此《钢铁侠》系列对她来说是一个很好的推荐。内容过滤评分系统的一个具体例子是 TF-IDF,它用于对文档搜索进行排序。
用户和电影的标签可能并不总是可用的。当标签数据比较稀疏的时候,内容过滤的方法可能就不可靠了。另一方面,协同过滤的方法主要依赖用户行为数据(如评分记录或电影观看历史)。在上面的例子中,爱丽丝和鲍勃都很喜欢玩具总动员这部电影,他们分别给电影打了 5 分和 4.5 分。根据这些评分记录,可以判断这两个用户可能有相似的偏好。现在考虑到鲍勃喜欢钢铁侠,我们预测爱丽丝也会有类似的行为,并向爱丽丝推荐钢铁侠 。K-近邻算法(KNN)是一种典型的协同过滤方法。然而,协同过滤有所谓的冷启动问题 —— 无法为没有评分记录的用户提供推荐。
基于记忆 vs 基于模型
根据显式或隐式使用特征,推荐系统也可以分为基于记忆和基于模型的方法。在上述例子中,所有用户和电影的特征都被明确的给出,这使得我们可以基于电影和用户的标签直接匹配。但有时需要深度学习模型从用户和电影信息中提取隐含特征(例如,根据电影的大纲对其分类的 NLP 模型)。基于模型的推荐系统利用机器学习模型来进行预测,而基于记忆的推荐系统主要利用显式特征。
下面是不同类型推荐系统的一些典型用例:
因子分解在推荐系统中是如何工作的
如上所述,协同过滤方法,例如 KNN,可以在不知道用户属性和电影属性的情况下预测电影评分。然而,当评分数据稀疏的时候,即特定用户只评分了几部电影时,这种方法可能不会产生准确的预测结果。在图 1 中,如果鲍勃没有对《玩具总动员》评分,KNN 就无法预测爱丽丝对《钢铁侠》的评分,因为爱丽丝和鲍勃之间没有联系,爱丽丝本身也没有邻居。为了解决这个挑战,因子分解结合了基于模型的方法和协同过滤的方法,以此来提高评分记录稀疏时预测的准确性。
图 2 说明了因子分解方法的直观性。因子分解也被称为隐语义或者矩阵因子分解方法。目标是为每一个用户和电影都获取一个向量,该向量表示了它们的潜在特征。在这个例子中(图 2),向量的维数被指定为 2。电影向量 的两个元素代表该电影的浪漫程度和动作内容,用户向量 的两个元素分别表示用户对浪漫和动作内容的偏好程度。用户 对电影 的评分预测是 和 的点积,正如我们所期待的那样,这两个向量越对齐,代表着用户越喜欢这部电影。
图 2 中的例子仅仅是说明了因子分解方法的直观性。在实践中,每个向量元素的含义通常是未知的。这些向量实际上是随机初始化的,并通过最小化以下的的损失函数来“训练”[1]。
其中 表示评分记录的数量, 表示隐语义向量的维度, 是用户 对电影 的评分, 是正则因子。第一项实质上是预测的平方误差( 和 对 的和),第二项是正则化以避免过拟合。损失函数的第一项也可以用矩阵的形式表达,
其中, 是以 为元素的评分矩阵, 和 分别是用户和电影的隐语义向量组成的矩阵。最小化预测的平方差等价于最小化 的 Frobenius 范式。因此,这种方法也叫矩阵分解方法。
你可能想知道为什么我们称这种方法为因子分解法。正如之前讨论的那样,评分矩阵 很有可能是一个稀疏矩阵,因为并非所有的用户都会对所有的电影进行评分。基于存储效率考虑,这些稀疏矩阵通常以图的形式储存,其中每个顶点代表一位用户或者一部电影,每条边表示一条评分记录,边的权重表示评分的高低。如下图所示,通过优化损失函数进而获取隐语义向量的梯度下降算法也可以表示为图算法。
可以将 和 的偏导表示如下:
上面的公式表明,一个隐向量在一个顶点上的偏导数只依赖于它的边和邻居顶点。对于我们的例子,用户向量的偏导数仅由用户之前评分过电影的隐向量和对该电影的评分所决定。这个属性使得我们可以将评分数据存储于图中(如图 5 所示),并且使用图算法来获取电影和用户之间的隐语义向量。用户和电影特征可以通过如下步骤获取。
值得一提的是计算导数以及更新隐语义向量可以在 Map-Reduce 框架下完成,第二步可以对每条边 (即评分)并行执行,第三步也可以对每个顶点 (即用户或者电影)并行执行。
为什么推荐需要使用图数据库
对于工业应用,数据库可以容纳上亿用户和电影以及数十亿的评分记录,这意味着评分矩阵 ,特性矩阵 和 加上其他中间变量在模型训练的时候会消耗以 TB 为单位的内存。这些问题可以通过在图数据库中训练潜特征来解决,这些评分图可以分布在一个多节点集群中,其中部分存储在磁盘上。此外,首选将图结构的用户(即评分记录)存储于数据库管理系统中,在数据库内训练模型避免了将图数据从数据库管理系统迁移到机器学习平台,从而可以在训练数据不断演化的情况下更好的继续支持对模型的更新。
如何在 TigerGraph 中构建一个推荐系统
这部分,我们在 TigerGraph 云提供的一个免费图数据库上,加载一个电影评分的图,然后在数据库中训练推荐模型。按照下面的步骤,只需 15 分钟,你就能拥有一个电影推荐系统。
参考创建你的第一个 TigerGraph 实例(其中的前三步),在 TigerGraph 云上创建一个免费的实例。步骤一中,选择In-Database Machine Learning Recommendation作为入门工具包。步骤三中选择 TG.Free。
参考文章开始使用 TigerGraph 云入门版,登录到 GraphStudio。在映射数据到图的 页面,你将明白数据文件是如何映射到图结构上的,在入门工具包中,MovieLens-100K 文件已经上传至实例中。MovieLens-100K 数据集有两个文件:
- movieList.csv 文件有两列,分别是每部电影的 id 和名字(电影年份)。
- rating.csv 文件是用户对电影的评分列表。总共有三列,分别代表用户 id、电影 id 和评分。
进入 Load Data 页面,然后点击 Start/Resume loading 按钮。在数据集加载完毕之后,你能在右边看到图的数据统计。MovieLens-100K 数据集包含来自 944 位用户对 1682 部电影的 100011 条评分记录。
加载完成后,你你能在右边看到图的统计数据。在 Explore Graph 页面,你能看到我们刚刚创建的二部图,每个用户和电影的信息都存储在顶点中,评分记录存储在边上。
在 Write Queries 页面,你将会发现推荐系统所需要的查询指令已经添加到数据库中。这些查询语句是使用 TigerGraph 查询语言 GSQL 编写的。点击 Install all queries 将所有的 GSQL 语句编译成 C++ 代码。你还可以在这个页面看到一个 README 指令。参考下面的步骤来使用这些电影评分记录构建一个推荐系统。
执行分割数据指令
该查询指令将评分数据分为验证集和测试集。测试数据的比例默认为 30%(也就是 30% 的评分数据将被用于验证模型,剩下的 70% 将被用于训练模型)。该查询指令还会输出总数据集、验证数据集和训练数据集的大小。
执行归一化指令
该查询指令通过将每条评分减去该电影的平均评分来进行归一化,每部电影的平均分通过训练集计算得出。
执行初始化指令
该指令初始化用户和电影的隐语义向量。隐语义向量中的元素通过一个正态分布的随机数发生器初始化。该指令的输入是正态分布的标准差和平均值。
执行训练指令
该指令使用梯度下降算法训练推荐模型。默认情况下特征的数量设置为 19。这个数量必须与初始化指令中隐语义向量的维度一致。指令的输入为学习率、正则化因子以及训练迭代的次数。查询输出为每次迭代的均方根误差(RMSE)。
在隐语义向量计算出来后,我们就可以测试并使用该模型进行推荐了。
执行测试指令
这个查询指令输出用户提供的真实评分数据以及模型的预测评分。该查询指令的输入是用户 id,而输出是该用户的所有评分以及预测评分。
执行推荐指令
该查询指令会输出对用户 top-10 推荐的电影。电影被推荐的参考是预测的评分。
总结
在图数据库中训练机器学习模型,这种方案在实现推荐模型的实时更新方面很有潜力。这篇文章,我们介绍了因子分解方法的机制,展示了如何使用 TigerGraph 云服务一步一步的构建你的电影推荐系统。当你熟悉了这个例子后,你应该就有信心根据你的使用情况来定制一个推荐系统了。
参考文献
[1] Ahmed, Amr, et al. “Distributed large-scale natural graph factorization” Proceedings of the 22nd international conference on World Wide Web (WWW 2013)
如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。
掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。