1

目前在 IBM Watson Assistant 中,您只能将一项技能分配给助理。如何以编程方式交换助手的主要技能?

4

2 回答 2

3

未来的计划是让 Assistant 支持多种技能以及自定义技能。目前,正如data_henrik 所提到的,您可以使用 V1 API 来调用每个技能。

但是拥有多种技能仍然存在挑战,这可能会给你一些见解。

这些是您可以采取的一些方法(在某些情况下,名称是编造的:)。

喷洒和祈祷

在这种方法中,您将用户话语发送到所有工作区并获得最高分。

如果您有大量意图 (>1,000) 并且这些意图之间存在明显差异,则需要此选项。这也是通话成本最高的。

网关

在此设置中,您拥有顶级技能。这试图理解每个问题应该被路由到哪里的意图。然后,您将它建议的第二个技能称为它返回的意图。

如果您有大量意图但主题相似,但又不够相似而无法归类为单一技能,则此方法有效。

路由器

类似于网关,除非您确定了要路由给您的最终技能,然后才使用该技能。如果该技能不理解后面的问题,那么它会将其路由回顶级技能以找出它应该去哪里。

如果您的客户有明确定义的路径,那么这个方法效果很好。因为他们倾向于在同一领域提出所有问题。

图形

类似于路由器,除了当一个子技能不理解这个人问什么时,而是回到顶层它试图弄清楚其他子技能与自己有什么共同关系(如果它不能它回到顶部)。

这有助于在多种技能可能具有相似意图的情况下,但在已经提出的其他问题的背景下,您会选择一种技能而不是另一种技能。

在链设置中,您尝试在第一个技能中回答用户问题。如果你不能,那么你去你的第二个技能,然后依此类推。

在这种情况下,您的意图按照已知频率的顺序进行映射。

如果您的意图非常相似,则此方法效果很好,但您知道人们问的最常见问题。不过,它是较难实施和维护的一种。


其他点。

  • 首先,每个技能都需要一个上下文对象。您不能跨技能共享上下文对象的系统部分。如果您使用的是 Premium 或 Watson Assistant Plus,那么这将在技能本身中得到处理(因此您只需要存储对话 ID)。

  • “网关”、“喷雾和祈祷”和“链”失去了在没有认真工作的情况下进行复杂对话流的能力。

  • 如果您计划从一项技能到另一项技能的一次性调用,您可以使用云功能来实现这一点。它降低了复杂性,并将逻辑置于应用层之外。我通过我的语言翻译示例实现了类似的效果。

  • 通过使用技能而不是助手,您将失去进行基于版本控制的部署的能力。您可以创建多个助手来解决此问题,但这会使事情变得更加混乱。

于 2019-05-06T07:38:14.637 回答
0

在 UI 中,在Assistants下,您可以单击分配的Skill及其虚线菜单,然后选择Swap Skill。因此,即使使用 Lite 计划,您也可以使用助手测试不同的技能。

如果您拥有 Premium 或 Plus 帐户,则可以拥有对话技能和搜索技能

拥有多种技能(工作空间)的另一种选择是使用V1 API实现应用程序。它是一个无状态的 REST API,您将消息发送到由其工作区/技能 ID 标识的机器人。根据上下文和流程,您的应用程序将选择正确的工作区并相应地发送消息。这样就可以创建专门的机器人(工作区)或从一种语言切换到另一种语言。

于 2019-05-06T06:04:47.957 回答