You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

46 lines
6.4 KiB
Markdown

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 017 | The Web 2018论文精读如何改进经典的推荐算法BPR
今天我们来看万维网大会上的一篇优秀短论文。在万维网大会上主要发表两类论文。一类是10页的长论文一类是2页的短论文或称作展板论文。短论文主要是发表短小的成果或者是还在研究过程中的重要成果。每一届的万维网大会都会评选出一篇最佳短论文奖。
今天我和你分享的论文,题目是《利用查看数据,贝叶斯个性化排序的一种改进的取样器》([An Improved Sampler for Bayesian Personalized Ranking by Leveraging View Data](https://www.comp.nus.edu.sg/~xiangnan/papers/www18-improvedBPR.pdf))。这篇论文也有六位作者,和我们介绍的上一篇论文一样,都来自清华大学和新加坡国立大学。
## 贝叶斯个性化排序
要想理解这篇论文的内容,我们必须要讲一下什么是“**贝叶斯个性化排序**”Bayesian Personalized Ranking或者简称是**BPR**。有关BPR的详细介绍可以阅读参考文献\[1\]。我们在这里仅对BPR进行一个高维度的总结。
简单来说,**BPR是推荐系统中的一个配对排序Pairwise学习算法**。在我们前面介绍搜索算法的时候曾经提到了各种配对排序学习算法。配对排序学习不是针对每一个数据实例来学习其标签或者响应变量而是学习一个相对的顺序希望能够把所有的正例都排列到负例之前。也就是说对于配对排序来说每一个数据实例的预测值本身并不重要排序算法在意的是对于一正一负的一个配对来说是否能够把正例给准确地排列到负例之上。这其实就要求BPR在数值上对正例的预测值能够比负例的预测值高。
BPR主要是解决了在推荐系统中长期以来只对单个数据点进行预测比如需要对用户物品的喜好矩阵建模的时候之前的大多数算法都无法有效地对没有观测到的数据进行建模。而BPR是配对算法因此我们只需要关注观测的数据以及他们之间的关系从而能够对用户的喜好特别是有“**隐反馈**”Implicit Feedback数据的时候取得更加明显的效果。这里的隐反馈指的并不是用户告诉系统其对每一个物品的喜好程度而是用户在和系统的交互过程中通过一些行为表达出的喜好。这些用户的行为往往并不全面因此需要算法和模型能够对这些行为进行有效建模。
## 论文的主要贡献和核心方法
了解了BPR大概是怎么回事以后我们来看一看这篇论文的主要贡献和核心方法。
首先我们刚才讲到BPR的核心是学习一个配对的排序问题。那么在训练的时候我们需要对一个正例和一个负例的配对进行学习更新参数。然而在一个自然的用户隐反馈数据集里正例相对来说往往是少数负例则是绝大多数。因此一个传统的方法就是在组成一个配对的时候相对于一个正例来说我们都“均匀地”Uniformly选取负样本来组成配对这个过程有时候也叫“采样”Sampling
这篇论文有两个主要贡献。第一个贡献是作者们发现如果在全局均匀地采样负样本第一没有必要第二可能反而会影响最后学习的效果。第二个贡献是针对电子商务的应用作者们发明了一种负样本采样的方法使得学习算法可以利用到更多的用户“浏览”View信息从而能够对算法的整体训练效果有大幅度的提升。
## 方法的实验效果
这篇论文的数据集分别使用了母婴产品“贝贝网”和天猫的数据。其中贝贝网有约16万用户、12万商品、260万次购买和4600万次浏览天猫的数据则有3万用户、3万多商品、46万次购买和150多万次浏览。两个数据集都呈现了大于99%的“稀疏度”Sparsity
首先,作者们实验了不从全局中选取负样本而仅仅采样一部分,而且是相比于原来的空间非常小的样本,比如仅仅几百个负样本而不是几万个的情况。实验效果在贝贝网上不仅没有影响算法的精确度,算法的精确度反而还有提升。而在天猫的数据集上,算法效果没有提升,而有一些小幅度的下降,但是作者们认为这样的代价还是值得的,因为数据集的减少,算法的训练时间会大幅度降低。从这个实验中,作者们得出了不需要从全局进行采样的结论。
紧接着作者们提出了一个新的概念那就是对用户的数据集合进行划分把用户的行为分为“购买集”C1、“浏览但没有购买集”C2、“剩下的数据”C3这三个集合。作者们提出BPR要想能够达到最好的效果需要对这三种数据集进行采样。也就是说我们需要组成C1和C2、C1和C3以及C2和C3的配对来学习。
具体来说用户在贝贝网和天猫的数据中尝试了不同的比例来对这三种集合进行采样。总体的经验都是C3中采样的数据要大于C2中的然后要大于C1中的。这其实就是说训练算法要更好地学习到用户不喜欢某件东西的偏好。采用这样的采样方式作者们展示了模型的效果比传统的BPR或仅仅使用“最流行的物品”作为推荐结果要好60%左右。
## 小结
今天我为你讲了今年万维网大会的一篇优秀短论文。文章介绍了如何对一个经典的推荐算法BPR进行改进从而提高效率并且大幅度提升算法有效度。
一起来回顾下要点第一我们从高维度介绍了BPR的含义第二我们简要介绍了论文的主要贡献和思路第三我们简单分享了论文的实验成果。
最后,给你留一个思考题,除了这篇论文提出的组成正例和负例的配对思路以外,你能不能想到在用户浏览网站的时候,还有哪些信息可以帮助我们组成更多的配对呢?
欢迎你给我留言,和我一起讨论。
**参考文献**
1\. Steffen Rendle, Christoph Freudenthaler, Zeno Gantner, and Lars Schmidt-Thieme. BPR: Bayesian personalized ranking from implicit feedback. Proceedings of the Twenty-Fifth Conference on Uncertainty in Artificial Intelligence (UAI '09). AUAI Press, Arlington, Virginia, United States, 452-461, 2009.