MRCP在美团语音交互中的实践和应用

news2025/1/11 18:49:09

当你和智能语音机器人对话交互时,你是否好奇电话背后的机器人如何“听懂”你的意思,又如何像人一样“回答”你的问题?其中比较重要的技术就是 MRCP。本文主要介绍了 MRCP 在美团语音交互中的实践和应用,基于美团自研的语音识别及语音合成能力,我们提升了外呼通话的成功率,并且保证了更好的用户体验。

  • 一、背景

    • 1.1 MRCP 是什么

    • 1.2 MRCP 使用场景

    • 1.3 美团自研的 ASR/TTS 能力

    • 1.4 我们为什么需要 MRCP

  • 二、设计与实现

    • 2.1 设计目标

    • 2.2 总体系统架构

    • 2.3 关键技术组件

    • 2.4  MRCP-Server 模块结构

    • 2.5 部署方案

  • 三、实践与应用效果

    • 3.1 应用范围

    • 3.2 应用效果

  • 四、结语

  • 五、名词解释

一、背景 

智能语音对话作为人工智能领域最先落地的分支之一,可以实现与人进行自然语言多轮对话,其核心技术在近年来不断地发展成熟,包括语音识别、自然语言理解、对话管理等。伴随着技术的成熟,越来越多的电话机器人开始走进我们的生活,这些电话机器人在客户服务、智能销售、通知触达等场景发挥着重要的作用。

当你和智能语音机器人对话交互时,你是否好奇电话背后的机器人如何“听懂”你的意思,又如何像人一样“回答”你的问题?经典的技术实现路径是:机器人首先通过“语音识别(ASR)”将用户输入语音识别成文字,再通过“自然语言理解(NLU)”识别意图,之后根据意图、系统信号等输入结合对话管理技术得到相应的回复,最后通过“语音合成(TTS)”生成语音播报给电话对端的用户。但要将 ASR、TTS 这些技术应用到电话系统上,还需要一些额外的工作和技术支撑,其中比较重要的技术之一也就是本文将要介绍的 MRCP

备注:本文涉及较多的专业名词,我们特别在文末附上了名词解释,以帮助大家进行阅读。

|  1.1 MRCP 是什么

MRCP(Media Resource Control Protocol, MRCP)是一种通讯协议,中文定义是:媒体资源控制协议,用于语音服务器向客户端提供各种语音服务(如语音识别和语音合成)。该协议定义了控制媒体处理资源所必需的请求(Request)、应答(Response)和事件(Event)等消息,它需要借助 RTP(Real-Time Transport Protocol, 实时传输协议)创建一个媒体会话、借助 SIP(Session Initiation Protocol, 会话初始化协议) 和 SDP(Session Description Protocol, 会话描述协议) 创建一个控制会话来实现媒体资源服务器端和客户端之间的控制[1]。

在传统的语音应用中,各集成商必须针对不同的 ASR/TTS 厂商提供的 API 接口进行专门的集成开发,不同 ASR/TTS 引擎的接口各不相同,从而导致了集成过程的复杂性和局限性。因此,在实现语音和网络技术集成方面必须需要比较规范的协议来进行处理。MRCP 协议是目前针对媒体资源和 IP 网络起草的标准协议。有了 MRCP 协议后,ASR/TTS 厂商提供 MRCP 协议的标准统一接口,语音集成开发商们不必再针对特定的 ASR/TTS 进行开发,为各种语音应用开发提供了更加灵活的选择,并有效地降低业务开发周期和成本[2]。

以语音合成(TTS)为例,图 1 展示了一个 MRCP 客户端连接媒体资源服务器的流程,在连接中会创建一个媒体会话和一个控制会话。假设连接成功,此时 MRCP 客户端对服务器端发起了一个 SPEAK 语音合成的请求,处理此请求的过程中包括了3个消息指令:SPEAK指令表示发送语音合成请求,IN-POGRESS指令表示正在处理中,SPEAK—COMPLETE指令表示处理完成[3]。

9e59accf434f268d92f24f23805a1608.jpeg

图1 MRCP 协议交互

MRCP 协议的消息格式和 HTTP 消息格式类似,如下以一次语音合成的 MRCP 消息为例,展示了 MRCP 消息的主要构成。

发起语音合成请求:

MRCP/2.0 380 SPEAK 14321
Channel-Identifier: 43b9ae17@speechsynth
Content-Type: application/ssml+xml
Content-Length: 253

您好,有什么能帮助您?

IN-PROGRESS 响应消息:

MRCP/2.0 119 14321 200 IN-PROGRESS        
#消息长度是119 bytes,ID是14321,200 表示成功,正在处理中
Channel-Identifier: 43b9ae17@speechsynth
Speech-Marker: timestamp=857206027059

COMPLETE 响应消息:

MRCP/2.0 157 SPEAK-COMPLETE 14321 COMPLETE
Channel-Identifier: 43b9ae17@speechsynth
Speech-Marker: timestamp=861500994355
#表示SPEAK请求的正常处理结束
Completion-Cause: 000 normal

|  1.2 MRCP 使用场景

目前,语音行业几乎所有的重要厂商都承诺支持 MRCP。MRCP 使用场景丰富,它支持目前最热门的开源语音通信平台 Asterisk 和 FreeSWITCH ,并且提供了丰富的接口文档,其中呼叫中心就是一个典型的案例。一个简单的呼叫中心如下图 2 所示:

3ed8a214660f2fe16222dfd20e3d4d0e.jpeg

图2 简单呼叫中心系统示意

  1. 当分机拨打外呼用户时,需要从运营商那里获得一条电话通讯线路,FreeSWITCH 指定路由通过网关到达运营商线路,通过运营商基础网络、连接用户通讯设备终端。

  2. 智能语音服务通过 MRCP 协议与 FreeSWITCH 进行对接,用户接通电话后,智能语音服务从呼叫中心设备中实时获取声音讯号,将语音讯号转化为文本流实时输出,并将要回复的文本话术经过语音合成转化为语音讯号,交由呼叫中心进行语音播报。

在此场景中可以看到,采用 MRCP 协议,调用方仅需要面向 MRCP 接口撰写程序,而无需考虑不同语音引擎产品之间的差异,可以真正做到一次开发、多种环境下应用,任何支持 MRCP 标准的语音引擎都可以被无缝集成和调用。

|  1.3 美团自研的 ASR/TTS 能力

自 2018 年起至今,美团语音交互部持续投入语音识别(ASR)和语音合成(TTS)的自主研发,目前已形成平台级的服务能力。美团语音识别重点针对美团场景进行优化,相比通用场景的识别率更高;参考 2022 年的数据,在电话呼叫场景的测试集中,美团语音识别的字准率达到 94.6%(很多业界头部厂商的字准率在 89% 左右)。在骑手语音助理、客服中心语音转译、美团 App / 外卖 App语音助理等典型业务场景中进行了落地和应用。

美团语音合成从美团各场景出发,建立起从端到云一体化,全面覆盖客服、配送、听书等各个方向的合成音色群,并支持不同数据量级的语音定制化能力,做到了通用场景好、特色场景精、定制周期短。其中现有声音的客服场景效果已领先于行业,具有小样本声音克隆、强表现力的配音能力,在性能和效果层面达到了业界一流水准;同时,美团语音合成在美团外卖配送、美团商家端、美团打车、美团客服等核心业务场景落地,支持日均亿级别的调用。

|  1.4 我们为什么需要 MRCP

1.4.1 赋能内部业务

随着美团自研的 ASR/TTS 逐步达到业界一流水平,美团内部越来越多业务接入美团自研的 TTS 和 ASR 能力。特别是 TTS,在应用的业务场景中取得超过外采系统捷通华声的效果,但在业务对接和优化过程中,也存在一些问题,可以概括为音色机械、音色不统一、合成延时过高等。

这几类问题,主要是在业务升级替换音色过程中,采取了将业务系统(如外呼系统)与语音的合成和识别能力的 HTTP/RPC 接口直接对接的方式,这种方式不仅投入大,需要逐个业务系统、逐个流程的对接,也容易因为系统复杂性、运营疏漏等问题出现音色不统一等体验问题。因此,按行业通用标准,以 MRCP 将语音合成和识别与电话系统直接对接的方式,可以有效地降低业务使用、升级语音能力的成本,平滑地提升用户体验。

音色不统一示例:对话流程中,一部分固定的话术文本使用的提前合成好的音频文件,另一部分动态的话术文本(如,录音中“请问你是某某店吗”)采用的实时合成的音频,两部分拼接在一起播放,音色不统一。

延时过高示例:部分业务对于动态话术文本,特别是本身句子较长的话术,待一整句合成完成后再播放到用户,给用户带来严重的迟滞感。

1.4.2 支撑对外商业化

另一方面,越来越多美团外部企业如中通天鸿、微呼科技、马上消费金融等,认可并计划接入美团语音自研的 TTS 和 ASR 能力;预期以标准的 MRCP 协议完成对接,在客户服务、通知触达、电话提示语音识别等场景,提升其呼叫中心的基础用户体验。

 二、设计与实现 

|  2.1 设计目标

如下图 3 所示,美团的小美机器人平台、木星通讯平台分别提供不同类型的语音对话机器人能力。以语音合成(TTS)为例,这些机器人平台直接调用 TTS 引擎的服务接口,将合成好的语音文件交由电话软交换平台(如FreeSWITCH)去播报,如链路 ① 所示。

我们的目标是将这种调用关系简化,以标准 MRCP 下的语音合成服务对接电话软交换平台,那么上述机器人平台则只用核心关注机器人的对话逻辑,将具体的语音合成逻辑解耦出来,那么链路 ② 所传递的内容即为机器人待播报的话术文本,由电话软交换平台去调用和处理语音合成。

98a384e8df90a65300d441efa5333f37.jpeg

图3 语音能力与业务系统对接方式比较

总而言之,目标结合自研流式 TTS 和 ASR 能力,建设 MRCP 协议下标准的语音合成和识别服务,达到:

  • 支持标准协议下的 TTS 和 ASR 能力对接方式,追齐业界主流厂商能力。

  • 以横向可扩展、业务解耦的方式,支持和助力美团内部业务,在智能外呼、内呼热线等场景下提升用户体验;并为美团语音能力的对外商业化探索,提供更好的支撑。

|  2.2 总体系统架构

2.2.1 系统层次架构

在系统层次上,围绕联络场景,美团语音交互部正在建设全联络场景智能化的平台化解决方案。具体来说,美团智能对话平台 AICC(AI for Contact Center),基于美团语音交互部领先的语音识别、自然语言理解、多轮对话、知识图谱等人工智能技术,为美团业务提供智能文字客服(在线客服)、智能语音客服(热线客服)、智能外呼、智能营销、智能质检等完整解决方案;帮助业务从传统服务模式向智能服务模式转型,助力美团业务的服务成本优化、客户服务体验提升,实现客户服务及营销智能化升级。

AICC 的层次架构如下图 4 所示,从整个 AICC 架构来看,TTS 和 ASR 处于语音技术平台,提供语音合成和识别的 PaaS 级能力;相应地,MRCP-TTS、MRCP-ASR扩充已有的 HTTP/RPC 接口的能力范围。

25c0ae965a36f851aad4e439b8747ec9.jpeg

图4 MRCP在AICC层次架构中的位置关系

2.2.2 系统间调用关系

以热线电话机器人的系统调用过程为例,MRCP 在系统中所处的位置以及同其他各环节的配合关系如下图 5 所示:

4f70c76fc8728e680220abbbe1170717.jpeg

图5 MRCP服务调用关系

  1. FreeSWITCH 电话软交换平台,负责和运营商打通通讯线路,以具备基础的电话通讯能力。

  2. FreeSWITCH 除了以内置模块(

    如 mod_java

    )的方式开发控制接口外,也以 ESL(

    Event Socket Library

    )的 Inbound/Outbound 方式开放接口,提供事件监听、通话控制等能力。

  3. ESL Server 将监听到的事件、消息传递给具体的业务逻辑,可以提供通讯层所有的事件供监听和处理,籍此实现机器人的语音对话交互能力。

  4. 将调语音相关的事件和信号处理解耦以后来看,热线、在线机器人的交互逻辑则可以简化、抽象为统一的模型和系统。

  5. 管理配置台主要负责一般对话机器人所需要的意图、槽位的定义、管理和配置任务型对话流程。

  6. 配置管理也可对 ASR、TTS 引擎需要的领域知识进行管理,比如客服领域的词库、样本数据集的持续标注等。

  7. 本文所述的MRCP在系统调用中处于此位置:在FreeSWITCH 收到合成/识别请求后,发起与 MRCP-Server 的交互,MRCP-Server 调用内部实现的 MRCP-TTS Plugin 与 MRCP-ASR Plugin 分别完成相应的合成或识别结果。

  8. ASR Engine 和 TTS Engine 指美团语音自研的语音合成和语音识别引擎,MRCP 通过 HTTP/RPC 接口与之完成通讯。

|  2.3 关键技术组件

要实现一个工业可用的 MRCP Server,有两个关键技术能力:一是 MRCP 协议本身的支持,二是 MRCP Server 的高可用,如多节点的负载均衡。

2.3.1 MRCP 协议实现

对于 MRCP 协议的实现,不仅仅需要支持 MRCP 协议本身,也需要支持一套完整的协议栈,包括文章开头部分提到的 SIP、RTP 协议等,这是一个复杂且庞大的工作。

参考业界的一般做法,我们选择基于开源的 UniMRCP 完成这些工作。UniMRCP 是一个开源的、跨平台的 MRCP 协议实现,由 C/C++ 语言编写,包括了 MRCP 客户端和服务端两个部分,它封装了 SIP、SDP、MRCPv1、MRCPv2、RTP/RTCP 协议栈,并为语音服务集成商提供了一致的 API[4]。

UniMRCP 完成了 MRCP 协议栈的封装,并没有实现 ASR 或 TTS ;基于其对底层协议栈的完整支持,我们在 UniMRCP的框架下实现相应的 Recog(ASR)和 Synth(TTS)插件(即 MRCP-TTS Plugin,MRCP-ASR Plugin),并改造适配美团日志框架、监控打点等基础技术组件,从而保障服务的稳定性和可维护性。

2.3.2 MRCP Server 负载均衡

对于实现 MRCP-Server 的负载均衡,我们选用开源的 Kamailio 来完成。Kamailio 的前身叫 Openser,作为出色的 SIP proxy,在大并发量使用时常常用于负载均衡媒体服务器,对 Asterisk、FreeSWITCH、MRCP 等实现集群能力[5]。Kamailio 经常与 FreeSWITCH 配合使用,最常用的场景是 Kamailio 作呼叫负载均衡服务器(一般主备配置),FreeSWITCH做媒体相关的处理如转码、放音、录音、呼叫排队等。

|  2.4  MRCP-Server 模块结构

由于 UniMRCP 提供的基础框架已经实现了服务接口、连接管理、协议管理,如何加载自定义插件,以及系统层的日志框架;并且 TTS 引擎与 ASR 引擎作为基础的依赖,已以 HTTP/RPC 协议的方式提供稳定的基础语音服务。因此,开发工作是在 UniMRCP 的基础上进行 TTS/ASR 插件的开发,模块结构如下图 6 所示,主要新增的模块已在图中标灰,其中:

6ca36bc281395ab3aecfed11bc8589ba.jpeg

图6 MRCP服务模块结构

  • MRCP-TTS Plugin 和 MRCP-ASR Plugin 两个为核心的模块,以插件的形式加载到 MRCP-Server。

  • MRCP-TTS Plugin 和 MRCP-ASR Plugin 抽象出公共的模块:

    • 事件/接口管理:订阅和注册 MRCP-Server 收到事件和消息,如信道建立事件、请求消息等等。

    • 会话管理:管理会话的创建、打开、关闭、销毁过程。

    • 线程池管理:管理调用 TTS 和 ASR 引擎服务接口所需的任务线程池。

    • 配置管理:读取配置文件对各自 Plugin 定义的配置项。

    • 语音数据处理:包括语音数据缓冲、时长计算等。

    • 服务注册:负责将服务注册到 OCTO,支持 MRCP 服务实例激活、摘除的自动发现。

  • 应用日志模块,将插件这一层的日志与美团的日志框架打通,将应用日志接入美团日志中心。

  • 监控打点模块,将合成首包延时、状态事件等支持,接入美团 Raptor 监控平台。

  • 鉴权模块,使用美团语音开放平台的统一认证服务,完成调用 TTS 和 ASR 引擎前的鉴权过程。

|  2.5 部署方案

在语音交互场景中,用户可以连续不间断的“说话”并听到“回应”,是保证本次交互顺利完成的重要基础。因此,高可用是 MRCP-Server 在部署方案设计中核心关注和考虑的维度,部分节点故障不影响整体的可用性,并可以快速摘除、恢复、替换故障节点。其中,关键的措施包括:

  • 统一的服务入口:使用美团 MGW(

    美团内部自研的四层负载均衡网关

    ) 创建固定的虚拟 IP (VIP),提供唯一的服务访问入口。

  • 资源隔离:为了减少语音合成和语音识别服务彼此间的影响,我们将 MRCP Server 拆分成两个服务,即 MRCP-TTS 和 MRCP-ASR,对二者进行隔离部署。

  • 跨地域、多机房部署:将 MRCP-TTS 和 MRCP-ASR 服务部署在多个机房,并且跨地域部署,以提高服务稳定性。

  • Kamailio 热备:为了防止 Kamailio 出现故障以影响整个链路,我们对 Kamailio 也采用了跨地域、多机房的部署,并且由 MGW 完成对 Kamailio 的多机热备。

  • 负载均衡:显而易见地,需要对 MRCP-TTS 和 MRCP-ASR 进行负载均衡。如何进行负载均衡?起初我们打算直接使用 MGW 对 MRCP-TTS 进行负载均衡,MGW 是支持到传输层的四层负载均衡,可以路由分发到具体的服务。在我们场景中所使用的 SIP、MRCP 均属于应用层的协议,数据传输基于 TCP/UDP,理论上四层负载均衡能够满足需要。但实际协议交互过程中,支持七层负载均衡的 Kamailio 能够在 SIP 协议经过的路由点时,在协议头中加入 <Via address><Contact address> 等字段,层层路由能够始终保持与同一台机器进行交互。比如,客户端通过 SIP-INVITE 经由 Kamalio 与 MRCP服务完成握手后,结束服务、客户端发送 SIP-BYE 消息时,Kamailio 可以准确路由到当时接受 INVITE 消息的同一个 MRCP 服务。因此,最终使用 Kamailio 完成对 MRCP-TTS 和 MRCP-ASR 的负载均衡。

对应地,整体部署如图7所示,在美团通过这种部署方式为业务提供稳定可用的服务。

f65775de47e93927ff3faec616438f56.jpeg

图7 MRCP整体系统部署方案

 三、实践与应用效果 

|  3.1 应用范围

3.1.1 美团内部业务赋能

目前 MRCP 已经在美团内外呼热线电话下的多个业务场景中广泛应用:

  • 美团外呼业务语音合成:结合小美智能外呼与木星自动外呼,在美团内部的太平洋客服坐席辅助外呼、营销类外呼、通知触达类外呼等场景,逐步接入 MRCP 协议下的流式语音合成。目前已接入 MRCP 的外呼机器人日均百万次合成调用,峰值约千路并发。

  • 美团内呼业务语音合成:内呼主要是支持美团呼入热线的语音合成,包括:10107888-美团客服热线、10109777-外卖客服热线、10105777-美团商服热线、10101777-美团骑手热线以及其他长尾业务热线。目前已接入 MRCP 的热线呼入机器人日均近千万次合成调用量,峰值千余路并发。

3.1.2 外部商业化应用

在外部商业化落地过程中,客户一般要求将 MRCP-Server 私有化部署到客户机房,服务的运维工作由客户自行保证;MRCP-Server 本身在 8C16G 容器中测试,可承载约 600 路并发访问。目前已支持的美团外部客户包括微呼科技、中通天鸿等。

|  3.2 应用效果

MRCP 将语音合成和识别能力接口标准化以后,在美团对接了外采的 Genesys 电话系统(主要支持内呼电话),以及自研的木星通讯系统(主要支持外呼电话),也在支持语音合成和识别能力商业化的过程中对接了中通天鸿、微呼科技等外部公司的电话系统。在这些业务对接和支持的过程中,一次开发多处复用,相较于早期的对接方式,极大提高了业务支持的效率。

此外,对于使用 MRCP-TTS 的业务,在语音合成的性能有明显提升,具体体现在:首包延时显著降低,且与待合成的话术文本句长无关。此前,使用 HTTP 接口进行整句合成播报,以大约 6~8 字每秒的合成速度、需要整句完成后用户才能听到声音。目前,MRCP-TTS 支持一边合成一边为用户播报语音。

从线上观测来看,内呼机器人的端到端延时降低了约 55%,外呼机器人的端到端延时降低了约 33%,并且做到了音色统一、无变量导致的音色跳跃问题。从业务使用 MRCP-TTS 前后的业务指标对比来看,有较为显著的效果:

  • 在美团电话热线的呼入场景,使用 MRCP-TTS 升级原来的语音播报服务后,不满意度下降 0.25pp~3.92pp,平均电话服务时长缩短 2.19s~5.3s,可见 MRCP-TTS 的应用带来了更好用户体验。

  • 在美团的智能外呼场景,结合 MRCP-TTS 提供流式语音合成服务后,对外呼机器人进行替换自研音色「美凡楠」的 A/B 试验,数据表明智能外呼通话成功率有效提升了 15% 。

在业务支持中,我们结合 MRCP 提供了多种音色,音色更加丰富真实,尽可能满足各个业务场景。下面列举了部分实际业务过程的录音,以及前文提到的语音合成问题改善情况。

卡顿优化

播报文案为:“我是美团网的,本次来电是想确认一下商家信息,方便用户找到您家的,请问您这边是许吉凉水吗?”

| 升级前:

| 升级后:

机械优化

播报文案为:“非常抱歉,查询到您的订单收货已超过48小时,由于生鲜商品容易腐烂,因此暂不支持超48小时的售后退款,下次遇到问题还请您尽早反馈,给您带来的不便我们深感抱歉。”

| 升级前:

| 升级后:

延时优化

对话过程如下:

客服:为尽快找到合适的客服人员,请用一句话描述您想咨询的服务及问题,我的外卖到哪了?酒店如何退单?
用户:我要退款。
客服:好的,请问是好邻居连锁便利这个外卖订单吗?
用户:不是。
客服:好的,那请问您要咨询的是达美乐比萨这个外卖订单吗?
用户:不是。
客服:为尽快找到合适的客服人员,请问您是要找美团外卖、休闲娱乐、还是酒店住宿的客服呢?
用户:不是。
客服:好的,那请问您要找账户登录手机解换绑小美果园及手机充值问题的客服吗?
用户:我要退款。
客服:正在为您转接人工。

| 升级前:

| 升级后:

 四、结语 

MRCP 协议及相关技术已经相对成熟,围绕技术本身而言的迭代和演进相对较少。未来,除了语音合成(TTS)和语音识别 (ASR) 外,语音交互部自研的声纹识别(VPR)技术也逐步成熟;其中,娇喘识别效果大幅提升、目前性能已超过头部厂商服务,年龄识别误差小于 7.5 岁(公开测试集评测)。预计结合 MRCP 在电话智能等场景提供相应技术能力,支持优化和提升业务流程及效果(如金服生意贷场景,通过声纹识别判断是否为虚假申贷人,减少恶意申贷造成的损失)。

从技术运用上看,一方面 MRCP 协议下的 TTS、ASR 为美团智能外呼机器人、智能呼入机器人等多个业务场景提供稳定的服务,并带来可观的业务效果提升;我们预期将其接入更多的业务场景,以客户为中心、给每一个用户带来流畅丝滑的人机对话体验,助力业务优化。另一方面,在标准化的 MRCP 协议接口的承载下,持续推进美团 TTS 和 ASR 能力的商业化。

 五、名词解释 

3e6445e27795ee39460137e0a7dbdfe9.png

 六、本文作者 

唐锐、森彬、子丰、亚男、王程、国桥、俞涛等,均来自美团平台/语音交互部。

 七、参考文献 

[1] Media Resource Control Protocol (2022) Wikipedia. Wikimedia Foundation. Available at: https://en.wikipedia.org/wiki/Media_Resource_Control_Protocol.

[2] 史俊波,詹舒波 (2010) MRCPv2协议及其在分布式语音资源解决方案中的应用, 中国科技论文在线-科技论文. Available at: http://www.paper.edu.cn/releasepaper/content/201009-322.

[3] zhu, james (2018) MRCP概要, CTI. Available at: http://www.ctiforum.com/news/guonei/534456.html.

[4] UniMRCP Introduction (no date) Home. Available at: https://www.unimrcp.org/.

[5] Kamailio Introduction (2022) The Kamailio SIP Server Project | The Open Source SIP Server. Available at: https://www.kamailio.org/w/.

----------  END  ----------

 推荐阅读 

  | 对话摘要技术在美团的探索(SIGIR)

  | ACM MM顶会论文 | 对话任务中的“语言-视觉”信息融合研究

  | 检索式对话系统在美团客服场景的探索与实践

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/400890.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

动态规划入门经典问题讲解

最近开始接触动态规划问题&#xff0c;以下浅谈&#xff08;或回顾&#xff09;一下这些问题的求解过程。解题思路对于动态规划问题&#xff0c;由于最终问题的求解需要以同类子问题作为基础&#xff0c;故需要定义一个dp数组&#xff08;一维或二维&#xff09;来记录问题求解…

Vue 3.0 单文件组件 【Vue3 从零开始】

#介绍 在很多 Vue 项目中&#xff0c;我们使用 app.component 来定义全局组件&#xff0c;紧接着用 app.mount(#app) 在每个页面内指定一个容器元素。 这种方式在很多中小规模的项目中运作的很好&#xff0c;在这些项目里 JavaScript 只被用来加强特定的视图。但当在更复杂的…

[Java·算法·中等]LeetCode39. 组合总和

每天一题&#xff0c;防止痴呆题目示例分析思路1题解1分析思路2题解2&#x1f449;️ 力扣原文 题目 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target &#xff0c;找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 &#xff0c;并以列表形…

Golang Map实现原理分析与解读

一、map的结构与设计原理 golang中map是一个kv对集合。底层使用hash table&#xff0c;用链表来解决冲突 &#xff0c;出现冲突时&#xff0c;不是每一个key都申请一个结构通过链表串起来&#xff0c;而是以bmap为最小粒度挂载&#xff0c;一个bmap可以放8个kv。在哈希函数的选…

配置临时SSL子域名泛化证书

配置临时SSL子域名泛化证书 三个月有效期第一步&#xff1a;访问SSL证书地址第二步&#xff1a;在华为云上/其他服务器上搜索DNS云解析服务类似的功能第三步&#xff1a;将SSL申请的信息添加到服务器的记录集中第四步&#xff1a;添加完信息进行保存获取key / crt第五步&#x…

蓝桥冲刺31天之第七天

目录 A&#xff1a;三角回文数 B&#xff1a;数数 C&#xff1a;数组切分 D&#xff1a;倍数问题 一星陨落&#xff0c;黯淡不了星空灿烂&#xff1b; 一花凋零&#xff0c;荒芜不了整个春天。 如果命运是世界上最烂的编剧&#xff0c; 你就要争取做人生最好的演员。 即使生…

06_02_Spark Streaming

Spark Streaming 课程目标 说出Spark Streaming的特点说出DStreaming的常见操作api能够应用Spark Streaming实现实时数据处理能够应用Spark Streaming的状态操作解决实际问题独立实现foreachRDD向mysql数据库的数据写入独立实现Spark Streaming对接kafka实现实时数据处理 1、…

打怪升级之CFileDialog类介绍

CFileDialog类 CFileDialog封装用于文件打开操作或文件保存操作的常见对话框。信息来源自Windows官方文档&#xff1a;https://learn.microsoft.com/zh-cn/cpp/mfc/reference/cfiledialog-class?viewmsvc-170 这里重点介绍几个常用的函数功能&#xff1a; 构造函数 explic…

当我在ChatGPT上问重建大师,它居然这样回答我

最近&#xff0c;ChatGPT风靡全球&#xff0c;现象级走红至各大社交媒体。作为最快突破1亿月活量的消费者应用&#xff0c;是怎么样理解重建大师的呢&#xff1f; 今天小编与ChatGPT展开对话&#xff0c;它告诉我&#xff1a; 短短不到一分钟时间&#xff0c;ChatGPT已经概括出…

Grafana 监控面板绘制流程

本篇作者&#xff1a;IoTDB 社区 -- 张洪胤本文以 IoTDB V1.0.1 版本为例本文档介绍了 Apache IoTDB 监控指标通过 Prometheus 的方式进行采集&#xff0c;并且使用 Grafana 的方式进行可视化。1监控指标的 Prometheus 格式说明对于 Metric Name 为 name, Tags 为 K1V1, ..., K…

ABB机器人Offs坐标偏移功能的具体使用方法

ABB机器人Offs坐标偏移功能的具体使用方法 Offs功能说明: 在机器人的工件坐标系中添加一个偏移量 举例说明: 参数及数据类型: 在RobotStudio的仿真操作: 如下图所示,在程序中添加一个移动指令,并记录该点位为p10, 如下图所示,复制该指令语句, 如下图所示,选中…

Qt音视频开发22-音频播放QAudioOutput

一、前言 以前一直以为只有Qt5以后才有QAudioOutput播放音频&#xff0c;其实从Qt4.6开始就有&#xff0c;在Qt6中变成了QAudioSink&#xff0c;功能一样。用QAudioOutput播放音频pcm数据极其方便&#xff0c;只需要指定音频播放设备&#xff08;可能电脑上有多个音频输出设备…

力扣sql简单篇练习(二十六)

力扣sql简单篇练习(二十六) 1 每家商店的产品价格 1.1 题目内容 1.1.1 基本题目信息 1.1.2 示例输入输出 1.2 示例sql语句 # 多行变成多列,考虑用sum if分组 SELECT product_id,sum(IF(storestore1,price,null)) store1,sum(IF(storestore2,price,null)) store2, sum(IF(st…

mmdetectionV2.x版本 训练自己的VOC数据集

mmdetection目录下创建data文件夹&#xff0c;路劲如图所示&#xff0c;不带yololabels 修改配置文件 mmdet/datasets/voc.py 配置图片格式 mmdet/datasets/xml_style.py 如果图片是jpg则改成jpg&#xff0c;是png格式就改成png&#xff0c;这里我不需要改&#xff0c;本…

C++11:包装器

文章目录1. 介绍2. function包装器2.1 介绍2.2 示例1用法2.3 示例22.4 function包装器的功能统一类型简化代码2.5 意义3. bind包装器3.1 介绍3.2 bind包装器的功能绑定固定参数3.3 意义1. 介绍 C 包装器是一种用于给其他编程接口提供更一致或更合适的接口的技术。它可以包装任…

人工智能书籍——《奇点临近》

当人们看到太多相同的时候&#xff0c;也许我们很无知&#xff1b; 当人们看到太多不同的时候&#xff0c;也许我们视野不够大&#xff1b; 当人们同时看到不同和相同的时候&#xff0c;也许这恰是我们的智慧原点。 物质是静止的能量&#xff0c;能量是运动的物质&#xff0c;生…

04 HiveHBase

Hive 一 Hive基本概念 1 Hive简介 学习目标 了解什么是Hive了解为什么使用Hive 1.1 什么是 Hive Hive 由 Facebook 实现并开源&#xff0c;是基于 Hadoop 的一个数据仓库工具&#xff0c;可以将结构化的数据映射为一张数据库表&#xff0c;并提供 HQL(Hive SQL)查询功能&…

05 Spark_Core

01 spark 入门 课程目标&#xff1a; 了解spark概念知道spark的特点&#xff08;与hadoop对比&#xff09;独立实现spark local模式的启动 1.1 spark概述 1、什么是spark 基于内存的计算引擎&#xff0c;它的计算速度非常快。但是仅仅只涉及到数据的计算&#xff0c;并没有涉…

【5】基础语法篇 - VL5 位拆分与运算

VL5 位拆分与运算 1 自己犯的错误 &#xff08;1&#xff09;语法错误 在begin end块 后面加了" ; " case(sel)2b00: begin validout<0; out<0; end;2b01: begin validout<1; out<d0 d1; end;2b10: begin validout<1; out<d0 d2; end;2b11: be…

分享几个常用的运维 shell 脚本

今天咸鱼给大家分享几个不错的 Linux 运维脚本&#xff0c;这些脚本中大量使用了 Linux 的文本三剑客&#xff1a; awkgrepsed 建议大家这三个工具都要了解并最好能够较为熟练的使用 根据 PID 显示进程所有信息 根据用户输入的PID&#xff0c;过滤出该PID所有的信息 #! /b…