Not Applicable.
Not Applicable.
1. Field of the Invention
The present invention relates in general to streaming data, and more specifically, to a distributed network based system for retrieving data from an internetwork and converting the data to text-to-speech for a registered user.
2. Description of the Related Art
In today's advanced electronic economy, information is retrieved from a variety of sources using various devices. News and stock reports, email messages, and sports information are only some of the information retrieved from devices such as pagers, advanced phone systems, and the internet. Given the busy schedule of people's lifestyle, it is understood that a majority of the people are trying to accomplish an increasing number of tasks in a given time period or schedule. Reading reports and messages to remain updated or informed on the economy becomes an increasingly time consuming event. Reading newsworthy updates and events in electronic format usually requires focus on the subject matter at hand. Furthermore, extended work hours especially for that portion of the economy that performs much of their work on the computer do not find it pleasing to read such updates and events on the computer at the end of a workday.
Text-to-speech conversion can be performed by software tools that have become available. Text-to-speech software converts words in electronic form to audible form. However, while many products convert text-to-speech, such products are designed to be installed on a single user's computer. These software products require a large amount of memory allocation and periodically require updating due to advances made in the field of text-to-speech applications which can become costly, including the initial installation, to the end user over time if the end user desires to maintain the latest technology.
In one aspect of the invention, a method is performed for outputting text-to-speech streaming data using a distributed network based message processing system to an end user. The distributed network system includes a user access server for controlling access of registered users to the data retrieval system. An internetwork data retrieval system server retrieves raw data from an internetwork. A text-to-speech server converts the raw data to an audible speech data. A memory storage output device stores a streaming media file containing the audible speech data and a streaming media server transmits the audible speech data to the registered users via the internetwork. During operation a registered user is authenticated. The raw data is retrieved from the internetwork. The raw data is parsed for text passages. The text passages are converted to the audible speech data. The audible speech data is converted to a streaming media file. The streaming media file is stored in a memory storage output device and the streaming media file is output to the registered user.
Referring now to the Drawings and particularly to
The user access server 12 registers a new user, authenticates an existing user, and grants a registered user access to the data retrieval system. The user access server 12 further maintains and updates user preferences that are stored in a user preference database.
The internetwork data retrieval server 14 retrieves new data in the form of raw data from a subscribed internetwork service 15 based on the user preferences stored in the user storage database. The subscribed internetwork service 15 is maintained by a service provider that comprises multimedia information in an electronic format. Examples of such providers are internet service providers, phone service providers, pager service providers, and email service providers. The internetwork data retrieval server continuously checks for new data associated with the subscribed internetwork service 15 for a registered user and stores the new data in a temporary file until the TTS server is ready to convert the temporary file.
The text-to-speech server 16 parses the retrieved new data for text portions and converts the text portions to audible speech data which is saved to a streaming media file.
The four mini servers are connected by a XML messaging backbone 20 (messaging system) that handles messaging and notifications between the servers. The servers may be co-located either within a central server, a common hardware device, or may be separately located separately from one another linked by a communication network line such as a LAN line. The memory storage device 18 may preferably be co-located with the streaming media server 22. The architecture of the distributed network system is capable of managing numerous data retrieval services and numerous users. Since the distributed network is network based, an end user needs only a computer 24 with an installed web browser, an email or instant message client, and a multimedia player to manage the audio file, listen to the data, and receive notification that new audio files are present.
In step 30, a user initiates a connection with the data retrieval system. In step 31, the data retrieval system waits for a user connection to the messaging system. A determination is made whether the user is connected to messaging system in step 32. If the determination is made that the user is not connected to the messaging system, a return is made to step 31 to wait for the user connection to the messaging system. If the determination is made in step 32 that the user is connected to the messaging system, the user access server waits for user authentication credentials (e.g. user identification and password) in step 33. The authentication is executed by the messaging system. The authentication credentials assures that a user is a valid user within the data retrieval system. In step 34, a determination is made whether the user is authenticated. If the user is not authenticated, then a determination is made in step 35 whether the user is already registered with the data retrieval system. If the user is registered with the data retrieval system, then return is made to step 33 to wait for the user authentication credentials. Otherwise, if the user is determined not registered with the data retrieval system in step 35, then an attempt is made to register the user with the data retrieval system in step 36. In step 37, the messaging system waits for data service registration commands. In step 38, a determination is made whether the user has authorization within the data retrieval system. Authorization ensures that a valid user has the necessary permissions to use the data retrieval service. The user may be authenticated but not authorized (e.g. the user is delinquent in paying a bill for the data retrieval service). If the user is not authorized, then the messaging system first determines whether the request for registration was made by the user in step 39. If the determination is made that the user did not request registration, then a return is made step 37 to wait for data service registration commands and authorization. If a determination is made that the user did request to register with the data retrieval service, a determination may further be made in step 39 regarding the payment process for access and use of the service. The user may be given payment options to choose from (e.g. subscription, one time payment, a prepaid account, credit card, etc.). The user access server will wait for a valid payment option. Once a valid payment option is validated, the user access server then waits for the user service preferences in step 40. Thus a new user may be able to setup or update their user preferences prior to becoming registered.
In step 41, a determination is made whether the user requested to be associated with a new service provided by a system provider (e.g. news service, sports service, stock service, email service, etc.) In step 42, a determination is made whether the user requested to be disassociated with an existing service. This would incur removing a specified service from the user preference database. In step 43, a determination is made whether the user requested to be removed from a service registration. This would indicate that the user no longer desires to have the data retrieval service available to the user, or that the user had a prepaid subscription and the subscription has expired. In step 45, the authentication service database is updated based on the user's request in step 41, 42, and 43. In step 44, a determination is made whether the user requested to update the service settings. In step 40 the data retrieval system waits for the user service preferences and then updates the authentication service database based on any updates to the service settings as in step 45. Service settings may contain information that is pertinent to the operation, viewing, and transfer of information to the user (e.g. encoders, internet viewers, file transfer protocols). The user database is updated in step 46 and a return is made to step 37 to wait for further service registration commands.
Alternatively, the user may manually identify a specific text portion, a specific data block, or a specific file while accessing a subscribed service that the user desires to be retrieved as raw data and converted to a streaming media file. An example would be the user logged on to a subscribed web based service and identifying (such as highlighting) the new data to be retrieved. An option would be available on the data retrieval system to include the highlighted data as part of the new data to be retrieved for converting to the streaming media file.
If a determination was made in step 54 that the new data is available, the new data is stored to a temporary data file in its raw, original format (e.g. HTML for web content, MIME/RFC 822 for email content) in step 57. In step 58, the data retrieval server transmits a data ready message to the TTS server via the messaging system indicating the new data is available and ready to be retrieved. In addition, the data ready message will instruct the TTS server how the TTS server should retrieve the new data. In step 59, a determination is made whether the data ready message is received by the TTS server. If the data ready message was not received by the TTS server, the data retrieval system will resend the data ready message to the TTS server in step 60. A return is made to step 59 to determine if the data ready message was received. The data retrieval system will continuously loop between step 59 and step 60 until the determination is made that the new data message was received by the TTS server. After a determination is made that the data ready message is received by the TTS server, a return is made to step 54 to determine if all new data has been checked for all users.
Once the temporary data file is received, the temporary data file will be parsed. Parsing, herein, is defined as the extraction of a particular type of text data or non-text data from the temporary data file. A plurality of TTS components may be customized to support a particular data parser (e.g. mail, HTML, XML, etc.) so as to parse for a particular search criteria such as text portions, identifiers, phrase, tags, or meta-data. In step 73, a determination is made if the new data is email. If the new data is email, then respective data parser modules parse the email for a header (meta-data), a main body, text attachments, and non-text attachments (meta-data). After parsing is completed, the parsed email data is ready to be converted from its original text format to audible speech data. If the determination is made in step 73 that the new data is not email, then a determination is made in step 75 whether the new data is in HTML. If the new data is HTML, then the HTML is parsed for text and meta-data in step 76. After parsing is complete, the parsed HTML data is ready to be converted from its original format to the streaming media file. If the determination is made in step 73 that the new data is not HTML, then a determination is made in step 77 whether the new data contains any text or meta-data. The temporary file is then parsed for non-email or non-HTML text and meta-data. If the temporary file contains non-email or non-HTML text or meta-data, the temporary file is parsed for text and meta-data in step 78. After the text or meta-data has been parsed, the parsed text data is ready to be converted to a streaming media file. If a determination is made in step 77 that no text or meta-data is present in the temporary file, then a return to step 70 is made to await a new data ready message.
In step 79, the parsed text is then converted to audible speech data. The audible speech data is then converted to a streaming media file in step 80. The audible speech data is compressed (using a media encoder) into a format that can be easily streamed to the end user. The TTS server may contain one or more encoders (e.g. mp3, wmf, mpeg, mov, etc.) for encoding the audible speech data. The user preference database may provide information concerning the particular encoder that will be supported for later retrieval of the streaming media file by the end users computer. In step 81, meta-data that has been retrieved from the new data is encoded using the appropriate encoder and is embedded into the streaming media file. In step 82, the TTS server transmits a streaming media file ready message to the streaming media server. The streaming media file ready message notifies the memory storage component that a new streaming media file is ready to be received and identifies the method by which the memory storage component may access it. In step 83, a determination is made whether the streaming media server successfully received the streaming media file ready message. If the streaming media file ready message was not received by the streaming media server, then the TTS server will resend the streaming media file ready message to the streaming media file server in step 84. The data retrieval system will keep looping between step 83 and 84 until the streaming media file ready message is received by the streaming media server. If the determination was made in step 83 that the streaming media file ready message is received by the streaming media server, then a return is made to step 70 to await a new data ready message.
In step 106, the user initiates a receive command. In step 105, the data retrieval system waits for the users command. A determination is made whether the user has entered a client disconnect command in step 107. If the user has entered the client disconnect command, then the user is disconnected in step 108. If the user has not entered a client disconnect command, then a determination is made whether a streaming management command has been entered in step 109. If a streaming management command has been entered, then a management option is performed in step 110. The management option may include saving the streaming media file to the local computer for later playback or a delete operation. A return is then made to step 105 to await the user's next command. If the streaming management command, is not entered in step 109, then a determination is made whether a streaming presentation command is entered in step 111. If the streaming management command is entered in step 111, then the data retrieval system streaming media server dynamically formats the streaming media file for presentation in step 112. The streaming media is then sent to the user for presentation in step 113. A return is then made to step 105 to await the user's next command. If a determination is made in step 111 that a streaming presentation command is not entered in step 111, then a return is then made to step 105 to await the user's next command.
As a result of the forgoing interactions of the server components, a user is able to listen to converted text items without requiring their own text-to-speech conversion tools. Items to be converted (e.g. email notes, stories from news services, and other internetwork text sources) are automatically retrieved on behalf of the user who can then access the audio files at the user's convenience.
Number | Name | Date | Kind |
---|---|---|---|
5945989 | Freishtat et al. | Aug 1999 | A |
6173250 | Jong | Jan 2001 | B1 |
6175822 | Jones | Jan 2001 | B1 |
6230130 | Castello da Costa et al. | May 2001 | B1 |
6466654 | Cooper et al. | Oct 2002 | B1 |
6757362 | Cooper et al. | Jun 2004 | B1 |
7137126 | Coffman et al. | Nov 2006 | B1 |
20020059073 | Zondervan et al. | May 2002 | A1 |
20040049389 | Marko et al. | Mar 2004 | A1 |