mantch

我们就会产生一个想法:能不能有一个机器人来回答这些重复的问题,它能 24 小时的工作不用休息,降低客户成本,还能挖掘聊天记录里面的一些有价值的知识点。这就是智能客服产生的背景。

1. 智能客服系统

智能客服产生的背景:为什么要有智能客服这样的一个产品,或者说研究方向呢?主要有以下这几个原因:

  • 我们日常生活中会遇到大量的客服问题,比如说你打电话给联通、移动等,或者说在淘宝上买东西,这些问题大部分都是一些重复的问题,而且频率也特别高,非常的耗人工;
  • 对于一个客服密集型的企业来说,大量的人工客服,造成了企业的客服成本非常的高;
  • 人工客服是没有办法做到 24 小时全天候的服务;
  • 在客户和客服的对话的过程中产生了大量的有价值的数据,这些数据也没有被很好的利用起来。

基于以上的这些原因,我们就会产生一个想法:能不能有一个机器人来回答这些重复的问题,它能 24 小时的工作不用休息,降低客户成本,还能挖掘聊天记录里面的一些有价值的知识点。这就是智能客服产生的背景。

1.1 智能客服的目标

如果说要做一个智能客服,那做智能客服的一个基本的目标,或者说它的技术目标是要做到什么样的程度呢?它是要完全的替代人工,还是要部分的替代人工呢?

一般情况下,一个智能客服的目标就是下面这张图里描述的这些:一个客服的机器人负责回答客户的一些高频简单问题,将疑难问题交给人工客服团队来回答。那这个一定比例是多大比例呢?我这边写了一个百分之 X,也就是说这个比例不太确定,它是根据不同的场景以及不同的技术条件,不同厂商的技术能力而不同的,有的厂商是 80%,有的是 90%,有的甚至 95%,这都是不确定的。

总之智能客服做的一个技术目标就是:一定比例的解决客服的简单的高频问题,将疑难问题仍然交给人工客服团队。这是目前智能客服一个基本的技术目标,是一个比较现实的目标。那么想让客服的机器人来完全取代人工客服,这个目标到目前为止,在绝大部分场景下还是没有办法实现的。

1.2 细分领域

整个智能客服系统的发展非常快,应用也划分了很多的细分领域。

  1. 第一大类是对话操作系统级别的系统。那么这一类系统比较有代表性的有亚马逊的 Alexa,这些系统都希望做操作系统级别的人机对话,就是把人机对话直接做成一个操作系统,那在这个系统上开发各种各样不同的智能硬件、软件等等这些应用。
  2. 第二大类,就是智能客服,智能客服里面又细分成两类:一类是企业内部的智能客服,为了企业自身的业务发展需要研发的智能客户系统;还有一类是对外服务的智能客服,并且以 SaaS 的方式对外服务。
  3. 第三大类就是个人助理类,最有名的就是苹果的 Siri,还有微软的 Cortana 等。智能家居现在做得比较火热的就是一些智能音箱,比如说亚马逊 Echo 等。还有些公司是做一些智能交互的服务,这些智能交互服务主要是自然语言处理和意图识别方面的服务,其他的厂商可以基于这些智能交互服务做一些自己的应用。
  4. 第四类是开放平台,这个开放平台也可以叫 Bot Factory,比较有代表性的,有 Google 的 API.AI、Facebook 的 Wit.AI、还有微软的 Luis.AI 等等。这些开放平台主要是做任务对话方面的一些定制。

1.3 智能客服常见功能

智能客服系统最常见的功能有哪些?目前最常见的形式是在人工客服系统基础上,扩展出智能客服的功能,最常见的功能有 单轮问答、多轮对话和人机协作。

  • 单轮问答:一问一答,但是没有记录上下文,每一次问答和下一次问答都没有任何的关系;
  • 多轮对话:是带着上下文来问答,每个问答可能跟它的上文是有一定关系,或者是它记录了上文的一些信息;
  • 人机协作:人机协作是一种比较有效的一种智能客服功能,现有的方式主要有两大类:一类是机器人加人工进行问答,另外一大类是机器人推荐答案,人工选择回答 。我们这里举几个例子:比如说上班的时候人工来回答,下班的时候机器人来回答;普通的客户机器人来回答,VIP 客户人工来回答;或者是说分渠道来选择,比如说微信渠道来的机器人回答,手机渠道来的人工回答;还有就是机器人优先,机器人答不出来,转给人工回答。

2. 智能客服的工作原理

刚才我们是给智能客服做了一个概述。接下来,我们介绍一下智能客服的工作原理。一个常见的智能客服,就包括以下这些模块并且按照一个类似的流程进行工作。

  1. 识别模块:首先可能会有一个 ASR(语音识别)模块,也可能没有,这取决于具体厂商的一个选择,这个语音识别模块会把语音转换成文字。如果没有语音识别模块,直接就是文字。
  2. 意图识别:对这个文字做一个问句的理解,或者说做一个查询的理解,理解完以后,再对意图做一个识别;
  3. 机器回答:最后,我们把这个问句的理解和意图识别的结果带到对话管理系统里边,对话管理系统会决定到底是给哪一种机器人发过去,这些机器人最后给出答案,将答案返回。

对话管理系统可以选择一个机器人将问题发过去,也可以同时将问题发给所有的机器人,当它们都回复答案时,进行答案选择再返回,使用哪种方式取决于厂商自己的一个选择。上图中这四种机器人分别对应了四种不同的模块:

  • 第一种是任务管理类的模块,比如说订机票,它属于一个特定的任务,这种机器人就类似苹果的 Siri,是任务处理类;
  • 第二种是知识库问答,也就是咨询问答类的,只是做一些咨询类的工作,一般情况下,它并不处理实际的一些任务;
  • 第三类是知识图谱问答,知识图谱是知识库常见的是提供一个问答对结构和一个树型结构,知识图谱提供一个图结构,可以认为是一个广义上的知识库问答。
  • 第四类是聊天机器人的技术,聊天并不是客服的首要功能,客服主要是解决问题的,不是来聊天的,为什么在一个智能客服系统里面会有聊天这么一个功能呢?原因在于,一是在用户没有输入知识库内容的时候,这个聊天机器人会被客户当成是测试厂商机器人技术能力的评测对象;二是在某些场景下,会让整个客服对话没那么单调。

2.1 自然语言理解

自然语言理解主要做一些什么事情呢?比如说用户的问题如果是多句话,那么我们做一个“分句”,对每一句话来寻找答案,最后呢,将答案组合起来,发给用户;“分词”很常见,分词后才能理解,才能进行标注,进行实体识别,这是常规的一些处理,然后就是句法分析、指代消解,再有就是词权重、语义相似度等等,做这些分析都是为后面的算法做准备,这是第一部分的预处理工作,就是自然语言理解或者自然语言处理的内容。

2.2 意图识别

第二部分的预处理工作就是意图识别。意图识别主要是用户的这句话暴露了用户什么样的意图,比如说我们这个例子里:“今天天气怎么样”,这个意图实际上就是用户要问天气。那么如果用户说“帮我定一张去上海的机票”,这个意思就是用户要订机票。

那么意图识别一般是怎么实现的?就是有模板和分类器两种方式。

模板的方式,比如说:“北京今天天气怎么样?”我们会建一个叫“city”的词典,这里面会有北京、上海、天津等城市;我们会把今天、明天、后天等等也做一个词典,词典名字叫做“date”。这样如果满足刚开始有一个“city”,中间有任意字符串,然后再有一个“date”,然后再有“天气”这个词,就满足了一个模板,那么我们基本上可以认为它是一个询问天气怎么样的意图,这是模板的方法。

分类器的方法很容易理解,我们在某一个特定领域里面收集大量语料,人工去标注这些语料是属于哪种意图的,用分类器模型来做一些二分类或者多分类的分类器,用来判断意图。但是分类器方法需要大量人工标注的数据,以及如何去收集多个领域里面的语料的问题。

基于知识库的问答可以使用检索或者分类模型来实现。检索式回答的流程是:首先对用户的输入问题做处理,如分词、抽取关键词、同义词扩展、计算句子向量等;然后基于处理结果在知识库中做检索匹配,例如利用BM25、TF-IDF或者向量相似度等匹配出一个问题集合,这类似推荐系统中的召回过程;

由于我们是一个问答系统,最终是直接返回给用户一个答案,因此需要从问题集合中挑出最相似的那个问题,这里会对问题集合做重排序,例如利用规则、机器学习或者深度学习模型做排序,每个问题会被打上一个分值,最终挑选出top1,将这个问题对应的答案返回给用户,这就完成了一次对话流程。在实际应用中,我们还会设置阈值来保证回答的准确性,若最终每个问题的得分低于阈值,会将头部的几个问题以列表的形式返回给用户,最终用户可以选择他想问的问题,进而得到具体的答案。

2.3 知识库

知识库问答的技术本质也是用一些跟搜索引擎相似的技术,分为两个阶段:第一个阶段是侯选集召回,第二个阶段是重排序。

首先是侯选集,侯选集召回有很多种方式,和搜索引擎相比,相对简单,原因是搜索引擎要召回的量特别的大,但是知识库,因为是人工导入的,它的召回的就没有那么复杂。

第二是重排序,其实我们可以用文本相似度、检索相关度,如果有足够数据的话,还可以用神经网络的语义相似度等,来做重排序工作。这些工作也可以用多模型融合的方式来做,将多个模型的结果综合考虑得到最终结果。这些都跟搜索引擎的技术没有特别本质的区别,也会有些微小的差别,这是知识库这块的工作。

2.4 知识图谱

知识图谱(Knowledge Graph),在图书情报界称为知识域可视化或知识领域映射地图,是显示知识发展进程与结构关系的一系列各种不同的图形,用可视化技术描述知识资源及其载体,挖掘、分析、构建、绘制和显示知识及它们之间的相互联系。

知识图谱问答最难的一点在于数据的整理,其次是工具方面。有很多开源的工具,例如:Neo4j、OrientDB、Titan。

假设我们解决了数据来源和更新的问题,同时也有了工具,接下来要做的事情就是查询转换的工作。因为一般的知识图谱工具都会有一些自己的查询语言,那么我们所要做的工作实际上就是把自然语言通过某种方式转换成知识图谱的工具所支持的查询语言。

查询转换也有常见的两种方式,一种是可以用模板,做一些查询转换的工作。

2.5 对话技术

对话技术就是我们前面所说的任务对话等等,比较典型的有三大类:

  1. 第一大类是一种用状态机,或者和状态机类似的填槽方式。这种方式的主要特点是将整个的对话过程抽象成一个有限状态机,每一轮对话,或者每几轮作为一种状态,随着对话状态的进行,这个状态机在不断的迁移,最终对话结束,状态机也结束。这里面的所有状态,以及所要执行的动作都是事先约定好的,所以状态机它比较适合一些场景简单的对话,对于场景复杂的对话,状态机这种方式就已经不太适应了。
  2. 第二大类就是马可夫决策过程(Markov Decision Process, MDP)的方式,它和状态机的区别在于它里面增加了动作,状态机里面的动作是我们事先约定好的,是固定的动作,已经事先知道对话到了那时候,于是就固定的采取这样的动作,但是 MDP 这种方式,状态不确定,动作也不确定,所以说我的状态和动作是需要根据我的上一个状态和将要采用的动作做了以后的回馈(Reward)来进行决策的,所以说这个决策过程在特定领域里有足够的语料的时候可以做出很好的效果,但是我们得想办法去找到合适的领域,以及找到足够的语料才能做这样的事情。
  3. 最后一类是端到端的模型。端到端的模型主要出发点是:我有一个问题,把问题输入到一个模型里面之后,这个模型是帮我解决了我们之前整个对话过程所有流程的所有问题,而这个模型是需要从数据里面去学习,包括自然语言处理、意图识别,包括整个系统里面方方面面的各种东西都要学习到。这个模型对于我们来说它是个黑盒,我给它一个问题,它也能给我答案,我并不需要仔细的去研究里面是怎么做得,我只需要设计训练这么一个模型就行了。

那么这三种方式是现在的比较常见的三类对话技术,第一大类,像状态机和填槽这一类是商用系统的主流;第二大类是学术界的主流,但是工业界也在积极的尝试,有的也已经落地,或者接近落地;端到端这种模型,主要还是停留在学术界的研究阶段,我并没有看到哪一个商业系统已经做到了端到端的模型的产品化,还没有成为商用主流的技术。

2.6 聊天机器人

在智能客服系统里面通常都会有聊天机器人的模块。这个模块主要有三种做法:

  1. 第一种就是检索式,比如答案是事先编辑好的,并不会随便生成,在检索式里面又会分为两大类:第一类是用大量的语料和模型来训练,收集大量的语料,把问题和答案给一个神经网络的模型,用这个模型帮我去找到问题和答案之间的相关度,这样的话,就能够用大量的语料训练出聊天机器人模型,这是最常见的一种方式;
  2. 第二种方式是基于规则来做,使用类似于之前介绍过的 Alice 机器人所用到的 AIML 标记语言,写大量的 pattern,以及在这个 pattern 下所需要的答案,写大量这样的人工规则就可以做一个检索式的机器人,但是这仅限于少量的小规模应用,如果需要编辑大量的规则,规则之间可能会有冲突等问题,所以主流的这种聊天机器人的方式是我们说到的第一种,用统计模型和大量的语料来训练聊天机器人。
  3. 第三种是生成式的聊天机器人,我需要把我的答案直接生成出来,这种方式是需要限定在一定的领域里面。开放领域里直接生成式的聊天机器人会有一些敏感词的问题,因为语料一般是网上收集的,想做到所有语料都人工审核成本是巨大的。所以说生成式需要把它限定在一个特定的领域里面,生成式分为两种:一种是纯粹的生成,一种是基于一些模板来生成。

3. 整体架构

整体技术架构如下图所示,包括基础服务层、应用服务层、编辑运营层、接入层以及在线客服系统。基础服务层提供对话系统的基础技术能力,系统需要对用户输入的一段语句进行理解,这里需要自然语言理解模块,对语句进行分词、词性标注、实体识别、关键词抽取和句法分析等;同时需要识别用户的意图,包括通用意图和业务意图,通用意图是指用户是来做业务咨询还是闲聊,业务意图是指若用户是做业务咨询,具体咨询什么业务,这里会使用文本分类的技术去识别用户意图。

基础服务之上是应用服务层,这一层具体实现了KB-Bot基于问答知识库的机器人、Task-Bot任务对话型机器和Chat-Bot闲聊类型机器人,这是智能客服系统的三种核心能力。编辑运营层是指有一个编辑团队支撑算法策略迭代,主要完成数据标注、问答运营、数据分析和效果评估的工作,这些工作输出会作用到基础服务层和应用服务层。基于应用服务层,对外提供通用的接口服务以便于业务方接入。此外,机器不是万能的,用户有很多复杂的问题仍需要人工解决,这里有一套在线客服系统提供了人工在线客服的能力,应用服务层会和这套在线客服系统做无缝对接。

4. 评价体系

智能客服系统需要有一个完备的评价体系去评价它的好坏,在我们的评价体系中有基于人工标注的评价和基于用户反馈的评价两种方式:

  1. 基于人工标注的评价

    系统的回答能力受限于知识库的丰富程度,因此并非能回答用户的所有问题,系统最佳的状态是将能回答的全部回答准确,不能回答的全部拒识,即拒绝回答。因此这里的评价指标包括有结果率、拒识率、召回率和准确率等,我们的目标是让系统的有结果率无限接近数据的真实有结果率,召回率和准确率尽量高。这里我们是通过标注标准评测集来计算系统的各项指标,我们会从每日的全量数据集中抽样出一个小数据集,保证小数据集的数据分布尽量符合全量数据集,然后由标注团队对数据集做标注,标注出每个问题的实际答案,一般标注完成后还有质检的环节,以保证标注结果尽量准确,这样便生成了每日数据的标准评测集。基于该标准评测集我们会去评价系统的好坏,并且每次做新模型迭代时都会使用标准评测集去评价新模型,只有新模型的效果好了才允许上线。

  2. 基于用户反馈的评价

    人工评价能够评价智能客服系统的准确率,但是答案是否合理,能否为用户解决问题,需要用户去反馈评价,整个智能客服系统的最终目标是帮助用户解决问题。我们会在产品上设计智能客服和在线客服的评价功能,例如会让用户评价智能客服的每个答案或者某次会话,在和人工客服聊天完毕会发送评价卡片给用户去评价满意度。最终我们会统计参评比例、满意度等指标,这些指标能够真正反应智能客服系统的好坏。实际中往往用户参评比例低,我们会使用各种方法去刺激用户评价。

5. 参考文献

15年研发经验博士手把手教学:从零开始搭建智能客服


作者:@mantchs

GitHub:https://github.com/NLP-LOVE/ML-NLP

欢迎大家加入讨论!共同完善此项目!群号:【541954936】NLP面试学习群


 评论