本文继续围绕工业级业务对话平台和框架Rasa,对Rasa对话机器人项目实战之教育领域Education Bot项目微服务下的代理模式及核心组件源码如action,dispatcher,tracker等进行解析。
一、Rasa对话机器人项目实战之教育领域Education Bot项目微服务下的代理模式及核心组件源码解析
- Rasa 3.X Architecture下的Agent与Action Server构建的的代理模式微服务解密
Agent虽然也有action接口(Rasa core),但是本身不会执行业务类型的action,用户与对话机器人交互需要执行业务逻辑时,是通过Agent发送请求到action server来执行相关业务微服务action的。
微服务action样例:
2. 代理模式下Rasa Core中的Action类代码逐行解密
这是Rasa core中的Action类,是由Agent来执行的,譬如对话生命周期相关的actions就会继承这个core的基类:
方法name在Rasa core的具体实现类中必须实现,否则就会报错:
下面是run方法,与微服务action中的run方法的参数是有区别的,譬如这里需要使用out_channel来表示Agent与用户对话使用的channel,而nlg参数表示使用哪一个语言生成组件,run方法返回事件列表:
3. 代理模式下Rasa SDK中的Action类代码逐行解密
这是SDK的微服务action的基类Action,微服务action通过执行后返回的事件来改变对话的状态:
方法name在微服务实现类中必须实现,否则就会报错:
下面是run方法,与Rasa core中的action的run方法的参数是有区别的,譬如这里需要使用dispatcher来发送responses给Rasa Agent,run方法返回的是Dict的列表,也可以使用这种方式来返回responses给Rasa Agent:
4. 代理模式下Rasa Core中的OutputChannel内幕机制及代码解析
这是OutputChannel,Rasa Agent通过channel来与用户进行交互,包括接收用户输入和发送响应给用户,基于这个基类可以有不同的具体实现类来实现不同channel的功能:
可以看到基于不同的message类型来发送不同的response给用户:
5. 代理模式下Rasa Core中的NaturalLanguageGenerator内幕机制及代码解析
这是NaturalLanguageGenerator,用于产生对话机器人发送给用户的响应(Rasa Agent -> bot user):
TemplateNaturalLanguageGenerator继承自NaturalLanguageGenerator,用于产生模板化的响应,并可以根据当前对话状态使用slot变量来控制输出给用户的响应:
下面是在微服务的run方法中的使用样例:
6. 代理模式下Rasa Core中的DialogueStateTracker内幕机制及代码解析
这是DialogueStateTracker,在下面的from_dict方法中的参数max_event_history会限制使用多少个历史events,而这些信息存储在Tracker Store中:
这是初始化方法,对tracker中的各个字段赋予初始值,tracker包括了在对话消息处理过程中所捕获的所有信息:
这个方法会通过现有的events来创建一个tracker:
返回当前tracker的状态信息:
7. 代理模式下Rasa Core中的Domain内幕机制及代码解析
这是Domain类,描述了对话机器人NLU组件和policy组件的作用域。Domain类是一个字典类,这是因为domain文件里的配置都是以key-value的形式来定义的:
这是加载domain文件的方法:
domain配置样例:
8. 代理模式下Rasa SDK中的CollectingDispatcher内幕机制及代码解析
这是CollectingDispatcher,在微服务action的run方法中,会使用传入的参数dispatcher来发送response给Rasa Agent,注意下面的注释”send messages back to user”是不准确的。在utter_message方法中,会对message内容处理后返回message,并以json格式发送给Rasa Agent:
9. 代理模式下Rasa SDK中的Tracker内幕机制及代码解析
这是Tracker类,是通过Rasa Agent发送给action server的请求来传入action的run方法的,并通过返回事件来更新tracker:
10. 代理模式下Rasa SDK中的DomainDict内幕机制及代码解析
这是SDK中的DomainDict,其实就是domain文件中配置信息的一个dictionary的表示,每一类配置信息都是以key-value的形式来存储的: