在上一篇([20]LUIS深入使用 - 定義Entities來截取參數)看完了如何定義entities之後,在這篇將來看看如何把定義的entities在程式裡面使用起來。
這一篇將先從加入訂房的intent,并且會依照使用者輸入的内容解析出來的entities作爲初始的表單值。
一起來看看如何在程式使用entities。
調整程式使用entities
將來調整現有的程式碼,會經過一下幾個動作:
- 調整
RootLuisDialog
- 加入ReserveRoom
intent的方法 - 把本來
RootDialog
和訂房有關的邏輯搬入 - 修正FormFlow建立方式 - 允許傳入預設值
- 調整邏輯加入entities的值
- 測試結果
調整RootLuisDialog - 加入ReserveRoom intent的方法
首先,要在RootLuisDialog
裡面增加一個新的方法,這個方法用來處理ReserveRoom
intent相關的邏輯
[LuisIntent("ReserveRoom")]
public Task ReserveRoom
(IDialogContext context, LuisResult result)
{
return Task.CompletedTask;
}
把本來和訂房有關的邏輯搬入
接下來從RootDialog
把呼叫ReserveRoomDialog
那段邏輯搬進來到ReserveRoom
方法裡面:
[LuisIntent("ReserveRoom")]
public Task ReserveRoom
(IDialogContext context, LuisResult result)
{
context.Call(new ReserveRoomDialog(), ReserverRoomAfterAsync);
return Task.CompletedTask;
}
....
修正FormFlow建立方式 - 允許傳入預設值
目前的FormFlow預設都是空值,但是如果有去的entities的話,這個值可以作爲預設值。因此,先調整FormFlow的建立方式。
修改ReserveRoomDialog
:
public ReserveRoomDialog(RoomReservation inRoomReservation)
{
RoomReservationState = inRoomReservation;
}
public ReserveRoomDialog()
:this(new RoomReservation())
{
}
public RoomReservation RoomReservationState { get; }
public Task StartAsync(IDialogContext context)
{
var reserveRoomForm =
new FormDialog<RoomReservation>
(RoomReservationState,
RoomReservation.BuildForm,
FormOptions.PromptInStart);
...
調整邏輯加入entities的值
這邊要把entities截取出來并且傳入到處理FormFlow的Dialog。
從LuisResult.Entities
裡面可以取得所有被截取出來的entities,這邊用個簡單邏輯,如果有unit
表示也有數字,依照這個概念取得要住幾晚
[LuisIntent("ReserveRoom")]
public Task ReserveRoom
(IDialogContext context, LuisResult result)
{
var roomReservation = new RoomReservation();
// 取得unit的entity
var unitEntity = result.Entities
.FirstOrDefault(x => x.Type == "unit");
// 有表示會給預設住多久
if(unitEntity != null)
{
var numberEntity = result.Entities
.FirstOrDefault(x => x.Type == "builtin.number");
var number = int.Parse(numberEntity.Entity);
// 如果單位是 天,表示實際住的晚上天數會減少1
if(unitEntity.Entity == "天")
{
number = number - 1;
}
roomReservation.NumberOfNightToStay = number;
}
context.Call(new ReserveRoomDialog(roomReservation),
ReserverRoomAfterAsync);
return Task.CompletedTask;
}
測試結果
以上是整個需要做調整的修改,接下來就可以進行測試了,這邊有三種情景:
- 我要住
- 題外話,上篇在training的時候沒有train過
我要住
,但是LUIS判別正確。這就是LUIS强大的地方,定義的越多,沒定義的語句也能夠判斷的出來。這個不是簡單if else可以做到的功能。 - 我要住3晚
- 我要住5天
結語
這篇看了如何在程式裡面取得LUIS判斷出來的entities,并且使用這些entities來給表單預設值。
entities定義的好會讓整個使用體驗非常好,因爲使用者可以用自然的語言做出填寫表單的動作。
當然,entities不止可用在定義表單的預設值,可以用的地方非常多,這就要看工程師們的想象力啦。
到目前爲止,LUIS的使用以及程式對接都清楚了,不過有些上綫之後管理層面的部分還沒介紹,例如怎麽持續完善這個LUIS的app,怎麽備份,怎麽對LUIS app做備份等等。
下一篇([22]LUIS管理及維護 - 持續加强app、多人維護、備份以及加入別的region key)先從如何持續完善開始。