CategoryResourceRepost/极客时间专栏/深度学习推荐系统实战/推荐模型篇/16 | 深度学习革命:深度学习推荐模型发展的整体脉络是怎样的?.md
louzefeng d3828a7aee mod
2024-07-11 05:50:32 +00:00

105 lines
14 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<audio id="audio" title="16 | 深度学习革命:深度学习推荐模型发展的整体脉络是怎样的?" controls="" preload="none"><source id="mp3" src="https://static001.geekbang.org/resource/audio/6c/cd/6c78a245f1eebb50f2860c5d3f75fbcd.mp3"></audio>
你好,我是王喆。今天,我们要开始学习激动人心的深度推荐模型部分了。
当下几乎所有互联网巨头的推荐业务中都有对深度学习推荐模型的落地和应用。从早期微软的Deep Crossing、Google的Wide&amp;Deep、阿里的MLR到现在影响力非常大的模型DIN、DIENYouTube的深度推荐模型等等。因此对于算法工程师来说紧跟业界的脚步去了解和掌握深度学习推荐模型是非常必要的。
那你可能想问了,深度学习推荐模型这么多,发展这么快,也没有一个统一的模板,我们该学哪个,怎么学呢?我想说的是,算法工程师的工作是一个持续优化和迭代的过程,如果想要追求更好的推荐效果,我们的思路不应该只局限于某一个被成功应用的模型,而是应该把眼光放得更高、更宽,去思考这些成功的推荐模型在业界下一步的发展方向是什么?有没有哪些其他的模型结构的思路可以借鉴。这些都是你在这个岗位上取得持续成功的关键。
那怎么才能做到这一点呢?我认为,只有建立起一个比较全面的深度学习模型知识库,我们才能在工作中做出正确的技术选择,为模型的下一步改进方向找到思路。
因此,这节课,我想和你深入聊一聊业界影响力非常大的深度学习推荐模型,以及它们之间的发展关系,带你从整体上建立起深度学习推荐模型的发展脉络。这不仅是我们建立行业知识储备的必需,也为我们后面实现深度推荐模型打下了基础。
## 深度学习对推荐系统的影响详解
在第一节课中,我们曾说过,**深度学习给推荐系统带来了革命性的影响**,能够显著提升推荐系统的效果,原因主要有两点,一是深度学习极大地增强了推荐模型的拟合能力,二是深度学习模型可以利用模型结构模拟用户兴趣的变迁、用户注意力机制等不同的用户行为过程。接下来,我们就结合这两点,来说说深度学习模型到强在哪里。
### 1. 深度学习模型的强拟合能力
首先我们来说说深度学习模型的强拟合能力。上一节课我们学习了经典的推荐算法矩阵分解。在矩阵分解模型的结构图1左用户One-hot向量和物品One-hot向量分居两侧它们会先通过隐向量层转换成用户和物品隐向量再通过点积的方式交叉生成最终的打分预测。
但是点积这种特征向量交叉的方式毕竟过于简单了在数据模式比较复杂的情况下往往存在欠拟合的情况。而深度学习就能大大加强模型的拟合能力比如在NeuralCF神经网络协同过滤模型中点积层被替换为多层神经网络理论上多层神经网络具备拟合任意函数的能力所以我们通过增加神经网络层的方式就能解决模型欠拟合的问题了。
<img src="https://static001.geekbang.org/resource/image/70/09/7063d223da013845534d3c84b7ab9409.jpg" alt="" title="图1 矩阵分解模型示意图
">
如果你不知道什么是欠拟合、正确拟合和过拟合的现象,可能就无法理解神经网络到底解决了什么问题。这里我就带你看一张很经典的示意图,来详细聊聊这三种现象 。
**“欠拟合”指的是模型复杂度低,无法很好地拟合训练集数据的现象。** 就像图2展示的那样模型曲线没办法“准确”地找到正负样本的分界线而深度学习模型就可以大大增加模型的“非线性”拟合能力像图2一样找到更加合适的分类面更准确地完成分类任务。当然过分复杂的深度学习模型存在着“过拟合”的风险**“过拟合”是指模型在训练集上的误差很小,但在测试集上的误差较大的现象**就像图2一样模型曲线过分精确地刻画分界线而忽略了对噪声的容忍能力这对于未知样本的预估来说往往是不利的。
[<img src="https://static001.geekbang.org/resource/image/88/87/885010f805fb5290ec53f4fd6667e087.jpg" alt="" title="图2拟合能力示意图图片来自Geeksforgeeks">](https://www.geeksforgeeks.org/regularization-in-machine-learning/)
### 2. 深度学习模型结构的灵活性
说完了深度学习模型的强拟合能力,我们再来看看它的灵活性。这里,你可能会有疑问了,灵活性和深度学习模型模拟用户行为有什么关系呢?我们先接着往下看。
如果你读过一些深度学习相关的论文肯定会发现每篇论文中的模型结构都不尽相同就像图3展示的那样它们有的是好多层有的像一个串是串在一起的而有的像一张网一样拥有多个输入和多个输出甚至还有的像金字塔会从输入到输出逐层变窄。
虽然,模型结构的复杂性让我们难以掌握它们的规律,但也正是因为深度模型拥有这样的灵活性,让它能够更轻松地模拟人们的思考过程和行为过程,让推荐模型像一个无所不知的超级大脑一样,把用户猜得更透。
[<img src="https://static001.geekbang.org/resource/image/60/26/60d7f9aaa4562251c1dyy78712a2fe26.jpg" alt="" title="图3 不同深度学习模型的结构图片来自ResearchGate">](https://www.researchgate.net/figure/The-structures-of-different-deep-learning-models_fig2_340123883)
这其中典型的例子就是阿里巴巴的模型DIN深度兴趣网络和DIEN深度兴趣进化网络。它们通过在模型结构中引入注意力机制和模拟兴趣进化的序列模型来更好地模拟用户的行为。
<img src="https://static001.geekbang.org/resource/image/20/32/202cfa968b1aa6fa4349722bb4ab4332.jpg" alt="" title="图4 DIN模型和DIEN的模型示意图">
我们重点关注图4的DIN模型它在神经网络中增加了一个叫做“激活单元“的结构这个单元就是为了模拟人类的注意力机制。举个例子来说我们在购买电子产品比如说笔记本电脑的时候更容易拿之前购买电脑的经验或者其他电子产品的经验来指导当前的购买行为很少会借鉴购买衣服和鞋子的经验。这就是一个典型的注意力机制我们只会注意到相关度更高的历史购买行为而DIN模型就是模拟了人类的注意力特点。
DIN模型的改进版DIEN模型就更厉害了它不仅引入了注意力机制还模拟了用户兴趣随时间的演化过程。我们来看那些彩色的层这一层层的序列结构模拟的正是用户兴趣变迁的历史通过模拟变迁的历史DIEN模型可以更好地预测下一步用户会喜欢什么。
这些通过改变模型结构来模拟用户行为的做法不胜枚举,很多重要的深度学习模型的改进动机也是基于这样的原理。也正是因为这样的灵活性,正确、全面地掌握不同深度学习模型的特点,以及它们之间的发展关系变得异常重要,只有这样,我们才能在实践中做到有的放矢、灵活应用。
## 深度学习推荐模型的演化关系图
说了这么多我们到底该怎么掌握不同深度学习模型之间的关系呢这里我梳理出了一张深度学习模型5年内的发展过程图图中的每一个节点都是一个重要的模型结构节点之间的连线也揭示了不用模型间的联系。
接下来我就带你梳理一下图中重要模型的原理以及不同模型间的关系。而在之后的课程中我们还会进一步学习重点模型的技术细节并且基于TensorFlow对它们进行实现。
<img src="https://static001.geekbang.org/resource/image/10/c5/10e8105911823d96348dc7288d4d26c5.jpg" alt="" title="图5 主流深度学习推荐模型的演化图谱">
首先我们来看整个演化图最中心部分这是深度学习最基础的结构我们叫它“多层神经网络”或者“多层感知机”简称MLPMultiLayer Perceptron。多层感知机的原理我们在[第3讲](https://time.geekbang.org/column/article/291245)中讲过,它就像一个黑盒,会对输入的特征进行深度地组合交叉,然后输出对兴趣值的预测。其他的深度推荐模型全都是在多层感知机的基础上,进行结构上的改进而生成的,所以**“多层感知机”是整个演化图的核心**。
从多层感知机向上还有一个重点模型我们需要知道那就是Deep Crossing。Deep Crossing实际上是一类经典深度学习模型的代表相比于MLPDeep Crossing在原始特征和MLP之间加入了Embedding层。这样一来输入的稀疏特征先转换成稠密Embedding向量再参与到MLP中进行训练这就解决了MLP不善于处理稀疏特征的问题。可以说**Embedding+MLP的结构是最经典也是应用最广的深度学习推荐模型结构**。
从MLP向下我们看到了Google提出的推荐模型Wide&amp;Deep。它把深层的MLP和单层的神经网络结合起来希望同时让网络具备很好的“记忆性”和“泛化性”。对“记忆性”和“泛化性”这两个名词陌生的同学也不用着急我们后面的课程会专门来讲解Wide&amp;Deep。
Wide&amp;Deep提出以来凭借着“易实现”“易落地”“易改造”的特点获得了业界的广泛应用。围绕着Wide&amp;Deep还衍生出了诸多变种比如通过改造Wide部分提出的Deep&amp;Cross和DeepFM通过改造Deep部分提出的AFM、NFM等等。总之**Wide&amp;Deep是业界又一得到广泛应用的深度推荐模型**。
除此之外我们还可以看到经典的深度学习模型跟其他机器学习子领域的交叉。这里我给你举3个比较著名的例子第1个是深度学习和注意力机制的结合诞生了阿里的深度兴趣网络DIN浙大和新加坡国立提出的AFM等等第2个是把序列模型引入MLP+Embedding的经典结构诞生了阿里的深度兴趣进化网络DIEN第3个是把深度学习和强化学习结合在一起诞生了微软的深度强化学习网络DRN以及包括[美团](https://tech.meituan.com/2018/11/15/reinforcement-learning-in-mt-recommend-system.html)、[阿里](https://102.alibaba.com/downloadFile.do?file=1517812754285/reinforcement_learning.pdf)在内的非常有价值的业界应用。
看了这诸多模型的演进过程,你肯定想问模型的演化有什么规律可循吗?接下来,我就把我总结出的,关于模型改进的四个方向告诉你 。
**一是改变神经网络的复杂程度。** 从最简单的单层神经网络模型AutoRec到经典的深度神经网络结构Deep Crossing它们主要的进化方式在于增加了深度神经网络的层数和结构复杂度。
**二是改变特征交叉方式。** 这种演进方式的要点在于大大提高了深度学习网络中特征交叉的能力。比如说改变了用户向量和物品向量互操作方式的NeuralCF定义了多种特征向量交叉操作的PNN等等。
**三是把多种模型组合应用。** 组合模型主要指的就是以Wide&amp;Deep模型为代表的一系列把不同结构组合在一起的改进思路。它通过组合两种甚至多种不同特点、优势互补的深度学习网络来提升模型的综合能力。
**四是让深度推荐模型和其他领域进行交叉。** 我们从DIN、DIEN、DRN等模型中可以看出深度推荐模型无时无刻不在从其他研究领域汲取新的知识。事实上这个过程从未停歇我们从今年的推荐系统顶会Recsys2020中可以看到NLP领域的著名模型Bert又与推荐模型结合起来并且产生了非常好的效果。一般来说自然语言处理、图像处理、强化学习这些领域都是推荐系统经常汲取新知识的地方。
总的来说,深度学习推荐模型的发展快、思路广,但每种模型都不是无本之木,它们的发展脉络都有迹可循。想要掌握好这些模型,在实际工作中做到拿来就用,我们就需要让这些模型脉络图像知识树一样扎根在心中,再通过不断地实践来掌握技术细节。
## 小结
这节课,我们通过学习深度学习对推荐系统的影响要素,以及经典深度学习模型之间的关系,初步建立起了深度学习模型的知识库。
我们知道,深度学习能够提升推荐系统的效果有两个关键因素,分别是它的“强拟合能力”和“结构的灵活性”。
对于“强拟合能力”来说,深度学习模型可以大大增加模型的“非线性”拟合能力,对复杂数据模型进行更准确的分类,避免“欠拟合”现象的发生,从而提升推荐效果。
对于“结构的灵活性”来说,深度学习模型可以通过灵活调整自身的结构,更轻松恰当地模拟人们的思考过程和行为过程,把用户猜得更透。
而整个深度学习推荐模型的演化过程是从最经典的多层神经网络向不同方向开枝散叶比如结合协同过滤发展出了NerualCF加入Embedding层发展出以Deep Crossing为代表的Embedding+MLP的结构以及把深度神经网络和单层网络结合起来发展出Wide&amp;Deep模型等等。
在这节课我们可以先忽略每个模型的细节着重建立一个整体的知识框架。之后的课程中我不仅会带你一一揭晓它们的技术细节还会利用TensorFlow实现其中几个经典的模型。期待继续与你一起学习
最后,我还是把这节课的重点知识梳理成了表格的形式,你可以借助它来复习巩固。
<img src="https://static001.geekbang.org/resource/image/be/ce/be5a662d3abd6a8dd5411038718d6cce.jpeg" alt="">
## 课后思考
有的同学说,深度学习这么流行,我把一些经典的深度模型结构实现好,肯定能提升我们公司推荐系统的效果,你觉得这种观点有问题吗?你觉得除了模型结构,还有哪些影响推荐效果的因素?为什么?
好啦,关于深度学习模型的知识库你建立起来了吗?欢迎把你的疑问和思考分享到留言区,也欢迎你能把这节课转发出去,我们下节课见!