UX Collective

We believe designers are thinkers as much as they are makers. https://linktr.ee/uxc

Follow publication

Part II

Creating Voice Interaction Flows

UX Design for voice interfaces

Poulami Chakraborty
UX Collective
Published in
6 min readDec 31, 2018

This is the second of a 3-part series on my design process for Voice Interfaces. The first part covered defining the product. This part is about designing the conversation.

Voice interfaces are now implicitly expected to be conversational — as opposed to command-based modality and/or one-turn exchanges.
Designing a conversational interface involves influencing user requests to, and modeling the responses from our voice agent.

A voice input or request has two layers:
Utterance: What the user says is a user utterance. Basically, an utterance is how a user phrases a request.
Example: A user can frame a request in any of the following ways:
“Set an alarm for 8'o clock”
“Alarm 8 a.m”
“I want to set an alarm”
“Wake me up at 8”

These are just a few. There may be1000 ways to ask to set an alarm.
While it is not possible to list the exhaustive set of utterances for any given goal, listing a few variations would be helpful in later part of the process.

Intent: This is the main objective behind any user request.
Example: In the above cases, the intent is to set an alarm.
Intent can be again divided into two types: primary intent is the actual task the user wants to do.
Secondary intents are for tasks to complement primary tasks.
Example: If the primary intent is to order a coffee, choosing a delivery address different from the default one could be a secondary intent.

Our assistant will support all primary user intents which correspond to the goals identified in the previous step.

(Any intent mentioned from here on will refer to a primary intent)

Conversation Modelling — Happy Flow

For a particular intent, we first model a complete conversation for the ‘happy paths’. ‘Happy paths’ are ones in which the user reaches the ideal outcome in the least (or within a certain) number of steps.
This step also helps us recognize the ‘slots’ or ‘variables’ required to fulfill the request. Variables are inputs or additional information which the user needs to provide to complete the intent.

Example:

User: I’d want to order a Salted Caramel Mocha Frappuccino
Assistant: Sure, what size would you like?
User: Grande
Assistant: 1 Grande Salted Caramel Mocha Frappuccino. Would you want it delivered to your office?
User: Yes
Assistant: Ok. Should I order it?
User: Wait, I would like non-fat milk
Assistant: Sure. Changed your milk preference to non-fat milk. Should I confirm the order?
User: Yes
Assistant: Order placed successfully. Your coffee will be reach you soon.

This is one possible way by which a user can complete a coffee order. Users may provide different amounts of information, and in different ways. Some may give all the information up front, while others provide it piece by piece. Some may have a lot of information to add, others just the mandatory information.
To handle this, the assistant needs to know the mandatory variables in what order to ask for them to complete the flow (in the above example in bold). These variables are necessary to complete the request.
The assistant needs to be, also, able to understand the optional variables (in the above example in bold italics). These are filters/customizations or choices to over-ride defaults, which users may request.

At the end of this step, we list out these mandatory variables, and all the optional variables we can think of, before we proceed to the next step.

The catalogue of utterance variation, carried out earlier, increases the chance of stumbling upon all possible variables in a flow.

User flow

Now it is time to extensively chart out all possible ‘flows’ or paths to complete a goal. It takes into account all the ways that a user may choose to phrase a request.

Prompts will be designed to ask for any missing mandatory variable & get the user to goal completion through the most optimized path.

Sample flow

The flow needs to handle edge cases and error cases.
Example of possibilities to consider when creating flows:
Invalid requests — User asks for something which is not possible. (ex: “Rate Ready Player Five 6 stars on Goodreads” or “the fifth one” while choosing from a list of 4 items)
Details in Multiple results —
How much information to give out in case of multiple results (ex: “What do I have planned today”? — if there are 5 results, how do you read it out: summarize, read out 1 in detail and wait for user to say “next”, or read out the title of each)
Disambiguation —
Some user requests may have ambiguous variables and require a little clarification before they can be fulfilled. Policies need to be defined for such cases. (ex: if user says weather in Springfield, you may ask each the user to clarify of the 34 Springfields they mean, or choose one based on their past behavior, or which is nearest)
Empty result state —
We cannot forget about the ‘0 results’ found pages. Without any specifically added responses for those cases, the default dialogues may end up sounding very mechanical (ex: “Find me non-stop AA flights from San Francisco to Vancouver” — there are no matching results.The assistant shouldn’t respond with “I found 0 results”.)
No user response —
Sometimes, the user may fail to answer within the response time after a prompt. There’s no way of knowing why a user didn’t reply, but repeating the same prompt again may not be the best available option. What should be the behavior for a particular state - Can we consider providing hints as to what they can say? Ask for a different piece of information, or phrase the earlier question in a different way? Not do anything?
Over-answers —
User may provide more information than what is being prompted. Of course, it depends on the platform capability, but the best experience is for the platform to be able to accommodate such cases. Asking for information which user has already provided makes the system look stupid. (ex:
Use: Set me a reminder
Assistant: What is this reminder for?
User: “Doctor appointment for 4 p.m. tomorrow

User has already provided the time for the appointment. So, it’s better not to prompt them for it again)
Optional variables —
While user shouldn’t be prompted for optional variables, they shouldn’t be prevented from providing them either. So, the VUI should make accommodations to support such requests. In other words, we need to make sure that the conversation shouldn’t fall apart (“I am sorry, I don’t understand that) when user says “with extra Chocolate curls” instead of “yes”/ “no”.
Intelligent Learning (over time)—
Are there any prompts that can be removed over time as the system learns more about the user? (“Book me an Uber” — if the user regularly requests Uber at 5 p.m. from his office location, maybe we can avoid asking the user for destination under those circumstances; inform the user of the assumption directly in the confirmation state. However, user should be easily able to override such defaults.)
Context-retention—
Natural conversations are not always one-turn.We need to consider how user may follow up after any response. (ex: “Is it going to rain today?” followed by “What about weekend?”)
No hierarchy —
Unlike GUIs, there are no back buttons in voice interfaces. Conversations only move forward. The user should be able to provide additional (optional) information at any stage without losing any previous progress. (Example: In the above happy path, modifying the type of milk during confirmation did not require the user to provide delivery address again)
Feedback of cancellation — Conversations don’t end abruptly. So, it’s necessary that we make sure to account for cases where user cancels a flow, or doesn’t opt for any suggested action. The assistant should provide the proper feedback that the task has been cancelled.
No assistant response — In some cases like “Play music”, “Turn on lights”, assistant needn’t give any reply, and just complete the task. These kinds of design specifications should also be included in the VUI.

Sample dialogue

Once we have finalized the flow, we can phrase the assistant responses or dialogues to make your interactions feel natural. Moreover, we need to adjust the language and tone to align with the persona we have defined for the assistant.

At this step, it helps to go back to the utterance variation catalogue and test if the dialogues seem ‘natural’ with any user utterance. If not, some response variation needs to be added & mapped to different user utterances.
Example: will the assistant response work for both “I’d want to order a Salted Caramel Mocha Frappuccino” and “Is it possible to get a Salted Caramel Mocha Frappuccino delivered now?”

Variations of responses are added so that the responses don’t feel repetitive and robotic.

Sign up to discover human stories that deepen your understanding of the world.

Free

Distraction-free reading. No ads.

Organize your knowledge with lists and highlights.

Tell your story. Find your audience.

Membership

Read member-only stories

Support writers you read most

Earn money for your writing

Listen to audio narrations

Read offline with the Medium app

Written by Poulami Chakraborty

Voice and Product Designer documenting thoughts and learnings.

No responses yet

Write a response