Itâ€™s always frustrating to hear people complain about poorly designed telephone applications, particularly when these complaints relate to government-sponsored applications. (Encouraging good design principles for developing voice applications is kind of the point of this here blog â€“ â€˜ya dig?)
You can imagine how disheartened I was to read a story cataloging a litany of complaints about one such system in my hometown newspaper. This article focuses on some extremely negative experiences by callers to the Medicare help line (1-800-MEDICARE). In an analysis of the Medicare help line, the General Accounting Office concluded late last year that less than two thirds of callers to this â€œhelpâ€ line received accurate answers to their questions.
To be perfectly fair, there are few things in this world â€“ with the possible exception of the U.S. Tax Code â€“ as complex as the Medicare program. Not a surprise considering itâ€™s the largest health insurance program in the nation, covering some 40 million Americans (and counting!). When eligibility and benefit rules are complex, the job of providing clear concise answers to recipient questions is difficult, so some degree of frustration is probably inevitable.
Itâ€™s also more likely that a phone system set up to answer benefit questions will have to utilize a mixture of automated dialogs and customer service representatives. Given the nature of the program, developing a fully automated system would seem to be highly impractical.
However, when I read about some of the negative caller experiences, I canâ€™t do anything but shake my head:
After two minutes of following instructions from an automated female voice, Bingham arrived at a list of choices.
“If you’re calling on the Medicare discount drug cards say, ‘Drug card,’ ” the voice said. “For Medicare health plans, say ‘Plan choices.’ ”
“Plan choices,” Bingham said.
“I’m sorry I didn’t understand you,” the voice said.
“Plan choices!” Bingham said again.
“I’m sorry, I still didn’t understand you.”
Bingham brought the telephone two inches from her lips.
“Please hold a moment while I transfer you to a customer service representative who can help you.”
This is just a fundamental lack of proper menu construction and grammar tuning â€“ the fact that these things do not appear to have been done for an application as heavily used as this one is almost criminal. At a minimum, the menu should accept both spoken and DTMF input so that a caller can use their key pad to enter a numeric choice if the application is having trouble recognizing what they are saying.
POORLY DESIGNED MENU STRUCTURE:
<noinput>I'm sorry I didn't understand you.</noinput>
<nomatch>I'm sorry I didn't understand you.</nomatch>
<prompt>Welcome to the Medicare help line. If you're calling on the Medicare discount drug cards say, Drug card. For Medicare health plans, say Plan Choices.
<choice next="#drugs">drug cards</choice>
<choice next="#choice">plan choices</choice>
This type of menu structure has several flaws. First, the prompts are too dissimilar to the menu choices â€“ if the desired input for the second item is â€œplan choices,â€ why doesnâ€™t the prompt direct the user to this input? â€œFor Medicare health plans, say Plan Choices.â€ should be â€œFor Medicare health plans, say Health Plans.â€ This increases the likelihood that the caller will provide the right input.
Second, the menu does not allow for approximate input â€“ if a caller says simply â€œcards,â€ or â€œdiscount cardsâ€ the application will not recognize the input. Under the VoiceXML 2.0 specification, the default setting for menu input is â€œexactâ€ — in other words, the VoiceXML interpreter will look for an exact match on the menu items, and will not recognize input that includes some (but not all) of the words in the menu item.
Third, the menu does not allow for DTMF entry, which would allow a caller to fall back to their key pad for entry if the application was having trouble recognizing their input. Properly constructed voice applications will check for the type of input being provided, and direct callers to modify it accordingly (demonstrated below).
Finally, the menu does not use tapered prompts to assist the caller in refining their input, or selecting the appropriate input type.
PROPERLY DESIGNED MENU STRUCTURE:
<!-- Accept attribute is set to allow approximate input -->
<!-- Tapered prompts when no input is detected -->
<prompt>I'm sorry. I didn't hear what you said. </prompt>
<prompt>I'm having trouble hearing you. If you are using a speaker phone, you may want to pick up your telephone handset or make sure your phone is not on mute</prompt>
<prompt>I'm sorry I'm still having trouble hearing you. Please wait while I transfer you to a customer service representative.</prompt>
<goto next="#transfer" />
<!-- Tapered prompts when application does not recognize input -->
<prompt>I'm sorry I didn't understand what you said. </prompt>
<if cond=" application.lastresult$.inputmode='voice'">
<prompt>I'm still having trouble hearing you. Please try entering your selection using your touch tone key pad. </prompt>
<prompt>I didn't get that. Please try entering your selection again. </prompt>
<prompt>I'm sorry. I'm still having trouble understanding your selection. Please wait while I transfer you to a customer service representative.</prompt>
<goto next="#transfer" />
<prompt>Welcome to the Medicare help line.
For the Medicare <value expr="_prompt"/> service, say <value expr="_prompt"/>, or press <value expr="_dtmf"/>.
<!-- menu choices allow for alternate DTMF input -->
<choice next="#drugs" dtmf="1">discount drug cards</choice>
<choice next="#choice" dtmf ="2">health plans</choice>
Additionally, a good system will verify user input if the confidence level on recognition is lower than a pre-specified threshold. There is a good overview of this technique in an earlier posting on this site.
This is pretty basic stuff â€“ even if the application developers didnâ€™t know enough to take this approach when they built the system, it is most certainly something that should have been uncovered during testing. This is the kind of second rate development that gives voice applications a bad rep.