LSTM模型在问答系统中的应用

作者: lirainbow0 | 来源:发表于2017-03-11 21:08 被阅读4121次

在问答系统的应用中,用户输入一个问题,系统需要根据问题去寻找最合适的答案。

1:采用句子相似度的方式。根据问题的字面相似度选择相似度最高的问题对应的答案,但是采用这种字面相似度的方式并不能有效的捕获用户意图的能力有限。

2:IBM早期应用在watson系统中的DeepQa算法。该算法通过人工抽取一系列的特征,然后将这些特征输入一个回归模型。该算法普适性较强,并且能有效的解决实际中的问题,但是准确率和召回率一般。

3:深度学习算法。依然是IBM的watson研究人员在2015年发表了一篇用CNN算法解决问答系统中答案选择问题的paper。通过深度学习算法不仅能够避免了人工手动抽取大量的问题特征的麻烦,并且取得了比DeepQa更好的效果。详细的介绍可以点击这里,我们组的同学去年也针对该paper做了详细的实验,具体的描述可以在这里找到。

大量的实验证明,在大数据量的情况下,深度学习算法和传统的自然语言算法相比可以获得更优的结果。并且深度学习算法无需手动抽取特征,因此实现相对简便。其中CNN算法被大量的研究和使用,CNN算法的优点在于实现简单(卷积)、并且能够捕获数据位置(单字成词情况下,一次窗口的卷积类似于一次切词的操作)的特征信息。但是对于时序的数据,LSTM算法比CNN算法更加适合。LSTM算法综合考虑的问题时序上的特征,通过3个门函数对数据的状态特征进行计算,这里将针对LSTM在问答系统中的应用进行展开说明。

2016年watson系统研究人员发表了“LSTM-BASED DEEP LEARNING MODELS FOR NON-FACTOID ANSWER SELECTION”,该论文详细的阐述了LSTM算法在问答系统的中的应用,这里将针对文中所描述的算法进行实验。

算法流程图

实验步骤

1:本次实验采用insuranceQA数据,你可以在这里获得。实验之前首先对问题和答案按字切词,然后采用word2vec对问题和答案进行预训练(这里采用按字切词的方式避免的切词的麻烦,并且同样能获得较高的准确率)。

2:由于本次实验采用固定长度的LSTM,因此需要对问题和答案进行截断(过长)或补充(过短)。

3:实验建模Input。本次实验采用问答对的形式进行建模(q,a+,a-),q代表问题,a+代表正向答案,a-代表负向答案。insuranceQA里的训练数据已经包含了问题和正向答案,因此需要对负向答案进行选择,实验时我们采用随机的方式对负向答案进行选择,组合成(q,a+,a-)的形式。

4:将问题和答案进行Embedding(batch_size, sequence_len, embedding_size)表示。

5:对问题和答案采用相同的LSTM模型计算特征(sequence_len, batch_size, rnn_size)。

6:对时序的LSTM特征进行选择,这里采用max-pooling。

7:采用问题和答案最终计算的特征,计算目标函数(cosine_similary)。

目标函数

参数设置

1:、这里优化函数采用论文中使用的SGD(采用adam优化函数时效果不如SGD)。

2、学习速率为0.1。

3:、训练150轮,大概需要1天的时间,从训练日志观察得到,100轮左右基本达到稳定。

4、margin这里采用0.1,其它参数也试过0.05、0.2效果一般。

5、这里训练没有采用dropout和l2约束,之前试过dropout和l2对实验效果没有提升,这里就没有采用了。

6、batch_size这里采用100。

7、rnn_size为300(继续调大没有明显的效果提升,而且导致训练速度减慢)

8、目标函数采用cosine_similary,实验时也试过欧几里德距离,但是效果不佳。

实验效果对比

QA_CNN:0.62左右

QA_LSTM:0.66左右

QA_BILSTM:0.68左右

:这里分别实验了单向的LSTM和双向的LSTM算法。单向的LSTM算法只能捕获当前词之前词的特征,而双向的LSTM算法则能够同时捕获前后词的特征,实验证明双向的LSTM比单向的LSTM算法效果更佳。

如果有任何问题欢迎发送邮件到lirainbow0@163.com。

相关文章

  • LSTM模型在问答系统中的应用

    在问答系统的应用中,用户输入一个问题,系统需要根据问题去寻找最合适的答案。 1:采用句子相似度的方式。根据问题的字...

  • LSTM_CNN在问答系统中的应用

    在前面的随笔中,已经分别介绍了CNN算法和LSTM算法在问答系统中的应用。其中LSTM算法在抽取特征之后,针对不同...

  • GRU模型在问答系统中的应用

    GRU模型与LSTM模型设计上十分的相似,LSTM包含三个门函数(input gate、forget gate和o...

  • Inner Attention模型在深度问答系统中的应用

    Attention机制在时序模型中的应用,已经被证明能够提升模型的性能。本文参考《Inner Attention ...

  • 阅读论文目录

    双轴LSTM神经网络与混沌理论在音乐生成系统中的研究与应用_林舜成(20181031)

  • 深度学习之LSTM

    LSTM是深度学习领域一个非常受欢迎的模型,它被用以解决各种各样的问题。在交通领域,LSTM被广泛应用于道路、航空...

  • 理解LSTM网络(整合)

    LSTM 已经在科技领域有了多种应用。基于 LSTM 的系统可以学习翻译语言、控制机器人、图像分析、文档摘要、语音...

  • 迁移学习在问答系统中的应用

    1.问答背景 样本: (Q, P, y) :(问答,答案,标签) 目标:匹配最佳的问题和答案 2.深度...

  • Attention机制在问答系统中的应用

    Attention机制最先被应用在图像处理中,后来逐渐被nlp引入,并且取得了不错的效果。watson系统研究人员...

  • 主题模型在推荐系统中的应用

    1、什么是推荐系统中的冷启动问题 推荐系统中的冷启动问题:在没有大量用户数据的情况下如何给用户进行个性化推荐,目的...

网友评论

    本文标题:LSTM模型在问答系统中的应用

    本文链接:https://www.haomeiwen.com/subject/kkjzgttx.html