AI内参_57_055_基于深度学习的搜索算法深度结构化语义模型
你好,我是洪亮杰。
今天我和你分享的主题是基于深度学习的搜索算法深度结构化语义模型。
近两个月,我们集中系统的分享了搜索核心技术模块,做一个简单的内容梳理。
我们讲解了搜索引擎方方面面的话题,从经典的信息检索技术查询、关键字理解文档理解到现代搜索引擎的架构和索引的核心技术,还从机器学习角度出发,分享了搜索引擎的最核心部分,也就是排序算法、深入排序算法的细节,讲解了排序支持向量机梯度,增强决策树以及经典的模型lambdmart.至此,整个人工智能领域关于搜索的经典话题也就告一段落了。
那么这个星期我们来看一些关于搜索算法的前沿。
思考火热的深度学习,不仅对图像、视频和音频这些领域产生了巨大的冲击,也对自然语言处理甚至搜索领域有不小的影响。
深度学习带给传统的模型和算法,以新的建模能力,核心的视角为以前所不能完成的应用打下了基础。
今天,我们来看一篇较早利用深度学习技术来进行搜索建模的论文,使用点击数据学习深度结构化的网络搜索语义模型。
这篇论文阐述了一个深度结构化语义模型,发表在第二十二届世界信息和知识管理大会CIKM二零一三上,发表于二零一三年的这篇论文应该算是比较早的直接使用深度学习中惊艳的论文,其主要目的是探索一些经典的深度学习方法,能否在搜索的应用中得到合适的效果?下面我们来了解一下这篇论文的作者群信息。
第一作者黄伯森是一名来自台湾的学者。
在发表论文的时候,他在伊利诺伊大学香槟分校攻读电子工程和计算机博士学位。
师从马克约翰森论文,是黄伯森在微软实习时的工作总结。
二零一五年,黄伯森博士毕业,然后于二零一六年加入了微软研究院。
到目前为止,他发表了三十多篇人工智能相关的论文,论文引用次数已经超过一千多次,其他作者均来自当时在微软研究院工作的学者,其中不乏著名学者,比如何晓东、邓丽、亚历克斯、阿希罗和拉里赫克等。
下面聊聊比较少被提及的阿希罗和赫克。
阿希罗曾长期在微软研究院担任语音相关研究组的经理职位。
二零一三年之后,他到苹果公司担任siri的资深总监赫克。
曾经在雅虎担任搜索和广告业务副总裁,然后到微软研究院担任语音组的首席科学家。
文章发表之后,赫克到了谷歌,在一个人工智能组担任总监,并于最近加入三星北美研究刘院担任资深副总裁。
这些学者主要是为了这个工作提供支持和指导工作。
这篇论文自二零一三年发表后,已经有超过三百九十多次的引用,是深度学习在搜索领域应用中被引用次数最多的论文之一。
下面详细讲讲这篇论文的核心之一。
要想理解这篇论文提出的思路,我们首先要简单回顾一下经典的搜索模型,构建在经典的搜索模型里,不管是TFIDFBM二五语言模型,还是基于继续学习的排序算法模型。
整体来说,一个共通的想法,就是争取用某种表示来表达查询关键字,然后用相同的或者类似的表示来表达文档,再通过某种程度的匹配函数来计算查询关键字,表示和文档表示之间的距离,然后进行排序。
那么从深度学习的角度来说,要想针对这个传统的模式进行革新,当然就可以从最主要的三个方面入手,查询关键字的表达、文档的表示和进行文档。
这篇文章也是沿着这个思路提出了深度结构化语义模型。
首先,深度结构化语义模型对查询关键字和文档进行了相似的处理。
具体来说,就是先把查询关键字或者文档转换为词向量这个词向量可以是最简单的词带的表达方式,也就是最基本的模型的输入,从词向量出发模型。
首先,学习一个词哈希,也就是把零或一的稀疏词向量转换成为一个稠密的向量表达。
这一步是把深度学习方法应用在自然语言处理中所通用的方法,目的就是把稀疏的输入转换为稠密的输入,降低输入的数据维度。
当查询关键字和文档都转换成稠密数组以后,深度结构化语义模型利用了深度学习中的重要经验,那就是通过非线性转换来获取数据深层次的语义信息。
而不仅仅只是传统方法中字面上的匹配。
这里查询关键字和文档也经用了简单的前馈神经网络的方法,对输入向量进行了多层的非线性转换。
非线性转换本身通过双曲正切函数实现,这应该算是最传统的深度学习模型的实现方法了。
经过多层转换之后,查询关键字和文档都变成了新的某种表达之后,如何来计算两者间的距离呢?这篇文章采用了非常直接的形式,那就是利用余弦函数来作为距离函数描述两个向量之间的距离。
在传统信息检索的语境当中,也经常用余弦函数来计算向量的距离。
所以在这里应该说并没有太多创新的地方。
总体来说,深度学习在这里的主要应用就是成为查询关键字和文档的表达的提取器。
传统方法中,人工提取各种类型的文字特性,相比在深度结构化语义模型中,基于前馈神经网络的特征提取器,自动提取了文字的深层语义信息。
提出了模型之后,我们来看这个模型是如何被训练出来的。
作者们首先利用了用户的点击信息,也就是针对某一个查询关键字有哪些文档被点击过作为正例数据,其他文档作为复利数据,然后把整个建模问题看作一个多类分类问题,这样就可以利用标签信息对整个模型进行学习了。
整体来说,这个深度学习模型是可以利用端到端的方式进行训练的,并且采用了随机梯度下降这样的优化算法,这里就不复述了。
最后,我们来看看深度结构化语义模型的实验效果。
因为深度结构化语义模型仅仅使用了查询关键字和文档之间的文字效果,因此提出的模型就无法和完整的利用很多特性的机器学习排序算法进行比较,只能和文字型的排序算法,例如TFI FBM二五和语言模型进行比较。
这也是文章并没有采用一些更为通用的数据集的原因。
最终,文章在数据集上采用bean的搜索数据,有一万六千多的查询,关键五不及每个查询关键字所对应的十五个文档,每个文档又有四级相关标签。
这样可以用来计算诸如NDCG这样的指标。
在这篇文章里,作者们比较了一系列的方法,比如TFIDFBM二五以及一些传统的降维方法,如LSA和PLSA.简单来说,深度结构化语义模型。
在最后的比较中取得了不错的结果,NDCG在第十位的表现是接近零点五,不过TFIDF的表现也有零点四六,而传统的PLSA和LSA也有零点四五左右的表现。
所以可以说深度结构化语言模型的效果虽然很明显,但并不是特别惊人。
今天我为你讲了深度结构化语义模型的一些基本原理。
这是利用深度学习技术对搜索算法进行改进的一个经典尝试。
我们在上面的实验结果总结中已经说到,虽然文章仅仅谈到了文本信息的匹配,并没有作为完整的排序算法进行比较。
但是也揭开了用深度模型来表征查询关键字和文档的研发序幕。
一起来回顾一下要点。
第一,我们简要介绍了提出深度结构化语义模型的历史。
第二,我们详细介绍了深度结构化语义模型的核心思路以及实验结论。
最后给你留一个思考题,除了文章中提到的余弦函数可以作为一个距离函数,还有没有其他的函数选择来表达两个向量之间的距离呢?欢迎你给我留言,和我一起讨论。
最后预告一个小活动,本周六,也就是一月十三日晚八点三十分,我会在即刻时间做一场直播,欢迎你参加,主题是人工智能。
二十问,如果你有想交流的问题,欢迎给我留言。
我们周六直火件。