1. Field of the Invention
The invention relates generally to handheld electronic devices and, more particularly, to a handheld electronic device that has a reduced keyboard and that facilitates the entry of text in a message.
2. Description of the Related Art
Numerous types of handheld electronic devices are known. Examples of such handheld electronic devices include, for instance, personal data assistants (PDAs), handheld computers, two-way pagers, cellular telephones and the like. Many handheld electronic devices also feature a wireless or other communication capability, although other handheld electronic devices are stand-alone devices that are functional without communication with other devices. Such handheld electronic devices are generally intended to be portable, and thus are of a relatively compact configuration in which keys and other structures often perform multiple functions under certain circumstances or may otherwise have multiple aspects or features assigned thereto. With advances in technology, handheld electronic devices are built to have progressively smaller form factors yet have progressively greater numbers of applications and features resident thereon. As a practical matter, the keys of a keypad can only be reduced to a certain small size before the keys become relatively unusable.
In language entry applications, such as in a messaging or e-mail application, a keypad must be capable of generating substantially all of the elements desirable or necessary to form the relevant language. For example, in a language that employs Roman letters, a keypad must be capable of generating substantially all twenty-six of the Roman letters. In order to provide such functionality with relatively few keys, some keypads have included multiple linguistic elements per key, such as providing a plurality of Roman letters on each of at least some of the keys when the keypad is used to generate a language that employs Roman letters.
In order to make use of the multiple linguistic elements on any given key, numerous keystroke interpretation systems have been provided. For instance, a “multi-tap system” allows a user to substantially unambiguously specify a particular linguistic element, for example, on a key by pressing the same key a number of times equal to the position of the desired linguistic element on the key. Anther keystroke interpretation system includes key chording in which keys are pressed in various combinations to achieve particular results. Still another keystroke interpretation system might include a disambiguation routine which seeks to interpret the keystrokes in view of stored dictionary data, linguistic rules, stored algorithms, and/or the like.
While such disambiguation systems have been generally effective for their intended purposes, such disambiguation systems are not without limitation. In certain applications, the function of a disambiguation routine can be cumbersome if a user must expend substantial effort in entering language. One such situation in which this may occur is in the context of a word that may not already be in the stored dictionary. Another exemplary situation in which this may occur is when a word is already be stored in the dictionary but is considered to have a relatively low frequency, and this may require significant input effort by the user to achieve the desired word. Also, a desired word may not already be stored in the dictionary of the device. It thus would be desirable to provide a handheld electronic device having a reduced keyboard wherein the device might make available to a user words and the like that the user might reasonably be expected to enter. Such words and the like might, for example, be somewhat unconventional.
In view of the foregoing, an improved handheld electronic device having a reduced keyboard provides facilitated language entry by making available to a user certain words that a user may reasonably be expected to enter. In some situations, certain words can be stored, for example, in a temporary dictionary for use in particular situations. For instance, the names of the recipients of an electronic message might be stored in a temporary dictionary for rapid retrieval when entering a salutation in the message. As another example, a number of the words in an existing electronic message may be stored in a temporary dictionary and made available to a user when replying to or forwarding the message since the existing message might include words that the user might reasonably be expected to type in the reply message or the forwarded message.
Accordingly, an aspect of the invention is to provide an improved handheld electronic device that has a reduced keyboard and that provides facilitated entry of language.
Another aspect of the invention is to provide an improved handheld electronic device having a reduced keyboard that can store certain data in one or more temporary dictionaries for retrieval in certain contexts.
Another aspect of the invention is to provide an improved handheld electronic device that has a reduced keyboard and that provides facilitated entry of a salutation in an electronic message to a recipient of the message.
Another aspect of the invention is to provide an improved handheld electronic device that has a reduced keyboard and that facilitates the entry of words in an electronic message on the basis of the word having previously appeared in another electronic message in the same message thread.
Another aspect of the invention is to provide an improved method of enabling disambiguation of an entry on a handheld electronic device having a reduced keyboard.
These and other aspects of the invention are provided by an improved method of enabling disambiguation of an input into a handheld electronic device. The handheld electronic device includes an input apparatus, an output apparatus, and a memory having a plurality of objects stored therein. The plurality of objects include a plurality of language objects and a plurality of frequency objects, with each of at least a portion of the language objects of the plurality of language objects being associated with an associated frequency object of the plurality of frequency objects. The handheld electronic device has a number of messages available thereon, with each message of at least a portion of the number of messages including a number of language objects. The input apparatus includes a plurality of input members, with each of at least a portion of the input members of the plurality of input members having a plurality of linguistic elements assigned thereto. The general nature of the method can be stated as including detecting at least one of a replying input and a forwarding input with respect to a message of the number of messages, detecting an ambiguous input including a number of input member actuations of a number of the input members of the plurality of input members, with each of at least a portion of the input members of the number of input members including a number of linguistic elements assigned thereto, and with at least one of the input members of the number of input members having a plurality of linguistic elements assigned thereto, determining that a first portion of the memory is associated with the message, with the first portion of the memory including at least a portion of the language objects of the number of language objects of the message, identifying in the first portion of the memory a first language object that corresponds with the ambiguous input, and outputting at least a portion of the first language object as a first proposed disambiguation of the ambiguous input.
Other aspects of the invention are provided by an improved method of enabling disambiguation of an input into a handheld electronic device. The handheld electronic device includes an input apparatus, an output apparatus, and a memory having a plurality of objects stored therein. The plurality of objects include a plurality of language objects and a plurality of frequency objects. The handheld electronic device has a number of messages available thereon, with each message of at least a portion of the number of messages including a number of language objects. Each of at least a portion of the language objects of the plurality of language objects is associated with an associated frequency object of the plurality of frequency objects. The input apparatus includes a plurality of input members, with each of at least a portion of the input members of the plurality of input members having a plurality of linguistic elements assigned thereto. The general nature of the method can be stated as including detecting at least one of a replying input and a forwarding input with respect to a message of the number of messages, storing in a first portion of the memory at least a portion of the language objects of the number of language objects of the message, detecting an ambiguous input including a number of input member actuations of a number of the input members of the plurality of input members, with each of at least a portion of the input members of the number of input members including a number of linguistic elements assigned thereto, and with at least one of the input members of the number of input members having a plurality of linguistic elements assigned thereto, identifying in the first portion of the memory a language object that corresponds with the ambiguous input, and outputting at least a portion of the language object as a first proposed disambiguation of the ambiguous input.
Other aspects of the invention are provided by an improved handheld electronic device, the general nature of which can be stated as including a processor apparatus, an input apparatus, and an output apparatus. The processor apparatus includes a memory having a plurality of objects stored therein, with the plurality of objects including a plurality of language objects and a plurality of frequency objects. Each of at least a portion of the language objects of the plurality of language objects is associated with an associated frequency object of the plurality of frequency objects. The input apparatus includes a plurality of input members, with each of at least a portion of the input members of the plurality of input members having a plurality of linguistic elements assigned thereto. The handheld electronic device has a number of messages available thereon, with each message of at least a portion of the number of messages including a number of language objects. The processor apparatus is adapted to detect at least one of a replying input and a forwarding input with respect to a message of the number of messages The processor apparatus is adapted to detect an ambiguous input including a number of input member actuations of a number of the input members of the plurality of input members, with each of at least a portion of the input members of the number of input members including a number of linguistic elements assigned thereto, and with at least one of the input members of the number of input members having a plurality of linguistic elements assigned thereto. The processor apparatus is adapted to make a determination that a first portion of the memory is associated with the message, with the first portion of the memory including at least a portion of the language objects of the number of language objects of the message. The processor apparatus is adapted to identify in the first portion of the memory a first language object that corresponds with the ambiguous input. The processor apparatus is adapted to output to the output apparatus an output including at least a portion of the first language object as a first proposed disambiguation of the ambiguous input.
A full understanding of the invention can be gained from the following Description of the Preferred Embodiments when read in conjunction with the accompanying drawings in which:
Similar numerals refer to similar parts throughout the specification.
An improved handheld electronic device 4 in accordance with the invention is indicated generally in
The input apparatus includes a keypad 24 that includes a plurality of keys 28. The input apparatus 12 additionally includes a track wheel 32 for additional input. Many of the keys 28 have one or more letters 30 assigned thereto, and a some of the keys 28 have a plurality of letters 30 assigned thereto. In the present exemplary embodiment, the exemplary letters 30 are Roman letters, and the exemplary Roman letters serve as linguistic elements for language entry into the handheld electronic device 4. It is understood that while the linguistic elements of the instant exemplary embodiment are depicted as being characters, specifically Roman letters, the linguistic elements could be other elements such as, for example and without limitation, other types of characters, ideograms, portions of ideograms such as strokes, and other elements that can be used in the generation of language. The expressions “text” and “word”, and variations thereof, are to be broadly construed herein and are not intended to be limiting in any fashion with regard to a particular language, a particular portion of a language or a means of providing an expression in a language, or to a particular language type or format.
The output apparatus 16 in the present exemplary embodiment includes a display 36. The output apparatus 16 may additionally include other output devices such as lights, speakers, and other output devices without limitation.
As can be seen in
The memory 44 includes a generic word list 48 that has a plurality of language objects and frequency objects stored therein. The language objects are, in the instant example, representative of words. The language objects and the frequency objects are associated. A given frequency object is representative of a frequency value that reflects, for instance, the relative likelihood that a language object with which the frequency object is associated is what is intended by a user when the user makes an input via the keypad 24. The memory 44 includes other objects stored and organized therein, as will be described in greater detail below.
The processor apparatus 20 has resident thereon a disambiguation routine that interfaces with the memory 44 and the objects stored therein to provide output in response to input via the input apparatus 12. In accordance with the invention, and in certain situations, certain words and the like may be stored in one or more temporary dictionaries in the memory 44 and made available to the user, such as when the user might reasonably be expected to wish to input such words. The words in such a temporary dictionary may be accorded a relatively high frequency value in order that such words, if appropriate, will be presented in whole or in part to the user at an early opportunity during the text entry process to limit the editing effort and other input that might otherwise be required to enter such words.
Although many uses for the invention will be apparent, one exemplary use of the invention is presented herein as being in the context of electronic mail. As can be seen in
In a situation where, for example, a user enters a replying or forwarding command with respect to one of the messages 52, the user can reasonably be expected to wish to enter certain language. Such expected language might include, for example, a salutation to one of the recipients and/or, by way of additional example, a reference to something that has already been referred to in a prior message in the same message thread. In some circumstances, some of the language that a user can reasonably be expected to wish to enter can be ascertained prior to entry of such language by the user. In accordance with an aspect of the invention, therefore, certain language is advantageously stored in one or more temporary dictionaries in the memory 44 for ready use by user in entering language.
Such an example is presented in
It is noted that in generating the exemplary new message 64, the e-mail client application fills in the names of the recipients 68 and the subject 100. The e-mail client application or other application or routine may advantageously also create a first temporary dictionary 84 (
The exemplary new message 64 is depicted in
Adjacent the exemplary salutatory expression 112 is a text input location 128 indicated by a cursor 136. In the vicinity of the cursor 136 is an exemplary first name 140.
In seeking to interpret the aforementioned ambiguous input, which could be intended to be the initial letter of a word starting with “Z” or a word starting with “X”, the disambiguation routine sought to identify in the first temporary dictionary 84 a language object stored therein that corresponds with either “Z” or “X”, and resultingly identified the first name 140 of “ZIGLEVEIT” since the names of the recipients 68 have been stored in the first temporary dictionary 84. Associated with such first name 140 would be a relatively high frequency value. The output of
In providing the output of
The output in the present exemplary embodiment depicted
In the present example, the user, in actuating the key 28 to which the letters 30 “Z” and “X” are assigned, likely intended to enter the name “ZIGLEVEIT” as part of the salutation 108 since the first recipient 72 is “ZIGLEVEIT JONES”. The first name 140 “ZIGLEVEIT” is unlikely to previously have been stored in the generic word list 48 or otherwise in the memory 44. By storing the first name 140 “ZIGLEVEIT” in the first temporary dictionary 84, the effort that otherwise would have been required of the user in entering the exemplary first name 140 “ZIGLEVEIT” is reduced. That is, in the absence of the first temporary dictionary 84 the disambiguation routine might have offered numerous variants to the user in attempting to predict the intent of the user in providing the aforementioned input, and such variants may have required numerous selection and/or movement inputs by the user in ultimately entering the name “ZIGLEVEIT”. By making available as a high frequency variant the first name “ZIGLEVEIT”, the additional effort that otherwise might have been required of the user in entering the first name 140 of the salutation 108 is reduced.
In certain disambiguation systems, the proposed output responsive to an input may be only the same length as the input. That is, in certain disambiguation routines the proposed output in response to a single keystroke might be a number of variants 132 that are only a single character, i.e., letter 30, in length. In the present exemplary embodiment of the disambiguation routine, however, the proposed output in response to the single keystroke of the key 28 to which the letters 30 “Z” and “X” are assigned was the entire first name 140 “ZIGLEVEIT”. The disambiguation routine thus provided a disambiguation in the nature of a predicted entire word in response to an ambiguous input consisting of a single keystroke. This is particularly advantageous because it avoids the need of the user to actuate all of the keys 28 that might otherwise be required to spell the first name 140 “ZIGLEVEIT”. In accordance with an aspect of the invention, therefore, the disambiguation routine determined that the current input was a part of the salutation 108, i.e., by determining that the text input location 128 was adjacent the salutatory expression 112 from among a number of predetermined salutatory expressions 112 and/or by being disposed at the first line 104 of the language input field 96. Since the salutation likely will be limited to the names of the recipients 68, the prediction of the entire first name 140 from the aforementioned single keystroke saves time and effort on the part of the user. In other embodiments, however, the output need not include an entire predicted name, and rather may be a letter-for-keystroke output.
In accordance with another aspect of the invention, the disambiguation routine may additionally provide a second name 144 as a variant 132 in combination with the first name 140, thus “ZIGLEVEIT & WILLIAM”. The first name 140 and the second name 144 correspond with the first recipient 72 and the second recipient 76, respectively. As such, in addition to providing as the default output 124 the entire first name 140, “ZIGLEVEIT”, the disambiguation routine additionally can provide as a first variant 132 the combined first and second names 140 and 144 of “ZIGLEVEIT & WILLIAM”. This saves additional time to the user if it is desired to provide the salutation 108 as addressing both the first and second recipients 72 and 76.
Depending upon the data stored in the memory 44, the variant component 120 of the output might additionally include, for example, a first friendly name 148 of “Ziggy” and/or a second friendly name 152 “Bill”, with the first and second friendly names 148 and 152 corresponding with the first and second names 140 and 144, respectively. Such a friendly variant 132 would provide an additional alternative in entering the salutation 108. The disambiguation routine has provided as additional variants 132 the variant 132 “Z” and the variant “X” as lower priority variants 132, and these may be provided for use in the event that the user has desired to enter a word beginning with either “Z” or “X” without intending to enter the first name 140. In the present example, the first name 140 is provided as the default output 124 since the single keystroke by the user is most likely to have been intended as beginning the input of the first name 140, which would be a likely entry as a part of the salutation 108.
A further aspect of the invention is depicted generally in
More specifically, many of the words in the original message 52 have been stored as language objects in a second temporary dictionary 92 in the memory 44. Such second temporary dictionary 92 may have been generated, for example, upon detection of the aforementioned replying input or a forwarding input with respect to the original message 52. Alternatively, if prior messages 52 in the same message thread as the original message 52 and the new message 64 of
In one embodiment of the invention, the memory 44 may include a plurality of second temporary dictionaries 92, each being associated with a corresponding message 52 and/or message thread. The disambiguation routine could identify such second temporary dictionaries 92 through the use of a lookup table 88 that might include, for instance, a table of first entries that are associated with messages 52 and/or message threads, and corresponding second entries having pointers to locations in the memory 44 where the appropriate second temporary dictionary 92 is located. In another embodiment, the memory 44 may include only a single second temporary dictionary 92 that is created upon replying to or forwarding message 52, with the stored language objects thereof being replaced with other language objects contained in another message 52 upon replying to or forwarding of the another message 52.
In the present exemplary embodiment of the handheld electronic device 4, upon detecting a replying or forwarding input with respect to one of the messages 52, the disambiguation routine determines from the lookup table 88 whether or not a second temporary dictionary 92 has already been generated for the particular message 52 and/or the related message thread, if any. In this regard, the first entries in the lookup table 88 with which the messages 52 are associated may, for example, include the subject 60 of the message 52 or may be in the form of a hash of the subject 60 of the message 52. A message thread including the message 52 could thus be identified so long as the subject 60 has not been changed. Other methods of identifying a given message 52 and/or message thread will be apparent.
If no corresponding second temporary dictionary 92 has yet been created for the given message 52, the disambiguation routine or other routine could generate the second temporary dictionary 92 by storing at a particular location in the memory 44 language objects corresponding with some or all of the words in the message 52. Such language objects could be associated with a relatively high frequency value, either by having corresponding frequency objects stored in the memory 44, by assigning to all language objects in the second temporary dictionary 92 a relatively high frequency value, or in other apparent fashions. Once a corresponding second temporary dictionary 92 has already been created for the message 52 and/or for the corresponding message thread, the respective second temporary dictionary 92 can be interrogated by the disambiguation routine in seeking to identify language objects stored therein that correspond with an ambiguous input into the handheld electronic device 4.
That is, a user may enter an ambiguous input in the form of a number of keystrokes of the keys 28. If any of the keys 28 has a plurality of letters 30 or other linguistic elements assigned thereto, the input will be ambiguous. With each successive keystroke, the disambiguation routine may interrogate the generic word list 48 for corresponding language objects and associated frequency objects, and will also seek to identify language objects stored in the corresponding second temporary dictionary 92, along with seeking associated frequency values for such language objects in the second temporary dictionary 92. The disambiguation routine potentially may also interrogate the first temporary dictionary 84 in seeking to identify additional language objects that correspond with the ambiguous input. The corresponding identified language objects from the generic word list 48 and the second temporary dictionary 92 (and first temporary dictionary 84, if appropriate) are then output in order of frequency value.
An example of the benefits provided by the second temporary dictionaries 92 is indicated generally in
In the example depicted in
An exemplary flowchart in
Regardless of whether the additional message was created as a result of detecting a replying or forwarding input to an existing message, or if an original message was created, the disambiguation routine or other routine stores, as at 212, the names of the recipients as found in, for example, a “TO:” field or a “CC:” field in the message in a first temporary dictionary 84. The disambiguation routine or other routine may determine, as at 216, whether a second temporary dictionary 92 has already been created for the message or message thread. Such a determination can be made by consulting the lookup table 88. If a second temporary dictionary 92 has already been created for the message thread, its location in the memory 44 is determined as at 220. If, however, no corresponding second temporary dictionary 92 has yet been created, such a second temporary dictionary 92 is created, as at 224. Upon creating such second temporary dictionary 92, the lookup table 88 is updated, as at 228, with entries that correspond with, for example, the location in the memory 44 of the second temporary dictionary 92 and a corresponding subject of the e-mail thread or a hash thereof, for instance. Such an updating operation can be provided with different types of entries in the lookup table 88 without departing from the concept of the invention.
The processor apparatus 20 may detect, as at 232, a text input that may be ambiguous. The disambiguation routine may then determine, as at 236, whether or not the input is a portion of a salutation 108. Such a determination can be made, as mentioned above, by determining the proximity of the text input location 128 to a salutatory expression 112, the presence of the text input location 128 on a first line 104 of the language input field 96, or in other fashions that will be apparent. If it is determined at 236 that the current input is a portion of a salutation 108, the disambiguation routine then determines, as at 240, whether the first temporary dictionary 84 includes a language object stored therein that corresponds with the input. If such a language object is identified, the disambiguation routine may retrieve, as at 244, the entry and a corresponding frequency value. The disambiguation routine may also consult the generic word list 48, as mentioned above, to identify other language objects and corresponding frequency values, as at 248. The identified language objects from the first temporary dictionary 84 and the generic word list 48 may then be output, as at 252 in order of decreasing frequency value. It is noted that the names 140, 144, and the like are anticipated to be associated with relatively higher frequency values than any language objects stored in and obtained from the generic word list 48 and thus are expected to be output as the default output 124. Processing then returns to 232.
If at 236 it is determined that the input is not a part of a salutation 108, processing may continues at 256 where it is determined whether the second temporary dictionary 92 that corresponds with the new message 64 has stored therein any language object that corresponds with the input. If yes, such corresponding language object or objects are obtained, as at 260, from the second temporary dictionary 92, along with any associated frequency value, which likely would be relatively high.
Regardless of whether any such language objects were identified in second temporary dictionary 92, the disambiguation routine obtains from the generic word list 48, as at 248, any language objects that correspond with the input, along with associated frequency values. The disambiguation routine then outputs, as at 252, at least a portion of the identified language objects, whether from the second temporary dictionary 92 or from the generic word list 48, in order of decreasing frequency value. Processing thereafter continues at 232.
The improved handheld electronic device 4 and associated method in accordance with the invention provide facilitated input in appropriate situations including, for example and without limitation, in the situation of a salutation or in entering text when replying to or forwarding an e-mail message. This advantageously reduces the time, effort, and attention required of a user in using the handheld electronic device 4.
While specific embodiments of the invention have been described in detail, it will be appreciated by those skilled in the art that various modifications and alternatives to those details could be developed in light of the overall teachings of the disclosure. Accordingly, the particular arrangements disclosed are meant to be illustrative only and not limiting as to the scope of the invention which is to be given the full breadth of the claims appended and any and all equivalents thereof.
Number | Name | Date | Kind |
---|---|---|---|
5945928 | Kushler et al. | Aug 1999 | A |
5953541 | King et al. | Sep 1999 | A |
6005495 | Connolly et al. | Dec 1999 | A |
6307548 | Flinchem et al. | Oct 2001 | B1 |
6636162 | Kushler et al. | Oct 2003 | B1 |
6802661 | Lee et al. | Oct 2004 | B1 |
6885317 | Gutowitz | Apr 2005 | B1 |
7048456 | Keinonen et al. | May 2006 | B2 |
7312726 | Fux et al. | Dec 2007 | B2 |
7333085 | Fux et al. | Feb 2008 | B2 |
7358866 | Fux et al. | Apr 2008 | B2 |
7395203 | Wu et al. | Jul 2008 | B2 |
20010006587 | Keinonen et al. | Jul 2001 | A1 |
20040156562 | Mulvey et al. | Aug 2004 | A1 |
20050027524 | Wu et al. | Feb 2005 | A1 |
20050027534 | Meurs et al. | Feb 2005 | A1 |
20050169527 | Longe et al. | Aug 2005 | A1 |
20050200609 | Van der Hoeven | Sep 2005 | A1 |
20050283364 | Longe et al. | Dec 2005 | A1 |
20060047498 | Fux et al. | Mar 2006 | A1 |
20060247917 | Fux et al. | Nov 2006 | A1 |
20070005336 | Pathiyal et al. | Jan 2007 | A1 |
Number | Date | Country |
---|---|---|
WO 9833111 | Jul 1998 | WO |
Number | Date | Country | |
---|---|---|---|
20060217965 A1 | Sep 2006 | US |