The invention relates to conversion of a number into a textual form and further to speech.
Written text can be converted into speech by a text-to-speech system which may be applied e.g. to multimedia, speaking website, message reading (e-mail, SMS), user interfaces for handsfree/eyesfree devices (navigation, mobile phones), automated context aware announcement systems (anything involving varying data, telephone services) and aids for the visually impaired.
A text pre-processor or text normalizer of a TTS system controls that all the information input to the TTS system can be presented properly with normal characters. The characters are further processed to create the corresponding pronunciations. However, numerical pieces of information such as “1”, “45”, “363” do not contain any clues about the pronunciation and hence the pronunciation has to be generated separately. One way to do it is to convert numbers into a textual representation. A number as text can then be pronounced using rules or look-up tables as in the case of any other non-numerical information using text strings: “1”→“one”, “45”→“forty-five”, etc.
Naturally, numbers have different textual representations in each language. Furthermore, the construction of a text string differs from one language to another. For example, in English “forty-three” contains words for the number “40” and “3”, in Finnish “neljäkymmentäkolme” contains words for “4”, “kymmentä” indicating tens and “3”. Number “74” in French would be “soixante-dix-quatre” which equals “60”, “10” and “4”.
Cardinal numbers present a special case of input to a TTS system. Pronunciations of each number separately cannot be stored in a look-up table, if the range of the required numbers is large. The size of the table for supporting numbers from 1 to 99999, for instance, is too huge.
Some rule-based approaches have been proposed for converting a number to text. However, the proposed solutions have many problems. Typically they are language-specific, and hence can convert a number into one language only. They are also typically based on complicated mathematics requiring, for example, modulo calculation. All in all, known rule-based approaches are both methodically and structurally complicated.
Therefore, a need exists for a simple solution for constructing a textual representation of a cardinal number. The solution should also be applicable to a plurality of languages.
An object of the invention is to provide an improved solution for converting a number into text. According to an aspect of the invention, there is provided a method of converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the method comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; and performing additionally the following operation in the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a method of converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the method comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; performing additionally the following operation on the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression; combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit; and converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the device comprising: a converter configured to convert, one by one, each digit of the cardinal number into a textual representation of a desired language; a combiner configured to add a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and a corrector configured to correct, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the device comprising: means for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; means for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and means for correcting, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the device comprising: a converter configured, one by one, to convert each digit of the cardinal number into a textual representation of a desired language; a combiner configured to add a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; a corrector configured to correct, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression, and to combine the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise to form the full textual representation of the number using the textual representation of the single digit; and a synthesizer configured to convert the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the device comprising: means for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; means for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; means for correcting, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression, and combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise to form the full textual representation of the number using the textual representation of the single digit; and means for converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a subscriber terminal including a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the device comprising: a converter configured, one by one, to convert each digit of the cardinal number into a textual representation of a desired language; a combiner configured to add a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and a corrector configured to correct, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a subscriber terminal including a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the device comprising: means for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; means for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and means for correcting, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a subscriber terminal including a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the device comprising: a converter configured to convert, one by one, each digit of the cardinal number into a textual representation of a desired language; a combiner configured to add a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; a corrector configured to correct, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression, and to combine the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise to form the full textual representation of the number using the textual representation of the single digit; and a synthesizer configured to convert the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a subscriber terminal including a device for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the device comprising: means for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; means for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; means for correcting, on the basis of language-dependent rules defining correct expressions, any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression, and combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise to form the full textual representation of the number using the textual representation of the single digit; and means for converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a computer program product encoding a computer program of instructions for executing a computer process for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the process comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; and performing additionally the following operation on the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a computer program product encoding a computer program of instructions for executing a computer process for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the process comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; performing additionally the following operation on the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression; combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit; and converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a computer program distribution medium readable by a computer and encoding a computer program of instructions for executing a computer process for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the process comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; and performing additionally the following operation on the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression.
According to another aspect of the invention, there is provided a computer program distribution medium readable by a computer and encoding a computer program of instructions for executing a computer process for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the process comprising: converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten: adding a textual representation of a place value to a textual representation of a digit; performing additionally the following operation on the basis of language-dependent rules defining correct expressions: correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression; combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit; and converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a data structure for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the data structure comprising: a first data field including information for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; a second data field including information for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and a third data field including information for correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression on the basis of language-dependent rules defining correct expressions.
According to another aspect of the invention, there is provided a computer program distribution medium readable by a computer, the computer program distribution medium having data structure for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into a textual representation of a desired language, the data structure comprising: a first data field including information for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; a second data field including information for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; and a third data field including information for correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression on the basis of language-dependent rules defining correct expressions.
According to another aspect of the invention, there is provided a data structure for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the data structure comprising: a first data field including information for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; a second data field including information for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; a third data field including information for correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression on the basis of language-dependent rules defining correct expressions, for combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit, and for converting the full textual representation of the number into speech.
According to another aspect of the invention, there is provided a computer program distribution medium readable by a computer, the computer program distribution medium having data structure for converting a cardinal number of a decimal number system including at least one digit in a sequence of places ordered by powers of ten into speech of a desired language, the data structure comprising: a first data field including information for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; a second data field including information for adding a textual representation of a place value to a textual representation of a digit depending on a place of a digit in the sequence of places ordered by powers of ten; a third data field including information for correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression on the basis of language-dependent rules defining correct expressions, for combining the textual representations for forming a full textual representation of the number if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit, and for converting the full textual representation of the number into speech.
The invention provides several advantages. The present solution provides a simple and effective way to convert a number into text and speech. The solution is very memory efficient and allows good coverage of numeric values with a very low memory footprint. A set of rules can be represented as data which can be included in language specific packages. This and uncomplicated syntax simplify logistics in manufacturing product variants in various languages.
In the following, the invention will be described in greater detail with reference to the embodiments and the accompanying drawings, in which
The present solution is suitable for electronic devices which may be user equipment, a computer etc. Application fields may include message reading, user interface for handsfree or eyesfree devices, automated context aware announcement systems and aids for the visually impaired.
With reference to
After pre-processing the text can be normalized in a normalization operation block 102. This block 102 may include, for example, converting numbers into textual representations, expanding abbreviations etc. A rule-based method for creating a text string of a number for pronunciation can be used. In the prior art, the rules for creating text strings of numbers are usually coded within a language specific program code, for instance, DLL (Dynamically Loaded Library). In some systems a complex script language that also handles other language specific processing is provided.
A linguistic processing block 104 may include linguistic and syntactic analysis and prosodic analysis. The linguistic and syntactic analysis may include morphological analysis, contextual analysis and categorizing words into clauses on the basis of some criteria. The prosodic analysis may utilize the linguistic and syntactic analysis to assign, for example, intonation contours, pauses, stress and speech segment durations.
A synthesis block 106 may perform letter-to-sound or text-to-phoneme conversion on the basis of data received from the linguistic processing block 104 in order to generate the actual speech waveform.
The terminal equipment comprises a processor 200, in which a computer program operations of the terminal equipment may be performed. For instance, the processor 200 may take care of digital signal treatment and controls the operation of other blocks. The user controls the electronic device and enters data with the terminal equipment's user interface 202 (display and keypad), and visual information, such as text and images, treated by the processor 200 is displayed to the user with the user interface. Data required by the processor 200 can be stored in a memory 206. A sound-processing unit 208 converts a signal arriving from the processor 200 to suit a loudspeaker 210. The sound-processing unit 208 may be a synthesizer for synthesing speech form text. Additionally, the speech-processing unit 208 may include a codec block. The sound-processing unit 208 may also convert a signal arriving from a microphone 212 to suit the processor 200. An RF block 214, in turn, converts a digital signal to be transmitted and arriving from the processor 200 into an analog, radio-frequency signal, so that the signal can be transmitted as electromagnetic radiation via an antenna 216. Correspondingly, a radio-frequency signal received by the antenna 216 is converted to a lower frequency and is digitized in the RF block 214 prior to application to the processor 200.
The present solution concentrates on the normalization operation block 102 where conversion of numbers into textual representations can be performed. Cardinal numbers 0, 1, 2, 3, . . . , which can be referred to as finite cardinal numbers, can also be called counting numbers, natural numbers, non-negative integers or whole numbers. They include no decimal part nor a fractional part. A cardinal number of a decimal number system includes at least one digit in a sequence of places ordered by powers of ten. For example, the number 15243 is a sequence of 1, 5, 2, 4 and 3 and it can be interpreted such that the number “1” represents how many times 10 000=104 is included in the number. The number “5” represents how many times 1000=103 is included in the number. The number “2” represents how many times 100=102 is included in the number. The number “4” represents how many times 10=101 is included in the number. Finally, the number “3” represents how many times 1=100 is included in the number. The numbers 10 000=104, 1000=103, 100=102, 10=101 and 1=100 are powers of ten, and the powers of ten define the place of the digit (in this example the places of 1, 2, 3, 4 and 5) in the sequence.
The combiner 304 may add a textual representation of a place value to a textual representation of a digit. Whether or not the combiner adds the textual representation of a place value, may depend on a place of a digit in the sequence of places ordered by powers of ten. In the decimal number system, the value of a digit depends on its place, or position, in the number i.e. in the sequence of digits. Each place has a value of 10 times the place of the preceding place on the right. The place values are the values of the powers of ten and can be written as ones (1=100), tens (10=101), hundreds (100=102), thousands (1000=103), ten thousands (10 000=104), hundred thousands (100 000=105), millions (1 000 000=106), etc. When a place has zero, it means that the place has no value. For example, in the case of 1 000 000 the sixth place means zero times hundred thousands. But the seventh place means one times million. Hence, the result is “one million”. If the number is, for example, 2, the combiner 304 needs to add nothing when converting it into English, because the converter 302 provides the correct result “two”.
The corrector 306 may correct any textual representation formed by the converter 302 and the combiner 304. In many cases, the corrector 306 needs to correct nothing, since the textual representation formed by the converter 302 and/or combiner 304 is already correct. But as there are usually exceptions and irregularities in the natural languages, the corrector 306 is important. A natural language is a human language used by people when discussing together or writing to each other. A natural language has evolved naturally in the human society. For example, Finnish, English, French and Japanese are natural languages. A language, such as Esperanto, which has been artificially constructed by a person, may also be acceptable. All the textual representations formed by the converter 302 and the combiner 304 which differ from textual representations of the natural language can be known beforehand. Because their number is limited, the differences can easily be tabulated relating to a digit or a combination of digits in a place known to result in a textual representation differing from a correct expression. The correction may be based on language-dependent rules defining correct expressions. The language-dependent rules can be supported by grammatical rules of the desired language.
Applying a first rule according to which each digit of the cardinal number is converted, one by one, into a textual representation of a desired language, a register element R5 of the register 402 includes a textual representation “one”. In a similar manner, a register element R4 includes a textual representation “two”, a register element R3 includes a textual representation “three”, a register element R2 includes a textual representation “six”, and the register element R1 includes a textual representation “eight”. If, for example, the least significant digit were “0”, a textual representation in the register element R1 could have been “”, but it could have been “zero” as well.
When a second rule is applied, textual representations of place values are added to textual representations of digits. The textual representations are added depending on places of digits in the sequence of places ordered by powers of ten. According to this example the textual representation of the place value in a register element T65 is unnecessary because it refers to hundred thousands. The most significant digit (in this case “1”) can be searched for to determine a need for possible place values. The place value of “ten thousand” is actually unnecessary in English. Hence, the contents of a register element T54 is empty, i.e. register element T54=“”. Next, the place value of “thousand” in a register element T43 may be added to “2”. The place value of “hundred” in a register element T32 may be added to “3”. The place values of “ten” and “one” in register elements T21 and T10 are unnecessary in English. Hence, the contents of the register elements T21 and T10 are empty, i.e. register element T21=“” and register element T10=“”. Combining the textual representations results in R5 T54 R4 T43 R3 T32 R2 T21 R1 T10 in a textual form “one two thousand three hundred six eight”. The textual representation of the number becomes correct with the third rule, according to which any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression is corrected. In this example two differences from the correct expression exists: “one two” and “six”. But before examining the third rule to correct them, let us first study tabulated rules for converting the digit into a textual representation and for combining a place value with the digits.
Next, data structure for converting a cardinal number is illustrated using FIGS. 5 to 16E. The data structure may be included in a computer program distribution medium readable by a computer. The language-specific data fields i.e. rules may be stored separately from the actual computer program performing the conversion. This enables the use of the same computer program for a plurality of languages, each language utilizing its own data fields during conversion.
Let us now study a third data field for correcting textual representations. The third data field can also be presented in a tabulated form. The first part of the table is shown in
The number of question marks refers to the number of digits in the number while the asterisk refers to a wildcard character. Depending on the number of digits in the number, registers of place values are emptied. If the maximum number of digits is five in the number (i.e. the number is smaller than 100 000), the register elements TXX having an index XX larger than 54 are emptied. If the maximum number of digits is four in the number (i.e. the number is smaller than 10 000), the register elements TXX (such as T65 and T54) having the index XX larger than 43 are emptied. If the maximum number of digits is three in the number (i.e. the number is smaller than 1000), the register elements TXX having the index XX larger than 32 are emptied. If the maximum number of digits is two in the number (i.e. the number is less than 100), the register elements TXX having the index XX larger than 21 are emptied. If the maximum number of digits is one in the number (i.e. the number is less than 10), the register element T21 is emptied in the similar manner.
A correction in English may relate to ten thousands. If the fifth digit is “2”, the contents of the register element R5 is set to “twenty”. If the fifth digit is “3”, the contents of the register element R5 is set to “thirty”. If the fifth digit is “4”, the contents of the register element R5 is set to “forty”. If the fifth digit is “5”, the contents of the register element R5 is set to “fifty”. If the fifth digit is “6”, the contents of the register element R5 is set to “sixty”. If the fifth digit is “7”, the contents of the register element R5 is set to “seventy”. If the fifth digit is “8”, the contents of the register element R5 is set to “eighty”. If the fifth digit is “9”, the contents of the register element R5 is set to “ninety”.
A correction in English may relate to numbers from ten thousand to nineteen thousand. In all of these cases, the fifth digit is “1” and the contents of the register element R4 is set to be empty. If the fourth digit is “0”, the contents of the register element R5 is “ten”. If the fourth digit is “1”, the contents of the register element R5 is set to “eleven”. If the fourth digit is “2”, the contents of the register element R5 is set to “twelve”. If the fourth digit is “3”, the contents of the register element R5 is set to “thirteen”. If the fourth digit is “4”, the contents of the register element R5 is set to “fourteen”. If the fourth digit is “5”, the contents of the register element R5 is set to “fifteen”. If the fourth digit is “6”, the contents of the register element R5 is set to “sixteen”. If the fourth digit is “7”, the contents of the register element R5 is set to “seventeen”. If the fourth digit is “8”, the contents of the register element R5 is set to “eighteen”. If the fourth digit is “9”, the contents of the register element R5 is set to “nineteen”.
In the cases relating to ten thousands and to the numbers from ten thousand to nineteen thousand, the textual representation of the combination of successive digits of a number including more than one digit in a place known to result in an incorrect expression is corrected. The correction can be performed by replacing the textual representation known to be incorrect by a correct textual representation.
A correction in English may relate to tens. If the second digit is “2”, the register element R2 is set to “twenty”. If the second digit is “3”, the register element R2 is set to “thirty”. If the second digit is “4”, the register element R2 is set to “forty”. If the second digit is “5”, the register element R2 is set to “fifty”. If the second digit is “6”, the register element R2 is set to “sixty”. If the second digit is “7”, the register element R2 is set to “seventy”. If the second digit is “8”, the register element R2 is set to “eighty”. If the second digit is “9”, the register element R2 is set to “ninety”.
A correction in English may relate to numbers between ten and twenty. In all these cases the second digit is “1”. If the first digit is “1”, the contents of the register element R2 is set to “eleven”. If the first digit is “2”, the contents of the register element R2 is set to “twelve”. If the first digit is “3”, the contents of the register element R2 is set to “thirteen”. If the first digit is “4”, the contents of the register element R2 is set to “fourteen”. If the first digit is “5”, the contents of the register element R2 is set to “fifteen”. If the first digit is “6”, the contents of the register element R2 is set to “sixteen”. If the first digit is “7”, the contents of the register element R2 is set to “seventeen”. If the first digit is “8”, the contents of the register element R2 is set to “eighteen”. If the first digit is “9”, the contents of the register element R2 is set to “nineteen”.
In the cases relating to tens and to the numbers between ten and twenty the textual representation of the combination of successive digits of a number including more than one digit in a place known to result in an incorrect expression is corrected. The correction can be performed by replacing the textual representation known to be incorrect by a correct textual representation.
If the third digit is “0”, the contents of the register element T32 is set to be empty. Finally, if the number is “0”, the contents of the register element R1 is set to “zero” while the other registers are emptied. After the necessary corrections, which in this case mean applying corrections relating to values between ten thousand and nineteen thousand (*12???→R5=“twelve”) and values between twenty and ninety (*6?→R2=“sixty”), the example of 12 368 becomes “twelve thousand three hundred sixty eight”. Before correction, the textual representation of *6? can be “six ten” or just “six”. Both forms can be corrected into the textual representation “sixty”.
This kind of method can be applied to a plurality of languages while the principles of applying place values and corrections differ from language to language. The different application of place values and corrections can be handled easily by changing the contents of register elements according to language-dependent rules defining correct expressions. The syntax is very simple and contains conditions and assignments only. Once again in short, each digit can be assigned as <number register element>=“<string>”. The place values can be formed as <place value register element >=“<string>”. The correction can be formed as <matching criteria>;<register element >=“<string>”|<register element >;<register element >=“<string>”|<register element>; . . . Matching criteria may use a wildcard character at the beginning or in the end of the criteria and an “any character” sign “?” at any location of the criteria. Otherwise < >denotes a required string, [ ] denotes an optional string, | is a separator between alternative, mutually exclusive arguments, ? is a symbol indicating any single digit, and * is a symbol indicating any number of digits.
Let us look at examples of the number “534 676” in English, Finnish, Swedish, French, German, Danish, Hungarian, Italian, Mandarin Chinese (Japanese) and Ukrainian. After applying the first rule, the number becomes five three four six seven six in English. After applying the second rule, the number becomes “” five hundred three “” four thousand six hundred seven six “”. After the third, rule the number can be written correctly by combining the textual representations together “” five hundred thirty”” four thousand six hundred seventy”” six””.
In all these languages the tabulated rules can be applied in a manner similar to that of English. Clearly, the same method can be applied to many other languages not mentioned in this application.
The embodiments of the invention may be realized in an electronic device comprising a display, a keyboard and a controller operationally connected to the keyboard and the display, for example. The controller may be configured to perform at least some of the steps described in connection with either of the methods shown in
The embodiments may also be implemented as a computer program comprising instructions for executing a computer process for converting, one by one, each digit of the cardinal number into a textual representation of a desired language; performing the following operation depending on a place of a digit in the sequence of places ordered by powers of ten; adding a textual representation of a place value to a textual representation of a digit; performing additionally the following operation based on language-dependent rules defining correct expressions; correcting any formed textual representation relating to at least one digit in a place known to result in a textual representation differing from a correct expression; combining the textual representations for forming a full textual representation of the number, if the number has more than one digit, and otherwise forming the full textual representation of the number using the textual representation of the single digit; and converting the full textual representation of the number into speech.
Either of the computer programs may be stored on a computer program distribution medium readable by a computer or a processor. The computer program medium may be, for example but not limited to, an electric, magnetic, optical, infrared or a semiconductor system, device or transmission medium. The medium may be a computer readable medium, a program storage medium, a record medium, a computer readable memory, a random access memory, an erasable programmable read-only memory, a computer readable software distribution package, a computer readable signal, a computer readable telecommunications signal, and a computer readable compressed software package.
The application of registers can be used for converting a time expressed in hours and minutes into textual representation. The implementation uses a register including multiple digits. Elements of a transition register, which is similar to a register of place values, are placed between each digit.
A register set-up is shown in
In English, a time can be handled, for example, according to the following rules:
where ? is a symbol indicating any single digit.
In Finnish, a time can be handled, for example, according to the following rules:
In German, a time can be handled, for example, according to the following rules:
The syntax can be considered as the following:
Additionally, abbreviations, such as km, km/h, m, kg, etc., relating to a number can be handled similarly. The implementation uses two main registers: one for a unit and the other for a number associated with the unit. There may also be additional transition register elements in front of the number, between the number and the unit and after the unit. A register set-up is presented in
The syntax can be considered as the following:
The mark_means a white space.
For example, an expression 453 km/h can be converted into a textual representation in English using the following rules:
Also note that if no white space exists in the beginning of “kilometers per hour”, the output sequence would be “453 kilometers per hour”. The white space can be included into the string as described above, or it can be placed into a transition register element DD21.
Even though the invention has been described above with reference to an example according to the accompanying drawings, it is clear that the invention is not restricted thereto but it can be modified in several ways within the scope of the appended claims.