高级能力和算法效果优化(一)| 学习笔记

简介: 快速学习高级能力和算法效果优化。

开发者学堂课程【3节课带你走进云小蜜产品 :高级能力和算法效果优化(一)】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/739/detail/13117


高级能力和算法效果优化(一)

 

本次课程目标是希望提供给大家一种机器人效果优化的抓手,让大家了解并掌握机器人效果优化的常用的流程以及手段,帮助大家将机器人的自然语言水平,包括实体识别,意图识别等做到端到端90%以上,找到业务可交互的效果。

 

内容介绍:

一、系统内置意图、实体

二、意图话术高级配置方式 LGF

三、机器人训练

四、总结

 

一、系统内置意图、实体

为了最大程度的减少用户规划构建的成本,所以做挖掘和沉淀,把一些通用的常用的意图和实体进行内置,并且能够保证内置意图、实体效果能够达到一个非常好的水平。

1、内置通用意图(19个,模型F1=91. 96%) :停止、取消、感谢、返回、重听、上一个、下一个、你是谁、转人工、信号不好、友好问候、寻求帮助、通用否定、通用肯定、客户不方便、客户说再见、骂人说脏话、质疑是机器人、客户反问什么事。预计到93年时内置意图会进一步得到扩展,增加很多行业意图,内置意图数量能够增加到1000个以上。

实体类别

数量

主要类别

示例

时间类

7

日期、时间、周期时间、持续时间等

2020年6月18号下午5点进行了三个小时的会议

地点类

28

国家、行政区划、POI系列等

我老家是山东省烟台市

我住在千鹤家园小区

数字类

22

各类数字、各类数量词、车牌、电话号等

工作完成了三分之一

车牌号码是京N98U6

医疗类

16

疾病、症状、检查、药品、诊断、用药频率等

老王患有糖尿病

我今天体温正常

这个药每天三次

生活类

8

快递相关、菜谱、食材等

帮我发顺丰快递

我要点一个西红柿炒鸡蛋

文娱类

3

人物名、电影和广播电台

是张艺谋拍的闪闪的红星吗

我要听央广之声

其他

20

人名、邮箱、人物关系、指代、账号等

我不是李四光,我是他的朋友

我的支付宝账号是douni@163.com

2、演示系统内置意图以及内置实体的使用方式。

(1)提前定义好查天气的对话流,对话流包括触发节点,条件是查天气意图。编辑话术。

image.png

(2)对应会进行城市参数的收集。

image.png

(3)调用查天气 API,查天气回复。

image.png

(4)增加转人工的功能,定义转人工的意图,点击用户输入节点,可以看到内置的意图19个,节点名称,转人工,触发条件会自动选,保存。

image.png

(5)增加转人工的回复,名称转人工回复,文本回复,人工服务转接中。

image.png

(6)测试,输入查天气,转人工,成功识别到转人工的意图。

image.png

(7)通过系统的意图能够节省成本,系统实体分两种类型,用户可以自己去创建自己的实体,一种是标准名词的实体,一种是正则名词的实体,标准名词的实体是由很多个词组成的,正则是用正则表达式组成的,但是用户自定义也是需要成本的,除了用户自定义之外,系统里预制了一些实体,比如长天气意图,它的参数就是收集城市,收集查询哪个城市的天气,使用的识别能力会展示系统实体展示的列表,@sys.geo-city。

image.png

如果替换成省份@sys.geo-provin。测试,就可以识别出省份的天气。

image.png

在对话流的配置中,优先使用内置的意图和实体,首先内置的效果会有保障,使用成本会低很多,后续会不断完善内置意图和实体,让它的数量越来越丰富。


二、意图话术高级配置方式 LGF

LGF 配置方式主要用来解决的问题是在对话启动以及 benefits 干预的时候,如果只能一条一条话术准备,配置效率会比较低。所以使用 LGF 方式,它配置单条 LGF,效果能够达到上百条,或者更多话术的效果,能够节省配置的成本。

image.png

1、对于机器人里面的每一个意图,它一般会包含非常多的说法,比如查天气的意图,北京的天气、明天的天气、杭州气温、查询明天北京天气情况、请问一下明天北京天气如何、请问后天上海天气怎么样等。如果一条话术一条话术去写,写的数量非常多,所以设计了一种高效的知识归纳的方式,比如通过.{0,2}[请问[一下]][${日期}][${城市}][的](天气|气温)[如何|怎么样].{0,2}一条可表示144个句子,不包含实体和通配符,如果把实体和通配符考虑进去,数量会更多。

2、演示 LGF 配置

(1)打开左边意图列表页面,里面会有新建意图编辑意图的入口,可以看到已经有的查天气意图,点击编辑页面。

image.png

(2)可以看到意图名称和用户话术,最下面有高级语义配置方式,可以看到已经配置了两条。

image.png

(3)测试,输入查天气,在窗口可以看到匹配类型lgf和匹配细节[我想|我要]查天气。

image.png

3、LGF 基本使用

(1)最简单的 LGF

今天的北京天气

Testing

今天的北京天气 OK

今天北京天气 FAIL

最简单的 LGF 就是普通的文本,这个 LGF 仅能匹配原封不动的“今天的北京天气”。

(2)可选部分

今天北京[]的天气

Testing

今天北京的天气 OK

今天北京天气 OK

明天北京天气 FAIL

使用[]表示文本中的某个部分是“可有可无的”,这样的 LGF 表达能匹配两个输入,“今天北京天气“和“今天北京的天气“。可以在不同的地方加入可选标记,能让句子的表达能力翻倍(x2) ,比如下面的表达就能匹配4个输入。

今天北京[的]天气[预报]

Testing

今天北京的天气 OK

今天北京天气 OK

今天北京的天气预报 OK

今天北京天气预报 OK

明天北京天气 FAIL

(3)逻辑或

使用|可以表达“逻辑或关系“,可以表达n个候选中的任意一个,同时避免表达歧义,建议使用()做隔离表达

(今天|明天|后天)北京[的]天气[预报]

Testing

今天北京的天气 OK

今天北京天气预报 OK

明天北京天气 OK

后天北京的天气预报 OK

明天上海的天气情况 FAIL

也可以使用[]形成天然的隔离

(今天|明天|后天)北京[的1天气[预报|情况|状况]

Testing

今天北京天气预报 OK

明天北京天气 OK

后天北京天气状况 OK

明天北京的天气情况 OK

上海的天气 FAIL

(4)参数表达

除了 LGF 的文本表达,Dialog Studio 构会有很多的参数填充需要,比如上述的天气的例子,需要知道“日期“和“城市”,才能进行对应的查询。

使用${}引用具体的参数(注意:是参数名称,而不是专有名词),这样就能命中非常多具体表达。

${日期}${城市}[的]天气[预报|情况|状况]

Testing

今天上海天气预报 OK

下周一北京天气 OK

3号重庆天气状况 OK

上海的天气 FAIL

城市允许的值非常多,可能有上百种,如果还是用或,写起来会非常的复杂,所以引入参数表达。

(5)通配符泛化

“逻辑或"和“可选部分”仍不能满足一些应用对泛化能力的需求。

[请问|查下|告诉我]${日期}${城市}[的]天气[预报|情况|状况] [如何|怎么样|好不好]

Testing

查下今天上海天气预报 OK

那个下周一北京天气 FAIL

查查3号重庆天气状况 FAIL

上海的天气 FAIL

LGF 也支持通配符,表示方式是.下限,上限},比如.{0,3}表示能匹配0个(没有)到3个任意字符(字符为UTF字符,中文字、标点、英文字母都算一个)

.{0,3}${日期}${城市}[的]天气[预报|情况|状况].{0,3}

Testing

查下今天上海天气预报 OK

那个下周一北京天气怎么用 OK

查查3号重庆天气状况如何? OK

不想查明天的天气 WARNING

上海的天气 FAIL

切记这样的泛化是很不可控的,很可能兼容了一些问题确引入更多的问题

(6)通配符导致优先级衰减

//意图A

.{0,3}吃饭去.{0,3}

//意图B

.{0,3}吃饭.{0,3}

Testing

吃饭意图 B

我们去吃饭去意图 A>意图 B (A 意图消耗通配符3个, B 意图消耗通配符4个)

吃午饭去吧 FAIL

(7)逻辑非

通配符泛化过程中容易引入不可控因素

{0,3}幸福大巴.{0,3}

Testing

幸福大巴信息 OK

预定幸福大巴 OK

退订幸福大巴 WARNING

幸福班车 FAIL

本意是希望能够匹配“幸福大巴”相关的内容,但 query 为“退订幸福大巴”时仍会命中,可能跟业务的初衷相悖

(!退订|取消){0,3}幸福大巴.{0,3}

Testing

幸福大巴信息 OK

预定幸福大巴 OK

退订幸福大巴 FAIL but CORRECT

幸福班车 FAIL

在通配符规则前使用(!)取代。表述取反的范围(注意不是,前面加上(!)),.表示任意字符,“逻辑非”(!)改变了字符范围,达到取反目的

需要注意的是当前版本(!..)中间的内容,仅支持“1”,还未支持“[]”,“()"等语法。

相关文章
|
2月前
|
机器学习/深度学习 算法 数据可视化
基于MVO多元宇宙优化的DBSCAN聚类算法matlab仿真
本程序基于MATLAB实现MVO优化的DBSCAN聚类算法,通过多元宇宙优化自动搜索最优参数Eps与MinPts,提升聚类精度。对比传统DBSCAN,MVO-DBSCAN有效克服参数依赖问题,适应复杂数据分布,增强鲁棒性,适用于非均匀密度数据集的高效聚类分析。
|
2月前
|
机器学习/深度学习 算法
采用蚁群算法对BP神经网络进行优化
使用蚁群算法来优化BP神经网络的权重和偏置,克服传统BP算法容易陷入局部极小值、收敛速度慢、对初始权重敏感等问题。
328 5
|
3月前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
267 14
|
3月前
|
canal 算法 vr&ar
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
142 1
|
2月前
|
机器学习/深度学习 人工智能 算法
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
158 0
|
3月前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
242 1
|
2月前
|
机器学习/深度学习 算法 物联网
基于遗传方法的动态多目标优化算法
基于遗传方法的动态多目标优化算法
|
3月前
|
机器学习/深度学习 存储 算法
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
173 0
|
3月前
|
存储 边缘计算 算法
【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析(Matlab代码实现)
【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析(Matlab代码实现)

热门文章

最新文章