推荐系统论文阅读(三十五)-亚马逊:多样性互补商品的召回算法

论文 :

论文题目:《P-Companion: A Principled Framework for Diversified  Complementary Product  Recommendation 》

地址:https://dl.acm.org/doi/pdf/10.1145/3340531.3412732

前面一篇文章里面我已经提到了商品的可替代性和互补性这两个关系,亚马逊这篇文章着重介绍了如何在保持多样性的前提下利用好商品之间的互补关系。

一 、背景

互补产品推荐(CPR)旨在提供经常一起购买的商品的推荐,以满足共同的需求,形成了电子商务服务的重要组成部分,但是,现有方法远非最佳。对于一种产品,如何推荐其不同类型的互补产品是我们在这项工作中要解决的关键问题。

在我们之前的第34篇文章中所提到的,我们认为共同购买的商品就是互补的,但是这边文章提出了co-purchase的物品并不一定是互补的,举个简单的例子吧,如果用户购买了两种不同品牌的口红那么当然说这两个口红不是互补的商品,但是可以说他们是相似的物品。如果说用户购买了手机跟手机壳,那么手机壳就是手机的互补商品,但是反过来就不行了,因为用户不会因为先把购买了手机壳再去找与之相匹配的手机。

更具体的来看下面的例子:

在图1中,我们显示了一个比较示例,详细阐述了生成高质量“一起购买”推荐的要求。以网球拍作为“查询产品”,我们比较了三组推荐列表。列表1包含其他三个类似的网球拍。清单2包含三个网球,清单3包含一个网球,一个球拍套和一个头带。当然,我们认为列表1通常更倾向于替代产品,并且不太可能在列表1中一起购买。虽然列表2和3都可以被视为合理的推荐,但我们认为列表3是更好的选择,因为它提出了三种不同类型的产品共同更好地满足了客户对网球运动的需求。该示例说明,理想的补充生产推荐解决方案应同时考虑相关性和多样性,以满足客户的需求。

在以前的工作中,我们会更倾向于去建模商品之间的相似度,如协同过滤或者一些item2vec的方法,但是建模物品之间的相似度遇到了一下几个挑战:

C1:互补关系不是对称的,并且互补推荐不仅仅基于相似性度量。例如,网球拍和头带在文字或图像特征上根本不相似。而且,SD卡可以是相机的补充产品,但不能相反。这些事实排除了大多数基于相似性的方法,并需要使用不同的机制来建立互补关系的模型。 

C2:互补推荐需要考虑多样性。这些推荐通常是一组具有不同类别和功能的商品,可以满足客户的需求。如图1所示,包含三种类型的网球相关产品的多元化推荐列表要优于仅一种类型的推荐列表。

C3:互补推荐在冷启动项目中受挫。也就是说,在电商领域中,相似度推荐难以解决冷启动问题。

带着这几个挑战,我们来看看亚马逊是怎么解决这些问题的。

二 、一些预定义

I:item 的集合

B ∈ I × I ,代表从客户的历史行为收集的成对商品之间的三个关系(即,共同购买B_{cp} ,共同浏览B_{cv} 和浏览后购买B_{pv} )。

C𝑖表示商品i的类别特征(例如,产品类别,类型,标题和描述)

w_{i}  \in C_{i},表示product type,也就是代表产品本身的功能特征。

互补商品推荐问题表述如下:

给定商品类别特征C(包括标题,项目类型等)和用户行为数据B作为输入,我们想要学习推荐模型M,M能在给定查询item i以及item类别w_{i} 和多样性程度𝐾的条件下,M会先预测𝐾个不同的互补商品类型{{w_{k} | k = 1,,2,3,...,K }},然后根据每种预测的互补商品类型生成𝐾个商品集{S_{w_{k} } }。

在共同浏览,共同购买和浏览后购买的不同组合的对比中,我们观察到仅在共同购买记录中包含产品对的B_{cp} -( B_{cv} \cup B_{pv}  )对MTurk投票得分最高,这比未经处理的共同购买的信号对高30%,所以亚马逊采用这部分数据进行训练。


三 、模型结构

先来看一下模型里面的一些符号的定义:

模型图:

3.1 Product2vec

这里采用的是GAT的方法,具体的细节可以去看GAT这篇论文,这里就不再详细介绍来。

其中,C_{i} 是item的特征,FFN是前馈神经网络,z是attention求得的分数,Ni是邻居节点,是训练的时候的正样本,\hat{Ni} 是负样本,y的定义为:

其中正样本的y定义为:

负样本的y定义为:

\theta _{Ni} 的计算为:


f(.)度量学习的函数,𝜆是区分𝑁𝑖和𝑁ˆi的距离,而\varepsilon 是边距。 上面那个优化的目的是迫使𝜃𝑖与\theta _{Ni} 之间的距离小于𝜆 − 𝜖,同时让𝜃𝑖和\theta _{Ni} 的距离至少为𝜖 + 𝜆。

损失函数其实就是hinge loss。

3.2 Complementary Type Transition

这里就是我们之前所说的如何来解决多样性问题的地方,主要是根据查询item和这个item的类型,来生成多个多个跟这个item相关的类型。

给定查询item i和候选item j,我们有他们之间的类型对{w_{i}, w_{j} },还有标签y_{i,j} ,文章采用encoder-decoder模型建模:

首先先把item i的类别的w映射成\gamma ,然后用度量学习的方式来学习。

其他的符号定义,可以参考前面的表,这里不再进行详细描述了,这个优化的目标主要是让co-purchase的商品之间的类别的embedding之间更相近。

3.3 Complementary Item Prediction

这部分是整个论文的最为关键的地方,不仅定义了如何通过度量学习的方式来进行互补商品的推荐,还在多种不同类别的条件下进行学习。

首先我们选取跟查询item的类别embedding相近的几个类别的embedding,然后我们把item本身的embedding\theta _{i} 映射到对应的类别中。

这里跟之前的度量学习的方式一样,只不过我们这里要优化的是我们映射后的item embedding跟候选item j之间的距离的度量。

3.4 Joint Training

这部分主要是为了让我们3.2和3.3中的两个度量优化函数进行加权,加权系数是\alpha

3.5 Model Details

这部分主要讲的是几个超参数的设置,比如L=64,d=128等等参数的设置。

以及,我们要知道在模型进行end-2-end学习完毕后该如何进行预测,也就是怎么来生成候选item,这里我们在问题定义的时候已经说了,从直观上来看就是先生成top-k个最相近的类别,然后在每个类别中运用3.3中的方法来生成候选的item,具体而言:

我们在有了

就可以就行推荐了,直接去取跟这个向量最相近的item就可以。

每个类别的取法都一样,这样我们就可以生成具有多个类别的多样性推荐列表了。

四、实验结果


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容