AIUI文档中心
AIUI平台说明
什么是AIUI
AIUI平台能力介绍
AIUI交互流程说明
AIUI快速入门
AIUI应用管理说明
应用接入和配置
应用后处理
敏感词
AIUI开发接入
AIUI接入概述
声学接入
交互接入
SDK接入
SDK介绍
参数配置
消息事件
交互状态
结果解析
WebSocketAPI接入
精简协议接入
常用功能
交互控制
语音唤醒
语音合成
用户个性化
自定义参数
离线命令词
翻译模式
流式识别
语义VAD
发音人列表
关键词过滤
情景模式
错误码
星火交互认知大模型说明
大模型概述
开发接入
SDK接入
API接入
大模型API服务鉴权
特色能力
超拟人合成
声音复刻
大模型功能
大模型错误码
软硬件产品接入
RK3328 降噪板
RK3328降噪板白皮书
RK3328降噪板使用手册
RK3328降噪板规格书
RK3328降噪板协议手册
RK3328 AIUI评估板开发套件
RK3328评估板白皮书
RK3328评估板使用手册
RK3328评估板规格书
RK3328评估板开发手册
RK3588 AIUI多模态开发套件
RK3588一体机多模态产品规格书
RK3588多模态套件使用手册
视频传输协议
串口通信协议
音频传输协议
ZG803 离线语音识别套件
ZG803 产品白皮书
USB声卡套件
USB声卡产品白皮书
USB声卡使用指南
AC7911 AIUI语音开发套件
AC7911-产品白皮书
AC7911-快速体验指南
AC7911-开发指南
AC7911-协议手册
AC7911-硬件参数
AIUI评估板接入
集成方式
软件包说明
AIUIServiceKitSDK
串口SDK
评估板参数配置
调试升级
技能工作室
技能概述
名词解析
技能
意图和语料
实体
动态实体
模糊匹配
填槽对话
技能设计规范
语音技能设计规范
开放技能接入审核规范
开放技能图标图片规范
技能开发
创建技能和意图
意图配置
技能测试
技能发布
技能后处理
技能导入导出
云函数APIv2.1
云函数APIv2.0
问答库开发
语句问答
关键词问答
文档问答
设备人设开发
技能协议
语义协议:重要字段和通用字段
技能后处理协议:标准请求
技能后处理协议:请求校验
技能后处理协议:Request_v2.1协议
技能后处理协议:Response_v2.1协议
技能资源限制
硬件设计参考
常见问题
AIUI常见问题
评估板常见问题
动态实体常见问题
联系方式
服务条款
AIUI开放平台服务协议
AIUI开放平台隐私政策
小飞在家用户协议
小飞在家隐私政策
小飞在家开源软件使用许可
讯飞账号隐私政策
讯飞账号用户协议
讯飞带屏音箱用户协议
讯飞带屏音箱隐私政策
AIUI SDK隐私政策
AIUI SDK合规使用说明
本文档使用 MrDoc 发布
-
+
首页
SDK接入
## 1. 版本说明 | SDK版本 | v1服务(结构化语义) | v2服务(星火交互认知大模型) | |---------------|----------------|-----------------| | 5.x | 支持 | <font color='red'>不支持 </font> | | 6.x | 支持 | 支持 | v1和v2服务的结果格式不同,5.x升级6.x SDK需要修改解析代码。<font color='red'>若不想修改解析代码,则修改aiui.cfg参数。</font>示例: ```json { //aiui_ver:云端服务版本,1(v1服务) 2(v2服务) "global": { "aiui_ver": "1" } } ``` ## 2. 集成方法 6.x版本接口跟旧版本一样,但是配置和结果格式不同。集成参考[官方文档](https://aiui-doc.xf-yun.com/project-1/doc-11/)。 ### 2.1 大模型aiui.cfg配置 ```json { /* 鉴权参数 */ "login":{ "appid": "", // 同老配置 "key": "", // 同老配置 "api_secret": "" // api密钥,在AIUI开放平台我的应用中查看。 }, /* 大模型参数 */ "cbmparams": { "nlp": { // 语义参数,一般不用改 "nlp": {"encoding": "utf8","compress": "raw","format": "json"}, "sub_scene": "cbm_v45" } } /* 其他参数同老配置 */ } ``` 其他参数详见[参数配置](https://aiui-doc.xf-yun.com/project-1/doc-13/)。 ### 2.2 大模型json结果 ```json { "data": [{ "params": {"sub": "xxx",}, "content": [{"dte": "utf8","dtf": "json","cnt_id": "0"}] }] } ``` cnt_id字段获取内容数据,Android示例: ```java private void processResult(AIUIEvent event) { JSONObject data = new JSONObject(event.info).getJSONArray("data").getJSONObject(0); String sub = data.getJSONObject("params").optString("sub"); JSONObject content = data.getJSONArray("content").getJSONObject(0); if (content.has("cnt_id")) { String cnt_id = content.getString("cnt_id"); // 获取结果数据 byte[] contentData = event.data.getByteArray(cnt_id); // 按sub值的不同,采取不同的方法来处理结果数据 if ("iat".equals(sub)) { } else if ("tts".equals(sub)) { } else if ("cbm_tidy".equals(sub)) } else if ("cbm_semantic".equals(sub)) { } else if ("nlp".equals(sub)) { } } } ``` sub字段说明: | sub | 说明 | 结果内容格式 | |----|----|----| | iat | 语音识别结果 | json字符串 | tts | 语音合成结果 | pcm音频、或url | cbm_intent_split | 意图拆分,判断用户一次说了多少个意图 | json字符串 | cbm_semantic | 结构化语义结果 | json字符串 | nlp | 大模型语义结果| json字符串 * iat、tts[解析参考](https://aiui-doc.xf-yun.com/project-1/doc-16/)。 * cbm_intent_split示例: ```json { "cbm_intent_split":{ "seq":0, // 结果序号 "status":3, // 数据状态 "text":"{\"query\":\"今天天气?明天呢?\",\"intent\":[ {\"index\":0,\"value\":\"今天天气怎样\"}, {\"index\":1,\"value\":\"明天天气怎样\"}]}" } } ``` 参数说明: | 参数名 | 说明 | |----|----| | seq | 结果序号,0,1,2... | status | 数据状态</br>0(长句开始)</br>1(长句中间结果)</br>2(长句结束)</br>3(短句结束,只有一个结果) | text |结构化语义结果,参考[语义协议](https://aiui-doc.xf-yun.com/project-1/doc-70/)。<br>query:用户输入文本<br>answer:结构化语义回复<br>intent:拆分后意图,例如"今天天气,明天呢?"被拆分成了两个意图。 * cbm_semantic示例: ```json { "cbm_meta":{ "seq":0, "status":3, "text":"{\"cbm_semantic\":{\"intent\":1}}" // intent是意图序号,对应cbm_intent_split中的intent序号 }, "cbm_semantic":{ "seq":0, "status":3, "text":"{\"answer\":{\"text\":\"明天小雨转阴......"}" } } ``` nlp结果示例: ```json { "cbm_meta":{ "seq":0, "status":0, "text":"{\"cbm_reply\":{\"intent\":1,\"nlp_origin\":\"cbm_semantic\"}}" }, "nlp":{ "seq":0, "status":0, "text":"今天天气晴..." // 应答文本 } } ``` 大模型结果分多次返回,完整结果要拼接text,示例: ```json "nlp":{"seq":0,"status":0,"text":"今天"} "nlp":{"seq":1,"status":1,"text":"天气"} "nlp":{"seq":2,"status":1,"text":"多云,有"} ... "nlp":{"seq":9,"status":2,"text":"。"} ``` Android结果处理示例代码参考SimpleDemo中的NlpDemo.java文件。
admin
2024年8月29日 17:36
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
Markdown文件
分享
链接
类型
密码
更新密码