Describe conversational language understanding
To work with conversational language understanding (CLU), you need to take into account three core concepts: utterances, entities, and intents.
Utterances
An utterance is an example of something a user might say, and which your application must interpret. For example, when using a home automation system, a user might use the following utterances:
"Switch the fan on."
"Turn on the light."
Entities
An entity is an item to which an utterance refers. For example, fan and light in the following utterances:
"Switch the fan on."
"Turn on the light."
You can think of the fan and light entities as being specific instances of a general device entity.
Intents
An intent represents the purpose, or goal, expressed in a user's utterance. For example, for both of the previously considered utterances, the intent is to turn a device on; so in your CLU application, you might define a TurnOn intent that is related to these utterances.
A CLU application defines a model consisting of intents and entities. Utterances are used to train the model to identify the most likely intent and the entities to which it should be applied based on a given input. The home assistant application we've been considering might include multiple intents, like the following examples:
Intent | Related Utterances | Entities |
---|---|---|
Greeting | "Hello" | |
"Hi" | ||
"Hey" | ||
"Good morning" | ||
TurnOn | "Switch the fan on" | fan (device) |
"Turn the light on" | light (device) | |
"Turn on the light" | light (device) | |
TurnOff | "Switch the fan off" | fan (device) |
"Turn the light off" | light (device) | |
"Turn off the light" | light (device) | |
CheckWeather | "What is the weather for today?" | today (datetime) |
"Give me the weather forecast" | ||
"What is the forecast for Paris?" | Paris (location) | |
"What will the weather be like in Seattle tomorrow?" | Seattle (location), tomorrow (datetime) | |
None | "What is the meaning of life?" | |
"Is this thing on?" |
In the table there are numerous utterances used for each of the intents. The intent should be a concise way of grouping the utterance tasks. Of special interest is the None intent. You should consider always using the None intent to help handle utterances that do not map any of the utterances you have entered. The None intent is considered a fallback, and is typically used to provide a generic response to users when their requests don't match any other intent.
After defining the entities and intents with sample utterances in your CLU application, you can train a language model to predict intents and entities from user input - even if it doesn't match the sample utterances exactly. You can then use the model from a client application to retrieve predictions and respond appropriately.