This invention relates generally to the correlation of symbols to sounds and more particularly to the conversion of text to phonemes.
Prior art approaches exist to convert text into corresponding sounds. Such techniques permit, for example, the conversion of text into audible synthesized speech. Many such approaches use phonemes that are units of a phonetic system of the relevant spoken language and that are usually perceived to be single distinct sounds in the spoken language. Using phonemes in this way in fact constitutes a relatively effective and accurate mechanism to achieve telling results. Unfortunately, however, prior art techniques do not always reliably select the correct phonemes.
Part of the problem stems from the fact that, in many spoken languages that have a corresponding symbolic alphabet, one or more of the symbols have more than one proper pronunciation. As a result, some symbols have more than one potentially appropriate phoneme (or set of phonemes) associated therewith. Various prior art approaches have been suggested to attempt mitigating the effect of this circumstance. Unfortunately, these solutions generally tend to be computationally intensive and/or require a considerable amount of memory. This tends to render such solutions inappropriate for use in resource-limited platforms (such as, for example, cellular telephones) where computational capacity itself and/or electric power can be considerably constrained.
For example, one prior art approach (known in at least some circles as “N-gram analysis”) uses a combination of probability analysis and grammatical context to weight a corresponding conclusion regarding pronunciation of a given word. To illustrate, the word “read” can be enunciated in English in either of two ways depending upon the grammatical context. By storing the rules regarding such context and by examining other words around the word “read” in view of those rules, one can potentially deduce a correct pronunciation for a given instance of the word. Again, however, such an approach often requires at least a significant quantity of memory as well as a fairly elaborate development and manipulation of contextual rules.
Many prior art approaches also fall short in view of another common occurrence; the need to pronounce a proper name or other word that is not in the dictionary of the process. To ameliorate, at least to some extent, this problem, the prior art suggests permitting a user to train the process by introducing the word along with its pronunciation. This approach, however, can be time consuming, tedious, confusing to the user, and again highly consumptive of memory and computational capacity.
The above needs are at least partially met through provision of the method and apparatus to facilitate correlating symbols to sounds described in the following detailed description, particularly when studied in conjunction with the drawings, wherein:
Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. For example, the dimensions of some of the elements in the figures may be exaggerated relative to other elements to help to improve understanding of various embodiments of the present invention, Also, common but well-understood elements that are useful or necessary in a commercially feasible embodiment are typically not depicted in order to facilitate a less obstructed view of these various embodiments of the present invention.
Generally speaking, pursuant to these various embodiments, a symbol-to-sound translator (such as a text to phoneme translator) utilizes a dictionary comprising a dendroid hierarchy of branches and nodes, wherein each node represents no more than one of the symbols and wherein each such symbol as is represented at a node has only one corresponding sound associated with that symbol at that node, and where each branch includes a plurality of nodes representing a string of the symbols in a particular sequence. In a preferred embodiment, at least some of the symbols comprise alphanumeric textual characters such as letters. If desired, a combination of symbols can be used to represent a single sound (such as the combination of letters “ch” that can be used in the English language to represent a single phoneme sound). Also in a preferred embodiment, at least some of the sounds can be comprised of phonemes. If desired, the strings of symbols as represented by the branches can represent entire words in the corresponding spoken language. In a preferred embodiment, however, such strings can also accommodate incomplete words such as, but not limited to, grammatical prefixes, suffixes, stems, and/or morphemes.
In a preferred embodiment, at least some of the nodes have a probability indicator correlated therewith. This indicator reflects how frequently the corresponding sound associated with the symbol at that node has been previously selected for use when translating an input that included the symbol at that node. If desired, such probability indicators can be recalculated and revised dynamically on a substantially continuous basis. In a alternative embodiment, a probability indicator located in one portion of a branch can be used to temporarily impact the probability indicator as associated with a node located elsewhere in that same branch. For example, the probability of use indicator for a given node can be modified as a function of at least one probability of use indicator for a lower hierarchical node on a shared branch. In a preferred embodiment, this modification comprises temporarily replacing the probability indicator at the given node with the probability indicator for the node located lower in the dictionary dendroid hierarchy.
Referring now to the drawings, and in particular
The text to phoneme translator 11 has one or more inputs to receive symbols. In this embodiment, at least some of the symbols comprise alphanumeric textual characters and in particular comprise combined alphanumeric textual characters such as a series of words comprising a plurality of sentences. Such text can be sourced to support a variety of different purposes. For example, the text may correspond to a word processing document, a webpage, a calculation or enquiry result, or any other text source that the user wishes, for whatever reason, to hear audibly enunciated.
In this embodiment, the text to phoneme translator 11 produces sounds comprised of phonemes (where phonemes are understood to each comprise units of a phonetic system of spoken language that are perceived to be single distinct sounds in the spoken language). Typically, a given integral sequence of symbols introduced at the input will yield a corresponding integral sequence of sounds at the output. For example, a first integral sequence of letters that comprise a single word will yield a corresponding integral sequence of phonemes that represent an audible utterance of that particular word. If desired, such phoneme information can be used to facilitate, for example, the synthesization of speech 13. Phoneme information can be used for other purposes as well, however, and these teachings are applicable for use in such alternative applications as well.
Such a symbols-to-sounds platform 10 can be a standalone platform or can be comprised as a part of some other device or mechanism, including but not limited to computers, personal digital assistants, telephones (including wireless and cordless telephones), and various consumer, retail, commercial, and industrial object interfaces.
Referring now to
Referring now to
Referring momentarily to
Each such node may then couple via a branch to one or more other nodes. For example, the first “g” node 42 noted above can couple to a number of other nodes 44 including a node 45 that includes the letter “o” and the corresponding sound S3 of“o” as occurs in the English word “song” (the other nodes 44 can include the same letter “o” and/or other letters entirely—for example, one node might include the letter “i” as part of the string “give”). In a similar fashion, this secondary node with the letter “o” 45 can itself branch to another hierarchical level 46 to represent yet additional symbols such as a node for the letter “n” (with corresponding sound S4 for the letter “n” pronounced as in the English word “con”) (and as part of a hierarchical branch that includes the string “gone”) and a node for the letter “i” (with corresponding sound S5 for the letter “i” pronounced as in the English word “stopping”) (and as part of a hierarchical branch that includes the string “going”).
So configured, it should be evident that many words and word parts are readily represented as strings of such nodes and that duplicate letter/sound entries are avoided to some extent by the dendroid hierarchical structure described. As a result, a dictionary composed in such a way can represent a relatively large quantity of textual input (and corresponding phoneme content) in a relatively small amount of memory.
In addition, a probability indicator (or indicators) can be also provided at some (or all) nodes to provide an indication of how frequently the corresponding sound associated with the symbol at that node has been selected for use when translating an input that included the symbol at that node. In particular, such an indicator can represent how many times the corresponding sound for the symbol at a given node has been selected as compared to identical symbols having different corresponding sounds at other nodes at the same hierarchical level as the given node. Such probabilities can be calculated apriori and included as a static component of the dictionary. In a preferred embodiment, however, the probability indicators are dynamic and change in value with experience and use of the dictionary. The probabilities can all begin at an equal level of probability (or can be initially offset as desired) and can then be recalculated as desired to update the probability indicators.
For example, and with continued reference to
So configured, and referring now back again to
Returning again to
In a process where the probability indicators are dynamically altered through use, the probability indicators can now be updated 37 to reflect this most recent use of the dictionary to select a particular sequence of phonemes to represent a given text input.
In a preferred embodiment, and referring now to
Viewed in a more rigorous light, consider that the probability P(β1, β2, K βn|α1, α2, K αm) indicates the likelihood for a given phone sequence β1, β2, K βn as a whole being generated from a given text string α1, α2, K αm. Pursuant to the above process, pronunciations for all possible sub-strings of the input are retrieved from the dendroid hierarchical dictionary and this probability is calculated as the sum of the probabilities for all possible phonetic realizations for the input sub-strings. For a given input word ω=α1, α2, . . . αm, let ωik (j)=αi . . . αj −lαj αj+l . . . αk denote the sub-string of word ω beginning in position i with letter αi, ending in position k with letter αk, and having a focus letter αj. In other words, αi . . . αj−l and αj+l . . . αk denote αj's left and right context respectively. Paths τik(j) in the hierarchical context tree are a set of letter-to-sound translations of ωik (j) found by searching the dictionary tree, where k>=j. Basically, as the search extends letter by letter from left to right, the context tree grows. If no letter match is found the context tree stops growing.
For each input word string, the platform 10 searches the dictionary repeatedly until all possible pronunciations of a given input sub-string are found. In other words, the search starts at each node of the dictionary tree until each of the nodes has been used as a starting node. In this way, the occurrence of each path τik (j) will be accumulated.
In many cases the dictionary will not include the whole text string. Nevertheless, in most cases, at least some partial segments of the text string will typically be found in the dictionary. A variable context length can therefore be used in this method as the sum of the probabilities for all the relevant input letter sequences.
In this way, the occurrence of each path τik (j) will be accumulated. To illustrate, let N(αi, αi+l, . . . αk) represent the counts for string segment α1, αi+l, . . . αk and let M(βil, βli+l, . . . βkl) represent the counts for its Ith transcription. The probability for transcription βil, βi+ll, . . . βk l can therefore be estimated as:
These probabilities comprise the probability indicators that are recorded at the leaf nodes of the context trees as described earlier. It should be noted that for each node in the context tree, there can be more than one probability associated with it, because the node can have more than one child node. With the first Viterbi pass, the probabilities on the leaf nodes propagate upwards and retain the maximum probability value for each node.
In effect, for each new word, the process chooses a letter as the focus and uses maximum possible context around the focused letter. The process then uses this word segment as a key to traverse the dendroid hierarchy of the dictionary. During this traversal, sub-trees are generated. These sub-trees contain all possible context segments ranging from a minimum length to maximum length. To start the tree traversal at any node of the dictionary tree, the counts M(βil, βli+l, . . . βkl) and N(βi, βi+l . . . βk) of how an orthographic segment is transformed into a pronunciation are accumulated.
After building the sub-tree, the probabilities of symbol to phoneme mapping at each level of the sub-tree are estimated. The probabilities at the leaf node of the sub-tree are then propagated upwardly with respect to the hierarchical structure of the tree. In a preferred embodiment, when the probability of mapping on a child node is larger than that of the parent, then the probability indicator for the parent node is replaced with that of the child node.
All the paths τik (j) in the sub-trees are translated into a lattice representation for generating N-best baseform transcriptions with a Viterbi search. To consider the edge effects where a given cut point could lose important context information, a window function that centers on the focused grapheme letters can be used to weigh down the contribution of the probabilities near both ends of the text string. Since the probabilities are estimated for each grapheme in the text with all possible context lengths, the probability of each grapheme is a mixture of all windowed segment probabilities. Penalties can also be added to adjust the weight for segments of different length. In general, a shorter context will be accorded a higher penalty because long contexts offer more disambiguation than shorter ones.
It should be observed that the focused letters whose phonemes are searched for can consist of a consonant string or a vowel string. This means that the process can obtain the corresponding phonemes without breaking the consonant or vowel strings. This can aid in avoiding a lot of unnecessary and misleading conversions. Also, each occurrence of the context segment is counted. Therefore the longest segment and the most frequent one play a dominant role in determining the letter-to-sound conversion. Further, the dictionary can be built up recursively so that it covers the data where basic rules can be learned. These basic rules should predict a significant part of the big dictionary accurately
So configured, the resultant dictionary and corresponding process are relatively well suited to facilitate various symbol-to-sound activities in a way that potentially requires less memory than prior approaches. In addition, the described platform and processes are well suited in particular to support the pronunciation of words that are not actually included in the dictionary for whatever reason, thereby meeting a significant existing need.
Those skilled in the art will recognize that a wide variety of modifications, alterations, and combinations can be made with respect to the above described embodiments without departing from the spirit and scope of the invention, and that such modifications, alterations, and combinations are to be viewed as being within the ambit of the inventive concept.
Number | Name | Date | Kind |
---|---|---|---|
5682501 | Sharman | Oct 1997 | A |
5835888 | Kanevsky et al. | Nov 1998 | A |
6016471 | Kuhn et al. | Jan 2000 | A |
6112173 | Hirayama | Aug 2000 | A |
6163768 | Sherwood et al. | Dec 2000 | A |
6347295 | Vitale et al. | Feb 2002 | B1 |
6363342 | Shaw et al. | Mar 2002 | B1 |
6470347 | Gillam | Oct 2002 | B1 |
6671856 | Gillam | Dec 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20040059574 A1 | Mar 2004 | US |