forked from shunliz/Machine-Learning
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmei-tuan-tui-jian-pai-xu.md
191 lines (102 loc) · 18.2 KB
/
mei-tuan-tui-jian-pai-xu.md
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
# 美团“猜你喜欢”深度学习排序模型实践
# 一. 引言 {#-}
推荐作为解决信息过载和挖掘用户潜在需求的技术手段,在美团点评这样业务丰富的生活服务电子商务平台,发挥着重要的作用。在美团App里,首页的“猜你喜欢”、运营区、酒店旅游推荐等重要的业务场景,都是推荐的用武之地。
![](https://tech.meituan.com/img/recommend_dnn/iphone_demo_no_kuang.png "arch")
图1 美团首页“猜你喜欢”场景
目前,深度学习模型凭借其强大的表达能力和灵活的网络结构在诸多领域取得了重大突破,美团平台拥有海量的用户与商家数据,以及丰富的产品使用场景,也为深度学习的应用提供了必要的条件。本文将主要介绍深度学习模型在美团平台推荐排序场景下的应用和探索。
# 二. 深度学习模型的应用与探索 {#-}
美团推荐场景中每天活跃着千万级别的用户,这些用户与产品交互产生了海量的真实行为数据,每天能够提供十亿级别的有效训练样本。为处理大规模的训练样本和提高训练效率,我们基于PS-Lite研发了分布式训练的DNN模型,并基于该框架进行了很多的优化尝试,在排序场景下取得了显著的效果提升。
![](https://tech.meituan.com/img/recommend_dnn/overview.png "arch")
图2 模型排序流程图
如上图所示,模型排序流程包括日志收集、训练数据生成、模型训练和线上打分等阶段。当推荐系统对浏览推荐场景的用户进行推荐时,会记录当时的商品特征、用户状态与上下文信息,并收集本次推荐的用户行为反馈。在经过标签匹配和特征处理流程后生成最终的训练数据。我们在离线运用PS-Lite框架对Multi-task DNN模型进行分布式训练,通过离线评测指标选出效果较好的模型并加载到线上,用于线上排序服务。
下面将着重介绍我们在特征处理和模型结构方面所做的优化与尝试。
## 特征处理 {#-}
美团“猜你喜欢”场景接入了包括美食、酒店、旅游、外卖、民宿、交通等多种业务,这些业务各自有着丰富的内涵和特点,同时各业务的供给、需求与天气、时间、地理位置等条件交织,构成了O2O生活服务场景下特有的多样性和复杂性,这就给如何更高效地组织排序结果提出了更高的要求。构造更全面的特征、更准确高效地利用样本一直是我们优化的重点方向。
### 特征种类 {#-}
* User特征:用户年龄,性别,婚否,有无孩子等
* Item特征:价格,折扣,品类和品牌相关特征,短期和长期统计类特征等
* Context特征:天气,时间,地理位置,温度等
* 用户行为:用户点击Item序列,下单Item序列等
除上述列举的几类特征外,我们还根据O2O领域的知识积累,对部分特征进行交叉,并针对学习效果对特征进行了进一步处理。具体的样本和特征处理流程如下:
![](https://tech.meituan.com/img/recommend_dnn/feature_cn.png "arch")
图3 训练数据处理流程
### 标签匹配 {#-}
推荐后台日志会记录当前样本对应的User特征、Item特征与Context特征,Label日志会捕获用户对于推荐项的行为反馈。我们把两份数据按照唯一ID拼接到一起,生成原始的训练日志。
### 等频归一化 {#-}
通过对训练数据的分析,我们发现不同维度特征的取值分布、相同维度下特征值的差异都很大。例如距离、价格等特征的数据服从长尾分布,体现为大部分样本的特征值都比较小,存在少量样本的特征值非常大。常规的归一化方法(例如**min-max**,**z-score**)都只是对数据的分布进行平移和拉伸,最后特征的分布仍然是长尾分布,这就导致大部分样本的特征值都集中在非常小的取值范围内,使得样本特征的区分度减小;与此同时,少量的大值特征可能造成训练时的波动,减缓收敛速度。此外也可以对特征值做对数转化,但由于不同维度间特征的分布不同,这种特征值处理的方式并不一定适用于其他维度的特征。
在实践中,我们参考了Google的Wide & Deep Model\[6\]中对于连续特征的处理方式,根据特征值在累计分布函数中的位置进行归一化。即将特征进行等频分桶,保证每个桶里的样本量基本相等,假设总共分了**n**个桶,而特征**xi**属于其中的第**bi\(bi∈ {0, ..., n - 1}\)**个桶,则特征**xi**最终会归一化成**bi/n**。这种方法保证对于不同分布的特征都可以映射到近似均匀分布,从而保证样本间特征的区分度和数值的稳定性。
### 低频过滤 {#-}
过多的极为稀疏的离散特征会在训练过程中造成过拟合问题,同时增加参数的储存数量。为避免该问题,我们对离散特征进行了低频过滤处理,丢掉小于出现频次阈值的特征。
经过上述特征抽取、标签匹配、特征处理后,我们会给特征分配对应的域,并对离散特征进行Hash处理,最终生成LIBFFM格式的数据,作为Multi-task DNN的训练样本。下面介绍针对业务目标所做的模型方面的优化尝试。
## 模型优化与尝试 {#-}
在模型方面,我们借鉴工业界的成功经验,在MLP模型的基础上,针对推荐场景进行模型结构方面的优化。在深度学习中,很多方法和机制都具有通用性,比如Attention机制在机器翻译,图像标注等方向上取得了显著的效果提升,但并不是所有具体的模型结构都能够直接迁移,这就需要结合实际业务问题,对引入的模型网络结构进行了针对性调整,从而提高模型在具体场景中的效果。
### Multi-task DNN {#multi-task-dnn}
推荐场景上的优化目标要综合考虑用户的点击率和下单率。在过去我们使用XGBoost进行单目标训练的时候,通过把点击的样本和下单的样本都作为正样本,并对下单的样本进行上采样或者加权,来平衡点击率和下单率。但这种样本的加权方式也会有一些缺点,例如调整下单权重或者采样率的成本较高,每次调整都需要重新训练,并且对于模型来说较难用同一套参数来表达这两种混合的样本分布。针对上述问题,我们利用DNN灵活的网络结构引入了Multi-task训练。
根据业务目标,我们把点击率和下单率拆分出来,形成两个独立的训练目标,分别建立各自的Loss Function,作为对模型训练的监督和指导。DNN网络的前几层作为共享层,点击任务和下单任务共享其表达,并在BP阶段根据两个任务算出的梯度共同进行参数更新。网络在最后一个全连接层进行拆分,单独学习对应Loss的参数,从而更好地专注于拟合各自Label的分布。
![](https://tech.meituan.com/img/recommend_dnn/DNN.png "arch")
图4 点击与下单多目标学习
Multi-task DNN的网络结构如上图所示。线上预测时,我们将Click-output和Pay-output做一个线性融合。
在此结构的基础上,我们结合数据分布特点和业务目标进行了进一步的优化:针对特征缺失普遍存在的情况我们提出Missing Value Layer,以用更合理的方式拟合线上数据分布;考虑将不同task的物理意义关联起来,我们提出KL-divergence Bound,以减轻某单一目标的Noise的影响。下面我们就这两块工作做具体介绍。
#### Missing Value Layer {#missing-value-layer}
通常在训练样本中难以避免地有部分连续特征存在缺失值,更好地处理缺失值会对训练的收敛和最终效果都有一定帮助。通常处理连续特征缺失值的方式有:取零值,或者取该维特征的平均值。取零值会导致相应权重无法进行更新,收敛速度减慢。而取平均值也略显武断,毕竟不同的特征缺失所表示的含义可能不尽相同。一些非神经网络的模型能比较合理的处理缺失值,比如XGBoost会通过Loss的计算过程自适应地判断特征缺失的样本被划分到左子树还是右子树更优。受此启发,我们希望神经网络也可以通过学习的方式自适应地处理缺失值,而不是人为设置默认值。因此设计了如下的Layer来自适应的学习缺失值的权重:
![](https://tech.meituan.com/img/recommend_dnn/missvaluelayer.png "arch")
图5 Miss Value Layer
通过上述的Layer,缺失的特征可以根据对应特征的分布去自适应的学习出一个合理的取值。
通过离线调研,对于提升模型的训练效果,自适应学习特征缺失值的方法要远优于取零值、取均值的方式,模型离线AUC随训练轮数的变化如下图所示:
![](https://tech.meituan.com/img/recommend_dnn/relative-auc-v2.png "arch")
图6 自适应学习特征缺失值与取0值和均值效果对比
AUC相对值提升如下表所示:
![](https://tech.meituan.com/img/recommend_dnn/default_value_relative_auc_word_v2.png "arch")
图7 自适应学习特征缺失值AUC相对值提升
#### KL-divergence Bound {#kl-divergence-bound}
我们同时考虑到,不同的标签会带有不同的Noise,如果能通过物理意义将有关系的Label关联起来,一定程度上可以提高模型学习的鲁棒性,减少单独标签的Noise对训练的影响。例如,可以通过MTL同时学习样本的点击率,下单率和转化率\(下单/点击\),三者满足**p\(点击\) \* p\(转化\) = p\(下单\)**的意义。因此我们又加入了一个KL散度的Bound,使得预测出来的**p\(点击\) \* p\(转化\)**更接近于**p\(下单\)**。但由于KL散度是非对称的,即**KL\(p\|\|q\) != KL\(q\|\|p\)**,因此真正使用的时候,优化的是**KL\(p\|\|q\) + KL\(q\|\|p\)**。
![](https://tech.meituan.com/img/recommend_dnn/KLDivergence.png "arch")
图8 KL-divergence Bound
经过上述工作,Multi-tast DNN模型效果稳定超过XGBoost模型,目前已经在美团首页“猜你喜欢”场景全量上线,在线上也取得了点击率的提升:
![](https://tech.meituan.com/img/recommend_dnn/ctronline.png "arch")
图9 线上CTR效果与基线对比图
线上CTR相对值提升如下表所示:
![](https://tech.meituan.com/img/recommend_dnn/online_relative_ctr_word.png "arch")
图10 线上CTR效果相对值提升
除了线上效果的提升,Multi-task训练方式也很好的提高了DNN模型的扩展性,模型训练时可以同时考虑多个业务目标,方便我们加入业务约束。
### 更多探索 {#-}
在Multi-task DNN模型上线后,为了进一步提升效果,我们利用DNN网络结构的灵活性,又做了多方面的优化尝试。下面就NFM和用户兴趣向量的探索做具体介绍。
#### NFM {#nfm}
为了引入Low-order特征组合,我们在Multi-task DNN的基础上进行了加入NFM的尝试。各个域的离散特征首先通过Embedding层学习得到相应的向量表达,作为NFM的输入,NFM通过Bi-Interaction Pooling的方式对输入向量对应的每一维进行2-order的特征组合,最终输出一个跟输入维度相同的向量。我们把NFM学出的向量与DNN的隐层拼接在一起,作为样本的表达,进行后续的学习。
![](https://tech.meituan.com/img/recommend_dnn/NFM.png "arch")
图11 NFM + DNN
NFM的输出结果为向量形式,很方便和DNN的隐层进行融合。而且从调研的过程中发现,NFM能够加快训练的收敛速度,从而更有利于Embedding层的学习。因为DNN部分的层数较多,在训练的BP阶段,当梯度传到最底层的Embedding层时很容易出现梯度消失的问题,但NFM与DNN相比层数较浅,有利于梯度的传递,从而加快Embedding层的学习。
通过离线调研,加入NFM后,虽然训练的收敛速度加快,但AUC并没有明显提升。分析原因是由于目前加入NFM模型部分的特征还比较有限,限制了学习的效果。后续会尝试加入更多的特征域,以提供足够的信息帮助NFM学出有用的表达,深挖NFM的潜力。
#### 用户兴趣向量 {#-}
用户兴趣作为重要的特征,通常体现在用户的历史行为中。通过引入用户历史行为序列,我们尝试了多种方式对用户兴趣进行向量化表达。
1. Item的向量化表达:线上打印的用户行为序列中的Item是以ID的形式存在,所以首先需要对Item进行Embedding获取其向量化的表达。最初我们尝试通过随机初始化Item Embedding向量,并在训练过程中更新其参数的方式进行学习。但由于Item ID的稀疏性,上述随机初始化的方式很容易出现过拟合。后来采用先生成item Embedding向量,用该向量进行初始化,并在训练过程中进行fine tuning的方式进行训练。
2. 用户兴趣的向量化表达:为生成用户兴趣向量,我们对用户行为序列中的Item向量进行了包括Average Pooling、 Max Pooling与Weighted Pooling三种方式的融合。其中Weighted Pooling参考了DIN的实现,首先获取用户的行为序列,通过一层非线性网络\(Attention Net\)学出每个行为Item对于当前要预测Item的权重\(Align Vector\),根据学出的权重,对行为序列进行Weighted Pooling,最终生成用户的兴趣向量。计算过程如下图所示:
![](https://tech.meituan.com/img/recommend_dnn/Attention.png "arch")
图12 Weighted Pooling
通过离线AUC对比,针对目前的训练数据,Average Pooling的效果为最优的。效果对比如下图所示:
![](https://tech.meituan.com/img/recommend_dnn/uemb_click_auc.png "arch")
图13 不同Pooling方式点击AUC对比
以上是我们在模型结构方面的优化经验和尝试,下面我们将介绍针对提高模型训练效率所做的框架性能优化工作。
## 训练效率优化 {#-}
经过对开源框架的广泛调研和选型,我们选择了PS-Lite作为DNN模型的训练框架。PS-Lite是DMLC开源的Parameter Server实现,主要包含Server和Worker两种角色,其中Server端负责模型参数的存储与更新,Worker端负责读取训练数据、构建网络结构和进行梯度计算。相较于其他开源框架,其显著优点在于:
* PS框架:PS-Lite的设计中可以更好的利用特征的稀疏性,适用于推荐这种有大量离散特征的场景。
* 封装合理:通信框架和算法解耦,API强大且清晰,集成比较方便。
![](https://tech.meituan.com/img/recommend_dnn/ps.png "arch")
图14 Parameter Server
在开发过程中,我们也遇到并解决了一些性能优化问题:
1. 为了节约Worker的内存,通常不会将所有的数据储存在内存中,而是分Batch从硬盘中Pre-fetch数据,但这个过程中存在大量的数据解析过程,一些元数据的重复计算\(大量的key排序去重等\),累计起来也是比较可观的消耗。针对这个问题我们修改了数据的读取方式,将计算过的元数据也序列化到硬盘中,并通过多线程提前将数据Pre-fetch到对应的数据结构里,避免了在此处浪费大量的时间来进行重复计算。
2. 在训练过程中Worker的计算效率受到宿主机实时负载和硬件条件的影响,不同的Worker之间的执行进度可能存在差异\(如下图所示,对于实验测试数据,大部分Worker会在700秒完成一轮训练,而最慢的Worker会耗时900秒\)。而通常每当训练完一个Epoch之后,需要进行模型的Checkpoint、评测指标计算等需要同步的流程,因此最慢的节点会拖慢整个训练的流程。考虑到Worker的执行效率是大致服从高斯分布的,只有小部分的Worker是效率极低的,因此我们在训练流程中添加了一个中断机制:当大部分的机器已经执行完当前Epoch的时候,剩余的Worker进行中断,牺牲少量Worker上的部分训练数据来防止训练流程长时间的阻塞。而中断的Worker在下个Epoch开始时,会从中断时的Batch开始继续训练,保证慢节点也能利用所有的训练数据。
![](https://tech.meituan.com/img/recommend_dnn/worker_time_cost.png "arch")
图15 Worker耗时分布
# 三. 总结与展望 {#-}
深度学习模型落地到推荐场景后,对业务指标有了明显的提升,今后我们还将深化对业务场景的理解,做进一步优化尝试。
在业务方面,我们将尝试对更多的业务规则进行抽象,以学习目标的方式加入到模型中。业务规则一般是我们短期解决业务问题时提出的,但解决问题的方式一般不够平滑,规则也不会随着场景的变化进行自适应。通过Multi-task方式,把业务的Bias抽象成学习目标,在训练过程中对模型的学习进行指导,从而可以比较优雅的通过模型解决业务问题。
在特征方面,我们会继续对特征的挖掘和利用进行深入调研。不同于其他推荐场景,对于O2O业务,Context特征的作用非常显著,时间,地点,天气等因素都会影响用户的决策。今后会继续尝试挖掘多样的Context特征,并利用特征工程或者模型进行特征的组合,用于优化对样本的表达。
在模型方面,我们将持续进行网络结构的探索,尝试新的模型特性,并针对场景的特点进行契合。学术界和工业界的成功经验都很有价值,给我们提供了新的思路和方法,但由于面临的业务问题和场景积累的数据不同,还是需要进行针对场景的适配,以达到业务目标的提升。
# 参考文献 {#-}
\[1\] Mu Li, David G. Andersen, Alexander Smola, and Kai Yu. Communication Efficient Distributed Machine Learning with the Parameter Server. NIPS, 2014b.
\[2\] Rich Caruana. Multitask Learning. Betascript Publishing, 1997.
\[3\] Xiangnan He and Tat-Seng Chua. Neural Factorization Machines for Sparse Predictive Analytics. Proceedings of the 40th International ACM SIGIR conference on Research and Development in Information Retrieval\(2017\).
\[4\] Guorui Zhou, Chengru Song, et al. Deep Interest Network for Click-Through Rate Prediction.arXiv preprint arXiv:1706.06978,2017.
\[5\] Dzmitry Bahdanau, Kyunghyun Cho, and Yoshua Bengio. Neural Machine Translation by Jointly Learning to Align and Translate. ICLR ’15, May 2015.
\[6\] H.-T. Cheng, L. Koc, J. Harmsen, T. Shaked, T. Chandra, H. Aradhye, G. Anderson, G. Corrado,