-->

AI内参_67_064_高级推荐模型之一张量分解模型

你好,我是洪亮杰。

今天我和你分享的主题是高级推荐模型之一,张量分解模型。

上周我们分享了推荐系统中矩阵分解的点点滴滴,简单复习一下讨论过的三个模型。

第一,基于隐变量的矩阵分解,其优势是显示的对用户和物品信息中的隐含结构进行建模,从而能够挖掘更加深层次的用户和物品关系。

第二,基于回归的隐变量模型,这是在基本的矩阵分解基础上衍生出来的一类模型。

这种基于回归的矩阵分解模型,把显示特性和隐变量结合起来,对解决冷启动问题有一定作用。

第三,分解机是由基于回归的隐变量模型衍生出来的,并且吸纳了基于信息的推荐系统的一些观点,成为了一种可以融合多种信息的强有力的工具。

这周我们跟随着这个脚步,进一步来讨论一些比较高级的模型,看这些模型如何抓住更多的用户和物品之间的关系。

今天我们先来聊一种叫做张量分解的模型。

为什么需要张量分解呢?在探讨张量分解的一些基本思想之前,我们先来看一看推荐系统在什么场景下需要张量分解,我们还是要从矩阵分解说起。

矩阵分解的核心思想是用矩阵这种数据结构来表达用户和物品的相互关系。

这里我们一般谈论的都是一些最简单的关系,例如评分,点击购买等。

在今天的内容里,我们依然只是讨论评分。

在这种二元的模式下,矩阵就是最好的表达用户和物品之间关系的数据结构。

然而,在真实的场景中,用户和物品的关系以及产生这种关系的周围环境是复杂的一种矩阵,并不能完全描述所有的变量。

例如,用户对于某个物品的评分是发生在某个地点、某个时间段内的,这种所谓的上下文关系,往往会对评分产生很大的影响。

遗憾的是一个矩阵,无法捕捉这样的上下文关系。

我们之前讨论过的基于回归的矩阵分解和分解机,本质上都是在某种程度上绕开这个问题,采用的方法就是依然用矩阵来表达二元关系。

但是把其他信息放进隐变量中,理论是采用基于信息的推荐系统的思路来得到相关信息的建模。

除了这种思路,还有没有别的办法可以把上下文关系融入到对用户和物品的建模中去呢?这时张量就该上场了。

从本质上说,张量就是矩阵的推广。

我们可以这么理解,矩阵是对二维关系建模的一种工具。

而张量就是对n维关系的一种建模。

在二维关系中,用户和物品的评分是唯一能够被建模的变量。

而到了n维关系中,理论上我们可以对任意多种上下文关系进行建模。

比如我们刚才提到的时间就可以组成一个三维的张量,分别为用户物品和时间。

然后在这个三维的张量中,每一个单元代表着某一个用户,对于某一个物品,在某一个时间段的评分,我们已经讲了张量的作用。

那么如何使用张量来进行推荐模型的建模呢?我们还是用刚才所说的用户物品和时间作为例子。

在这个三维的张量里,每一个元素代表的是用户对于物品在某个时间段上的评分。

那么根据矩阵分解的思路,我们怎么来对这个张量进行分解呢?遗憾的是,张量的分解要比矩阵分解更为复杂。

与矩阵分解不同,张量分解至少有两种不同的形式,这两种形式会引导出不同的分解模型和算法。

第一种分解模式叫CP分解。

拿我们刚才所说的三维张量来讲,CP分解是把一个三维张量分解为三个矩阵。

具体来说,比如我们的三维张量是n维用户乘以m维的物品乘以二维的时间段。

那么分解出来的三个矩阵就分分别为n维乘以k维的用户矩阵,m维乘以k维的物品矩阵,以及二维乘以k维的时间矩阵。

这三个矩阵中的每一个向量,都代表某一个用户,某一个物品和某一个时间段。

K在这里是一个参数,类似于矩阵分解中的隐变量的维度。

我们也就可以把这个k理解成为隐变量的维度。

那么在原始的三维张量中,某一个元素就是这三个矩阵的某三个向量对应元素乘积相加的结果。

Cp分解的一大好处就是分解出来的三个矩阵的隐变量维度是一样的,这就减少了需要调整的参数的个数。

第二种分解模式叫做HOSVD分解,这种分解和CP分解最大的不同就是分解出来的三个矩阵的维度不再一样。

也就是说,在我们之前的例子中,用户矩阵的维度可以是n乘以a物品,矩阵的维度是m乘以b时间段,矩阵的维度是r乘以c当然这样就无法还原之前的n乘以m乘以r的三维张量了。

于是在技术上还需要乘以一个a乘以b乘以c的小张量,才能对原始数据进行复原。

所以通俗的讲,HOSVD分解就是把一个三维的张量分解成为三个矩阵和一个更小的张量的乘积。

那HOSVD相比CP分解有什么好处呢?好处自然就是给不同的数据,以不同的自由度,因为不再限制用户物品和时间段,都必须有一样的维度,但同时也带来了难点。

那就是有了更多的超参数需要调整。

值得一提的是,我们仅仅是讲了讲张量分解的一个基本思路。

在实际的运作中还有一个重要的步骤,那就是设计目标函数,或者说是定义损失函数。

在一般的分解过程中,我们可以定义平方差,也就是原始数值和预测数值之间的平方差来作为损失函数。

当然也可以使用其他的损失函数,这一点和矩阵分解是一样的。

怎么来求解张量分解呢?虽然张量是对矩阵的自然延伸,张量分解是矩阵分解的某种延伸,但是求解张量分解则是一个相对比较难的问题。

一种比较简单的论式依然是使用SGD,随即梯度下降法,也就是把张量的分解问题看作是一个一般的优化问题。

关于这种方法的细节,我在这里不详细讲解了。

感兴趣的话建议阅读文末的参考文献。

这是一篇很经典的论文,是第一次把张量分解使用在推荐系统中。

另外一种方法也是在矩阵分解中可以使用的,叫做ALS方法。

这种方法则是在优化每一轮的时候,按住所有其他的矩阵变量不动,单独优化一个变量。

举例来说,如果我们要优化用户矩阵,那么我们就按住物品矩阵和时间段矩阵不动,不去更新里面的参数。

而仅仅更新用户矩阵里面的参数,同理,在下一轮的优化中,可以仅仅更新物品矩阵里的参数,这种方法也是行之有效的一种优化方法。

今天我为你讲了推荐系统的一个高级模型,张量分解张量分解模型主要用来对上下文的信息进行建模。

一起来回顾一下要点。

第一,我们简要介绍了为什么需要张量分解。

第二,我们详细介绍了张量分解的基本原理。

第三,我们简要的讨论了如何求解张量分解,最后给你留一个思考题。

从概念上来看,用张量分解对上下文信息进行建模的最大问题是什么?欢迎你给我留言,和我一起讨论。