设备端接入文档

优质
小牛编辑
145浏览
2023-12-01

1.1.1. 开放平台 Websocket 协议 speech 接口定义文档

1.1.2. 概述

本文档目的是描述云端语音接口的 WebSocket 版本的开放协议,主要包含语音识别、语义理解、语音合成三大部分功能,主要面向想要了解语音交互细节,并具有一定开发能力的开发者或用户,该协议同时兼容云云对接和设备对接。

1.1.3. 协议详解

协议可分为以下部分:

索引

1.1.4. 服务地址

环境地址用途
线上wss://apigwws.open.rokid.com/api对外提供的正式稳定环境

1.1.5. 协议地址

1.1.6. 协议概述

此文档用于定义开放平台上云端应用接口开发协议,协议遵循 websocket 协议。协议采用先认证,再使用的方式,步骤如下:

  • 建立 wss 连接,注意是 websocket + ssl
  • 认证设备
  • 如果认证中 service 为 speech,则此连接后续可进行一次或多次语音交互,直至连接断开
  • 如果认证中 service 为 tts,则此连接后续可进行一次或多次语音合成,直至连接断开
  • 如果需要同时使用语音识别与语音合成,则需要建立两条 wss 连接,每条连接需要分别作认证

语音交互

流程
  1. 需要先进行 service 为 speech 的 设备认证
  2. 一次完整的语音识别的数据包以 id 来标识,称为一个 session
  3. 设备端发送三种类型的数据
    • START 设置 session 的参数数据
    • VOICE 发送 session 的语音数据
    • END 表示 session 结束
  4. 云端返回三种 RespType 的数据
    • INTERMEDIATE 返回 asr 的中间结果,典型的有 extra 中 activation
    • ASR_FINISH 返回 asr 识别结果
    • FINISH 返回 nlp 结果
  5. 每个 session 以 FINISH 结束
SpeechRequest
参数类型描述默认值
idint32唯一标识,用于跟踪一个完整的请求,处理及响应事件。0
typeReqTypeSTART、VOICE、END 或 TEXT
voicebytes需要识别的语音流
asrbytes需要理解的 asr 文本
optionsSpeechOptions辅助理解的选项,内容见下表

options 字段的详细说明

参数类型描述默认值
langstring语音流的语言,目前支持 zh-CN,en-US。zh-CN
codecstring语音流的编码,目前支持 PCM,OPU,OPU2,OPUS,AMRWB,AMRNB,PCM8K。
PCM,OPU,OPU2,OPUS,AMRWB 的语音数据格式为单通道,采样率16Khz,16bit;
AMRNB,PCM8K的语音数据格式为单通道,采样率8Khz,16bit;
PCM
vad_modeVadModeLOCAL、CLOUDLOCAL
vend_timeoutuint32如果 vad_mode 为 CLOUD 时,指定 vad 时间,单位 ms,推荐设置为 500ms0
no_nlpbool是否需要语义理解(nlp)false
no_intermediate_asrbool是否需要 asr 的实时识别结果false
stackstring设备当前的应用栈信息,"appid1:appid2"按照应用被调用的时间逆序排列
voice_triggerstring激活词,即用于唤醒设备的名字,如"若琪";可用 "\" 分隔指定多个,如 "若琪\洛奇"
voice_powerfloat语音流的音强,若设置则在多设备中作仲裁,同时只有音强最强的设备有响应0
trigger_startfloat语音流的激活词的开始位置。0
trigger_lengthfloat语音流的激活词的长度。0
skill_optionsstring设备上的状态信息,为 json 结构,此结构会传给相应的 skill 的 cloud app
voice_extrastringasr 引擎 的参数,json 格式
vad_beginuint32vad begin 的窗口大小 :-(0
no_trigger_confirmbool是否需要云端激活词的二次确认功能false
说明
  1. voice_trigger 激活词:设备的名字,当用户说这个词时,设备会被唤醒,并给出反应。
  2. VAD:语音活性检测(Voice activity detection),当用户说了一个指令后,停顿一定时间(可以由vad_timeout参数设定),会被设备或云端认为已经说完
  3. 仲裁:同一用户的多个设备同时收到语音指令时,由 voice_power 的强弱决定离说话人的远近,从而最近的设备有响应,而其它设备无响应
  4. 声纹:由 trigger_start 及 trigger_length 来指明 激活词 在语音流中的位置,声纹服务用来作说话人识别
  5. voice的编码格式如下:
    • 识别支持pcm语音流识别,单通道 数据位宽16bit 采样率16kHZ pcm
    • 识别支持opu语音流识别,单通道 数据位宽16bit 采样率16kHZ opu opu压缩每帧数据格式由1字节(数据长度)+ opus压缩320字节数据
SpeechResponse
参数类型描述
idint32唯一标识,用于跟踪一个完整的请求,处理及响应事件。
resultSpeechErrorCode错误信息
typeRespType结果类型:INTERMEDIATE、ASR_FINISH、FINISH
asrstringasr实时识别的结果
nlpstringnlp识别的结果: {"appId": "技能id", "appName": "技能名称", "asr": "asr识别结果", "cloud": "是否为云端技能: true / fasle", "intent": "意图", "pattern": "设定的用户语句","slots": { "槽名称": { "type": "槽类型", "value": "槽的值" }}}
actionstringcloud app处理的结果,json字符串
extrastring目前有:{"activation": "xxx"}
vprstring声纹的结果,json字符串,目前为:{"id": "xxx"}
asr_phoneticismsstring每个字的拼音结果,json字符串,如“晓”字的拼音为{"phoneticism":"xiao3","word":"晓","type":"CHINESE"}
voice_triggerstring激活词的识别结果
说明
  1. 字段 extra 返回 激活词(由 SpeechRequest 中的 voice_trigger 指定)的二次确认、仲裁、声纹结果,为 json 格式,其中 activation 有如下取值:

    • none: 无激活词
    • accept: 有激活词,并且识别结果确认以激活词开头
    • fake: 有激活词,但识别结果不以激活词开头
    • reject: 有激活词,但语音能量 voice_power 不是仲裁设备中最大的
    • invalidate: 打开了声纹锁,但说话者并不是已录制的用户
  2. 当语音指令为 "激活词xxx" 时,如 "若琪现在几点",除返回上述的 activation 值外,字段 extra 还会返回 {"oneshot": false}
  3. SpeechRequest 中的 no_trigger_confirm 指定是否返回字段 extra 中 activation 为 "fake" 的结果
  4. SpeechRequest 中的 no_intermediate_asr 指定是否返回字段 asr 中间结果
  5. SpeechRequest 中的 no_nlp 指定是否返回字段 nlp 结果
  6. voice的编码格式如下:
    • 识别支持pcm语音流识别,单通道 数据位宽16bit 采样率16kHZ pcm
    • 识别支持opu语音流识别,单通道 数据位宽16bit 采样率16kHZ opu opu压缩每帧数据格式由1字节(数据长度)+ opus压缩320字节数据

1.1.7. 典型场景

本地vad

  • 如果发送的 VOICE 中包含 "若琪今天天气怎么样",需要发送 END
  • 使用场景
    • 物理按键开始拾音(发送 START),发送 VOICE...,放开结束拾音(发送 END)
    • 用激活词唤醒(发送 START),发送 VOICE…,本地 vad 结束(发送 END)

云端vad

如果发送的 VOICE 中包含 "若琪今天天气怎么样",设置 vad_timeout 为 500ms,不需要发送 END