Voice Conversation Repair
Conversation Repair refers to the ability of an assistant to handle conversations that deviate from the happy path. Rasa handles Conversation Repair automatically using a set of customizable patterns.
New in 3.11
Rasa Pro now comes with voice-first Conversation Repair capabilities. They complement the text-first Conversation Repair capabilities.
Overview
Session Start
Session Start defines the behaviour when an assistant proactively starts the conversation.
This pattern is triggered by the message /session_start
which can be sent on behalf
of the user based on certain UI interactions.
This pattern can be used along with a customized action_session_start
for dynamic greetings.
Example: Bot starts a conversation
Repeat
Beta feature
This feature is currently released in a beta version and disabled by default. The feature might change in the future.
If you want to enable this beta feature, set the environment variable
RASA_PRO_BETA_REPEAT_COMMAND=true
.
Repeat defines the behaviour when a user asks the assistant to repeat the last message.
Example: User asks the assistant to repeat the last message
User Silence
Beta Feature
This conversation repair pattern only works with Voice Stream channels.
This feature is currently released in a beta version and disabled by default. The feature might change in the future.
If you want to enable this beta feature, use the boolean parameter
monitor_silence
in the Voice Stream Channel configuration.
User silence on a voice call beyond a certain threshold time can trigger
the User Silence pattern. The silence threshold can be configured by
the slot silence_timeout
.
By default, the silence is handled in a three step approach. If the user is silent for a set amount of time, the assistant first repeats its last message. If the silence continues, the assistant asks if the user is still there. If the user remains silent beyond this point, the assistant informs the user that the call will be ended and then hangs up. This behavior ensures the conversation can gracefully handle periods of user silence.
Example: User remains silent during the conversation
The silence timeout threshold can be dynamically adjusted during
conversations using the silence_timeout
slot. Here's an example
flow that increases the timeout when collecting an order ID
(where users might need extra time to look up information) and
then resets it back to a normal value:
Configurations
Default Behavior
Rasa ships a default behavior for every conversation repair case that works out-of-the-box. Each case is handled through a pattern which is a special flow designed specifically to handle the case:
pattern_session_start
for starting the session.pattern_repeat_bot_messages
for repeating the bot message.pattern_user_silence
for handling user silence.
The default patterns in Rasa Pro 3.11 can be found here
Modifying default behaviour
It is possible to override the default behaviour of each conversation repair case by creating a flow with the same name as that of the pattern used to handle the corresponding case, like pattern_session_start
. If the pattern uses a default action which needs to be modified, you can override the implementation of the default action by implementing a new custom action and use that custom action in the flow.
info
Make sure the assistant is re-trained after the modification is completed.
Common Modifications
In additional to the modifications available to the text assistants, here are some common modifications that can be done to voice assistants.
Handling Call Start and Call Metadata
New in 3.11
We have unified the call handling patterns across Voice Channel Connectors, all voice channels handle call starts, ends and metadata in a similar manner.
The assistant will receive the message /session_start
when the call is picked up
along with the call metadata. This intent triggers the Session Start pattern. Here's
a customized pattern that sends utter_greet
when the call connects:
The following call metadata is received for Twilio:
call_id
is the unique call identifier from Twilio (CallSid
parameter as sent by Twilio Voice)user_phone
is the phone number of the user (Caller
)bot_phone
is the phone number of the bot (Called
)direction
is the call direction. It can be eitherinbound
oroutbound
Action action_session_start
is triggered at the beginning of each Rasa session
and it can be used to set certain slots based on this metadata. These slots can be
used in your utterances for a dynamic greeting. Here is an example:
Handling the End of a Call
Call can be ended by the user or by the assistant.
When the call is ended by the user
/session_end
message is received by the assistant along with aSessionEnded
event to the conversation.Assistant flows can use the default action
action_hangup
to disconnect calls. This action also will add aSessionEnded
event to the conversation.
Using Responses relevant to Voice Channels
It is recommended to use channel specific responses with voice channels. This can be done with channel specific responses:
In the above example, note that emoji doesn't translate well to speech. URLs are difficult to conprehend due to the temporal nature of voice vs permanence of text. Words like "Type" or "Click" assume interactions that aren't possible on a phone call. Special characters are awkward when spoken.
You can also use SSML in the responses to allow for more customisation in the audio responses from the assistant.