This invention relates generally to text-to-speech synthesizers, and more particularly to a method and apparatus for improving text-to-speech performance.
Synthesizing text-to-speech (TTS) is MIPS (Million Instructions Per Second) intensive. In battery-operated devices, resources such as a microprocessor and accompanying memory may not always be available to provide a consistent performance when synthesizing TTS, especially when such resources are concurrently being used by other software applications. Consequently, the performance of synthesizing TTS can sound choppy or unintelligible to a user with a device having limited resources. Moreover, frequent synthesis of TTS can drain battery life.
The embodiments of the invention described below help to overcome this limitation in the art.
Embodiments in accordance with the invention provide a method and apparatus for improving text-to-speech (TTS) performance.
In a first embodiment of the present invention, a device provides a method for improving text-to-speech performance. The method includes the steps of synthesizing a vocabulary of frequently used text expressions into speech expressions, storing the speech expressions in the vocabulary, determining if a text expression from an application operating in the device is in the vocabulary, selecting a corresponding speech expression from the vocabulary if the text expression is included therein, synthesizing the text expression into a speech expression if the text expression is not in the vocabulary, playing the speech expression audibly from the device, and repeating the foregoing steps starting from the determining step during operation of the application.
In a second embodiment of the present invention, a device provides a method for improving text-to-speech performance. The method includes the steps of determining if a text expression from an application operating in the device is in a vocabulary, selecting a corresponding speech expression from the vocabulary if the text expression is included therein, synthesizing the text expression into a corresponding speech expression if the text expression is not in the vocabulary, playing said corresponding speech expression audibly from the device, monitoring a frequency of use of said text expression, storing the text expression and the corresponding speech expression in the vocabulary if the frequency of use of said expression is greater than a predetermined threshold and said expressions were not previously stored, eliminating one or more text expressions and corresponding speech expressions from the vocabulary if the frequency of use of said expressions falls below the predetermined threshold, and repeating the foregoing steps during operation of the application.
In a third embodiment of the present invention, a device comprising an audio system, a memory, and a processor coupled to the foregoing elements. The processor is programmed to determine if a text expression from an application operating in the device is in a vocabulary, selecting a corresponding speech expression from the vocabulary if the text expression is included therein, synthesize the text expression into a corresponding speech expression if the text expression is not in the vocabulary, play said corresponding speech expression audibly from the audio system, monitor a frequency of use of said text expression, store in the memory a vocabulary of said text expression and corresponding speech expression if the frequency of use of said expressions is greater than a predetermined threshold, eliminate from the vocabulary one or more text expressions and corresponding speech expressions if the frequency of use of said expressions falls below the predetermined threshold, and repeat the foregoing steps during operation of the application.
While the specification concludes with claims defining the features of embodiments of the invention that are regarded as novel, it is believed that the embodiment of the invention will be better understood from a consideration of the following description in conjunction with the figures, in which like reference numerals are carried forward.
The processor 102, for example, comprises a conventional microprocessor, a DSP (Digital Signal Processor), or like computing technology singly or in combination to operate software applications that control the components 102-114 of the device 100 in accordance with the invention. The memory 104 is a conventional memory device for storing software applications and for processing data therein. The audio system 106 is a conventional audio device for processing and presenting to an end user of the device 100 audio signals such as music or speech. The power supply 112 utilizes conventional supply technology for powering the components 102-114 of the device 100. Where the device is portable, the power supply 112 utilizes batteries coupled to conventional circuitry to supply power to the device 100.
In more sophisticated applications, the device 100 can utilize a transceiver 114 to communicate wirelessly to other devices via a conventional communication system such as a cellular network. Moreover, the device 100 can utilize a display 108 for presenting a UI (User Interface) for manipulating operations of the device 100 by way of a conventional keypad with navigation functions coupled to the input/output port 110.
The application can be any conventional software application that utilizes TTS (Text-To-Speech) synthesis in the normal course of operation. A conventional J2ME (Java 2 platform Micro Edition) application is an example of such an application. Generally, J2ME applications consist of a JAR (Java ARchive) file containing class and resource files and an application descriptor file. The application descriptor file can include a vocabulary of frequently used text expressions, or such a vocabulary can be managed in a separate file referred to herein as a VDF (Vocabulary Descriptor File). Maintaining the vocabulary in a file separate from the application descriptor file provides the end user of the device 100 or the enterprise supplying the J2ME application the flexibility to customize and update the vocabulary independent of the application. Moreover, the VDF can be made available to more than one J2ME application operating on the processor 102.
The VDF can consist of an application name, an application JAR file, an application version, and application vocabulary list. The vocabulary list consists of expressions consisting of words and/or short phrases used frequently by the application. The expressions in the vocabulary can be formatted using SSML (Speech Synthesis Markup Language) which provides the capability to control aspects of speech such as pronunciation, volume, pitch, and rate, just to name a few.
Prior to operating the application, the method 200 can be supplemented by pre-loading the application with a VDF containing a predetermined vocabulary of frequently used expressions. In this embodiment, the determining step 202 is preceded with a step (not shown in
Referring back to method 200, after the determining step the processor 102 selects in step 204 a corresponding speech expression from the vocabulary in the VDF if the text expression is included therein. If not, the text expression of the J2ME application is synthesized in step 206 by the conventional TTS engine mentioned above. In step 208, the processor 102 directs the audio system 106 to play the corresponding speech expression. In step 210, the processor 102 monitors a frequency of use of the text expression, and stores in the memory 104, in step 212, the text expression and corresponding speech expression if the frequency of use is greater than a predetermined threshold and said expressions were not previously stored in the memory 104.
In step 214, the processor 102 eliminates from the memory 104 one or more text expressions and corresponding speech expressions from the vocabulary if the frequency of use of said expressions falls below the predetermined threshold. Execution of step 214 can be dependent on whether additional room is needed in the memory 104 as a consequence of the preceding storage steps.
The storage and elimination steps 212-214 follow a conventional database technique for efficiently storing and retrieving said text and speech expressions to and from the memory 104. Additionally, the end user of the device 100 or the supplier of the J2ME application can elect the value of the predetermined threshold according to, for example, the nature of application, or some other relevant operating factor.
To enhance TTS performance, the processor 102 continues to repeat the foregoing steps starting from the determination step 202 during operation of the J2ME application. In addition, to capture historical patterns of frequently used expressions, the processor 102 can apply conventional caching techniques to the memory 104, to enhance TTS performance by reducing the incidence of synthesis steps, increase the speed of storage and retrievals, which together improve the battery life of the device 100.
The method 200 can be further supplemented with, for example, a periodic update of one or more vocabularies of frequently used expressions supplied by the enterprise providing the J2ME application. The vocabularies can be received through the input port 110 (e.g., coupled to the Internet with a conventional modem), or can be received over-the-air by way of the wireless transceiver 114. When these vocabularies are received, the text expressions are synthesized by the processor 102 to generate corresponding speech expressions. The vocabulary in the memory 104 is then updated with the foregoing expressions. When additional vocabularies and/or updated vocabularies are received and synthesized, the processor 102 may call on step 214 to make room in the memory 104 if there is insufficient room for these new expressions. The updated vocabularies can help to enhance the end user experience and battery life of the device 100 as fewer synthesis steps are required.
In light of the foregoing description, it should be recognized that embodiments in the present invention could be realized in hardware, software, or a combination of hardware and software. These embodiments could also be realized in numerous configurations contemplated to be within the scope and spirit of the claims below. It should also be understood that the claims are intended to cover the structures described herein as performing the recited function and not only structural equivalents.
For example, although wired communications and wireless communications may not be structural equivalents in that wired communications employ a physical means for communicating between devices (e.g., copper or optical cables), while wireless communications employ radio signals for communicating between devices, a wired communication system and a wireless communication system achieve the same result and thereby provide equivalent structures. Accordingly, equivalent structures that read on the description are intended to be included within the scope of the invention as defined in the following claims.