This application claims the benefit of priority of U.S. provisional application No. 61/153,267, entitled MULTIPLE LANGUAGE VOICE RECOGNITION, filed Feb. 17, 2009, the entire disclosures of which are incorporated herein by reference.
Embodiments of the present invention relate generally to computer-implemented voice recognition, and more particularly, to a speech recognition method and apparatus that accounts for the possibility that native speakers of different languages may pronounce a given word differently.
In the field of computer speech recognition a speech recognition system receives an audio stream and filters the audio stream to extract and isolate sound segments that make up speech. The sound segments are sometimes referred to as phonemes. The speech recognition engine then analyzes the phonemes by comparing them to a defined pronunciation dictionary, grammar recognition network and an acoustic model.
Sublexical speech recognition systems are usually equipped with a way to compose words and sentences from more fundamental units. For example, in a speech recognition system based on phoneme models, pronunciation dictionaries can be used as look-up tables to build words from their phonetic transcriptions. A grammar recognition network can then interconnect the words.
A data structure that relates words in a given language represented, e.g., in some graphical form (e.g., letters or symbols) to particular combinations of phonemes is generally referred to as a Grammar and Dictionary (GnD). An example of a Grammar and Dictionary is described, e.g., in U.S. Patent Application publication number 20060277032 to Gustavo Hernandez-Abrego and Ruxin Chen entitled Structure for Grammar and Dictionary Representation in Voice Recognition and Method For Simplifying Link and Node-Generated Grammars, the entire contents of which are incorporated herein by reference.
One problem often encountered in applications that use Speech Recognition is that native speakers of different languages may pronounce the same written word differently. For example, words in both Mandarin and Cantonese are represented by the same Chinese characters. Each character corresponds to the same meaning in both Mandarin and Cantonese, but the word corresponding to the character is pronounced differently in the two languages. In software applications marketed to speakers of both languages that use speech recognition it would be desirable for the speech recognition system to be able to handle speakers of both languages.
A related problem is that in many contexts, e.g., song titles, relevant word combinations, may contain words from different languages. A speaker's pronunciation of a given song title containing both English and Italian words may vary depending on the speaker's native language is English or Italian as well as the speaker's familiarity with a non-native language. It would be desirable for speech recognition systems to handle this situation.
Although it is possible for a GnD to associate multiple pronunciations with a given word, manually generating such a GnD in a way that takes into account pronunciation differences due a speaker's native language is a labor-intensive and time-intensive process.
It is within this context that embodiments of the current invention arise.
Embodiments of the invention provide for voice recognition systems and methods that can handle multiple pronunciations for a hybrid of two or more different languages.
Embodiments of the present invention provide an efficient, self-contained and small foot-print method and system for cross-language Grapheme to Phoneme conversion (G2P) that includes pronunciation refining. This method may be used in a voice recognition system to generate an optimized set of pronunciations in a target language from words that might come from a different language, referred here as orthographic language. Pronunciations for both source and target languages may be generated in parallel and then consolidated on an extended set of pronunciations given in the phonemes of the target language. These pronunciations can be used as part of a voice response system for speech recognition or text-to-speech conversion. The grapheme to phoneme (G2P) conversion may be based on a graphone framework that generates multiple possible pronunciations for each word. Excess pronunciations generated may be refined using a “center” pronunciation created by consensus among the set of pronunciations.
The basics of a grapheme to phoneme (G2P) conversion method are described, e.g., in US Patent Application Publication number 20060031069 entitled “System And Method For Efficiently Performing A Grapheme-To-Phoneme Conversion Procedure” by Jun Huang, Gustavo Hernandez-Abrego and Lex Olorenshaw, the entire contents of which are incorporated herein by reference.
According to an embodiment of the invention, a GnD that can handle more than one language at the same time may be generated automatically. Embodiments of the present invention utilize an improved data structure and process for handling a Grammar and Dictionary (GnD) for multiple language voice recognition. The data structure that can associate multiple pronunciations with each orthographic word in the GnD based on different language classifications. These classifications include the following:
Orthographic Language is the language of origin of a word in the GnD.
Display Language is the language used by a graphical display that displays the words. The display language generally refers to the encoding of a data string (e.g., an ASCII string) for each word as it is displayed. The encoding causes a given string to be displayed in a particular graphical format, e.g., the Roman, Greek, Arabic, Hebrew, Russian, or other alphabet, traditional Chinese characters, simplified Chinese characters and the like. The orthographic language generally depends on the display language, though it is possible for two or more languages to be mapped to the same display language.
Phoneme Language—the language that determines a particular set of acoustic phonemes used to determine the pronunciation. Different languages typically use different sets of phonemes. Therefore, to automate the process of generating a pronunciation automatically, it is useful to know the phoneme set
Pronunciation Language—the language used as a basis for determining pronunciation. The pronunciation language may be based on an assumption about the speaker's native language. In the discussion below, the following notation is used. For a native speaker of a language the word the name of the language is followed by the word “native” in parentheses. Thus, for the pronunciation of a Spanish word by native speaker of Spanish, the pronunciation language would be indicated as Spanish (native). For the pronunciation of a word in a second language by a native speaker of a first language, the pronunciation language would be indicated as First Language-Second Language. Thus, for the pronunciation of a Spanish word by native speaker of English, the pronunciation language would be indicated as Spanish-English. The pronunciation language for an English word by a native Spanish speaker would be English-Spanish.
Target Language—the language relevant to the context of the software application that uses the voice recognition system/method. The application language may be the same as the orthographic language in many contexts. However, in some contexts, a hybrid or application-specific language may be used.
Embodiments of the invention utilize these different language classifications to automatically generate a GnD having multiple possible pronunciations associated with a given word in the target language to provide the GnD good word recognition performance.
As seen in
By way of example, these features of the pronunciation generator 101 may be implemented by one or more computer programs may be stored in a computer memory unit in the form of instructions that can be executed on the processing unit. The instructions of the program may be configured to implement, amongst other things, certain parts of a speech processing method that involves converting an input word from the application data 103 into one or more pronunciations and wherein each pronunciation includes a set of one or more phonemes and associating each pronunciation of the one or more pronunciations with the input word in an entry in a computer database 108. Each phoneme represents a sound in a pronunciation of the input word by a speaker of the first or second language and the database entry includes information identifying a pronunciation language and/or a phoneme language for each pronunciation.
Embodiments of the present invention may use a combination of integrated technologies with intermediate steps, adaptations and transformations to facilitate recognition one or more foreign languages in automated speech recognition. Embodiments of the present invention handle foreign word recognition using a mixed hybrid integrated recognition strategy. By way of example, foreign English words can be recognized by combining a native language recognizer with a foreign language recognizer and using intermediate steps to cover different possible ways in which one could pronounce a word a foreign language. Although the example that follows focuses on “English” spoken by native Spanish Speakers, the techniques described here can also be used for other combinations of languages.
By way of non-limiting example, consider a case in which the name of the Australian performer: “Kylie Minogue” is recognized by native Spanish speakers using an English based recognizer (foreign recognizer for Spanish people) and a Spanish based recognizer (native recognizer for Spanish people) at the same time.
Normally, in the literature, English recognition by foreign speakers is performed using only an English recognizer that has been adapted for foreign speakers. Although this approach is very suitable for speakers with very good English pronunciation it is considerably less robust when the speaker has a strong accent or limited familiarity with the English language. In this case, a better approach would be to use an integrated system or a system combination that includes both an English recognizer and a Native recognizer in conjunction with certain other intermediate steps. This strategy tries to cover and model the English target pronunciation and the native initial pronunciation and tries to account for different ways a foreign speaker may attempt to pronounce words in a non-native language. Different strategies may be used to deploy an integrated hybrid recognizer to cover the different levels of non-native language knowledge that a foreign speaker may have. To illustrate this approach, some non limiting examples of this approach are discussed below.
1) For very initial learners having little ability to read in English, a good strategy could be to generate pronunciations using a foreign G2P. In this example a Foreign (e.g., Spanish) G2P 104A and a foreign-based (e.g., Spanish) recognizer 105 may be used to recognize English words. In the case of English and Spanish, the pronunciation generator 101 generates Spanish pronunciations through Spanish G2P conversion, based on Spanish pronunciations, of English words. 2) The next step in learning a non-native language is “knowing how to read but not yet knowing how to pronounce”. For speakers that read English and identify the foreign pronunciation but utter English words using their native phoneme system it is a better strategy to use the foreign-based (e.g., Spanish) recognizer 105. However, the pronunciation in this case will be generated with the native G2P 104B but with transformed pronunciations. In this case the speaker's pronunciation may be modeled assuming that such speaker knows “the English way of speaking” and can read English but still uses her native phoneme system. By way of example, many English learners in Europe may stay in this stage if they can read English and only occasionally speak and listen to English. The pronunciation generator 101 may generate pronunciations automatically for such speakers using two components: A G2P corresponding to the orthographic (native) language (e.g., English) 104B and Phoneme Transformation Rules 106 between the orthographic and target languages, in case of recognizing English words spoken by a Spanish speaker. The English phonemes are transformed to Spanish phonemes according to the Transformation Rules 106.
Transforming English pronunciations of entire words into corresponding native Spanish pronunciations with conventional methods is a challenging, laborious and time-consuming task. The pronunciations could be generated using expert knowledge. However, in certain embodiments of the present invention these corresponding pronunciations may be generated automatically by transforming the phonemes of the Orthographic language (e.g., English) to the corresponding phonemes in the target language (e.g., Spanish). The following example illustrates how some general rules can be applied to do the phoneme transformation automatically, thereby saving manual work and that can be applied to new words.
Here are some examples of phoneme transformation rules 106 that may be used for transforming English phonemes to Spanish phonemes. English phonemes are labeled with ‘//EN’ and Spanish phonemes with ‘//SP’:
As a first example, the English word ‘water’ in English may be transcribed into the English phoneme set “w//EN ax//EN t//EN er//EN”. Using the Spanish phoneme set this may be transformed into “w//SP a//SP t//SP e//SP r//SP”. The English schwa “ax//EN” is transformed in Spanish to “a//SP” because the schwa represents the sound corresponding to the character ‘a’ in ‘water’.
As a second example, the English word ‘the’ can be transcribed in English as “dh//EN ax//EN” or “dh//EN ah//EN”. Using the Spanish phoneme set this may be transformed into “d//SP e//SP”. In this case the English schwa “ax//EN” or the phoneme “ah//EN” associated to the character ‘e’, can both be transformed into the Spanish phoneme “e//SP”. In this example, the English phoneme “dh//EN” has been transformed to the Spanish phoneme “d//SP” because it is the closest Spanish phoneme from an acoustic standpoint.
As a third example, in the English word ‘station’ the English schwa phoneme “ax//EN” may be transformed this time into the Spanish diphthong “j//SP o//SP”.
Station: s//EN t//EN ey//EN sh//EN ax//EN n//EN (Original English transcription)
Station: e//SP s//SP t//SP e//SP j//SP s//SP j//SP o//SP n//SP (transformed Spanish transcription)
The “ax//EN” represent the English letters ‘io’ and is transformed and pronounced in Spanish by “j//SP o//SP”.
The main reason for the transformation rule above is that Spanish speakers learn English using English written information and often are unable to distinguish the English schwa (which does not exist in Spanish) so they reduce it to their native pronunciation style. In a recognizer this transformation rule can be applied automatically by means of conditional rules that also take into account the orthography. In another example, Italian Speakers may follow also this same pattern because the schwa, and other central vowels, do not exist in Italian as well. Consequently, techniques similar to those described above can also be applied to generate pronunciations of English words by native speakers of Italian.
c) Other automatic transformation rules can be also applied. Tried and tested phonological rules of the target language can be applied when transforming the pronunciations of the orthographic language. Continuing with the Spanish to English example, in Spanish the sequences of phonemes “s//SP t//SP”, “s//SP p//SP” and “s//SP k//SP” are in fact pronounced “e//SP s//SP t//SP”, “e//SP s//SP p//SP” and “e//SP s//SP k//SP”. When Spanish speakers speak English they tend to apply this rule. In the previous case, the word ‘Station’ begins with the English phonemes “s//EN t//EN” that can be transformed into the Spanish phonemes “e//SP s//SP t//SP” following this phonological rule.
By way of example, the English phone set (TIMIT style) may be mapped into the Spanish phone set (SAMPA Style): as follows:
Combinations of 1) and 2) are also possible. For example, foreign acronyms can be said using either the native transcription rules or the English transcription rules. Thus, the acronym U2 may be pronounced as either ‘u dos’ or ‘you two’. Consequently both pronunciations may be mapped to the acronym that is displayed as ‘U2’ by the application using the speech recognition system described herein.
3) For Speakers that have a higher level of familiarity with the English language, some of the transformations can also be applied to an English voice recognizer 110 directly. This can also be done in combination with other known techniques such as HMM adaptation, integrate HMM training, intermediate phone merging. Alternatively, the transformation rules may allow for the use of some non-native phones that are more easily learned (“sh//EN”, “v//EN” . . . ).
Not only rules based methods but Data driven methods can also be used to generate pronunciations that try to properly model non-native speech of foreign speakers in an intermediate learning stage. In the process of learning a foreign language, intermediate learner speakers try to approximate “the way they speak” and try to mimic as close as possible the foreign language. At this stage a “rules based system” does not model the high degree of existing variability. Foreign speakers try also to speak a non-native language using “acoustic similarity knowledge and even random best guess”, not only written rules. For example, speakers will try to mimic acoustic closed foreign pronunciations as an alternative to written based rules pronunciations.
In the previous example of the word ‘water’, some non-native Spanish speakers would try to say not only “w//SP a//SP t//SP e//SP r//SP”. Alternatively they may try also the pronunciation: “w//SP o//SP t//SP e//SP r//SP”. The phones “a//SP” and “o//SP” are acoustically very close to each other in Spanish and acoustically very close to the English schwa “ax//En”. Some Spanish speakers may also be able to mix the two language phone sets and may be able to produce cross language pronunciations like: “w//SP ax//EN t//SP e//SP r//SP”. Some speakers may also be able to generate pronunciations with intermediate phone sets of the two languages.
The alternative acoustic based pronunciations can be generated using similarity models like distance measures, pattern matching systems . . . or, acoustics confusion knowledge. Once automatically generated, the pronunciations can be validated and selected using a real speech database and real recordings of non-native speakers.
4) For speakers with a very high level of proficiency in English, the pronunciation generator may use a purely English system, i.e., native G2P 104B for pronunciation generation and native voice recognizer 110.
Finally, Combinations and integration of combinations involving some or all the strategies described above with respect to strategies 1), 2), 3), and 4) can be used in a unique integrated system to cover all the levels of ability of a foreign speaker to speak a non-native language. In this way, the pronunciation generator 101 will generate two or more pronunciations (native plus foreign) for each given word.
When dealing with word sequences like phrases or sentences, it is not difficult to see that the number of pronunciations can get out of control. If two pronunciations may be needed for one word, four pronunciations will be needed for a sequence of two words and eight for a sequence of three words. For the sake of practicality, a pronunciation refinement may be needed as part of the pronunciation generator 101. By way of example, the pronunciation generator 101 may include an optional consensus module 107 that refines the pronunciation mapping of entries in the database 108 by discarding unlikely, redundant, or invalid pronunciations. The basics of a similar pronunciation refinement that utilizes a consensus module are described in US Patent Application Publication number 20060031070 entitled “System and Method For Efficiently Implementing A Refined Dictionary For Speech Recognition” by Gustavo Hernandez-Abrego and Lex Olorenshaw, the entire contents of which are incorporated herein by reference.
The consensus module 107 may perform multiple sequence alignment procedures by aligning corresponding phonemes from pronunciation for each input word. The consensus module 107 may define a “center” pronunciation among the possible multiple pronunciations of a word to refine and discard pronunciations that might be spurious to the voice recognition system 110. By way of example, two center pronunciations may be generated from a consensus of the two sets of pronunciations (orthographic and target languages) and those pronunciations in each set that lie too far away for consensus may be eliminated. In a preferred embodiment, the consensus module 107 may use a Multiple Sequence Alignment (MSA) step to find a consensus among the orthographic and target sets of pronunciation. MSA is a common tool in computational biology but it is not yet a widespread technique in speech and language technologies.
In some embodiments, transformation rules 106 may transform a set of phonemes from one language to another through use of a set of intermediate phonemes that are used to multiple languages. The intermediate phonemes of such a set are sometimes referred to herein as “phoneme classes”. The phoneme classes may be determined from the phonetics of multiple languages. Phoneme classes may be determined by an application based on the application's need. It is usually advisable to group together phonemes of similar sound characteristic. This intermediate mapping of phonemes allows a mapping of phonemes from any source language to any target language provided the phonemes of each language of interest for G2P are mapped to the intermediate phonemes.
According to an embodiment of the present invention, a speech processing system, e.g., as shown in
By way of non-limiting example, as illustrated in
If an English-Italian pronunciation cannot be generated at 207) based on the orthographic language of the word based on the application's need, a pronunciation may be generated using mapping information that maps Italian phonemes to English phonemes, e.g., as described above. Specifically, the pronunciation of Italian orthographic word obtained from 204) or 207) may be broken up into its constituent phonemes for pronunciation by a native Italian speaker. Each phoneme that makes up the word is mapped to one or more corresponding English phonemes. Such mapping may be done by a direct mapping of Italian phonemes to corresponding English phonemes (if one exists). Alternatively, a mapping may be generated by way of the phoneme classes, as discussed above. The resulting set of English phonemes and the corresponding Italian word may then be included in the English-Italian GnD. Since some of the Italian phonemes in the word may be mapped to two or more English phonemes, there may be more than one English-Italian pronunciation. However, the data structure may allow for one-to-many mappings to handle these different pronunciations.
In some special situations, a mixture of more than two phoneme languages could exist in one pronunciation entry. The entry can still be labeled as of EN Phone Lang or IT Phone Lang based on what phoneme language plays more important role for the entry. The previous processing may still be applied to generate the final GnD with a mixed Phoneme Lang in a single entry. An example of such an entry is:
Station: s//EN t//EN ey//EN sh//EN e//SP n//EN
The acoustic model used for “e//SP” of the left context phoneme of “sh//EN” and right context “n//EN” is the native Spanish model of “e//SP” of the left context phone “x//SP” and right context “n//SP”. This is assuming the phoneme classes defined by the application maps “sh/EN” to “x//SP”, “n//EN” to “n//SP”.
In some embodiments, the process illustrated in
As illustrated in
In some embodiments, the apparatus 100 may include a voice recognition module 110 and a foreign-based voice recognition module 105 that works in conjunction with the pronunciation generator 101. The voice recognition modules 110 and 105 may be implemented in hardware or software or some combination of both hardware and software. The voice recognition modules 110 and 105 receive a voice signal 115 that represents an utterance from a speaker SP. The voice signal 115 may be generated, e.g., using a microphone 117 to convert speech sounds from the speaker SP into an electrical signal using an electrical transducer. The electrical signal may be an analog signal, which may be converted to a digital signal through use of an analog to digital (A/D) converter. The digital signal may then be divided into a multiple units called frames, each of which may be further subdivided into samples. Each frame may be analyzed, e.g., using a Hidden Markov Model (HMM) to determine if the frame contains a known phoneme. The application of Hidden Markov Models to speech recognition is described in detail, e.g., by Lawrence Rabiner in “A Tutorial on Hidden Markov Models and Selected Applications in Speech Recognition” in Proceedings of the IEEE, Vol. 77, No. 2, February 1989, which is incorporated herein by reference in its entirety for all purposes.
Sets of input phonemes 111A, 111B determined from the voice signal 115 may be compared against multiple sets of phonemes (possibly from different languages) that make up pronunciations in the database 108. If a match is found between the phonemes from the voice signal 115 and a pronunciation in an entry in the database (referred to herein as a matching entry), the matching entry word 113 may correspond to a particular change of state of a computer apparatus that is triggered when the entry matches the phonemes determined from the voice signal.
As used herein, a “change of state” refers to a change in the operation of the apparatus. By way of example, a change of state may include execution of a command or selection of particular data for use by another process handled by the application 102. A non-limiting example of execution of a command would be for the apparatus to begin the process of selecting a song upon recognition of the word “select”. A non-limiting example of selection of data for use by another process would be for the process to select a particular song for play when the input phoneme set matches the title of the song.
The voice recognition modules 110 and 105 may address conflicts between different words with the same or similar pronunciation. Consider the case of the English words ‘worker’ and ‘work’. These words may be converted into phonemes as follows:
‘worker’−w(ao|er)k er. MPL=4.
‘work’−w er[k]. MPL=3.
The notation (ao|er) indicates that two possible phonemes may correspond to the combination ‘or’ in the orthographic word ‘word’. The notation [k] indicates that the phoneme in brackets is optional. The notation MPL indicates the maximum pronunciation length for the word, which is the largest number of phonemes the word could have.
In some cases, two or more words with different maximum pronunciation lengths may have equally likely pronunciations. In such a case, the voice recognition modules 110 and 105 may reject the word having the longer pronunciation length if both are equally likely.
A speech processing apparatus may be configured in accordance with embodiments of the present invention in any of a number of ways. By way of example,
The apparatus 300 generally includes a processing unit (CPU) 301 and a memory unit 302. The apparatus 300 may also include well-known support functions 311, such as input/output (I/O) elements 312, power supplies (P/S) 313, a clock (CLK) 314 and cache 315. The apparatus 300 may further include a storage device 316 that provides non-volatile storage for software instructions 317 and data 318. By way of example, the storage device 316 may be a fixed disk drive, removable disk drive, flash memory device, tape drive, CD-ROM, DVD-ROM, Blu-ray, HD-DVD, UMD, or other optical storage devices.
The processing unit 301 may include one or more processing cores. By way of example and without limitation, the CPU 302 may be a parallel processor module, such as a Cell Processor. An example of a Cell Processor architecture is described in detail, e.g., in Cell Broadband Engine Architecture, copyright International Business Machines Corporation, Sony Computer Entertainment Incorporated, Toshiba Corporation Aug. 8, 2005 a copy of which may be downloaded at http://cell.scei.co.jp/, the entire contents of which are incorporated herein by reference.
The memory unit 302 may be any suitable medium for storing information in computer readable form. By way of example, and not by way of limitation, the memory unit 302 may include random access memory (RAM) or read only memory (ROM), a computer readable storage disk for a fixed disk drive (e.g., a hard disk drive), or a removable disk drive.
The processing unit 301 may be configured to run software applications and optionally an operating system. Portions of such software applications may be stored in the memory unit 302. Instructions and data may be loaded into registers of the processing unit 302 for execution. The software applications may include a main application 303, such as a video game application. The main application 303 may operate in conjunction with application data 304 and speech processing software, which may include a pronunciation generator 305, a GnD 306, and a voice recognizer 307, portions of all of which may be stored in the memory 302 and loaded into registers of the processing unit 301 as necessary.
Through appropriate configuration of the foregoing components, the CPU 301 and pronunciation generator 305 may be configured to implement the speech processing operations described above with respect to
The voice recognizer 307 may include a speech conversion unit configured to convert a sound signal produced by a speaker into a set of input phonemes. The sound signal may be converted to a digital signal via microphone 322 and A/D converter, which may be implemented, e.g., as part of the I/O function 312. The voice recognizer 307 may be further configured to compare the set of input phonemes to one or more entries in the GnD 306 and trigger the application 304 to execute a change of state corresponding to a database entry that includes a pronunciation that matches the set of input phonemes. Speech recognition may be made more robust through the generation multiple pronunciations for a given word based on language assumptions about the speaker.
The apparatus 300 may include a network interface 325 to facilitate communication via an electronic communications network 327. The network interface 325 may be configured to implement wired or wireless communication over local area networks and wide area networks such as the Internet. The system 300 may send and receive data and/or requests for files via one or more message packets 326 over the network 327.
The apparatus 300 may further comprise a graphics subsystem 330, which may include a graphics processing unit (GPU) 335 and graphics memory 337. The graphics memory 337 may include a display memory (e.g., a frame buffer) used for storing pixel data for each pixel of an output image. The graphics memory 337 may be integrated in the same device as the GPU 335, connected as a separate device with GPU 335, and/or implemented within the memory unit 302. Pixel data may be provided to the graphics memory 337 directly from the processing unit 301. In some embodiments, the graphics unit may receive a video signal data extracted from a digital broadcast signal decoded by a decoder (not shown). Alternatively, the processing unit 301 may provide the GPU 335 with data and/or instructions defining the desired output images, from which the GPU 335 may generate the pixel data of one or more output images. The data and/or instructions defining the desired output images may be stored in memory 302 and/or graphics memory 337. In an embodiment, the GPU 335 may be configured (e.g., by suitable programming or hardware configuration) with 3D rendering capabilities for generating pixel data for output images from instructions and data defining the geometry, lighting, shading, texturing, motion, and/or camera parameters for a scene. The GPU 335 may further include one or more programmable execution units capable of executing shader programs.
The graphics subsystem 330 may periodically output pixel data for an image from the graphics memory 337 to be displayed on a video display device 340. The video display device 350 may be any device capable of displaying visual information in response to a signal from the apparatus 300, including CRT, LCD, plasma, and OLED displays that can display text, numerals, graphical symbols or images. The digital broadcast receiving device 300 may provide the display device 340 with a display driving signal in analog or digital form, depending on the type of display device. In addition, the display 340 may be complemented by one or more audio speakers that produce audible or otherwise detectable sounds. To facilitate generation of such sounds, the apparatus 300 may further include an audio processor 350 adapted to generate analog or digital audio output from instructions and/or data provided by the processing unit 301, memory unit 302, and/or storage 316. The audio output may be converted to audible sounds, e.g., by a speaker 355.
The components of the apparatus 300, including the processing unit 301, memory 302, support functions 311, data storage 316, user input devices 320, network interface 325, graphics subsystem 330 and audio processor 350 may be operably connected to each other via one or more data buses 360. These components may be implemented in hardware, software or firmware or some combination of two or more of these.
Embodiments of the present invention are usable with applications or systems that utilize a camera, which may be a depth camera, sometimes also known as a 3D camera or zed camera. By way of example, and not by way of limitation, the apparatus 300 may optionally include a camera 324, which may be a depth camera, which, like the microphone 322, may be coupled to the data bus via the I/O functions. The main application 303 may analyze images obtained with the camera to determine information relating to the location of persons or objects within a field of view FOV of the camera 324. The location information can include a depth z of such persons or objects. The main application 304 may use the location information in conjunction with speech processing as described above to obtain inputs.
According to another embodiment, instructions for carrying out speech processing as described above may be stored in a computer readable storage medium. By way of example, and not by way of limitation,
The storage medium 400 contains pronunciation generation instructions 401 including one or more G2P instructions 402 for converting the input word into one or more pronunciations, wherein each pronunciation includes one or more phonemes selected from a set of phonemes associated with the second language. The G2P instructions 402 may be configured to perform G2P in two or more different languages. The pronunciation generation instructions also include one or more pronunciation association instructions 403 configured to associate each generated pronunciation with the input word in an entry in a computer database in a memory unit.
The pronunciation generation instructions 401 may also include language association instructions 404 configured to associate a phoneme language and pronunciation language with each pronunciation entry in the database.
The medium 400 may also optionally include one or more voice recognition instructions 405. The voice recognition instructions 405 may be configured for converting input speech signals to groups of input phonemes and comparing the groups of input phonemes to pronunciations in the database, e.g., as described above with respect to voice recognizer 110 of
Embodiments of the present invention provide a complete system and method to automatically generate pronunciations from input words that can be of a language different from the target language. No user-intervention is needed before or after the pronunciation generation. This method generates two kinds of pronunciations: one estimated using the characteristics of the orthographic language (the language of the input word) and one estimated from the target language (the language of interest for the G2P conversion). To change the source language results in a phoneme conversion based on a cross-language intermediate phoneme mapping that is used internally. To deal with the possible excess of generated entries, a pronunciation refinement step may be applied to optimize the set of pronunciations coming from both the target and source languages. All these steps (pronunciation generation, cross-language conversion and pronunciation refinement) have been implemented on a self-contained, compact and efficient framework that allows the system to run embedded on software that implements speech recognition, such as the PlayStation Voice Response (PSVR) software.
While the above is a complete description of the preferred embodiment of the present invention, it is possible to use various alternatives, modifications and equivalents. Therefore, the scope of the present invention should be determined not with reference to the above description but should, instead, be determined with reference to the appended claims, along with their full scope of equivalents. Any feature described herein, whether preferred or not, may be combined with any other feature described herein, whether preferred or not. In the claims that follow, the indefinite article “A”, or “An” refers to a quantity of one or more of the item following the article, except where expressly stated otherwise. The appended claims are not to be interpreted as including means-plus-function limitations, unless such a limitation is explicitly recited in a given claim using the phrase “means for”.
Number | Name | Date | Kind |
---|---|---|---|
4956865 | Lennig et al. | Sep 1990 | A |
4977598 | Doddington et al. | Dec 1990 | A |
RE33597 | Levinson et al. | May 1991 | E |
5031217 | Nishimura | Jul 1991 | A |
5050215 | Nishimura | Sep 1991 | A |
5129002 | Tsuboka | Jul 1992 | A |
5148489 | Erell et al. | Sep 1992 | A |
5222190 | Pawate et al. | Jun 1993 | A |
5228087 | Bickerton | Jul 1993 | A |
5345536 | Hoshimi et al. | Sep 1994 | A |
5353377 | Kuroda et al. | Oct 1994 | A |
5438630 | Chen et al. | Aug 1995 | A |
5455888 | Iyengar et al. | Oct 1995 | A |
5459798 | Bailey et al. | Oct 1995 | A |
5473728 | Luginbuhl et al. | Dec 1995 | A |
5502790 | Yi | Mar 1996 | A |
5506933 | Nitta | Apr 1996 | A |
5509104 | Lee et al. | Apr 1996 | A |
5535305 | Acero et al. | Jul 1996 | A |
5581655 | Cohen et al. | Dec 1996 | A |
5602960 | Hon et al. | Feb 1997 | A |
5608840 | Tsuboka | Mar 1997 | A |
5615296 | Stanford et al. | Mar 1997 | A |
5617407 | Bareis | Apr 1997 | A |
5617486 | Chow et al. | Apr 1997 | A |
5617509 | Kushner et al. | Apr 1997 | A |
5627939 | Huang et al. | May 1997 | A |
5649056 | Nitta | Jul 1997 | A |
5649057 | Lee et al. | Jul 1997 | A |
5655057 | Takagi | Aug 1997 | A |
5677988 | Takami et al. | Oct 1997 | A |
5680506 | Kroon et al. | Oct 1997 | A |
5680510 | Hon et al. | Oct 1997 | A |
5719996 | Chang et al. | Feb 1998 | A |
5745600 | Chen et al. | Apr 1998 | A |
5758023 | Bordeaux | May 1998 | A |
5787396 | Komori et al. | Jul 1998 | A |
5794190 | Linggard et al. | Aug 1998 | A |
5799278 | Cobbett et al. | Aug 1998 | A |
5812974 | Hemphill et al. | Sep 1998 | A |
5825978 | Digalakis et al. | Oct 1998 | A |
5835890 | Matsui et al. | Nov 1998 | A |
5860062 | Taniguchi et al. | Jan 1999 | A |
5880788 | Bregler | Mar 1999 | A |
5890114 | Yi | Mar 1999 | A |
5893059 | Raman | Apr 1999 | A |
5903865 | Ishimitsu et al. | May 1999 | A |
5907825 | Tzirkel-Hancock | May 1999 | A |
5913193 | Huang et al. | Jun 1999 | A |
5930753 | Potamianos et al. | Jul 1999 | A |
5937384 | Huang et al. | Aug 1999 | A |
5943647 | Ranta | Aug 1999 | A |
5956683 | Jacobs et al. | Sep 1999 | A |
5963903 | Hon et al. | Oct 1999 | A |
5963906 | Turin | Oct 1999 | A |
5983178 | Naito et al. | Nov 1999 | A |
5983180 | Robinson | Nov 1999 | A |
6009390 | Gupta et al. | Dec 1999 | A |
6009391 | Asghar et al. | Dec 1999 | A |
6023677 | Class et al. | Feb 2000 | A |
6035271 | Chen | Mar 2000 | A |
6061652 | Tsuboka et al. | May 2000 | A |
6067520 | Lee | May 2000 | A |
6078884 | Downey | Jun 2000 | A |
6092042 | Iso | Jul 2000 | A |
6108627 | Sabourin | Aug 2000 | A |
6112175 | Chengalvarayan | Aug 2000 | A |
6138095 | Gupta et al. | Oct 2000 | A |
6138097 | Lockwood et al. | Oct 2000 | A |
6148284 | Saul | Nov 2000 | A |
6151573 | Gong | Nov 2000 | A |
6151574 | Lee et al. | Nov 2000 | A |
6188982 | Chiang | Feb 2001 | B1 |
6188984 | Manwaring et al. | Feb 2001 | B1 |
6223159 | Ishii | Apr 2001 | B1 |
6226612 | Srenger et al. | May 2001 | B1 |
6236963 | Naito et al. | May 2001 | B1 |
6246980 | Glorion et al. | Jun 2001 | B1 |
6253180 | Iso | Jun 2001 | B1 |
6256607 | Digalakis et al. | Jul 2001 | B1 |
6272464 | Kiraz et al. | Aug 2001 | B1 |
6292776 | Chengalvarayan | Sep 2001 | B1 |
6347295 | Vitale et al. | Feb 2002 | B1 |
6405168 | Bayya et al. | Jun 2002 | B1 |
6411932 | Molnar et al. | Jun 2002 | B1 |
6415256 | Ditzik | Jul 2002 | B1 |
6442519 | Kanevsky et al. | Aug 2002 | B1 |
6446039 | Miyazawa et al. | Sep 2002 | B1 |
6456965 | Yeldener | Sep 2002 | B1 |
6526380 | Thelen et al. | Feb 2003 | B1 |
6593956 | Potts et al. | Jul 2003 | B1 |
6629073 | Hon et al. | Sep 2003 | B1 |
6662160 | Chien et al. | Dec 2003 | B1 |
6671666 | Ponting et al. | Dec 2003 | B1 |
6671668 | Harris | Dec 2003 | B2 |
6671669 | Garudadri et al. | Dec 2003 | B1 |
6681207 | Garudadri | Jan 2004 | B2 |
6721699 | Xu et al. | Apr 2004 | B2 |
6738738 | Henton | May 2004 | B2 |
6757652 | Lund et al. | Jun 2004 | B1 |
6801892 | Yamamoto | Oct 2004 | B2 |
6832190 | Junkawitsch et al. | Dec 2004 | B1 |
6868382 | Shozakai | Mar 2005 | B2 |
6901365 | Miyazawa | May 2005 | B2 |
6907398 | Hoege | Jun 2005 | B2 |
6934681 | Emori et al. | Aug 2005 | B1 |
6963836 | Van Gestel | Nov 2005 | B2 |
6980952 | Gong | Dec 2005 | B1 |
7003460 | Bub et al. | Feb 2006 | B1 |
7043431 | Riis et al. | May 2006 | B2 |
7107216 | Hain | Sep 2006 | B2 |
7133535 | Huang et al. | Nov 2006 | B2 |
7139707 | Sheikhzadeh-Nadjar et al. | Nov 2006 | B2 |
7269556 | Kiss et al. | Sep 2007 | B2 |
7472061 | Alewine et al. | Dec 2008 | B1 |
7590533 | Hwang | Sep 2009 | B2 |
7966173 | Emam et al. | Jun 2011 | B2 |
8032377 | Massimino | Oct 2011 | B2 |
8069045 | Emam et al. | Nov 2011 | B2 |
20020049591 | Hain | Apr 2002 | A1 |
20020069063 | Buchner et al. | Jun 2002 | A1 |
20020116196 | Tran | Aug 2002 | A1 |
20030033145 | Petrushin | Feb 2003 | A1 |
20030177006 | Ichikawa et al. | Sep 2003 | A1 |
20040059576 | Lucke | Mar 2004 | A1 |
20040078195 | Oda et al. | Apr 2004 | A1 |
20040088163 | Schalkwyk | May 2004 | A1 |
20040220804 | Odell | Nov 2004 | A1 |
20050010408 | Nakagawa et al. | Jan 2005 | A1 |
20050038655 | Mutel et al. | Feb 2005 | A1 |
20050065789 | Yacoub et al. | Mar 2005 | A1 |
20050187758 | Khasin | Aug 2005 | A1 |
20050286705 | Contolini et al. | Dec 2005 | A1 |
20060020462 | Reich | Jan 2006 | A1 |
20060020463 | Reich | Jan 2006 | A1 |
20060031069 | Huang et al. | Feb 2006 | A1 |
20060031070 | Abrego et al. | Feb 2006 | A1 |
20060178876 | Sato et al. | Aug 2006 | A1 |
20060195319 | Prous Blancafort et al. | Aug 2006 | A1 |
20060224384 | Dow et al. | Oct 2006 | A1 |
20060229864 | Suontausta et al. | Oct 2006 | A1 |
20060277032 | Hernandez-Abrego et al. | Dec 2006 | A1 |
20070005206 | Zhang et al. | Jan 2007 | A1 |
20070015121 | Johnson et al. | Jan 2007 | A1 |
20070082324 | Johnson et al. | Apr 2007 | A1 |
20070112566 | Chen | May 2007 | A1 |
20070198261 | Chen | Aug 2007 | A1 |
20070198263 | Chen | Aug 2007 | A1 |
20070233487 | Cohen et al. | Oct 2007 | A1 |
20080052062 | Stanford | Feb 2008 | A1 |
20080294441 | Saffer | Nov 2008 | A1 |
20090024720 | Karray et al. | Jan 2009 | A1 |
20090076821 | Brenner et al. | Mar 2009 | A1 |
Number | Date | Country |
---|---|---|
0866442 | Sep 1998 | EP |
1571651 | Sep 2005 | EP |
WO 2004111999 | Dec 2004 | WO |
Entry |
---|
Lawrence Rabiner, “A Tutorial on Hidden Markov Models and Selected Application Speech Recognition”—Proceeding of the IEEE, vol. 77, No. 2, Feb. 1989. |
Steven B. Davis et al., “Comparison of Parametric Representations for Monosyllabic Word Recognition in Continuously Spoken Sentences”—IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. ASSP 28, No. 4, p. 357-366, Aug. 1980. |
G. David Forney, Jr., “The Viterbi Agorithm”—Proceeding of the IEEE, vol. 61, No. 3, p. 268-278, Mar. 1973. |
Kai-Fu Lee et al., “Speaker-Independent phone Recognition Using Hidden Markov Models”—IEEE Transaction in Acoustics, Speech, and Signal Processing, vol. 37, No. 11, p. 1641-1648, Nov. 1989. |
Hans Werner Strube, “Linear Prediction on a Warped Frequency Scale,”—The Journal of the Acoustical Society of America, vol. 68, No. 4, p. 1071-1076, Oct. 1980. |
Leonard E. Baum et al., “A Maximization Technique Occurring in The Statistical Analysis of Probabilistic Functions of Markov Chains,”—The Annals of Mathematical Statistics, vol. 41, No. 1, p. 164-171, Feb. 1970. |
Rohit Sinha et al., “Non-Uniform Scaling Based Speaker Normalization” 2002 IEEE, May 13, 2002, vol. 4, pp. I-589-1-592. |
Li Lee et al., “Speaker Normalization Using Efficient Frequency Warping Procedures” 1996 IEEE, vol. 1, pp. 353-356. |
Vasilache, “Speech recognition Using HMMs With Quantized Parameters”, Oct. 2000, 6th International Conference on Spoken Language Processing (ICSLP 2000), pp. 1-4. |
Bocchieri, “Vector Quantization for the Efficient Computation of Continuous Density Likelihoods”, Apr. 1993, International conference on Acoustics, Speech, and Signal Processing, IEEE, pp. 692-695. |
Claes et al. “A Novel Feature Transformation for Vocal Tract Length Normalization in Automatic Speech Recognition”, IEEE Transformations on Speech and Audio Processing, vol. 6, 1998, pp. 549-557. |
M. Tamura et al. “Adaptation of Pitch and Spectrum for HMM-Based Speech Synthesis Using MLLR”, proc of ICASSP 2001, vl. 1, pp. 1-1, May 2001. |
Cherif A, “Pitch and Formants Extraction Algorithm for Speech Processing,” Electronics, Circuits and Systems, 2000, ICECS 2000. The 7th IEEE International Conference on vol. 1, Dec. 17-20, 2000, pp. 595-598, vol. 1. |
L. Lee, R. C. Rose, “A frequency warping approach to speaker normalization,” in IEEE Transactions on Speech and Audio Processing, vol. 6, No. 1, pp. 49-60, Jan. 1998. |
W. H. Abdulla and N. K. Kasabov. 2001. Improving speech recognition performance through gender separation. In Proceedings of ANNES, pp. 218-222. |
Iseli, M., Y. Shue, and A. Alwan (2006). Age- and Gender-Dependent Analysis of Voice Source Characteristics, Proc. ICASSP, Toulouse. |
U.S. Appl. No. 61/153,267 entitled “Multiple Language Voice Recognition”, filed Feb. 17, 2009. |
“Cell Broadband Engine Architecture”, copyright International Business Machines Corporation, Sony Computer Entertainment Incorporated, Toshiba Corporation Aug. 8, 2005. |
International Search Report and Written Opinion dated Mar. 19, 2010 issued for International Application PCT/US10/23098. |
International Search Report and Written Opinion dated Mar. 22, 2010 issued for International Application PCT/US10/23102. |
International Search Report and Written Opinion dated Apr. 5, 2010 issued for International Application PCT/US10/23105. |
Japanese Non-Final Notification of Reasons for Refusal mailed date Feb. 26, 2013 issued for Japanese Patent Application No. 2011-551105. |
Extended Search Report dated Nov. 27, 2012 in European Patent Application No. 107444128.9. |
Viet-Bac Le et al: “First Steps in Fast Acoustic Modeling for a New Target Language: Application to Vietnamese”, 2005 IEEE International Conference on Acoustics, Speech, and Signal Processing Mar. 18-23, 2005—Philadelphia, PA, USA, IEEE, Piscataway, NJ, vol. 1, Mar. 18, 2005, pp. 821-824, XP010792164, DOI: 10.1109/ICASSP.2005.1415240 ISBN: 978-0-7803-8874-1. |
Khe Chai Sim et al: “Robust phone set mapping using decision tree clustering for cross-lingual phone recognition”, Acoustics, Speech and Signal Processing, 2008. ICASSP 2008. IEEE International Conference on, IEEE, Piscataway, NJ, USA, Mar. 31, 2008, pp. 4309-4312, XP031251550, ISBN: 978-1-4244-1483-3. |
Number | Date | Country | |
---|---|---|---|
20100211376 A1 | Aug 2010 | US |
Number | Date | Country | |
---|---|---|---|
61153267 | Feb 2009 | US |