The present disclosure relates to speech recognition systems. More particularly, the present disclosure relates to automated tools that help to tune a speech recognition system.
Many automated attendants, interactive voice response (IVR) systems, name dialers and voicemail systems use speech recognition as an alternative to dual tone multiple frequency (DTMF) menu navigation. More specifically, speech recognition technology allows a caller to speak, e.g., voice commands and/or a person's name rather than pressing DTMF keys on a telephone to select commands and “spell” a person's name. Such technology is especially useful for identifying users since spelling a person's name using DTMF keys can be quite difficult. That is, not only is it time consuming to find the correct letters that are grouped on individual keys on the DTMF keypad, but often times the caller might not even know how to spell the person's name. Moreover, in some situations, it may be dangerous to force a caller to enter a person's name via the keypad. For instance, the caller may be using a mobile telephone while driving, and it would be unsafe for the driver to pay attention to dialing/pressing keys. Thus, there has been a trend to increasingly rely on speech recognition system technology over DTMF approaches.
Unfortunately, it is not uncommon for speech recognition systems to do a relatively poor job of accurately recognizing, in particular, some peoples' names. When a caller speaks a person's name or any other speech, the speech recognition system records the sound, attempts to phonetically break the sound down into, for example, syllables or other phonetic segments and then match appropriate spellings to the syllables or segments, thus resulting in a text string. That text string, however, may, in fact, have very little resemblance to the actual spelling of the intended person's name.
Broadly, embodiments provide methods, logic, and systems that aid an administrator to maintain or tune a speech recognition system. One method includes accessing a voice mail record of a user, accessing a recorded audio file of a name of the user in the voice mail record spoken by the user, providing the audio file to a speech recognition system, processing the audio file in the speech recognition system and obtaining a text result, determining whether a confidence score of the text result is below a predetermined threshold, and adding, at least, the name of the user to a list of low confidence names.
Once the list has been generated, an administrator can then listen to each name as recorded within the voice mail system (or other repository where such recordings might be available) and enter into the speech recognition system alternate spellings for the respective names. In this way, the speech recognition system can be tuned to provide improved results for specific peoples' names. Moreover, the tuning may also provide more generally applicable tuning information for the speech recognition system.
The telephone automated attendant 110 comprises a call processing system for answering telephone calls and for helping to direct a caller to a requested party. Such systems typically enable a telephone caller to dial into the system and be presented with an audible menu of options. Each option may correspond to a particular dual tone multiple frequency (DTMF) digit, thereby enabling the caller to select a desired option by pressing one of the touch tone keys on his/her telephone. In accordance with described embodiments, automated attendant 110 is also configured to handle voice commands and other speech from a caller.
More specifically, a caller may issue a voice command including, e.g., a request for information, a request to leave a message, or, of particular interest in the instant context, a request to be connected to a particular named person, e.g., an employee, registered user, etc. The voice command from the caller is directed to the speech to text converter 112, which is configured to receive a recorded file, e.g., a .WAV file, of the voice command from the automated attendant 110. Alternatively, the speech to text converter 112 may be connected directly or in parallel with automated attendant 110 and make its own a recording of the spoken name.
The recorded file is processed by the speech to text converter 112 such that a text string is output that can then be further processed as appropriate. For a spoken name, e.g., “Alan Gatzke,” in the best of circumstances, the speech to text converter 112 will output a spelling identical to the person's name. That text version of the user's name can then be used to make a query to, e.g., corporate directory 114, which may store names, telephone numbers, office locations, etc., associated with the registered users.
Where the text version of the name is found in the corporate directory, the automated attendant 110 may attempt to connect the caller with the desired person, i.e., transfer the caller to the identified person. That person may pick up the telephone and answer the call. If the person does not answer the call, the call may be further transferred to voice mail system 116. Voice mail systems typically play a recorded message, from, e.g., a stored .WAV file, such as: “Alan Gatzke is unavailable. Please leave a message after the tone.” Many voice mail systems require users to also record their names separately from other messages so that the audio of a person's name can be used in default messages, or for other purposes. For example, some voice mail systems are configured to voice a standard message, and use only the audio of the person's name, as in: “The person at extension 1212, [audio of person's name is inserted], is not available. Please leave a message after the tone.” Such systems enable administrators to better control/standardize the types of messages that can be played for callers.
A user's separately recorded name can also be used, if stored more generally in corporate directory 114, for teleconferencing announcements, among other uses.
As will be explained in more detail later herein, it may be particularly convenient to have access to the separately recorded name of a person.
As noted earlier, it is not uncommon for speech recognition systems to do a relatively poor job of accurately recognizing and converting some peoples' names to text. This may be due to the complexity of the name, the speaker's accent, background noise, or simple mispronunciation of the person's name. In any event, when a caller speaks a person's name, the speech recognition system attempts to phonetically break the sound into, e.g., syllables or segments, and then match appropriate spellings to those syllables or segments, resulting in the desired text string. That resulting text string, however, may have very little resemblance to the actual spelling of the intended person's name.
In response to the foregoing, embodiments described herein help to “tune” the speech to text converter of the speech recognition system (or a library thereof) so that when a name is spoken, an appropriate text string, i.e., one that can be matched with the person's actual name, is output.
To achieve improved tuning, and still with reference to
In an embodiment, speech recognition tuning tool 150 includes a controller 156 that is in communication with memory 160, which may be in the form of random access memory (RAM), read only memory (ROM), magnetic memory, or any other form of tangible memory with which process logic, as will be explained in detail herein, can be stored and retrieved by controller 156, and speech recognition tuning tool 150, generally. Further, the functionality described below may be carried out by controller 156 upon execution of process logic stored in memory 160, controller 156 or speech recognition tuning tool 150. Controller 156 is, for example, a data processor, e.g., a microprocessor or microcontroller, that executes the process logic. In another form, the controller 156 is implemented by digital logic gates, a programmable gate array device or other programmable or fixed logic device, and which logic is configured to perform the process logic.
Thus, in an embodiment, speech recognition tuning tool 150 could be part of computer device, such as a laptop computer. Alternatively, speech recognition tuning tool 150 may provided as an administrator utility for an overall automated attendant system, such as Cisco Unity Connection available from Cisco, San Jose, Calif. In the latter instance, the functionality provided by the speech recognition tuning tool 150 may be encoded on, e.g., a CD-ROM, or downloaded over a network connection to a computer from which the speech recognition tuning tool 150 can be operated.
Because many people tend to avoid adding their own alternate spellings to speech recognition systems to counter the sometimes poor performance of speech to text converters, this responsibility often falls to system administrators. While system administrators can add alternate spellings to the system, it is extremely time consuming to do so, especially for systems that have thousands of users. In any event, an administrator may not even know that some peoples' names are not being handled well by the speech to text converter 112.
The speech recognition tuning tool 150 aids an administrator or other authorized user to identify the names of the users with which the speech to text converter 150 has difficulty. That set of names is typically a much smaller subset of the total number of user names in the system making it much more manageable for the administrator to only enter alternate spellings for those specific users.
In order to obtain a list of names for which the speech to text converter 112 is having difficulty, the speech recognition tuning tool 150 accesses user names from the voice mail system 116. More specifically, the tool retrieves the audio file for each name and sends the audio file to the speech to text converter 112. Preferably, the audio file is one that includes only a person's names. If not, then the name of the user may first have to be isolated. Segmenting, isolating or selecting specific words or phrases (in this case, someone's name) from an audio file are known and will not be described herein.
When the speech recognition tuning tool 150 receives the results back from the speech to text converter 112 it checks the “confidence score” for that result. The score may be presented as a number scale, a percentage, or any other scheme that can rate how “well” the speech to text converter 112 performed for a given audio input. If the confidence score falls below a configurable and predetermined threshold, then that name is added to a list of low confidence names, stored in, e.g., low confidence audio recording database 152.
The foregoing is described in more detail with reference to
Once the speech recognition tuning tool 150 has iterated through the list of all of the recorded names from the voice mail system 116, the administrator can manually enter alternate spellings for each of the identified low confidence names. Specifically, the administrator can use the tool to successively play the recorded names in the “low confidence” list, and after listening to each recorded name, enter appropriate alternate spellings for that name. The list of “low confidence names” is likely to be a much smaller subset of the entire list of recorded names in any given system. After the list of alternate spellings has been created by the administrator, the tool 150 adds those names back into the speech to text converter 112 or associated dictionary or library of the speech recognition system. With the names dictionary so updated, the speech to text converter 112 should have much better results when people speak those names.
Once heard, and at step 406, the tool 150 is configured to receive alternate spellings via a keyboard, touch display 154, etc. These alternate spellings are then saved in the dictionary of the speech recognition system at step 408, and then, at step 410 it is determined whether there are more names in the list of low confidence names to analyze and for which to create alternate spellings.
Although the recorded voice names will more than likely be retrieved from a voice mail system, speech recognition tuning tool 150 could also retrieve the recorded names from other sources such as a conferencing server, IVR system, etc. Any speech application (IVR, automated attendant, name dialer, etc.) using the “tuned” speech to text converter can, accordingly, benefit from the improved names dictionary.
In a preferred use, the speech recognition tuning tool 150 is used periodically for maintenance purposes. More specifically, large enterprises, with hundreds or even thousands of employees, may experience employee turnover over time. By periodically (e.g., weekly, monthly, etc.), running the tool 150, it is possible to capture peoples' names for which it may be desirable to tune the dictionary. In an embodiment, the tool 150 is run when a number of new employees reaches a predetermined threshold.
Embodiments described herein can greatly reduce the number of names that an administrator must analyze. Embodiments may also identify some names that one might not normally consider to be problematic. Thus, embodiments may identify names prior to users complaining that calls intended for them are not being properly routed.
Furthermore, the tuning employed to improve name recognition, can also be applied generally by the speech recognition system and thus improve the overall performance of the system.
Although the apparatus, logic, and method are illustrated and described herein as embodied in one or more specific examples, it is nevertheless not intended to be limited to the details shown, since various modifications and structural changes may be made therein without departing from the scope of the apparatus, system, and method and within the scope and range of equivalents of the claims. Accordingly, it is appropriate that the appended claims be construed broadly and in a manner consistent with the scope of the apparatus, logic, and method, as set forth in the following claims.
Number | Name | Date | Kind |
---|---|---|---|
6272464 | Kiraz et al. | Aug 2001 | B1 |
6389394 | Fanty | May 2002 | B1 |
6397182 | Cruickshank et al. | May 2002 | B1 |
6434521 | Barnard | Aug 2002 | B1 |
6839667 | Reich | Jan 2005 | B2 |
6940954 | Toebes | Sep 2005 | B1 |
6978238 | Wohlsen et al. | Dec 2005 | B2 |
7277851 | Henton | Oct 2007 | B1 |
7580840 | Bhasin et al. | Aug 2009 | B1 |
7624016 | Ju et al. | Nov 2009 | B2 |
7809567 | Ju et al. | Oct 2010 | B2 |
7826945 | Zhang et al. | Nov 2010 | B2 |
8121838 | Kobal et al. | Feb 2012 | B2 |
20020169613 | Damiba | Nov 2002 | A1 |
20020196911 | Gao et al. | Dec 2002 | A1 |
20030117365 | Shteyn | Jun 2003 | A1 |
20030139925 | Anderson et al. | Jul 2003 | A1 |
20040098263 | Hwang et al. | May 2004 | A1 |
20050049860 | Junqua et al. | Mar 2005 | A1 |
20050203751 | Stevens et al. | Sep 2005 | A1 |
20050289463 | Wu et al. | Dec 2005 | A1 |
20060004572 | Ju et al. | Jan 2006 | A1 |
20060116885 | Shostak | Jun 2006 | A1 |
20060129398 | Wang et al. | Jun 2006 | A1 |
20060256942 | Gatzke et al. | Nov 2006 | A1 |
20060293886 | Odell et al. | Dec 2006 | A1 |
20060293889 | Kiss et al. | Dec 2006 | A1 |
20070005206 | Zhang et al. | Jan 2007 | A1 |
20070239455 | Groble et al. | Oct 2007 | A1 |
20070265850 | Kennewick et al. | Nov 2007 | A1 |
20080010058 | Weng et al. | Jan 2008 | A1 |
20080052076 | Metz | Feb 2008 | A1 |
20080077409 | Sannerud | Mar 2008 | A1 |
20080273672 | Didcock et al. | Nov 2008 | A1 |
20090043576 | Miller et al. | Feb 2009 | A1 |
20090043587 | Shostak | Feb 2009 | A1 |
20090216525 | Shostak | Aug 2009 | A1 |
20090248395 | Alewine et al. | Oct 2009 | A1 |
20090248415 | Jablokov et al. | Oct 2009 | A1 |
20090276215 | Hager | Nov 2009 | A1 |
20090287484 | Bushey et al. | Nov 2009 | A1 |
20100161337 | Pulz et al. | Jun 2010 | A1 |
20100177877 | Hamaker et al. | Jul 2010 | A1 |
20100250240 | Shu | Sep 2010 | A1 |
20110022387 | Hager | Jan 2011 | A1 |
Entry |
---|
Beaufays et al. “Learning Name Pronunciations in Automatic Speech Recognition Systems” 2003. |
Spiegel et al. “Proper Name Pronunciations for Speech Technology Applications” 2003. |
“Speech Connect for Cisco Unity Product Overview” 2008. |
Yu et al. “Improved Name Recognition With User Modeling” 2003. |
“Installation and Administration Guide for the Speech Connect for Cisco Unity Feature” May 2009. |
Davel et al. “Dictionarymaker User Manual Version 2.0(I)” 2006. |
“User Guide for the Cisco Unity Connection Assistant Web Tool”, Release 7.x; Cisco Systems, Inc., Aug. 25, 2008; pp. 1-72. |
Number | Date | Country | |
---|---|---|---|
20110022386 A1 | Jan 2011 | US |