USRE46139E1 - Language input interface on a device - Google Patents

Language input interface on a device Download PDF

Info

Publication number
USRE46139E1
USRE46139E1 US14/516,533 US201414516533A USRE46139E US RE46139 E1 USRE46139 E1 US RE46139E1 US 201414516533 A US201414516533 A US 201414516533A US RE46139 E USRE46139 E US RE46139E
Authority
US
United States
Prior art keywords
candidate
phonetic string
presenting
representations
alphabet
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US14/516,533
Inventor
Yasuo Kida
Kenneth Kocienda
Elizabeth Caroline Furches Cranfill
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Apple Inc filed Critical Apple Inc
Priority to US14/516,533 priority Critical patent/USRE46139E1/en
Application granted granted Critical
Priority to US15/257,780 priority patent/US20160370996A1/en
Publication of USRE46139E1 publication Critical patent/USRE46139E1/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • G06F3/04886Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures by partitioning the display area of the touch-screen or the surface of the digitising tablet into independently controllable areas, e.g. virtual keyboards or menus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/018Input/output arrangements for oriental characters
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/02Input arrangements using manually operated switches, e.g. using keyboards or dials
    • G06F3/023Arrangements for converting discrete items of information into a coded form, e.g. arrangements for interpreting keyboard generated codes as alphanumeric codes, operand codes or instruction codes
    • G06F3/0233Character input methods
    • G06F3/0237Character input methods using prediction or retrieval techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/126Character encoding
    • G06F40/129Handling non-Latin characters, e.g. kana-to-kanji conversion
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/274Converting codes to words; Guess-ahead of partial word inputs

Definitions

  • a virtual keyboard can be of the form of a software application or a feature of a software application to simulate a computer keyboard.
  • a virtual keyboard can be used by a user to input text by selecting or tabbing areas of the touch-sensitive display corresponding to keys of the virtual keyboard.
  • These smaller keyboards and virtual keyboards may have keys that correspond to more than one character.
  • some of the keys can, by default, correspond to a character in the English language, for example, the letter “a,” and may also correspond to other additional characters, such as another letter or the letter with an accent option, e.g., the character “ä,” or other characters with accent options.
  • a user may find it difficult to type characters not readily available on the virtual keyboard.
  • Input methods for devices having multi-language environments can present unique challenges with respect to input and spelling correction which may need to be tailored to the selected language to ensure accuracy and an efficient workflow.
  • one aspect of the subject matter described in this specification can be embodied in methods that include the actions of presenting a virtual keyboard in a first region of a touch sensitive display of a device, receiving an input representing a phonetic string on the virtual keyboard, presenting the entered phonetic string in a second region of the touch sensitive display, identifying one or more candidates based on the phonetic string, presenting at least a subset of the candidates in the first region or the second region, receiving an input selecting one of the candidates, and replacing the entered phonetic string with the selected candidate.
  • Other embodiments of this aspect include corresponding systems, apparatus, computer program products, and computer readable media.
  • Text in languages that require phonetic string-to-character conversion can be input more efficiently on a portable device.
  • Error correction and word prediction techniques can be applied to entry of East Asain languages.
  • FIG. 1 is a block diagram of an example mobile device.
  • FIG. 2 is a block diagram of an example implementation of the mobile device of FIG. 1 .
  • FIGS. 3A-3F illustrate an example user interface for entering text.
  • FIG. 4 illustrates an example text input process
  • FIG. 1 is a block diagram of an example mobile device 100 .
  • the mobile device 100 can be, for example, a handheld computer, a personal digital assistant, a cellular telephone, a network appliance, a camera, a smart phone, an enhanced general packet radio service (EGPRS) mobile phone, a network base station, a media player, a navigation device, an email device, a game console, or a combination of any two or more of these data processing devices or other data processing devices.
  • EGPS enhanced general packet radio service
  • the mobile device 100 includes a touch-sensitive display 102 .
  • the touch-sensitive display 102 can implement liquid crystal display (LCD) technology, light emitting polymer display (LPD) technology, or some other display technology.
  • LCD liquid crystal display
  • LPD light emitting polymer display
  • the touch sensitive display 102 can be sensitive to haptic and/or tactile contact with a user.
  • the touch-sensitive display 102 can comprise a multi-touch-sensitive display 102 .
  • a multi-touch-sensitive display 102 can, for example, process multiple simultaneous touch points, including processing data related to the pressure, degree, and/or position of each touch point. Such processing facilitates gestures and interactions with multiple fingers, chording, and other interactions.
  • Other touch-sensitive display technologies can also be used, e.g., a display in which contact is made using a stylus or other pointing device.
  • the mobile device 100 can display one or more graphical user interfaces on the touch-sensitive display 102 for providing the user access to various system objects and for conveying information to the user.
  • the graphical user interface can include one or more display objects 104 , 106 .
  • the display objects 104 , 106 are graphic representations of system objects.
  • system objects include device functions, applications, windows, files, alerts, events, or other identifiable system objects.
  • the mobile device 100 can implement multiple device functionalities, such as a telephony device, as indicated by a phone object 110 ; an e-mail device, as indicated by the e-mail object 112 ; a network data communication device, as indicated by the Web object 114 ; a Wi-Fi base station device (not shown); and a media processing device, as indicated by the media player object 116 .
  • a telephony device as indicated by a phone object 110
  • an e-mail device as indicated by the e-mail object 112
  • a network data communication device as indicated by the Web object 114
  • a Wi-Fi base station device not shown
  • a media processing device as indicated by the media player object 116 .
  • particular display objects 104 e.g., the phone object 110 , the e-mail object 112 , the Web object 114 , and the media player object 116 , can be displayed in a menu bar 118 .
  • device functionalities can be accessed from a top-level graphical user interface, such as the graphical user interface illustrated in FIG. 1 . Touching one of the objects 110 , 112 , 114 , or 116 can, for example, invoke corresponding functionality.
  • the mobile device 100 can implement network distribution functionality.
  • the functionality can enable the user to take the mobile device 100 and provide access to its associated network while traveling.
  • the mobile device 100 can extend Internet access (e.g., Wi-Fi) to other wireless devices in the vicinity.
  • mobile device 100 can be configured as a base station for one or more devices. As such, mobile device 100 can grant or deny network access to other wireless devices.
  • the graphical user interface of the mobile device 100 changes, or is augmented or replaced with another user interface or user interface elements, to facilitate user access to particular functions associated with the corresponding device functionality.
  • the graphical user interface of the touch-sensitive display 102 may present display objects related to various phone functions; likewise, touching of the email object 112 may cause the graphical user interface to present display objects related to various e-mail functions; touching the Web object 114 may cause the graphical user interface to present display objects related to various Web-surfing functions; and touching the media player object 116 may cause the graphical user interface to present display objects related to various media processing functions.
  • the top-level graphical user interface environment or state of FIG. 1 can be restored by pressing a button 120 located near the bottom of the mobile device 100 .
  • each corresponding device functionality may have corresponding “home” display objects displayed on the touch-sensitive display 102 , and the graphical user interface environment of FIG. 1 can be restored by pressing the “home” display object.
  • the top-level graphical user interface can include additional display objects 106 , such as a short messaging service (SMS) object 130 , a calendar object 132 , a photos object 134 , a camera object 136 , a calculator object 138 , a stocks object 140 , a weather object 142 , a maps object 144 , a notes object 146 , a clock object 148 , an address book object 150 , and a settings object 152 .
  • SMS short messaging service
  • Touching the SMS display object 130 can, for example, invoke an SMS messaging environment and supporting functionality; likewise, each selection of a display object 132 , 134 , 136 , 138 , 140 , 142 , 144 , 146 , 148 , 150 , and 152 can invoke a corresponding object environment and functionality.
  • Additional and/or different display objects can also be displayed in the graphical user interface of FIG. 1 .
  • the display objects 106 can be configured by a user, e.g., a user may specify which display objects 106 are displayed, and/or may download additional applications or other software that provides other functionalities and corresponding display objects.
  • the mobile device 100 can include one or more input/output (I/O) devices and/or sensor devices.
  • I/O input/output
  • a speaker 160 and a microphone 162 can be included to facilitate voice-enabled functionalities, such as phone and voice mail functions.
  • an up/down button 184 for volume control of the speaker 160 and the microphone 162 can be included.
  • the mobile device 100 can also include an on/off button 182 for a ring indicator of incoming phone calls.
  • a loud speaker 164 can be included to facilitate hands-free voice functionalities, such as speaker phone functions.
  • An audio jack 166 can also be included for use of headphones and/or a microphone.
  • a proximity sensor 168 can be included to facilitate the detection of the user positioning the mobile device 100 proximate to the user's ear and, in response, to disengage the touch-sensitive display 102 to prevent accidental function invocations.
  • the touch-sensitive display 102 can be turned off to conserve additional power when the mobile device 100 is proximate to the user's ear.
  • an ambient light sensor 170 can be utilized to facilitate adjusting the brightness of the touch-sensitive display 102 .
  • an accelerometer 172 can be utilized to detect movement of the mobile device 100 , as indicated by the directional arrow 174 . Accordingly, display objects and/or media can be presented according to a detected orientation, e.g., portrait or landscape.
  • the mobile device 100 may include circuitry and sensors for supporting a location determining capability, such as that provided by the global positioning system (GPS) or other positioning systems (e.g., systems using Wi-Fi access points, television signals, cellular grids, Uniform Resource Locators (URLs)).
  • GPS global positioning system
  • URLs Uniform Resource Locators
  • a positioning system e.g., a GPS receiver
  • a positioning system can be integrated into the mobile device 100 or provided as a separate device that can be coupled to the mobile device 100 through an interface (e.g., port device 190 ) to provide access to location-based services.
  • a port device 190 e.g., a Universal Serial Bus (USB) port, or a docking port, or some other wired port connection
  • the port device 190 can, for example, be utilized to establish a wired connection to other computing devices, such as other communication devices 100 , network access devices, a personal computer, a printer, a display screen, or other processing devices capable of receiving and/or transmitting data.
  • the port device 190 allows the mobile device 100 to synchronize with a host device using one or more protocols, such as, for example, the TCP/IP, HTTP, UDP and any other known protocol.
  • the mobile device 100 can also include a camera lens and sensor 180 .
  • the camera lens and sensor 180 can be located on the back surface of the mobile device 100 .
  • the camera can capture still images and/or video.
  • the mobile device 100 can also include one or more wireless communication subsystems, such as an 802.11b/g communication device 186 , and/or a BluetoothTM communication device 188 .
  • Other communication protocols can also be supported, including other 802.x communication protocols (e.g., WiMax, Wi-Fi, 3 G), code division multiple access (CDMA), global system for mobile communications (GSM), Enhanced Data GSM Environment (EDGE), etc.
  • 802.x communication protocols e.g., WiMax, Wi-Fi, 3 G
  • CDMA code division multiple access
  • GSM global system for mobile communications
  • EDGE Enhanced Data GSM Environment
  • FIG. 2 is a block diagram 200 of an example implementation of the mobile device 100 of FIG. 1 .
  • the mobile device 100 can include a memory interface 202 , one or more data processors, image processors and/or central processing units 204 , and a peripherals interface 206 .
  • the memory interface 202 , the one or more processors 204 and/or the peripherals interface 206 can be separate components or can be integrated in one or more integrated circuits.
  • the various components in the mobile device 100 can be coupled by one or more communication buses or signal lines.
  • Sensors, devices, and subsystems can be coupled to the peripherals interface 206 to facilitate multiple functionalities.
  • a motion sensor 210 can be coupled to the peripherals interface 206 to facilitate the orientation, lighting, and proximity functions described with respect to FIG. 1 .
  • Other sensors 216 can also be connected to the peripherals interface 206 , such as a positioning system (e.g., GPS receiver), a temperature sensor, a biometric sensor, or other sensing device, to facilitate related functionalities.
  • a camera subsystem 220 and an optical sensor 222 can be utilized to facilitate camera functions, such as recording photographs and video clips.
  • an optical sensor 222 e.g., a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor, can be utilized to facilitate camera functions, such as recording photographs and video clips.
  • CCD charged coupled device
  • CMOS complementary metal-oxide semiconductor
  • Communication functions can be facilitated through one or more wireless communication subsystems 224 , which can include radio frequency receivers and transmitters and/or optical (e.g., infrared) receivers and transmitters.
  • the specific design and implementation of the communication subsystem 224 can depend on the communication network(s) over which the mobile device 100 is intended to operate.
  • a mobile device 100 may include communication subsystems 224 designed to operate over a GSM network, a GPRS network, an EDGE network, a Wi-Fi or WiMax network, and a BluetoothTM network.
  • the wireless communication subsystems 224 may include hosting protocols such that the device 100 may be configured as a base station for other wireless devices.
  • An audio subsystem 226 can be coupled to a speaker 228 and a microphone 230 to facilitate voice-enabled functions, such as voice recognition, voice replication, digital recording, and telephony functions.
  • the I/O subsystem 240 can include a touch screen controller 242 and/or other input controller(s) 244 .
  • the touch-screen controller 242 can be coupled to a touch screen 246 .
  • the touch screen 246 and touch screen controller 242 can, for example, detect contact and movement or break thereof using any of a plurality of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, and surface acoustic wave technologies, as well as other proximity sensor arrays or other elements for determining one or more points of contact with the touch screen 246 .
  • the other input controller(s) 244 can be coupled to other input/control devices 248 , such as one or more buttons, rocker switches, thumb-wheel, infrared port, USB port, and/or a pointer device such as a stylus.
  • the one or more buttons can include an up/down button for volume control of the speaker 228 and/or the microphone 230 .
  • a pressing of the button for a first duration may disengage a lock of the touch screen 246 ; and a pressing of the button for a second duration that is longer than the first duration may turn power to the mobile device 100 on or off.
  • the user may be able to customize a functionality of one or more of the buttons.
  • the touch screen 246 can, for example, also be used to implement virtual or soft buttons and/or a keyboard.
  • the mobile device 100 can present recorded audio and/or video files, such as MP3, AAC, and MPEG files.
  • the mobile device 100 can include the functionality of an MP3 player, such as an iPodTM.
  • the mobile device 100 may, therefore, include a 30-pin connector that is compatible with the iPodTM.
  • Other input/output and control devices can also be used.
  • the memory interface 202 can be coupled to memory 250 .
  • the memory 250 can include high-speed random access memory and/or non-volatile memory, such as one or more magnetic disk storage devices, one or more optical storage devices, and/or flash memory (e.g., NAND, NOR).
  • the memory 250 can store an operating system 252 , such as Darwin, RTXC, LINUX, UNIX, OS X, WINDOWS, or an embedded operating system such as VxWorks.
  • the operating system 252 may include instructions for handling basic system services and for performing hardware dependent tasks.
  • the operating system 252 can be a kernel (e.g., UNIX kernel).
  • the memory 250 may also store communication instructions 254 to facilitate communicating with one or more additional devices, one or more computers and/or one or more servers.
  • the memory 250 may include graphical user interface instructions 256 to facilitate graphic user interface processing; sensor processing instructions 258 to facilitate sensor-related processing and functions; phone instructions 260 to facilitate phone-related processes and functions; electronic messaging instructions 262 to facilitate electronic-messaging related processes and functions; web browsing instructions 264 to facilitate web browsing-related processes and functions; media processing instructions 266 to facilitate media processing-related processes and functions; GPS/Navigation instructions 268 to facilitate GPS and navigation-related processes and instructions; camera instructions 270 to facilitate camera-related processes and functions; and/or other software instructions 272 to facilitate other processes and functions, e.g., security processes and functions.
  • the memory 250 may also store other software instructions (not shown), such as web video instructions to facilitate web video-related processes and functions; and/or web shopping instructions to facilitate web shopping-related processes and functions.
  • the media processing instructions 266 are divided into audio processing instructions and video processing instructions to facilitate audio processing-related processes and functions and video processing-related processes and functions, respectively.
  • An activation record and International Mobile Equipment Identity (IMEI) 274 or similar hardware identifier can also be stored in memory 250 .
  • IMEI International Mobile Equipment Identity
  • Language data 276 can also be stored in memory 250 .
  • Language data 276 can include, for example, word dictionaries (i.e., list of possible words in a language) for one or more languages, dictionaries of characters and corresponding phonetics, one or more corpuses of characters and character compounds, and so on.
  • Each of the above identified instructions and applications can correspond to a set of instructions for performing one or more functions described above. These instructions need not be implemented as separate software programs, procedures, or modules.
  • the memory 250 can include additional instructions or fewer instructions.
  • various functions of the mobile device 100 may be implemented in hardware and/or in software, including in one or more signal processing and/or application specific integrated circuits.
  • FIGS. 3A-3F illustrate an example user interface for entering multi-lingual text on mobile device 100 .
  • Mobile device 100 can display a text input area 302 and a virtual keyboard 304 on the touch-sensitive display 102 .
  • the text input area 302 can be any area where input text can be displayed, e.g., a note-taking application, an email application, and so on.
  • the text input area 302 can be one or more text fields located in a document (e.g., a web page rendered in a web browser application).
  • the virtual keyboard 304 includes one or more virtual keys 303 that each correspond to a letter in an alphabet (e.g., Latin alphabet).
  • the virtual keyboard 304 can include a keyboard toggle key 308 for toggling between letter keys and keys for numbers, punctuation, etc. (i.e., either letter keys or numbers/punctuation keys can be displayed in the virtual keyboard 304 ).
  • a user can enter text by touching the touch-sensitive display 102 on the areas of the desired keys of the virtual keyboard 304 ; the user selects or hits the desired keys of the virtual keyboard 304 .
  • Letters, numbers, etc. corresponding to the touched keys are displayed in the text input area 302 as unconverted current input 310 -A.
  • the user can hit the backspace key 306 to delete the last input character.
  • the mobile device 100 includes capability to input text in a non-English language using Latin alphabet virtual keyboard.
  • the mobile device 100 can include capability for inputting Chinese and/or Japanese text, including Chinese or Japanese characters and symbols, using a Latin alphabet virtual keyboard (e.g., virtual keyboard with letters arranged in a QWERTY layout).
  • a Latin alphabet virtual keyboard e.g., virtual keyboard with letters arranged in a QWERTY layout.
  • the device 100 can include a Chinese or Japanese text entry mode that utilizes a Latin alphabet keyboard.
  • a user can use the virtual keyboard to enter a phonetic string of letters representing sounds or syllables in the non-English language.
  • a user can user the virtual keyboard to type in a romanization of one or more characters or symbols in Chinese or Japanese.
  • the implementations in this specification will be described in reference to entry of Japanese language text. It should be appreciated, however, that the described implementations can be applied to other non-English languages (e.g., Chinese). More generally, the described implementations can be applied to any text input interface that involves identification, presentation, and selection of candidates for inputs, regardless of language (e.g., Latin alphabet romanization to non-Latin-alphabet text, spelling and grammar correction, thesaurus features, etc.).
  • the letter is displayed in the text input area 302 as an unconverted current input 310 -A, as shown in FIG. 3A .
  • the input 310 -A is displayed with underlining or some other formatting (e.g., bold text, italics, highlighting).
  • the underlining/formatting indicates that the input is a provisional input subject to conversion pending additional input from the user, whether that additional input is additional letters or a selection of a candidate by the user. For example, in FIG. 3A , the user hits the “s” key, and the letter “s” is displayed in the text input area 302 as current input 310 -A with underlining.
  • the virtual keyboard 304 can include a “confirm” key 314 that, when hit by the user, accepts the displayed input 310 -A as is.
  • the accepted input is displayed without the underlining.
  • the user can hit the “confirm” key 314 to accept the input string “s” as is; “s” is displayed without underlining.
  • hitting of the “confirm” key 214 also adds a space after the accepted input.
  • the addition of the space after the accepted input depends on whether the accepted input is in a language where spaces separate words and/or whether the accepted input is the end of a sentence, to name a few example criteria.
  • key 314 is a “space” key that, when pressed, accepts the current input as is, effectively serving as a “confirm” key.
  • the virtual keyboard 304 can also include a “show candidates” key 312 .
  • the user can bring up a tray of candidate characters, symbols, and combinations thereof (e.g., kanji, kana combinations) with which to replace the input 310 -A.
  • the tray of candidates is further described below.
  • the user next hits the letter “e” on the keyboard, resulting in the string “se.”
  • the string “se” can be converted by the device 100 to the hiragana symbol “ ”, of which the string “se” is the romanization, and the hiragana symbol “ ” , is displayed as converted current input 310 -B with underlining, as shown in FIG. 3B .
  • the user can hit the “confirm” key 314 to accept the hiragana symbol “ ”, as is; “ ”, is then displayed without underlining.
  • the user can hit the “show candidates” key 312 to bring up the tray of candidates related to the string “se” (e.g., characters whose phonetic readings begin with “se”).
  • the user next hits the “n” key, resulting in the string “sen.”
  • the terminal “n” letter is converted to the hiragana symbol “ ”, of which the terminal “n” is the romanization, and appended to the already-converted hiragana symbol “ ”.
  • the hiragana symbol “ ” is displayed as converted current input 310 -B with underlining, as shown in FIG. 3C .
  • the device 102 can display one or more suggested candidates 318 inline for the input 310 -B.
  • the suggested candidates can include single characters, phonetic symbols (e.g., Japanese kana), and combinations of multiple characters and/or phonetic symbols. For example, in FIG.
  • the kanji character “ ” is displayed as a suggested candidate for “ ” (“sen”) is the onyomi reading for the kanji character “ ”
  • the user can hit a suggested candidate (i.e., touch the touch-sensitive display 102 over the area of the desired suggested candidate) to select a suggested candidate, continue typing letter keys on the virtual keyboard 304 to add to the input 310 -B, or hit the “show candidates” key 312 to bring up the candidates tray, among other actions.
  • the selected suggested candidate is displayed as accepted input 336 , as shown in FIG. 3F .
  • the current input 310 -B is extended and possible candidates for the current input 310 -B are narrowed down.
  • the one or more suggested candidates 318 that are presented to the user are determined by the device 100 to be the best match for the input 310 -B based on one or more criteria (e.g., frequency in the language, exact match, etc.).
  • more candidates can be displayed by the device 100 when the user hits an arrow graphical object 319 or the like on the touch-sensitive display 102 .
  • a candidates tray 322 can be displayed.
  • the inline suggested candidates list 318 can expand to show more candidates.
  • the arrow 319 gives the user a hint that there are additional candidates available.
  • the user can hit the confirm key 314 once to select the first candidate of the suggested candidates 318 , hit the confirm key 314 twice in quick succession to select the second candidate of the suggested candidates 318 , and so on.
  • a candidates tray 322 can be displayed, as shown in FIG. 3D .
  • the candidates tray 322 is displayed in place of the virtual keyboard 304 .
  • the candidates tray 322 is displayed over all or part of the text input area 302 .
  • the candidates tray 322 slides over the virtual keyboard 304 or the text input area 302 , and the sliding is displayed as an animated effect. When the candidates tray 322 is removed from view, the candidates tray 322 can slide off the touch-sensitive display 102 .
  • the candidates tray 322 can include one or more candidate keys 330 , each of the candidate keys 330 corresponding to a candidate for conversion of the input 310 -B.
  • a candidate (whether for the candidate keys 330 or suggested candidates 318 ) can be a character, a phonetic or syllabic symbol (e.g., a kana symbol), romanization, multi-character combinations forming words or phrases, multi-symbol combinations forming words or phrases, a combination of characters and symbols forming words or phrases, and so on.
  • the candidates can include characters whose phonetic reading is or begins with the input 310 -B as a reading, words that begin with the input 310 -B, and so on.
  • the candidates tray 322 includes some candidate keys 330 that correspond to kanji characters that has “ ” as a reading.
  • the candidates in the candidates tray are ordered based on various criteria as to which candidate is the best candidate.
  • the candidates for the suggested candidates 318 and the candidates tray 322 are identified and ordered using predictive text and/or error correction techniques, examples of which include fuzzy matching, techniques for determining cursor position based on a finger contact, and so on.
  • predictive text technique is disclosed in Masui, “An Efficient Text Input Method for Pen-based Computers,” in Proceedings of the ACM Conference on Human Factors in Computing Systems (CHI '98), Addison-Wesley, April 1998, pp. 328-335, the disclosure of which is incorporated by reference herein in its entirety.
  • An example of a techniques for determining cursor position based on a finger contact is disclosed in U.S. patent application Ser. No. 11/850,015, titled “Methods for Determining a Cursor Position from a Finger Contact with a Touch Screen Display,” filed Sep. 4, 2007, the disclosure of which is incorporated by reference herein in its entirety.
  • the candidates tray 322 can also include a keyboard switch key 328 for switching back to the virtual keyboard 304 .
  • the candidates tray 322 can also include back candidates key 326 and/or next candidates key 324 for moving back and forth between sets of candidate keys 330 within the candidates tray 322 .
  • the candidates tray 322 also includes the confirm key 314 .
  • the user can hit a candidate key 330 to replace the input 310 -B with the candidate corresponding to the hit candidate key 330 .
  • a candidate key 330 For example, from FIG. 3D , if the user hits the key that corresponds to the candidate character “ ” (key 332 ), the input 310 -B is replaced with the character “ ” The character “ ” is displayed as accepted input 336 , as shown in FIG. 3E .
  • the candidates tray 322 reverts back to virtual keyboard 304 .
  • the virtual keyboard 304 can include a “space” key 334 and a “return” key 332 in place of “confirm” key 314 and show candidate key 312 , respectively.
  • FIG. 3F the user can enter a new phonetic string input.
  • the virtual keyboard 304 can include a key for switching between multiple input keyboards for various languages.
  • the candidates tray 322 includes a cancel key 331 for reverting back to the virtual keyboard 304 from the candidates tray 322 without selecting a candidate.
  • a candidate in the suggested candidates 318 or candidates tray 322 is highlighted as the “currently selected” candidate.
  • the initial highlighted candidate can be the phonetic string itself in the suggested candidates 318 or candidates tray 322 or the “best” candidate.
  • Key 312 can be a “next candidate” key, where a press of the key moves the highlighting to the next candidate.
  • the confirm key 314 can be used to accept the highlighted candidate.
  • no candidate is automatically selected or highlighted by default; the user can hit the confirm key 314 to accept the phonetic string as is.
  • the user can hit the next candidate key (and optionally a previous candidate key) to move through the candidates and highlight one of them.
  • the current input 310 -B changes to show the currently highlighted candidate, while still displayed with underlining or other formatting to indicate that the current input 310 -B is still provisional.
  • Hitting a return key e.g., return key 332
  • confirms the currently selected candidate or the phonetic string i.e., whatever phonetic string or candidate is shown in the current input 310 -B).
  • Adding more phonetic symbols by typing on the virtual keyboard 304 also automatically accepts the currently selected candidate or the phonetic string (i.e., whatever phonetic string or candidate is shown in the current input 310 -B).
  • FIG. 4 illustrates an example text input process 400 .
  • the process 400 will be described in reference to a device (e.g., device 100 ) that performs the process 400 .
  • a virtual keyboard is displayed in a first region of a touch-sensitive display of a device ( 402 ).
  • the device displays virtual keyboard 304 on a portion of the touch-sensitive display 102 .
  • An input is received entering a phonetic string on the virtual keyboard ( 404 ).
  • a user can enter one or more letters using the virtual keyboard.
  • the entered letters can constitute a phonetic string.
  • the phonetic string can be a romanization of characters, words, and the like in a language that does not use the Latin alphabet, for example.
  • the input phonetic string is displayed in a second region of the display ( 406 ).
  • the device 100 can display the phonetic string in a text input area on the touch-sensitive Display 102 .
  • the device 100 converts the phonetic string to, for example, symbols corresponding to the phonetic string (e.g., Japanese kana, Chinese zhuyin, etc.).
  • One or more candidates matching the phonetic string are identified ( 408 ).
  • the device 100 can look up the phonetic string in a dictionary, character database, or the like, and finds matching characters for the phonetic string.
  • the device 100 can segment the phonetic string based on syllables or another criteria and find candidates for each of the segments.
  • At least a subset of the identified candidates is displayed in the first region of the touch sensitive display ( 410 ).
  • the candidates can be displayed in a candidates tray 322 that is displayed in place of the virtual keyboard 304 .
  • the user can navigates to the overflow candidates by hitting the back candidates 326 or next candidates key 324 .
  • Input is received selecting one of the candidates ( 412 ). For example, a user can hit one of the candidate keys 330 in a candidates tray 322 to select the corresponding candidate.
  • the displayed phonetic string is replaced with the selected candidate ( 414 ).
  • the selected candidate is displayed on the touch-sensitive display in place of the input phonetic string.
  • the virtual keyboard 304 and the candidates tray 322 can be dynamically resized based on the orientation of the touch-sensitive display 102 .
  • FIGS. 3A-3F show the virtual keyboard 304 or the candidates tray 322 in portrait orientation. If the device 100 , and thus the touch-sensitive display 102 , is rotated to landscape orientation, the device 100 can detect the rotation and resize the keyboard 304 and the candidates tray 322 to fit the landscape width of the touch-sensitive display 102 .
  • the suggested candidates 318 are displayed in the same orientation as the text input, whose orientation can vary by language. For example, if the text is displayed from left-to-right, the suggested candidates 318 are displayed from left to right. If the text is displayed from right to left, the suggested candidates 318 are displayed from right to left. If the text displayed from top to bottom, the suggested candidates 318 are displayed from top to bottom.
  • the phonetic string can be input by voice rather than typing on the virtual keyboard 304 .
  • the device 100 can include a voice recognition module that receives and processes a user's voice input and generates a phonetic string based on the voice input. The device 100 can identify candidates for the phonetic string generated by the voice recognition module for selection by the user.
  • the disclosed and other embodiments and the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them.
  • the disclosed and other embodiments can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer-readable medium for execution by, or to control the operation of, data processing apparatus.
  • the computer-readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more them.
  • data processing apparatus encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers.
  • the apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.
  • a propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
  • a computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
  • a computer program does not necessarily correspond to a file in a file system.
  • a program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code).
  • a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
  • the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output.
  • the processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
  • a processor will receive instructions and data from a read-only memory or a random access memory or both.
  • the essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data.
  • a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • a computer need not have such devices.
  • Computer-readable media suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
  • semiconductor memory devices e.g., EPROM, EEPROM, and flash memory devices
  • magnetic disks e.g., internal hard disks or removable disks
  • magneto-optical disks e.g., CD-ROM and DVD-ROM disks.
  • the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
  • the disclosed embodiments can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer.
  • a display device e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor
  • a keyboard and a pointing device e.g., a mouse or a trackball
  • Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • the disclosed embodiments can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of what is disclosed here, or any combination of one or more such back-end, middleware, or front-end components.
  • the components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
  • LAN local area network
  • WAN wide area network

Abstract

Methods, systems, and apparatus, including computer program products, for inputting text. A virtual keyboard is presented in a first region of a touch sensitive display of a device. An input representing a phonetic string is received on the virtual keyboard. The entered phonetic string is presented in a second region of the touch sensitive display. One or more candidates are identified based on the phonetic string. At least a subset of the candidates is presented. An input selecting one of the candidates is received. The entered phonetic string is replaced with the selected candidate.

Description

BACKGROUND
The subject matter of this specification is related generally to text input interfaces.
Traditional computer keyboards may be too large for portable devices, such as mobile phones, multimedia players, or personal digital assistants (PDAs). Some portable devices include a smaller version of the traditional computer keyboard or use a virtual keyboard to receive user input. A virtual keyboard can be of the form of a software application or a feature of a software application to simulate a computer keyboard. For example, in a portable device with a touch-sensitive display, a virtual keyboard can be used by a user to input text by selecting or tabbing areas of the touch-sensitive display corresponding to keys of the virtual keyboard.
These smaller keyboards and virtual keyboards may have keys that correspond to more than one character. For example, some of the keys can, by default, correspond to a character in the English language, for example, the letter “a,” and may also correspond to other additional characters, such as another letter or the letter with an accent option, e.g., the character “ä,” or other characters with accent options. Because of the physical limitations (e.g., size) of the virtual keyboard, a user may find it difficult to type characters not readily available on the virtual keyboard.
Input methods for devices having multi-language environments can present unique challenges with respect to input and spelling correction which may need to be tailored to the selected language to ensure accuracy and an efficient workflow.
SUMMARY
In general, one aspect of the subject matter described in this specification can be embodied in methods that include the actions of presenting a virtual keyboard in a first region of a touch sensitive display of a device, receiving an input representing a phonetic string on the virtual keyboard, presenting the entered phonetic string in a second region of the touch sensitive display, identifying one or more candidates based on the phonetic string, presenting at least a subset of the candidates in the first region or the second region, receiving an input selecting one of the candidates, and replacing the entered phonetic string with the selected candidate. Other embodiments of this aspect include corresponding systems, apparatus, computer program products, and computer readable media.
Particular embodiments of the subject matter described in this specification can be implemented to realize one or more of the following advantages. Text in languages that require phonetic string-to-character conversion can be input more efficiently on a portable device. Error correction and word prediction techniques can be applied to entry of East Asain languages.
The details of one or more embodiments of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of an example mobile device.
FIG. 2 is a block diagram of an example implementation of the mobile device of FIG. 1.
FIGS. 3A-3F illustrate an example user interface for entering text.
FIG. 4 illustrates an example text input process.
Like reference numbers and designations in the various drawings indicate like elements.
DETAILED DESCRIPTION Example Mobile Device
FIG. 1 is a block diagram of an example mobile device 100. The mobile device 100 can be, for example, a handheld computer, a personal digital assistant, a cellular telephone, a network appliance, a camera, a smart phone, an enhanced general packet radio service (EGPRS) mobile phone, a network base station, a media player, a navigation device, an email device, a game console, or a combination of any two or more of these data processing devices or other data processing devices.
Mobile Device Overview
In some implementations, the mobile device 100 includes a touch-sensitive display 102. The touch-sensitive display 102 can implement liquid crystal display (LCD) technology, light emitting polymer display (LPD) technology, or some other display technology. The touch sensitive display 102 can be sensitive to haptic and/or tactile contact with a user.
In some implementations, the touch-sensitive display 102 can comprise a multi-touch-sensitive display 102. A multi-touch-sensitive display 102 can, for example, process multiple simultaneous touch points, including processing data related to the pressure, degree, and/or position of each touch point. Such processing facilitates gestures and interactions with multiple fingers, chording, and other interactions. Other touch-sensitive display technologies can also be used, e.g., a display in which contact is made using a stylus or other pointing device. Some examples of multi-touch-sensitive display technology are described in U.S. Pat. Nos. 6,323,846, 6,570,557, 6,677,932, and 6,888,536, each of which is incorporated by reference herein in its entirety.
In some implementations, the mobile device 100 can display one or more graphical user interfaces on the touch-sensitive display 102 for providing the user access to various system objects and for conveying information to the user. In some implementations, the graphical user interface can include one or more display objects 104, 106. In the example shown, the display objects 104, 106, are graphic representations of system objects. Some examples of system objects include device functions, applications, windows, files, alerts, events, or other identifiable system objects.
Example Mobile Device Functionality
In some implementations, the mobile device 100 can implement multiple device functionalities, such as a telephony device, as indicated by a phone object 110; an e-mail device, as indicated by the e-mail object 112; a network data communication device, as indicated by the Web object 114; a Wi-Fi base station device (not shown); and a media processing device, as indicated by the media player object 116. In some implementations, particular display objects 104, e.g., the phone object 110, the e-mail object 112, the Web object 114, and the media player object 116, can be displayed in a menu bar 118. In some implementations, device functionalities can be accessed from a top-level graphical user interface, such as the graphical user interface illustrated in FIG. 1. Touching one of the objects 110, 112, 114, or 116 can, for example, invoke corresponding functionality.
In some implementations, the mobile device 100 can implement network distribution functionality. For example, the functionality can enable the user to take the mobile device 100 and provide access to its associated network while traveling. In particular, the mobile device 100 can extend Internet access (e.g., Wi-Fi) to other wireless devices in the vicinity. For example, mobile device 100 can be configured as a base station for one or more devices. As such, mobile device 100 can grant or deny network access to other wireless devices.
In some implementations, upon invocation of device functionality, the graphical user interface of the mobile device 100 changes, or is augmented or replaced with another user interface or user interface elements, to facilitate user access to particular functions associated with the corresponding device functionality. For example, in response to a user touching the phone object 110, the graphical user interface of the touch-sensitive display 102 may present display objects related to various phone functions; likewise, touching of the email object 112 may cause the graphical user interface to present display objects related to various e-mail functions; touching the Web object 114 may cause the graphical user interface to present display objects related to various Web-surfing functions; and touching the media player object 116 may cause the graphical user interface to present display objects related to various media processing functions.
In some implementations, the top-level graphical user interface environment or state of FIG. 1 can be restored by pressing a button 120 located near the bottom of the mobile device 100. In some implementations, each corresponding device functionality may have corresponding “home” display objects displayed on the touch-sensitive display 102, and the graphical user interface environment of FIG. 1 can be restored by pressing the “home” display object.
In some implementations, the top-level graphical user interface can include additional display objects 106, such as a short messaging service (SMS) object 130, a calendar object 132, a photos object 134, a camera object 136, a calculator object 138, a stocks object 140, a weather object 142, a maps object 144, a notes object 146, a clock object 148, an address book object 150, and a settings object 152. Touching the SMS display object 130 can, for example, invoke an SMS messaging environment and supporting functionality; likewise, each selection of a display object 132, 134, 136, 138, 140, 142, 144, 146, 148, 150, and 152 can invoke a corresponding object environment and functionality.
Additional and/or different display objects can also be displayed in the graphical user interface of FIG. 1. For example, if the device 100 is functioning as a base station for other devices, one or more “connection” objects may appear in the graphical user interface to indicate the connection. In some implementations, the display objects 106 can be configured by a user, e.g., a user may specify which display objects 106 are displayed, and/or may download additional applications or other software that provides other functionalities and corresponding display objects.
In some implementations, the mobile device 100 can include one or more input/output (I/O) devices and/or sensor devices. For example, a speaker 160 and a microphone 162 can be included to facilitate voice-enabled functionalities, such as phone and voice mail functions. In some implementations, an up/down button 184 for volume control of the speaker 160 and the microphone 162 can be included. The mobile device 100 can also include an on/off button 182 for a ring indicator of incoming phone calls. In some implementations, a loud speaker 164 can be included to facilitate hands-free voice functionalities, such as speaker phone functions. An audio jack 166 can also be included for use of headphones and/or a microphone.
In some implementations, a proximity sensor 168 can be included to facilitate the detection of the user positioning the mobile device 100 proximate to the user's ear and, in response, to disengage the touch-sensitive display 102 to prevent accidental function invocations. In some implementations, the touch-sensitive display 102 can be turned off to conserve additional power when the mobile device 100 is proximate to the user's ear.
Other sensors can also be used. For example, in some implementations, an ambient light sensor 170 can be utilized to facilitate adjusting the brightness of the touch-sensitive display 102. In some implementations, an accelerometer 172 can be utilized to detect movement of the mobile device 100, as indicated by the directional arrow 174. Accordingly, display objects and/or media can be presented according to a detected orientation, e.g., portrait or landscape. In some implementations, the mobile device 100 may include circuitry and sensors for supporting a location determining capability, such as that provided by the global positioning system (GPS) or other positioning systems (e.g., systems using Wi-Fi access points, television signals, cellular grids, Uniform Resource Locators (URLs)). In some implementations, a positioning system (e.g., a GPS receiver) can be integrated into the mobile device 100 or provided as a separate device that can be coupled to the mobile device 100 through an interface (e.g., port device 190) to provide access to location-based services.
In some implementations, a port device 190, e.g., a Universal Serial Bus (USB) port, or a docking port, or some other wired port connection, can be included. The port device 190 can, for example, be utilized to establish a wired connection to other computing devices, such as other communication devices 100, network access devices, a personal computer, a printer, a display screen, or other processing devices capable of receiving and/or transmitting data. In some implementations, the port device 190 allows the mobile device 100 to synchronize with a host device using one or more protocols, such as, for example, the TCP/IP, HTTP, UDP and any other known protocol.
The mobile device 100 can also include a camera lens and sensor 180. In some implementations, the camera lens and sensor 180 can be located on the back surface of the mobile device 100. The camera can capture still images and/or video.
The mobile device 100 can also include one or more wireless communication subsystems, such as an 802.11b/g communication device 186, and/or a Bluetooth™ communication device 188. Other communication protocols can also be supported, including other 802.x communication protocols (e.g., WiMax, Wi-Fi, 3 G), code division multiple access (CDMA), global system for mobile communications (GSM), Enhanced Data GSM Environment (EDGE), etc.
Example Mobile Device Architecture
FIG. 2 is a block diagram 200 of an example implementation of the mobile device 100 of FIG. 1. The mobile device 100 can include a memory interface 202, one or more data processors, image processors and/or central processing units 204, and a peripherals interface 206. The memory interface 202, the one or more processors 204 and/or the peripherals interface 206 can be separate components or can be integrated in one or more integrated circuits. The various components in the mobile device 100 can be coupled by one or more communication buses or signal lines.
Sensors, devices, and subsystems can be coupled to the peripherals interface 206 to facilitate multiple functionalities. For example, a motion sensor 210, a light sensor 212, and a proximity sensor 214 can be coupled to the peripherals interface 206 to facilitate the orientation, lighting, and proximity functions described with respect to FIG. 1. Other sensors 216 can also be connected to the peripherals interface 206, such as a positioning system (e.g., GPS receiver), a temperature sensor, a biometric sensor, or other sensing device, to facilitate related functionalities.
A camera subsystem 220 and an optical sensor 222, e.g., a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor, can be utilized to facilitate camera functions, such as recording photographs and video clips.
Communication functions can be facilitated through one or more wireless communication subsystems 224, which can include radio frequency receivers and transmitters and/or optical (e.g., infrared) receivers and transmitters. The specific design and implementation of the communication subsystem 224 can depend on the communication network(s) over which the mobile device 100 is intended to operate. For example, a mobile device 100 may include communication subsystems 224 designed to operate over a GSM network, a GPRS network, an EDGE network, a Wi-Fi or WiMax network, and a Bluetooth™ network. In particular, the wireless communication subsystems 224 may include hosting protocols such that the device 100 may be configured as a base station for other wireless devices.
An audio subsystem 226 can be coupled to a speaker 228 and a microphone 230 to facilitate voice-enabled functions, such as voice recognition, voice replication, digital recording, and telephony functions.
The I/O subsystem 240 can include a touch screen controller 242 and/or other input controller(s) 244. The touch-screen controller 242 can be coupled to a touch screen 246. The touch screen 246 and touch screen controller 242 can, for example, detect contact and movement or break thereof using any of a plurality of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, and surface acoustic wave technologies, as well as other proximity sensor arrays or other elements for determining one or more points of contact with the touch screen 246.
The other input controller(s) 244 can be coupled to other input/control devices 248, such as one or more buttons, rocker switches, thumb-wheel, infrared port, USB port, and/or a pointer device such as a stylus. The one or more buttons (not shown) can include an up/down button for volume control of the speaker 228 and/or the microphone 230.
In one implementation, a pressing of the button for a first duration may disengage a lock of the touch screen 246; and a pressing of the button for a second duration that is longer than the first duration may turn power to the mobile device 100 on or off. The user may be able to customize a functionality of one or more of the buttons. The touch screen 246 can, for example, also be used to implement virtual or soft buttons and/or a keyboard.
In some implementations, the mobile device 100 can present recorded audio and/or video files, such as MP3, AAC, and MPEG files. In some implementations, the mobile device 100 can include the functionality of an MP3 player, such as an iPod™. The mobile device 100 may, therefore, include a 30-pin connector that is compatible with the iPod™. Other input/output and control devices can also be used.
The memory interface 202 can be coupled to memory 250. The memory 250 can include high-speed random access memory and/or non-volatile memory, such as one or more magnetic disk storage devices, one or more optical storage devices, and/or flash memory (e.g., NAND, NOR). The memory 250 can store an operating system 252, such as Darwin, RTXC, LINUX, UNIX, OS X, WINDOWS, or an embedded operating system such as VxWorks. The operating system 252 may include instructions for handling basic system services and for performing hardware dependent tasks. In some implementations, the operating system 252 can be a kernel (e.g., UNIX kernel).
The memory 250 may also store communication instructions 254 to facilitate communicating with one or more additional devices, one or more computers and/or one or more servers. The memory 250 may include graphical user interface instructions 256 to facilitate graphic user interface processing; sensor processing instructions 258 to facilitate sensor-related processing and functions; phone instructions 260 to facilitate phone-related processes and functions; electronic messaging instructions 262 to facilitate electronic-messaging related processes and functions; web browsing instructions 264 to facilitate web browsing-related processes and functions; media processing instructions 266 to facilitate media processing-related processes and functions; GPS/Navigation instructions 268 to facilitate GPS and navigation-related processes and instructions; camera instructions 270 to facilitate camera-related processes and functions; and/or other software instructions 272 to facilitate other processes and functions, e.g., security processes and functions. The memory 250 may also store other software instructions (not shown), such as web video instructions to facilitate web video-related processes and functions; and/or web shopping instructions to facilitate web shopping-related processes and functions. In some implementations, the media processing instructions 266 are divided into audio processing instructions and video processing instructions to facilitate audio processing-related processes and functions and video processing-related processes and functions, respectively. An activation record and International Mobile Equipment Identity (IMEI) 274 or similar hardware identifier can also be stored in memory 250.
Language data 276 can also be stored in memory 250. Language data 276 can include, for example, word dictionaries (i.e., list of possible words in a language) for one or more languages, dictionaries of characters and corresponding phonetics, one or more corpuses of characters and character compounds, and so on.
Each of the above identified instructions and applications can correspond to a set of instructions for performing one or more functions described above. These instructions need not be implemented as separate software programs, procedures, or modules. The memory 250 can include additional instructions or fewer instructions. Furthermore, various functions of the mobile device 100 may be implemented in hardware and/or in software, including in one or more signal processing and/or application specific integrated circuits.
Language Input Interface
FIGS. 3A-3F illustrate an example user interface for entering multi-lingual text on mobile device 100. Mobile device 100 can display a text input area 302 and a virtual keyboard 304 on the touch-sensitive display 102. The text input area 302 can be any area where input text can be displayed, e.g., a note-taking application, an email application, and so on. In some implementations, the text input area 302 can be one or more text fields located in a document (e.g., a web page rendered in a web browser application). The virtual keyboard 304 includes one or more virtual keys 303 that each correspond to a letter in an alphabet (e.g., Latin alphabet). The virtual keyboard 304 can include a keyboard toggle key 308 for toggling between letter keys and keys for numbers, punctuation, etc. (i.e., either letter keys or numbers/punctuation keys can be displayed in the virtual keyboard 304). A user can enter text by touching the touch-sensitive display 102 on the areas of the desired keys of the virtual keyboard 304; the user selects or hits the desired keys of the virtual keyboard 304. Letters, numbers, etc. corresponding to the touched keys are displayed in the text input area 302 as unconverted current input 310-A. The user can hit the backspace key 306 to delete the last input character.
In some implementations, the mobile device 100 includes capability to input text in a non-English language using Latin alphabet virtual keyboard. For example, the mobile device 100 can include capability for inputting Chinese and/or Japanese text, including Chinese or Japanese characters and symbols, using a Latin alphabet virtual keyboard (e.g., virtual keyboard with letters arranged in a QWERTY layout). For example, the device 100 can include a Chinese or Japanese text entry mode that utilizes a Latin alphabet keyboard. A user can use the virtual keyboard to enter a phonetic string of letters representing sounds or syllables in the non-English language. For example, a user can user the virtual keyboard to type in a romanization of one or more characters or symbols in Chinese or Japanese.
For convenience, the implementations in this specification will be described in reference to entry of Japanese language text. It should be appreciated, however, that the described implementations can be applied to other non-English languages (e.g., Chinese). More generally, the described implementations can be applied to any text input interface that involves identification, presentation, and selection of candidates for inputs, regardless of language (e.g., Latin alphabet romanization to non-Latin-alphabet text, spelling and grammar correction, thesaurus features, etc.).
When a user inputs in a first letter of a phonetic string, the letter is displayed in the text input area 302 as an unconverted current input 310-A, as shown in FIG. 3A. In some implementations, the input 310-A is displayed with underlining or some other formatting (e.g., bold text, italics, highlighting). The underlining/formatting indicates that the input is a provisional input subject to conversion pending additional input from the user, whether that additional input is additional letters or a selection of a candidate by the user. For example, in FIG. 3A, the user hits the “s” key, and the letter “s” is displayed in the text input area 302 as current input 310-A with underlining.
The virtual keyboard 304 can include a “confirm” key 314 that, when hit by the user, accepts the displayed input 310-A as is. The accepted input is displayed without the underlining. For example, in FIG. 3A, the user can hit the “confirm” key 314 to accept the input string “s” as is; “s” is displayed without underlining. In some implementations, hitting of the “confirm” key 214 also adds a space after the accepted input. In some other implementations, the addition of the space after the accepted input depends on whether the accepted input is in a language where spaces separate words and/or whether the accepted input is the end of a sentence, to name a few example criteria. In some implementations, key 314 is a “space” key that, when pressed, accepts the current input as is, effectively serving as a “confirm” key.
The virtual keyboard 304 can also include a “show candidates” key 312. By hitting the “show candidates” key 312, the user can bring up a tray of candidate characters, symbols, and combinations thereof (e.g., kanji, kana combinations) with which to replace the input 310-A. The tray of candidates is further described below.
Continuing from the example input 310-A shown in FIG. 3A, the user next hits the letter “e” on the keyboard, resulting in the string “se.” The string “se” can be converted by the device 100 to the hiragana symbol “
Figure USRE046139-20160906-P00001
”, of which the string “se” is the romanization, and the hiragana symbol “
Figure USRE046139-20160906-P00001
” , is displayed as converted current input 310-B with underlining, as shown in FIG. 3B. The user can hit the “confirm” key 314 to accept the hiragana symbol “
Figure USRE046139-20160906-P00001
”, as is; “
Figure USRE046139-20160906-P00001
”, is then displayed without underlining. Alternatively, the user can hit the “show candidates” key 312 to bring up the tray of candidates related to the string “se” (e.g., characters whose phonetic readings begin with “se”).
Continuing from the example input 310-B as shown in FIG. 3B, the user next hits the “n” key, resulting in the string “sen.” The terminal “n” letter is converted to the hiragana symbol “
Figure USRE046139-20160906-P00002
”, of which the terminal “n” is the romanization, and appended to the already-converted hiragana symbol “
Figure USRE046139-20160906-P00001
”. The hiragana symbol “
Figure USRE046139-20160906-P00003
” is displayed as converted current input 310-B with underlining, as shown in FIG. 3C.
In some implementations, the device 102 can display one or more suggested candidates 318 inline for the input 310-B. The suggested candidates can include single characters, phonetic symbols (e.g., Japanese kana), and combinations of multiple characters and/or phonetic symbols. For example, in FIG. 3C, the kanji character “
Figure USRE046139-20160906-P00004
” is displayed as a suggested candidate for “
Figure USRE046139-20160906-P00003
Figure USRE046139-20160906-P00003
” (“sen”) is the onyomi reading for the kanji character “
Figure USRE046139-20160906-P00004
” In some implementations, the user can hit a suggested candidate (i.e., touch the touch-sensitive display 102 over the area of the desired suggested candidate) to select a suggested candidate, continue typing letter keys on the virtual keyboard 304 to add to the input 310-B, or hit the “show candidates” key 312 to bring up the candidates tray, among other actions. If the user selects a suggested candidate, the selected suggested candidate is displayed as accepted input 336, as shown in FIG. 3F. If the user continues typing on the letter keys on the virtual keyboard 304, the current input 310-B is extended and possible candidates for the current input 310-B are narrowed down.
In some implementations, the one or more suggested candidates 318 that are presented to the user are determined by the device 100 to be the best match for the input 310-B based on one or more criteria (e.g., frequency in the language, exact match, etc.).
In some implementations, more candidates can be displayed by the device 100 when the user hits an arrow graphical object 319 or the like on the touch-sensitive display 102. For example, when the user hits the arrow 319, a candidates tray 322 can be displayed. Alternatively, the inline suggested candidates list 318 can expand to show more candidates. The arrow 319 gives the user a hint that there are additional candidates available.
In some implementations, the user can hit the confirm key 314 once to select the first candidate of the suggested candidates 318, hit the confirm key 314 twice in quick succession to select the second candidate of the suggested candidates 318, and so on.
If the user hits the “show candidates” key 312 or the arrow 319, a candidates tray 322 can be displayed, as shown in FIG. 3D. In some implementations, the candidates tray 322 is displayed in place of the virtual keyboard 304. In some other implementations, the candidates tray 322 is displayed over all or part of the text input area 302. In some implementations, the candidates tray 322 slides over the virtual keyboard 304 or the text input area 302, and the sliding is displayed as an animated effect. When the candidates tray 322 is removed from view, the candidates tray 322 can slide off the touch-sensitive display 102.
The candidates tray 322 can include one or more candidate keys 330, each of the candidate keys 330 corresponding to a candidate for conversion of the input 310-B. A candidate (whether for the candidate keys 330 or suggested candidates 318) can be a character, a phonetic or syllabic symbol (e.g., a kana symbol), romanization, multi-character combinations forming words or phrases, multi-symbol combinations forming words or phrases, a combination of characters and symbols forming words or phrases, and so on. The candidates can include characters whose phonetic reading is or begins with the input 310-B as a reading, words that begin with the input 310-B, and so on. For example, in FIG. 3D, the candidates tray 322 includes some candidate keys 330 that correspond to kanji characters that has “
Figure USRE046139-20160906-P00003
” as a reading. In some implementations, the candidates in the candidates tray are ordered based on various criteria as to which candidate is the best candidate.
In some implementations, the candidates for the suggested candidates 318 and the candidates tray 322 are identified and ordered using predictive text and/or error correction techniques, examples of which include fuzzy matching, techniques for determining cursor position based on a finger contact, and so on. An example of a predictive text technique is disclosed in Masui, “An Efficient Text Input Method for Pen-based Computers,” in Proceedings of the ACM Conference on Human Factors in Computing Systems (CHI '98), Addison-Wesley, April 1998, pp. 328-335, the disclosure of which is incorporated by reference herein in its entirety. An example of a techniques for determining cursor position based on a finger contact is disclosed in U.S. patent application Ser. No. 11/850,015, titled “Methods for Determining a Cursor Position from a Finger Contact with a Touch Screen Display,” filed Sep. 4, 2007, the disclosure of which is incorporated by reference herein in its entirety.
In some implementations, if the candidates tray 322 is displayed over the virtual keyboard 304, the candidates tray 322 can also include a keyboard switch key 328 for switching back to the virtual keyboard 304. The candidates tray 322 can also include back candidates key 326 and/or next candidates key 324 for moving back and forth between sets of candidate keys 330 within the candidates tray 322. In some implementations, the candidates tray 322 also includes the confirm key 314.
The user can hit a candidate key 330 to replace the input 310-B with the candidate corresponding to the hit candidate key 330. For example, from FIG. 3D, if the user hits the key that corresponds to the candidate character “
Figure USRE046139-20160906-P00005
” (key 332), the input 310-B is replaced with the character “
Figure USRE046139-20160906-P00003
” The character “
Figure USRE046139-20160906-P00003
” is displayed as accepted input 336, as shown in FIG. 3E. In FIG. 3E, the candidates tray 322 reverts back to virtual keyboard 304. The virtual keyboard 304 can include a “space” key 334 and a “return” key 332 in place of “confirm” key 314 and show candidate key 312, respectively. From FIG. 3F, the user can enter a new phonetic string input.
In some implementations, the virtual keyboard 304 can include a key for switching between multiple input keyboards for various languages.
In some implementations, the candidates tray 322 includes a cancel key 331 for reverting back to the virtual keyboard 304 from the candidates tray 322 without selecting a candidate.
In some implementations, a candidate in the suggested candidates 318 or candidates tray 322 is highlighted as the “currently selected” candidate. When the suggested candidates 318 or candidates tray 322 is first displayed after an input of a phonetic string, the initial highlighted candidate can be the phonetic string itself in the suggested candidates 318 or candidates tray 322 or the “best” candidate. Key 312 can be a “next candidate” key, where a press of the key moves the highlighting to the next candidate. In some implementations, there can be a “previous candidate” key to move the highlighting backward to a previous candidate. The confirm key 314 can be used to accept the highlighted candidate.
In some other implementations, when the user inputs a phonetic sting, no candidate is automatically selected or highlighted by default; the user can hit the confirm key 314 to accept the phonetic string as is. The user can hit the next candidate key (and optionally a previous candidate key) to move through the candidates and highlight one of them. As different candidates are highlighted, the current input 310-B changes to show the currently highlighted candidate, while still displayed with underlining or other formatting to indicate that the current input 310-B is still provisional. Hitting a return key (e.g., return key 332) confirms the currently selected candidate or the phonetic string (i.e., whatever phonetic string or candidate is shown in the current input 310-B). Adding more phonetic symbols by typing on the virtual keyboard 304 also automatically accepts the currently selected candidate or the phonetic string (i.e., whatever phonetic string or candidate is shown in the current input 310-B).
FIG. 4 illustrates an example text input process 400. For convenience, the process 400 will be described in reference to a device (e.g., device 100) that performs the process 400.
A virtual keyboard is displayed in a first region of a touch-sensitive display of a device (402). For example, the device displays virtual keyboard 304 on a portion of the touch-sensitive display 102.
An input is received entering a phonetic string on the virtual keyboard (404). A user can enter one or more letters using the virtual keyboard. The entered letters can constitute a phonetic string. The phonetic string can be a romanization of characters, words, and the like in a language that does not use the Latin alphabet, for example.
The input phonetic string is displayed in a second region of the display (406). The device 100 can display the phonetic string in a text input area on the touch-sensitive Display 102. In some implementations, the device 100 converts the phonetic string to, for example, symbols corresponding to the phonetic string (e.g., Japanese kana, Chinese zhuyin, etc.).
One or more candidates matching the phonetic string are identified (408). For example, the device 100 can look up the phonetic string in a dictionary, character database, or the like, and finds matching characters for the phonetic string. In some implementations, the device 100 can segment the phonetic string based on syllables or another criteria and find candidates for each of the segments.
At least a subset of the identified candidates is displayed in the first region of the touch sensitive display (410). For example, the candidates can be displayed in a candidates tray 322 that is displayed in place of the virtual keyboard 304. In some implementations, if there are more candidates than can fit in the tray 322, the user can navigates to the overflow candidates by hitting the back candidates 326 or next candidates key 324.
Input is received selecting one of the candidates (412). For example, a user can hit one of the candidate keys 330 in a candidates tray 322 to select the corresponding candidate.
The displayed phonetic string is replaced with the selected candidate (414). In some implementations, the selected candidate is displayed on the touch-sensitive display in place of the input phonetic string.
In some implementations, the virtual keyboard 304 and the candidates tray 322 can be dynamically resized based on the orientation of the touch-sensitive display 102. For example, FIGS. 3A-3F show the virtual keyboard 304 or the candidates tray 322 in portrait orientation. If the device 100, and thus the touch-sensitive display 102, is rotated to landscape orientation, the device 100 can detect the rotation and resize the keyboard 304 and the candidates tray 322 to fit the landscape width of the touch-sensitive display 102.
In some implementations, the suggested candidates 318 are displayed in the same orientation as the text input, whose orientation can vary by language. For example, if the text is displayed from left-to-right, the suggested candidates 318 are displayed from left to right. If the text is displayed from right to left, the suggested candidates 318 are displayed from right to left. If the text displayed from top to bottom, the suggested candidates 318 are displayed from top to bottom.
In some implementations, the phonetic string can be input by voice rather than typing on the virtual keyboard 304. For example, the device 100 can include a voice recognition module that receives and processes a user's voice input and generates a phonetic string based on the voice input. The device 100 can identify candidates for the phonetic string generated by the voice recognition module for selection by the user.
The disclosed and other embodiments and the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. The disclosed and other embodiments can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer-readable medium for execution by, or to control the operation of, data processing apparatus. The computer-readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more them. The term “data processing apparatus” encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them. A propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. However, a computer need not have such devices. Computer-readable media suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, the disclosed embodiments can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
The disclosed embodiments can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of what is disclosed here, or any combination of one or more such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
While this specification contains many specifics, these should not be construed as limitations on the scope of what being claims or of what may be claimed, but rather as descriptions of features specific to particular embodiments. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understand as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Particular embodiments of the subject matter described in this specification have been described. Other embodiments are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking and parallel processing may be advantageous.

Claims (108)

What is claimed is:
1. A method comprising:
presenting a virtual keyboard corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving an input on the virtual keyboard representing a phonetic string;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
replacing the entered phonetic string with the selected candidate representation.
2. The method of claim 1, wherein:
the phonetic string comprises Chinese romanization; and
the candidates comprise Chinese characters.
3. The method of claim 1, wherein:
the phonetic string comprises Japanese romanization; and
the candidates comprise one or more of the group consisting of Japanese kanji characters and Japanese kana symbols.
4. The method of claim 1, wherein the virtual keyboard comprises keys corresponding to letters of the Latin alphabet.
5. The method of claim 1, wherein the candidates comprise multi-character words.
6. The method of claim 1, wherein identifying one or more candidates based on the phonetic string comprises identifying one or more candidates using text prediction from the phonetic string.
7. The method of claim 6, wherein presenting at least a subset of the candidates comprises presenting the subset of the candidates in an order determined based on the text prediction.
8. A portable device comprising:
a touch-sensitive display;
memory;
one or more processors; and
instructions stored in the memory and configured for execution by the one or more processors, the instructions comprising instructions to:
present a virtual keyboard corresponding to a first alphabet in a first region of the touch-sensitive display of a device;
receive an input on the virtual keyboard representing a phonetic string;
present the phonetic string in a second region of the touch-sensitive display;
identify one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identify one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
present a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receive an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
replace the entered phonetic string with the selected candidate representation.
9. The device of claim 8, wherein:
the phonetic string comprises Chinese romanization; and
the candidates comprise Chinese characters.
10. The device of claim 8, wherein:
the phonetic string comprises Japanese romanization; and
the candidates comprise one or more of the group consisting of Japanese kanji characters and Japanese kana symbols.
11. The device of claim 8, wherein the virtual keyboard comprises keys corresponding to letters of the Latin alphabet.
12. The device of claim 8, wherein the candidates comprise multi-character words.
13. The device of claim 8, further comprising instructions to identify one or more candidates using text prediction from the phonetic string.
14. The device of claim 13, further comprising instructions to present the subset of the candidates in an order determined based on the text prediction.
15. A computer program product, encoded on a tangible program carrier, operable to cause a portable device to perform operations comprising:
presenting a virtual keyboard corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving an input on the virtual keyboard representing a phonetic string;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic strings wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
replacing the entered phonetic string with the selected candidate representation.
16. The program product of claim 15, wherein:
the phonetic string comprises Chinese romanization; and
the candidates comprise Chinese characters.
17. The program product of claim 15, wherein:
the phonetic string comprises Japanese romanization; and
the candidates comprise one or more of the group consisting of Japanese kanji characters and Japanese kana symbols.
18. The program product of claim 15, wherein the virtual keyboard comprises keys corresponding to letters of the Latin alphabet.
19. The program product of claim 15, wherein the candidates comprise multi-character words.
20. The program product of claim 15, wherein identifying one or more candidates based on the phonetic string comprises identifying one or more candidates using text prediction from the phonetic string.
21. The program product of claim 20, wherein presenting at least a subset of the candidates comprises presenting the subset of the candidates in an order determined based on the text prediction.
22. A method comprising:
presenting a virtual keyboard corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving an input on the virtual keyboard representing a phonetic string;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting at least a subset of the candidate representations and a subset of the additional candidate representations inline with the phonetic string in the second region, where the candidate representations are displayed according to an orientation of text in the second region;
receiving an input selecting one of the candidate representations and the additional candidate representations; and
replacing the entered phonetic string with the selected candidate representation.
23. The method of claim 1, further comprising identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets, wherein the candidate tray includes at least a subset of the additional candidate representations.
24. The method of claim 1, wherein the candidate tray further includes the phonetic string.
25. The method of claim 1, wherein the second alphabet comprises logographic characters.
26. The method of claim 1, wherein the candidate tray is presented in place of the virtual keyboard.
27. The method of claim 8, wherein the candidate tray is presented in place of the virtual keyboard.
28. The method of claim 15, wherein the candidate tray is presented in place of the virtual keyboard.
29. The method of claim 1, wherein presenting the candidate tray comprises presenting the candidate tray in the second region of the touch-sensitive display.
30. The method of claim 1, wherein replacing the entered phonetic string comprises replacing the entered phonetic string in the second region of the touch-sensitive display.
31. The method of claim 1, wherein presenting the candidate tray comprises presenting the candidate tray adjacent to the phonetic string.
32. The method of claim 1, wherein presenting the candidate tray comprises presenting the candidate tray adjacent to the phonetic string in the second region.
33. The method of claim 1, further comprising:
receiving an input on the virtual keyboard representing a second phonetic string;
presenting the second phonetic string in the second region of the touch-sensitive display; and
receiving an input confirming the second phonetic string.
34. The method of claim 1, further comprising:
presenting an option to expand the candidate tray to include a larger subset of the candidate representations.
35. The method of claim 1, further comprising:
providing a confirm key.
36. The method of claim 35, wherein the received input of a selected candidate representation comprises a number of hits to the confirm key in succession.
37. The method of claim 36, wherein each of the candidate representations presented in the candidate tray corresponds to a different number of hits of the confirm key.
38. The method of claim 1, further comprising:
providing an option of replacing the virtual keyboard in the first region with at least a subset of the candidate representations.
39. The method of claim 1, further comprising:
providing an option of presenting a different subset of the candidate representations in the candidate tray.
40. The method of claim 1, wherein presenting the phonetic string in the second region comprises:
displaying the phonetic string using a phonetic representation different from the first alphabet.
41. The method of claim 1, further comprising:
displaying a visual indicator that identifies the presented phonetic string as a provisional input.
42. The method of claim 1, wherein presenting the candidate tray comprises:
presenting the subset of candidate representations according to a text orientation associated with the second alphabet.
43. The method of claim 42, wherein the text orientation comprises a left to right orientation.
44. The method of claim 42, wherein the text orientation comprises a right to left orientation.
45. The method of claim 42, wherein the text orientation comprises a top to bottom orientation.
46. The method of claim 1, further comprising:
presenting a next candidate key configured to allow a user to select a next candidate of the one or more candidate representations.
47. The method of claim 1, further comprising:
presenting a previous candidate key configured to allow a user to select a previous candidate of the one or more candidate representations.
48. The device of claim 8, wherein the instructions to present the candidate tray include instructions to present the candidate tray in the second region of the touch-sensitive display.
49. The device of claim 8, wherein the instructions to replace the entered phonetic string include instructions to replace the entered phonetic string in the second region of the touch-sensitive display.
50. The device of claim 8, wherein the instructions to present the candidate tray include instructions to present the candidate tray adjacent to the phonetic string.
51. The device of claim 8, wherein the instructions to present the candidate tray comprise instructions to present the candidate tray adjacent to the phonetic string in the second region.
52. The device of claim 8, further comprising instructions to:
receive an input on the virtual keyboard representing a second phonetic string;
present the second phonetic string in the second region of the touch-sensitive display; and
receive an input confirming the second phonetic string.
53. The device of claim 8, further comprising instructions to:
present an option to expand the candidate tray to include a larger subset of the candidate representations.
54. The device of claim 8, further comprising instructions to:
provide a confirm key.
55. The device of claim 54, wherein the instructions to receive an input of a selected candidate representation include instructions to recognize a number of hits to the confirm key in succession.
56. The device of claim 55, further comprising instructions to:
associate each of the candidate representations presented in the candidate tray with a different number of hits of the confirm key.
57. The device of claim 8, further comprising instructions to:
provide an option of replacing the virtual keyboard in the first region with at least a subset of the candidate representations.
58. The device of claim 8, further comprising instructions to:
provide an option of presenting a different subset of the candidate representations in the candidate tray.
59. The device of claim 8 wherein the instructions to present the phonetic string in the second region comprise instructions to display the phonetic string using a phonetic representation different from the first alphabet.
60. The device of claim 8, further comprising instructions to:
display a visual indicator that identifies the presented phonetic string as a provisional input.
61. The device of claim 8, wherein the instructions to present the candidate tray comprise instructions to present the subset of candidate representations according to a text orientation associated with the second alphabet.
62. The device of claim 61, wherein the text orientation comprises a left to right orientation.
63. The device of claim 61, wherein the text orientation comprises a right to left orientation.
64. The device of claim 61, wherein the F comprises a top to bottom orientation.
65. The device of claim 8, further comprising instructions to present a next candidate key configured to allow a user to select a next candidate of the one or more candidate representations.
66. The device of claim 8, further comprising instructions to present a previous candidate key configured to allow a user to select a previous candidate of the one or more candidate representations.
67. The program product of claim 15, wherein presenting the candidate tray comprises presenting the candidate tray in the second region of the touch-sensitive display.
68. The program product of claim 15, wherein replacing the entered phonetic string comprises replacing the entered phonetic string in the second region of the touch-sensitive display.
69. The program product of claim 15, wherein presenting the candidate tray comprises presenting the candidate tray adjacent to the phonetic string.
70. The program product of claim 15, wherein presenting the candidate tray comprises presenting the candidate tray adjacent to the phonetic string in the second region.
71. The program product of claim 15, wherein the operations further comprise:
receiving an input on the virtual keyboard representing a second phonetic string;
presenting the second phonetic string in the second region of the touch-sensitive display; and
receiving an input confirming the second phonetic string.
72. The program product of claim 15, wherein the operations further comprise:
presenting an option to expand the candidate tray to include a larger subset of the candidate representations.
73. The program product of claim 15, wherein the operations further comprise:
providing a confirm key.
74. The program product of claim 73, wherein the received input of a selected candidate representation comprises a number of hits to the confirm key in succession.
75. The program product of claim 74, wherein each of the candidate representations presented in the candidate tray corresponds to a different number of hits of the confirm key.
76. The program product of claim 15, wherein the operations further comprise:
providing an option of replacing the virtual keyboard in the first region with at least a subset of the candidate representations.
77. The program product of claim 15, wherein the operations further comprise:
providing an option of presenting a different subset of the candidate representations in the candidate tray.
78. The program product of claim 15, wherein presenting the phonetic string in the second region comprises:
displaying the phonetic string using a phonetic representation different from the first alphabet.
79. The program product of claim 15, further comprising:
displaying a visual indicator that identifies the presented phonetic string as a provisional input.
80. The program product of claim 15, wherein presenting the candidate tray comprises presenting the subset of candidate representations according to a text orientation associated with the second alphabet.
81. The program product of claim 80, wherein the text orientation comprises a left to right orientation.
82. The program product of claim 80, wherein the text orientation comprises a right to left orientation.
83. The program product of claim 80, wherein the text orientation comprises a top to bottom orientation.
84. The program product of claim 15, wherein the operations further comprise:
presenting a next candidate key configured to allow a user to select a next candidate of the one or more candidate representations.
85. The program product of claim 15, wherein the operations further comprise:
presenting a previous candidate key configured to allow a user to select a previous candidate of the one or more candidate representations.
86. The method of claim 22, wherein presenting the subset of candidate representations comprises presenting a candidate tray in the second region of the touch-sensitive display.
87. The method of claim 22, wherein replacing the entered phonetic string comprises replacing the entered phonetic string in the second region of the touch-sensitive display.
88. The method of claim 22, wherein presenting the subset of the candidate representations comprises presenting the candidate representations adjacent to the phonetic string.
89. The method of claim 22, wherein presenting the subset of candidate representations comprises presenting the candidate representations adjacent to the phonetic string in the second region.
90. The method of claim 22, further comprising:
receiving an input on the virtual keyboard representing second phonetic string;
presenting the second phonetic string in the second region of the touch-sensitive display; and
receiving an input confirming the second phonetic string.
91. The method of claim 22, further comprising:
presenting an option to expand the subset of the candidate representations.
92. The method of claim 22, further comprising:
providing a confirm key.
93. The method of claim 92, wherein the received input of a selected candidate representation comprises a number of hits to the confirm key in succession.
94. The method of claim 93, wherein each of the candidate representations corresponds to a different number of hits of the confirm key.
95. The method of claim 22, further comprising:
providing an option of replacing the virtual keyboard in the first region with at least a subset of the candidate representations.
96. The method of claim 22, further comprising:
providing an option of presenting a different subset of the candidate representations.
97. The method of claim 22, wherein presenting the phonetic string in the second region comprises:
displaying the phonetic string using a phonetic representation different from the first alphabet.
98. The method of claim 22, further comprising:
displaying a visual indicator that identifies the presented phonetic string as a provisional input.
99. The method of claim 22, wherein the orientation of text comprises a left to right orientation.
100. The method of claim 22, wherein the orientation of text comprises a right to left orientation.
101. The method of claim 22, wherein the orientation of text comprises a top to bottom orientation.
102. The method of claim 22, further comprising:
presenting a next candidate key configured to allow a user to select a next candidate of the one or more candidate representations.
103. The method of claim 22, further comprising:
presenting a previous candidate key configured to allow a user to select a previous candidate of the one or more candidate representations.
104. A method comprising:
presenting a virtual keyboard corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving an input on the virtual keyboard representing a phonetic string;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
removing the presented phonetic string and presenting the selected candidate representation.
105. A non-transitory computer-readable storage medium storing one or more programs, the one or more programs comprising instructions, which when executed by an electronic device with a touch-sensitive display, cause the device to:
present a virtual keyboard corresponding to a first alphabet in a first region of the touch-sensitive display of the device;
receive an input on the virtual keyboard representing a phonetic string;
present the phonetic string in a second region of the touch-sensitive display;
identify one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identify one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
present a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receive an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
remove the presented phonetic string and present the selected candidate representation.
106. A method comprising:
presenting a virtual keyboard corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving input representing a phonetic string corresponding to the first alphabet;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
removing the presented phonetic string and presenting the selected candidate representation.
107. A method comprising:
presenting a virtual keyboard in a first region of a touch-sensitive display of a device;
receiving an input on the virtual keyboard representing a phonetic string;
presenting the phonetic string using a first alphabet in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the one or more candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
removing the presented phonetic string and presenting the selected candidate representation.
108. A method comprising:
presenting one or more virtual keys corresponding to a first alphabet in a first region of a touch-sensitive display of a device;
receiving an input on the one or more virtual keys, wherein the input represents a phonetic string;
presenting the phonetic string in a second region of the touch-sensitive display;
identifying one or more candidate representations based on the phonetic string, wherein the one or more candidate representations correspond to a second alphabet different from the first alphabet;
identifying one or more additional candidate representations based on the phonetic string in a third alphabet different from the first and second alphabets;
presenting a candidate tray including at least a subset of the candidate representations and a subset of the additional candidate representations;
receiving an input of a selected candidate representation of the candidate representations and the additional candidate representations; and
removing the presented phonetic string and presenting the selected candidate representation.
US14/516,533 2008-03-04 2014-10-16 Language input interface on a device Active 2030-07-04 USRE46139E1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US14/516,533 USRE46139E1 (en) 2008-03-04 2014-10-16 Language input interface on a device
US15/257,780 US20160370996A1 (en) 2008-03-04 2016-09-06 Language input interface on a device

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/042,309 US8289283B2 (en) 2008-03-04 2008-03-04 Language input interface on a device
US14/516,533 USRE46139E1 (en) 2008-03-04 2014-10-16 Language input interface on a device

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US12/042,309 Reissue US8289283B2 (en) 2008-03-04 2008-03-04 Language input interface on a device

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US15/257,780 Continuation US20160370996A1 (en) 2008-03-04 2016-09-06 Language input interface on a device

Publications (1)

Publication Number Publication Date
USRE46139E1 true USRE46139E1 (en) 2016-09-06

Family

ID=41053100

Family Applications (3)

Application Number Title Priority Date Filing Date
US12/042,309 Ceased US8289283B2 (en) 2008-03-04 2008-03-04 Language input interface on a device
US14/516,533 Active 2030-07-04 USRE46139E1 (en) 2008-03-04 2014-10-16 Language input interface on a device
US15/257,780 Abandoned US20160370996A1 (en) 2008-03-04 2016-09-06 Language input interface on a device

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US12/042,309 Ceased US8289283B2 (en) 2008-03-04 2008-03-04 Language input interface on a device

Family Applications After (1)

Application Number Title Priority Date Filing Date
US15/257,780 Abandoned US20160370996A1 (en) 2008-03-04 2016-09-06 Language input interface on a device

Country Status (3)

Country Link
US (3) US8289283B2 (en)
CN (1) CN101526879B (en)
HK (1) HK1137525A1 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20190332255A1 (en) * 2016-03-25 2019-10-31 Huawei Technologies Co., Ltd. Character Input Method and Apparatus, and Terminal
US10635305B2 (en) * 2018-02-01 2020-04-28 Microchip Technology Incorporated Touchscreen user interface with multi-language support
US11341962B2 (en) 2010-05-13 2022-05-24 Poltorak Technologies Llc Electronic personal interactive device

Families Citing this family (155)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080168478A1 (en) 2007-01-07 2008-07-10 Andrew Platzer Application Programming Interfaces for Scrolling
US20080168402A1 (en) 2007-01-07 2008-07-10 Christopher Blumenberg Application Programming Interfaces for Gesture Operations
US20090058823A1 (en) * 2007-09-04 2009-03-05 Apple Inc. Virtual Keyboards in Multi-Language Environment
US8661340B2 (en) 2007-09-13 2014-02-25 Apple Inc. Input methods for device having multi-language environment
US10203873B2 (en) 2007-09-19 2019-02-12 Apple Inc. Systems and methods for adaptively presenting a keyboard on a touch-sensitive display
US9110590B2 (en) 2007-09-19 2015-08-18 Typesoft Technologies, Inc. Dynamically located onscreen keyboard
US10126942B2 (en) 2007-09-19 2018-11-13 Apple Inc. Systems and methods for detecting a press on a touch-sensitive surface
US9454270B2 (en) 2008-09-19 2016-09-27 Apple Inc. Systems and methods for detecting a press on a touch-sensitive surface
US9489086B1 (en) 2013-04-29 2016-11-08 Apple Inc. Finger hover detection for improved typing
JP5034931B2 (en) * 2007-12-26 2012-09-26 ソニー株式会社 Display device, program, and recording medium
US10176827B2 (en) 2008-01-15 2019-01-08 Verint Americas Inc. Active lab
KR101499546B1 (en) * 2008-01-17 2015-03-09 삼성전자주식회사 Method and apparatus for controlling display area in touch screen device, and computer readable medium thereof
US8717305B2 (en) 2008-03-04 2014-05-06 Apple Inc. Touch event model for web pages
US8289283B2 (en) 2008-03-04 2012-10-16 Apple Inc. Language input interface on a device
US8908973B2 (en) * 2008-03-04 2014-12-09 Apple Inc. Handwritten character recognition interface
US8645827B2 (en) 2008-03-04 2014-02-04 Apple Inc. Touch event model
US8949743B2 (en) * 2008-04-22 2015-02-03 Apple Inc. Language input interface on a device
KR101111566B1 (en) * 2008-05-23 2012-02-24 삼성전자주식회사 Converting Method And Device For Interface of Portable Device
JP2009288873A (en) * 2008-05-27 2009-12-10 Ntt Docomo Inc Mobile terminal and character input method
US9355090B2 (en) 2008-05-30 2016-05-31 Apple Inc. Identification of candidate characters for text input
US8862989B2 (en) * 2008-06-25 2014-10-14 Microsoft Corporation Extensible input method editor dictionary
US8508475B2 (en) * 2008-10-24 2013-08-13 Microsoft Corporation User interface elements positioned for display
US8982105B2 (en) * 2008-12-09 2015-03-17 Sony Corporation Ergonomic user interfaces and electronic devices incorporating same
US10489434B2 (en) 2008-12-12 2019-11-26 Verint Americas Inc. Leveraging concepts with information retrieval techniques and knowledge bases
US20100171888A1 (en) * 2009-01-05 2010-07-08 Hipolito Saenz Video frame recorder
CN101770340A (en) * 2009-01-05 2010-07-07 深圳富泰宏精密工业有限公司 Electronic device and input method thereof
US9684521B2 (en) 2010-01-26 2017-06-20 Apple Inc. Systems having discrete and continuous gesture recognizers
US8285499B2 (en) 2009-03-16 2012-10-09 Apple Inc. Event recognition
US8566045B2 (en) 2009-03-16 2013-10-22 Apple Inc. Event recognition
US8564541B2 (en) * 2009-03-16 2013-10-22 Apple Inc. Zhuyin input interface on a device
US20100241983A1 (en) * 2009-03-17 2010-09-23 Walline Erin K System And Method For Accelerometer Based Information Handling System Keyboard Selection
KR101524740B1 (en) 2009-03-19 2015-06-01 구글 인코포레이티드 Input method editor
WO2010105427A1 (en) * 2009-03-19 2010-09-23 Google Inc. Input method editor
CN102439544A (en) * 2009-03-20 2012-05-02 谷歌股份有限公司 Interaction with ime computing device
GB0905457D0 (en) 2009-03-30 2009-05-13 Touchtype Ltd System and method for inputting text into electronic devices
US10191654B2 (en) 2009-03-30 2019-01-29 Touchtype Limited System and method for inputting text into electronic devices
US9189472B2 (en) * 2009-03-30 2015-11-17 Touchtype Limited System and method for inputting text into small screen devices
GB0917753D0 (en) 2009-10-09 2009-11-25 Touchtype Ltd System and method for inputting text into electronic devices
US9424246B2 (en) 2009-03-30 2016-08-23 Touchtype Ltd. System and method for inputting text into electronic devices
US7721222B1 (en) * 2009-06-10 2010-05-18 Cheman Shaik Dynamic language text generation system and method
US9110515B2 (en) * 2009-08-19 2015-08-18 Nuance Communications, Inc. Method and apparatus for text input
US8943094B2 (en) 2009-09-22 2015-01-27 Next It Corporation Apparatus, system, and method for natural language processing
US9223590B2 (en) * 2010-01-06 2015-12-29 Apple Inc. System and method for issuing commands to applications based on contextual information
US20110093497A1 (en) * 2009-10-16 2011-04-21 Poon Paul C Method and System for Data Input
KR20110064629A (en) * 2009-12-08 2011-06-15 삼성전자주식회사 Operation method and device for optional key map of portable device
CN101763217A (en) * 2009-12-15 2010-06-30 中兴通讯股份有限公司 Mobile terminal having moving Chinese input candidate box and implementation method thereof
US8621380B2 (en) * 2010-01-06 2013-12-31 Apple Inc. Apparatus and method for conditionally enabling or disabling soft buttons
US8482539B2 (en) * 2010-01-12 2013-07-09 Panasonic Corporation Electronic pen system
US9052894B2 (en) * 2010-01-15 2015-06-09 Apple Inc. API to replace a keyboard with custom controls
WO2011091594A1 (en) 2010-01-29 2011-08-04 Nokia Corporation Virtual keyboard, input method, and associated storage medium
US8782556B2 (en) * 2010-02-12 2014-07-15 Microsoft Corporation User-centric soft keyboard predictive technologies
US20110242138A1 (en) * 2010-03-31 2011-10-06 Tribble Guy L Device, Method, and Graphical User Interface with Concurrent Virtual Keyboards
EP3306454B1 (en) * 2010-05-25 2019-04-03 Sony Mobile Communications Inc. A user interface for a touch sensitive display on an electronic device
JP5525921B2 (en) * 2010-06-07 2014-06-18 株式会社リコー Mobile terminal, electronic document transmission system, server, device, character encoding method, program
CN102279652A (en) * 2010-06-11 2011-12-14 宏达国际电子股份有限公司 Electronic device and input method thereof
US8552999B2 (en) 2010-06-14 2013-10-08 Apple Inc. Control selection approximation
CN101872286B (en) * 2010-06-22 2013-06-12 宇龙计算机通信科技(深圳)有限公司 Switching method, device and mobile terminal for background of electronic calendar date
CN102375663A (en) * 2010-08-23 2012-03-14 亚旭电脑股份有限公司 Key touch type handheld data processing equipment
KR101701151B1 (en) * 2010-09-20 2017-02-02 삼성전자주식회사 Integrated Message Transmitting and Receiving Method and Apparatus Using Portable Device
US9122744B2 (en) 2010-10-11 2015-09-01 Next It Corporation System and method for providing distributed intelligent assistance
JP5782699B2 (en) * 2010-10-15 2015-09-24 ソニー株式会社 Information processing apparatus, input control method for information processing apparatus, and program
US8587547B2 (en) 2010-11-05 2013-11-19 Apple Inc. Device, method, and graphical user interface for manipulating soft keyboards
US9141285B2 (en) 2010-11-05 2015-09-22 Apple Inc. Device, method, and graphical user interface for manipulating soft keyboards
US9092132B2 (en) 2011-01-24 2015-07-28 Apple Inc. Device, method, and graphical user interface with a dynamic gesture disambiguation threshold
US8842082B2 (en) 2011-01-24 2014-09-23 Apple Inc. Device, method, and graphical user interface for navigating and annotating an electronic document
CN102096553B (en) * 2011-01-28 2013-02-13 鸿富锦精密工业(深圳)有限公司 Electronic reader and method for displaying input method thereof
US8872773B2 (en) 2011-04-05 2014-10-28 Blackberry Limited Electronic device and method of controlling same
US20120256846A1 (en) * 2011-04-05 2012-10-11 Research In Motion Limited Electronic device and method of controlling same
US20120256857A1 (en) * 2011-04-05 2012-10-11 Mak Genevieve Elizabeth Electronic device and method of controlling same
WO2012159245A1 (en) * 2011-05-20 2012-11-29 Microsoft Corporation Displaying key pinyins
US9262076B2 (en) 2011-09-12 2016-02-16 Microsoft Technology Licensing, Llc Soft keyboard interface
US8856674B2 (en) 2011-09-28 2014-10-07 Blackberry Limited Electronic device and method for character deletion
US8490008B2 (en) 2011-11-10 2013-07-16 Research In Motion Limited Touchscreen keyboard predictive display and generation of a set of characters
US9652448B2 (en) 2011-11-10 2017-05-16 Blackberry Limited Methods and systems for removing or replacing on-keyboard prediction candidates
US9310889B2 (en) 2011-11-10 2016-04-12 Blackberry Limited Touchscreen keyboard predictive display and generation of a set of characters
US9122672B2 (en) 2011-11-10 2015-09-01 Blackberry Limited In-letter word prediction for virtual keyboard
US9715489B2 (en) 2011-11-10 2017-07-25 Blackberry Limited Displaying a prediction candidate after a typing mistake
US9002699B2 (en) * 2011-11-14 2015-04-07 Microsoft Technology Licensing, Llc Adaptive input language switching
KR20130055404A (en) * 2011-11-18 2013-05-28 삼성전자주식회사 Method and apparatus for inputting character in a touch device
JP6087949B2 (en) 2011-12-12 2017-03-01 グーグル インコーポレイテッド Techniques for translating multiple consonants or vowels consisting of multiple characters into another language using a touch computing device
US9836177B2 (en) 2011-12-30 2017-12-05 Next IT Innovation Labs, LLC Providing variable responses in a virtual-assistant environment
US9557913B2 (en) 2012-01-19 2017-01-31 Blackberry Limited Virtual keyboard display having a ticker proximate to the virtual keyboard
US9152323B2 (en) 2012-01-19 2015-10-06 Blackberry Limited Virtual keyboard providing an indication of received input
EP2812777A4 (en) 2012-02-06 2015-11-25 Michael K Colby Character-string completion
DE112012000189B4 (en) 2012-02-24 2023-06-15 Blackberry Limited Touch screen keyboard for providing word predictions in partitions of the touch screen keyboard in close association with candidate letters
US8996356B1 (en) 2012-04-10 2015-03-31 Google Inc. Techniques for predictive input method editors
US9104260B2 (en) 2012-04-10 2015-08-11 Typesoft Technologies, Inc. Systems and methods for detecting a press on a touch-sensitive surface
US9201510B2 (en) 2012-04-16 2015-12-01 Blackberry Limited Method and device having touchscreen keyboard with visual cues
US9223537B2 (en) 2012-04-18 2015-12-29 Next It Corporation Conversation user interface
US10417037B2 (en) 2012-05-15 2019-09-17 Apple Inc. Systems and methods for integrating third party services with a digital assistant
CA2873240C (en) * 2012-05-16 2020-11-17 Xtreme Interactions Inc. System, device and method for processing interlaced multimodal user input
US9182233B2 (en) * 2012-05-17 2015-11-10 Robert Bosch Gmbh System and method for autocompletion and alignment of user gestures
US9207860B2 (en) 2012-05-25 2015-12-08 Blackberry Limited Method and apparatus for detecting a gesture
US9116552B2 (en) 2012-06-27 2015-08-25 Blackberry Limited Touchscreen keyboard providing selection of word predictions in partitions of the touchscreen keyboard
US9141200B2 (en) * 2012-08-01 2015-09-22 Apple Inc. Device, method, and graphical user interface for entering characters
US10838513B2 (en) * 2012-08-06 2020-11-17 Nokia Technologies Oy Responding to selection of a displayed character string
US9063653B2 (en) 2012-08-31 2015-06-23 Blackberry Limited Ranking predictions based on typing speed and typing confidence
US9524290B2 (en) 2012-08-31 2016-12-20 Blackberry Limited Scoring predictions based on prediction length and typing speed
US20140063067A1 (en) * 2012-08-31 2014-03-06 Research In Motion Limited Method to select word by swiping capacitive keyboard
US9536049B2 (en) 2012-09-07 2017-01-03 Next It Corporation Conversational virtual healthcare assistant
US8843845B2 (en) * 2012-10-16 2014-09-23 Google Inc. Multi-gesture text input prediction
US8806384B2 (en) * 2012-11-02 2014-08-12 Google Inc. Keyboard gestures for character string replacement
KR101755625B1 (en) * 2013-01-07 2017-07-07 삼성전자주식회사 Display apparatus, method for ui display thereof and computer-readable recording medium
US8832589B2 (en) 2013-01-15 2014-09-09 Google Inc. Touch keyboard using language and spatial models
US10445115B2 (en) 2013-04-18 2019-10-15 Verint Americas Inc. Virtual assistant focused user interfaces
JP5786887B2 (en) * 2013-04-22 2015-09-30 コニカミノルタ株式会社 Information processing apparatus, information processing apparatus control method, information processing apparatus control program, and operation terminal control program
US9733716B2 (en) 2013-06-09 2017-08-15 Apple Inc. Proxy gesture recognizer
US10289302B1 (en) 2013-09-09 2019-05-14 Apple Inc. Virtual keyboard animation
TWI475405B (en) * 2013-09-17 2015-03-01 Wistron Corp Electronic device and text-input interface displaying method thereof
US9529449B1 (en) * 2013-12-04 2016-12-27 Google Inc. Input method editors for indic languages
US9830044B2 (en) 2013-12-31 2017-11-28 Next It Corporation Virtual assistant team customization
KR20150128303A (en) 2014-05-09 2015-11-18 삼성전자주식회사 Method and apparatus for controlling displays
US9966065B2 (en) 2014-05-30 2018-05-08 Apple Inc. Multi-command single utterance input method
US9715875B2 (en) 2014-05-30 2017-07-25 Apple Inc. Reducing the need for manual start/end-pointing and trigger phrases
CN105242865A (en) * 2014-07-10 2016-01-13 北京三星通信技术研究有限公司 Input processing method, input processing apparatus and mobile terminal comprising apparatus
USD748632S1 (en) 2014-07-17 2016-02-02 Charles M. Curley Keyboard
USD748631S1 (en) 2014-07-17 2016-02-02 Charles M. Curley Keyboard
US20160071517A1 (en) 2014-09-09 2016-03-10 Next It Corporation Evaluating Conversation Data based on Risk Factors
EP3002669A1 (en) * 2014-09-30 2016-04-06 Advanced Digital Broadcast S.A. System and method for controlling a virtual input interface
EP3002661A1 (en) * 2014-09-30 2016-04-06 Advanced Digital Broadcast S.A. System and method for controlling a virtual input interface
US9904374B2 (en) * 2014-11-19 2018-02-27 Lenovo (Singapore) Pte. Ltd. Displaying corrected logogram input
US10460227B2 (en) 2015-05-15 2019-10-29 Apple Inc. Virtual assistant in a communication session
US10275436B2 (en) * 2015-06-01 2019-04-30 Apple Inc. Zoom enhancements to facilitate the use of touch screen devices
JP5906345B1 (en) * 2015-08-05 2016-04-20 株式会社Cygames Program, electronic device, system and control method for predicting touch target based on operation history
US10178218B1 (en) 2015-09-04 2019-01-08 Vishal Vadodaria Intelligent agent / personal virtual assistant with animated 3D persona, facial expressions, human gestures, body movements and mental states
US10802711B2 (en) * 2016-05-10 2020-10-13 Google Llc Volumetric virtual reality keyboard methods, user interface, and interactions
US10586535B2 (en) 2016-06-10 2020-03-10 Apple Inc. Intelligent digital assistant in a multi-tasking environment
GB201610984D0 (en) 2016-06-23 2016-08-10 Microsoft Technology Licensing Llc Suppression of input images
KR101683076B1 (en) * 2016-07-25 2016-12-06 삼성전자 주식회사 Operation Method And Device for Optional Key map of Portable device
US11204787B2 (en) 2017-01-09 2021-12-21 Apple Inc. Application integration with a digital assistant
JP6699630B2 (en) * 2017-06-30 2020-05-27 京セラドキュメントソリューションズ株式会社 Input device and input method
US10949614B2 (en) * 2017-09-13 2021-03-16 International Business Machines Corporation Dynamically changing words based on a distance between a first area and a second area
US11720222B2 (en) 2017-11-17 2023-08-08 International Business Machines Corporation 3D interaction input for text in augmented reality
DK179822B1 (en) 2018-06-01 2019-07-12 Apple Inc. Voice interaction at a primary device to access call functionality of a companion device
CN108983972A (en) * 2018-06-29 2018-12-11 福州大学 Brain control Chinese character input method based on stroke and association
JP2020009232A (en) * 2018-07-10 2020-01-16 京セラドキュメントソリューションズ株式会社 Symbol input device and symbol input control method
US11568175B2 (en) 2018-09-07 2023-01-31 Verint Americas Inc. Dynamic intent classification based on environment variables
US11196863B2 (en) 2018-10-24 2021-12-07 Verint Americas Inc. Method and system for virtual assistant conversations
US11475898B2 (en) 2018-10-26 2022-10-18 Apple Inc. Low-latency multi-speaker speech recognition
DK201970509A1 (en) 2019-05-06 2021-01-15 Apple Inc Spoken notifications
US11423908B2 (en) 2019-05-06 2022-08-23 Apple Inc. Interpreting spoken requests
US11475884B2 (en) 2019-05-06 2022-10-18 Apple Inc. Reducing digital assistant latency when a language is incorrectly determined
US11307752B2 (en) 2019-05-06 2022-04-19 Apple Inc. User configurable task triggers
US11140099B2 (en) 2019-05-21 2021-10-05 Apple Inc. Providing message response suggestions
US11496600B2 (en) 2019-05-31 2022-11-08 Apple Inc. Remote execution of machine-learned models
DK180129B1 (en) 2019-05-31 2020-06-02 Apple Inc. User activity shortcut suggestions
US11289073B2 (en) 2019-05-31 2022-03-29 Apple Inc. Device text to speech
US11360641B2 (en) 2019-06-01 2022-06-14 Apple Inc. Increasing the relevance of new available information
US11488406B2 (en) 2019-09-25 2022-11-01 Apple Inc. Text detection using global geometry estimators
US11295088B2 (en) 2019-11-20 2022-04-05 Apple Inc. Sanitizing word predictions
US11181988B1 (en) 2020-08-31 2021-11-23 Apple Inc. Incorporating user feedback into text prediction models via joint reward planning
EP4057259A1 (en) * 2021-03-12 2022-09-14 OMRON Corporation Character input device, character input method, and character input program
EP4060644A1 (en) * 2021-03-15 2022-09-21 OMRON Corporation Character input device, character input method, and character input program
CN114356113A (en) * 2021-12-27 2022-04-15 维沃移动通信有限公司 Input method and input device
US20230222294A1 (en) * 2022-01-12 2023-07-13 Bank Of America Corporation Anaphoric reference resolution using natural language processing and machine learning

Citations (243)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4974191A (en) 1987-07-31 1990-11-27 Syntellect Software Inc. Adaptive natural language computer interface system
US5128672A (en) 1990-10-30 1992-07-07 Apple Computer, Inc. Dynamic predictive keyboard
US5282265A (en) 1988-10-04 1994-01-25 Canon Kabushiki Kaisha Knowledge information processing system
US5379057A (en) 1988-11-14 1995-01-03 Microslate, Inc. Portable computer with touch screen and computer system employing same
US5386556A (en) 1989-03-06 1995-01-31 International Business Machines Corporation Natural language analyzing apparatus and method
US5434777A (en) 1992-05-27 1995-07-18 Apple Computer, Inc. Method and apparatus for processing natural language
US5479488A (en) 1993-03-15 1995-12-26 Bell Canada Method and apparatus for automation of directory assistance using speech recognition
US5526259A (en) 1990-01-30 1996-06-11 Hitachi, Ltd. Method and apparatus for inputting text
US5535119A (en) 1992-06-11 1996-07-09 Hitachi, Ltd. Character inputting method allowing input of a plurality of different types of character species, and information processing equipment adopting the same
JPH08272787A (en) 1995-03-29 1996-10-18 Sharp Corp Character processor
US5577241A (en) 1994-12-07 1996-11-19 Excite, Inc. Information retrieval system and method with implementation extensible query architecture
US5682539A (en) 1994-09-29 1997-10-28 Conrad; Donovan Anticipated meaning natural language interface
JPH1049272A (en) 1996-08-05 1998-02-20 Hozumi Nishie Keyboard on which touch typing operation is easy
US5727950A (en) 1996-05-22 1998-03-17 Netsage Corporation Agent based instruction system and method
US5748974A (en) 1994-12-13 1998-05-05 International Business Machines Corporation Multimodal natural language interface for cross-application tasks
US5794050A (en) 1995-01-04 1998-08-11 Intelligent Text Processing, Inc. Natural language understanding system
US5826261A (en) 1996-05-10 1998-10-20 Spencer; Graham System and method for querying multiple, distributed databases by selective sharing of local relative significance information for terms related to the query
US5895466A (en) 1997-08-19 1999-04-20 At&T Corp Automated natural language understanding customer service system
US5899972A (en) 1995-06-22 1999-05-04 Seiko Epson Corporation Interactive voice recognition method and apparatus using affirmative/negative content discrimination
US5915249A (en) 1996-06-14 1999-06-22 Excite, Inc. System and method for accelerated query evaluation of very large full-text databases
US5959629A (en) * 1996-11-25 1999-09-28 Sony Corporation Text input device and method
US5987404A (en) 1996-01-29 1999-11-16 International Business Machines Corporation Statistical natural language understanding using hidden clumpings
US6052656A (en) 1994-06-21 2000-04-18 Canon Kabushiki Kaisha Natural language processing system and method for processing input information by predicting kind thereof
JP2000112636A (en) 1998-10-07 2000-04-21 Kanazawa Engineering Systems:Kk Kana (japanese syllabary) input device
US6081750A (en) 1991-12-23 2000-06-27 Hoffberg; Steven Mark Ergonomic man-machine interface incorporating adaptive pattern recognition based control system
US6088731A (en) 1998-04-24 2000-07-11 Associative Computing, Inc. Intelligent assistant for use with a local computer and with the internet
US6115053A (en) 1994-08-02 2000-09-05 New York University Computer animation method and system for synthesizing human-like gestures and actions
US6144938A (en) 1998-05-01 2000-11-07 Sun Microsystems, Inc. Voice user interface with personality
WO2000074240A1 (en) 1999-05-27 2000-12-07 America Online Keyboard system with automatic correction
US6188999B1 (en) 1996-06-11 2001-02-13 At Home Corporation Method and system for dynamically synthesizing a computer program by differentially resolving atoms based on user context data
JP2001125896A (en) 1999-10-26 2001-05-11 Victor Co Of Japan Ltd Natural language interactive system
US6233559B1 (en) 1998-04-01 2001-05-15 Motorola, Inc. Speech control of multiple applications using applets
US6278968B1 (en) 1999-01-29 2001-08-21 Sony Corporation Method and apparatus for adaptive speech recognition hypothesis construction and selection in a spoken language translation system
US6286064B1 (en) 1997-01-24 2001-09-04 Tegic Communications, Inc. Reduced keyboard and method for simultaneous ambiguous and unambiguous text input
US6323846B1 (en) 1998-01-26 2001-11-27 University Of Delaware Method and apparatus for integrating manual input
JP2002024212A (en) 2000-07-12 2002-01-25 Mitsubishi Electric Corp Voice interaction system
US6356866B1 (en) 1998-10-07 2002-03-12 Microsoft Corporation Method for converting a phonetic character string into the text of an Asian language
JP2002108543A (en) 2000-09-21 2002-04-12 Nokia Mobile Phones Ltd Method for inputting kana character
US6421672B1 (en) 1999-07-27 2002-07-16 Verizon Services Corp. Apparatus for and method of disambiguation of directory listing searches utilizing multiple selectable secondary search keys
JP3314276B2 (en) 1991-09-03 2002-08-12 エドワード・ディ・リン Multi-state multi-function key and keyboard for data or signal input to circuit board
US6434524B1 (en) 1998-09-09 2002-08-13 One Voice Technologies, Inc. Object interactive user interface using speech recognition and natural language processing
US6446076B1 (en) 1998-11-12 2002-09-03 Accenture Llp. Voice interactive web-based agent system responsive to a user location for prioritizing and formatting information
US6453292B2 (en) 1998-10-28 2002-09-17 International Business Machines Corporation Command boundary identifier for conversational natural language
JP2002325965A (en) 2001-04-27 2002-11-12 Sega Corp Input character processing method
US20020168107A1 (en) 1998-04-16 2002-11-14 International Business Machines Corporation Method and apparatus for recognizing handwritten chinese characters
US20020167545A1 (en) 2001-04-26 2002-11-14 Lg Electronics Inc. Method and apparatus for assisting data input to a portable information terminal
US6490563B2 (en) 1998-08-17 2002-12-03 Microsoft Corporation Proofreading with text to speech feedback
US6499013B1 (en) 1998-09-09 2002-12-24 One Voice Technologies, Inc. Interactive user interface using speech recognition and natural language processing
US6501937B1 (en) 1996-12-02 2002-12-31 Chi Fai Ho Learning method and system based on questioning
US6513063B1 (en) 1999-01-05 2003-01-28 Sri International Accessing network-based electronic information through scripted online interfaces using spoken input
US6523061B1 (en) 1999-01-05 2003-02-18 Sri International, Inc. System, method, and article of manufacture for agent-based navigation in a speech-based data navigation system
US6526395B1 (en) 1999-12-31 2003-02-25 Intel Corporation Application of personality models and interaction with synthetic characters in a computing system
JP2003517158A (en) 1999-11-12 2003-05-20 フェニックス ソリューションズ インコーポレーテッド Distributed real-time speech recognition system
US6567549B1 (en) * 1996-12-05 2003-05-20 Palmsource Inc. Method and apparatus for immediate response handwriting recognition system that handles multiple character sets
US6570557B1 (en) 2001-02-10 2003-05-27 Finger Works, Inc. Multi-touch system and method for emulating modifier keys via fingertip chords
US6598039B1 (en) 1999-06-08 2003-07-22 Albert-Inc. S.A. Natural language interface for searching database
US6601026B2 (en) 1999-09-17 2003-07-29 Discern Communications, Inc. Information retrieval by natural language querying
US20030160817A1 (en) 2002-01-28 2003-08-28 Takayuki Ishida Graphical user interface for an information mediation system
US6615172B1 (en) 1999-11-12 2003-09-02 Phoenix Solutions, Inc. Intelligent query engine for processing voice based queries
US6650735B2 (en) 2001-09-27 2003-11-18 Microsoft Corporation Integrated voice access to a variety of personal information services
US20030216913A1 (en) 2002-05-14 2003-11-20 Microsoft Corporation Natural input recognition tool
US6661409B2 (en) 2001-08-22 2003-12-09 Motorola, Inc. Automatically scrolling handwritten input user interface for personal digital assistants and the like
US6665640B1 (en) 1999-11-12 2003-12-16 Phoenix Solutions, Inc. Interactive speech based learning/training system formulating search queries based on natural language parsing of recognized user queries
US20040006458A1 (en) * 2002-07-03 2004-01-08 Vadim Fux Method and system of creating and using Chinese language data and user-corrected data
US6677932B1 (en) 2001-01-28 2004-01-13 Finger Works, Inc. System and method for recognizing touch typing under limited tactile feedback conditions
US6691151B1 (en) 1999-01-05 2004-02-10 Sri International Unified messaging methods and systems for communication and cooperation among distributed agents in a computing environment
US6691111B2 (en) 2000-06-30 2004-02-10 Research In Motion Limited System and method for implementing a natural language user interface
US6742021B1 (en) 1999-01-05 2004-05-25 Sri International, Inc. Navigating network-based electronic information using spoken input with multimodal error feedback
US6757718B1 (en) 1999-01-05 2004-06-29 Sri International Mobile navigation of network-based electronic information using spoken input
US6757362B1 (en) 2000-03-06 2004-06-29 Avaya Technology Corp. Personal virtual assistant
US6766179B1 (en) 1999-10-04 2004-07-20 Koninklijke Philips Electronics N.V. Cross-shape layout of chinese stroke labels with lyric
US20040140956A1 (en) * 2003-01-16 2004-07-22 Kushler Clifford A. System and method for continuous stroke word-based text input
US6778951B1 (en) 2000-08-09 2004-08-17 Concerto Software, Inc. Information retrieval method with natural language interface
US6789231B1 (en) 1999-10-05 2004-09-07 Microsoft Corporation Method and system for providing alternatives for text derived from stochastic input sources
US6792082B1 (en) 1998-09-11 2004-09-14 Comverse Ltd. Voice mail system with personal assistant provisioning
US6807574B1 (en) 1999-10-22 2004-10-19 Tellme Networks, Inc. Method and apparatus for content personalization over a telephone interface
US6810272B2 (en) 1998-01-14 2004-10-26 Nokia Mobile Phones Limited Data entry by string of possible candidate information in a hand-portable communication terminal
US20040230912A1 (en) 2003-05-13 2004-11-18 Microsoft Corporation Multiple input language selection
US6822585B1 (en) 1999-09-17 2004-11-23 Nokia Mobile Phones, Ltd. Input of symbols
US6848080B1 (en) 1999-11-05 2005-01-25 Microsoft Corporation Language input architecture for converting one text form to another text form with tolerance to spelling, typographical, and conversion errors
WO2005008899A1 (en) 2003-07-17 2005-01-27 Xrgomics Pte Ltd Letter and word choice text input method for keyboards and reduced keyboard systems
US20050024341A1 (en) 2001-05-16 2005-02-03 Synaptics, Inc. Touch screen with user interface enhancement
US20050071332A1 (en) 1998-07-15 2005-03-31 Ortega Ruben Ernesto Search query processing to identify related search terms and to correct misspellings of search terms
JP2005092441A (en) 2003-09-16 2005-04-07 Aizu:Kk Character input method
US20050080625A1 (en) 1999-11-12 2005-04-14 Bennett Ian M. Distributed real time speech recognition system
US20050099408A1 (en) * 2003-11-10 2005-05-12 Microsoft Corporation Data input panel character conversion
US6895558B1 (en) 2000-02-11 2005-05-17 Microsoft Corporation Multi-access mode electronic personal assistant
US6895380B2 (en) 2000-03-02 2005-05-17 Electro Standards Laboratories Voice actuation with contextual learning for intelligent machine control
US20050152600A1 (en) 2004-01-14 2005-07-14 International Business Machines Corporation Method and apparatus for performing handwriting recognition by analysis of stroke start and end points
US6928614B1 (en) 1998-10-13 2005-08-09 Visteon Global Technologies, Inc. Mobile office with speech recognition
US6937975B1 (en) 1998-10-08 2005-08-30 Canon Kabushiki Kaisha Apparatus and method for processing natural language
US6964023B2 (en) 2001-02-05 2005-11-08 International Business Machines Corporation System and method for multi-modal focus detection, referential ambiguity resolution and mood classification using multi-modal input
US6980949B2 (en) 2003-03-14 2005-12-27 Sonum Technologies, Inc. Natural language processor
US6996531B2 (en) 2001-03-30 2006-02-07 Comverse Ltd. Automated database assistance using a telephone for a speech based or text based multimedia communication mode
US20060053387A1 (en) 2004-07-30 2006-03-09 Apple Computer, Inc. Operation of a computer with touch screen interface
US7027974B1 (en) 2000-10-27 2006-04-11 Science Applications International Corporation Ontology-based parser for natural language processing
US7030863B2 (en) 2000-05-26 2006-04-18 America Online, Incorporated Virtual keyboard system with automatic correction
US20060085757A1 (en) 2004-07-30 2006-04-20 Apple Computer, Inc. Activating virtual keys of a touch-screen virtual keyboard
US7036128B1 (en) 1999-01-05 2006-04-25 Sri International Offices Using a community of distributed electronic agents to support a highly mobile, ambient computing environment
US7050977B1 (en) 1999-11-12 2006-05-23 Phoenix Solutions, Inc. Speech-enabled server for internet website and method
US20060117067A1 (en) 2004-11-30 2006-06-01 Oculus Info Inc. System and method for interactive visual representation of information content and relationships using layout and gestures
US20060122834A1 (en) 2004-12-03 2006-06-08 Bennett Ian M Emotion detection device & method for use in distributed systems
US7062428B2 (en) 2000-03-22 2006-06-13 Canon Kabushiki Kaisha Natural language machine interface
US20060143007A1 (en) 2000-07-24 2006-06-29 Koh V E User interaction with voice information services
US20060144211A1 (en) 2004-11-19 2006-07-06 Yoshimoto Inc. Data input device and data input method
US7092928B1 (en) 2000-07-31 2006-08-15 Quantum Leap Research, Inc. Intelligent portal engine
US7096432B2 (en) 2002-05-14 2006-08-22 Microsoft Corporation Write anywhere tool
EP1698982A2 (en) 2005-03-01 2006-09-06 Microsoft Corporation Grammatically correct contraction spelling suggestions for French
US7107204B1 (en) 2000-04-24 2006-09-12 Microsoft Corporation Computer-aided writing system and method with cross-language writing wizard
US7119794B2 (en) 2003-04-30 2006-10-10 Microsoft Corporation Character and text unit input correction system
US7127046B1 (en) 1997-09-25 2006-10-24 Verizon Laboratories Inc. Voice-activated call placement systems and methods
US7137126B1 (en) 1998-10-02 2006-11-14 International Business Machines Corporation Conversational computing via conversational virtual machine
US7137076B2 (en) 2002-07-30 2006-11-14 Microsoft Corporation Correcting recognition results associated with user input
US7136710B1 (en) 1991-12-23 2006-11-14 Hoffberg Steven M Ergonomic man-machine interface incorporating adaptive pattern recognition based control system
US20060265668A1 (en) * 2005-05-23 2006-11-23 Roope Rainisto Electronic text input involving a virtual keyboard and word completion functionality on a touch-sensitive display screen
US7177798B2 (en) 2000-04-07 2007-02-13 Rensselaer Polytechnic Institute Natural language interface using constrained intermediate dictionary of results
US20070055529A1 (en) 2005-08-31 2007-03-08 International Business Machines Corporation Hierarchical methods and apparatus for extracting user intent from spoken utterances
US7200559B2 (en) 2003-05-29 2007-04-03 Microsoft Corporation Semantic object synchronous understanding implemented with speech application language tags
CN1949158A (en) 2005-10-11 2007-04-18 摩托罗拉公司 Input of text to electronic apparatus
US20070088556A1 (en) 2005-10-17 2007-04-19 Microsoft Corporation Flexible speech-activated command and control
US20070100790A1 (en) 2005-09-08 2007-05-03 Adam Cheyer Method and apparatus for building an intelligent automated assistant
US7216073B2 (en) 2001-03-13 2007-05-08 Intelligate, Ltd. Dynamic natural language understanding
US7216080B2 (en) 2000-09-29 2007-05-08 Mindfabric Holdings Llc Natural-language voice-activated personal assistant
US20070120822A1 (en) 2005-11-30 2007-05-31 Kabushiki Kaisha Toshiba Information processing apparatus and change-over method
US7233904B2 (en) 2001-05-14 2007-06-19 Sony Computer Entertainment America, Inc. Menu-driven voice control of characters in a game environment
US20070139382A1 (en) * 2005-12-15 2007-06-21 Microsoft Corporation Smart soft keyboard
US20070185917A1 (en) 2005-11-28 2007-08-09 Anand Prahlad Systems and methods for classifying and transferring information in a storage network
CN101021763A (en) 2007-04-09 2007-08-22 庄德重 Soft keyboard layout fast inputting method on touch screen
US7290039B1 (en) 2001-02-27 2007-10-30 Microsoft Corporation Intent based processing
KR100776800B1 (en) 2006-06-16 2007-11-19 한국전자통신연구원 Method and system (apparatus) for user specific service using intelligent gadget
US20070282595A1 (en) 2006-06-06 2007-12-06 Microsoft Corporation Natural language personal information management
US20080015864A1 (en) 2001-01-12 2008-01-17 Ross Steven I Method and Apparatus for Managing Dialog Management in a Computer Conversation
US7324947B2 (en) 2001-10-03 2008-01-29 Promptu Systems Corporation Global speech user interface
US20080034032A1 (en) 2002-05-28 2008-02-07 Healey Jennifer A Methods and Systems for Authoring of Mixed-Initiative Multi-Modal Interactions and Related Browsing Mechanisms
US20080030481A1 (en) 1999-03-18 2008-02-07 602531 British Columbia Ltd. Data entry for personal computing devices
KR100810500B1 (en) 2005-12-08 2008-03-07 한국전자통신연구원 Method for enhancing usability in a spoken dialog system
US20080094356A1 (en) 2006-09-06 2008-04-24 Bas Ording Methods for Determining a Cursor Position from a Finger Contact with a Touch Screen Display
US7376556B2 (en) 1999-11-12 2008-05-20 Phoenix Solutions, Inc. Method for processing speech signal features for streaming transport
US7376648B2 (en) 2004-10-20 2008-05-20 Oracle International Corporation Computer-implemented methods and systems for entering and searching for non-Roman-alphabet characters and related search systems
US7376645B2 (en) 2004-11-29 2008-05-20 The Intellection Group, Inc. Multimodal natural language query system and architecture for processing voice and proximity-based queries
US7379874B2 (en) 2000-07-20 2008-05-27 Microsoft Corporation Middleware layer between speech related applications and engines
US7386449B2 (en) 2002-12-11 2008-06-10 Voice Enabling Systems Technology Inc. Knowledge-based flexible natural speech dialogue system
US20080140657A1 (en) 2005-02-03 2008-06-12 Behnam Azvine Document Searching Tool and Method
US7392185B2 (en) 1999-11-12 2008-06-24 Phoenix Solutions, Inc. Speech based learning/training system using semantic decoding
US7398209B2 (en) 2002-06-03 2008-07-08 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US7403888B1 (en) * 1999-11-05 2008-07-22 Microsoft Corporation Language input user interface
US7403938B2 (en) 2001-09-24 2008-07-22 Iac Search & Media, Inc. Natural language query processing
EP1949158A1 (en) 2005-11-02 2008-07-30 Stratos International, Inc. Rugged mt-mt connector
US7409337B1 (en) 2004-03-30 2008-08-05 Microsoft Corporation Natural language processing interface
US7426467B2 (en) 2000-07-24 2008-09-16 Sony Corporation System and method for supporting interactive user interface operations and storage medium
US20080228496A1 (en) 2007-03-15 2008-09-18 Microsoft Corporation Speech-centric multimodal user interface design in mobile technology
US20080247519A1 (en) 2001-10-15 2008-10-09 At&T Corp. Method for dialog management
US7447635B1 (en) 1999-10-19 2008-11-04 Sony Corporation Natural language interface control system
US7454351B2 (en) 2004-01-29 2008-11-18 Harman Becker Automotive Systems Gmbh Speech dialogue system for dialogue interruption and continuation control
KR20080109322A (en) 2007-06-12 2008-12-17 엘지전자 주식회사 Method and apparatus for providing services by comprehended user's intuited intension
US20090006343A1 (en) 2007-06-28 2009-01-01 Microsoft Corporation Machine assisted query formulation
US7475010B2 (en) 2003-09-03 2009-01-06 Lingospot, Inc. Adaptive and scalable method for resolving natural language ambiguities
US7483894B2 (en) 2006-06-07 2009-01-27 Platformation Technologies, Inc Methods and apparatus for entity search
US20090030800A1 (en) 2006-02-01 2009-01-29 Dan Grois Method and System for Searching a Data Network by Using a Virtual Assistant and for Advertising by using the same
US20090037837A1 (en) * 2007-08-03 2009-02-05 Google Inc. Language Keyboard
JP2009036999A (en) 2007-08-01 2009-02-19 Infocom Corp Interactive method using computer, interactive system, computer program and computer-readable storage medium
US20090058823A1 (en) 2007-09-04 2009-03-05 Apple Inc. Virtual Keyboards in Multi-Language Environment
US7502632B2 (en) 2004-06-25 2009-03-10 Nokia Corporation Text messaging device
US20090077464A1 (en) 2007-09-13 2009-03-19 Apple Inc. Input methods for device having multi-language environment
US20090076796A1 (en) 2007-09-18 2009-03-19 Ariadne Genomics, Inc. Natural language processing method
US7526466B2 (en) 1998-05-28 2009-04-28 Qps Tech Limited Liability Company Method and system for analysis of intended meaning of natural language
US7539656B2 (en) 2000-03-06 2009-05-26 Consona Crm Inc. System and method for providing an intelligent multi-step dialog with a user
US20090150156A1 (en) 2007-12-11 2009-06-11 Kennewick Michael R System and method for providing a natural language voice user interface in an integrated voice navigation services environment
US7548895B2 (en) 2006-06-30 2009-06-16 Microsoft Corporation Communication-prompted user assistance
US20090164441A1 (en) 2007-12-20 2009-06-25 Adam Cheyer Method and apparatus for searching using an active ontology
KR20090086805A (en) 2008-02-11 2009-08-14 이점식 Self-evolving artificial intelligent cyber robot system
US20090226091A1 (en) 2008-03-04 2009-09-10 Apple Inc. Handwriting Recognition Interface On A Device
KR100920267B1 (en) 2007-09-17 2009-10-05 한국전자통신연구원 System for voice communication analysis and method thereof
US7599918B2 (en) 2005-12-29 2009-10-06 Microsoft Corporation Dynamic search with implicit user intention mining
US20090265669A1 (en) 2008-04-22 2009-10-22 Yasuo Kida Language input interface on a device
US7616190B2 (en) 2004-05-26 2009-11-10 Microsoft Corporation Asian language input using keyboard
US7620549B2 (en) 2005-08-10 2009-11-17 Voicebox Technologies, Inc. System and method of supporting adaptive misrecognition in conversational speech
US20090295737A1 (en) 2008-05-30 2009-12-03 Deborah Eileen Goldsmith Identification of candidate characters for text input
US20090299745A1 (en) 2008-05-27 2009-12-03 Kennewick Robert A System and method for an integrated, multi-modal, multi-device natural language voice services environment
US7634409B2 (en) 2005-08-31 2009-12-15 Voicebox Technologies, Inc. Dynamic speech sharpening
US7640160B2 (en) 2005-08-05 2009-12-29 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US20100036660A1 (en) 2004-12-03 2010-02-11 Phoenix Solutions, Inc. Emotion Detection Device and Method for Use in Distributed Systems
US20100042400A1 (en) 2005-12-21 2010-02-18 Hans-Ulrich Block Method for Triggering at Least One First and Second Background Application via a Universal Language Dialog System
US7676026B1 (en) 2005-03-08 2010-03-09 Baxtech Asia Pte Ltd Desktop telephony system
US7684985B2 (en) 2002-12-10 2010-03-23 Richard Dominach Techniques for disambiguating speech input using multimodal interfaces
US7693720B2 (en) 2002-07-15 2010-04-06 Voicebox Technologies, Inc. Mobile systems and methods for responding to natural language speech utterance
US7702500B2 (en) 2004-11-24 2010-04-20 Blaedow Karen R Method and apparatus for determining the meaning of natural language
US7707027B2 (en) 2006-04-13 2010-04-27 Nuance Communications, Inc. Identification and rejection of meaningless input during natural language classification
US7711672B2 (en) 1998-05-28 2010-05-04 Lawrence Au Semantic network methods to disambiguate natural language meaning
US7716056B2 (en) 2004-09-27 2010-05-11 Robert Bosch Corporation Method and system for interactive conversational dialogue for cognitively overloaded device users
US7720674B2 (en) 2004-06-29 2010-05-18 Sap Ag Systems and methods for processing natural language queries
US7734461B2 (en) 2006-03-03 2010-06-08 Samsung Electronics Co., Ltd Apparatus for providing voice dialogue service and method of operating the same
US7752152B2 (en) 2006-03-17 2010-07-06 Microsoft Corporation Using predictive user models for language modeling on a personal device with user behavior models based on statistical modeling
US7783486B2 (en) 2002-11-22 2010-08-24 Roy Jonathan Rosser Response generator for mimicking human-computer natural language conversation
US20100217604A1 (en) 2009-02-20 2010-08-26 Voicebox Technologies, Inc. System and method for processing multi-modal device interactions in a natural language voice services environment
US7801722B2 (en) 2006-05-23 2010-09-21 Microsoft Corporation Techniques for customization of phonetic schemes
US7818176B2 (en) 2007-02-06 2010-10-19 Voicebox Technologies, Inc. System and method for selecting and presenting advertisements based on natural language processing of voice-based input
US7822608B2 (en) 2007-02-27 2010-10-26 Nuance Communications, Inc. Disambiguating a speech recognition grammar in a multimodal application
US20100280983A1 (en) 2009-04-30 2010-11-04 Samsung Electronics Co., Ltd. Apparatus and method for predicting user's intention based on multimodal information
US20100277579A1 (en) 2009-04-30 2010-11-04 Samsung Electronics Co., Ltd. Apparatus and method for detecting voice based on motion information
US20100312547A1 (en) 2009-06-05 2010-12-09 Apple Inc. Contextual voice commands
US20100318576A1 (en) 2009-06-10 2010-12-16 Samsung Electronics Co., Ltd. Apparatus and method for providing goal predictive interface
US20100332235A1 (en) 2009-06-29 2010-12-30 Abraham Ben David Intelligent home automation
US7873654B2 (en) 2005-01-24 2011-01-18 The Intellection Group, Inc. Multimodal natural language query system for processing and analyzing voice and proximity-based queries
US7881936B2 (en) 1998-12-04 2011-02-01 Tegic Communications, Inc. Multimodal disambiguation of speech recognition
US20110082688A1 (en) 2009-10-01 2011-04-07 Samsung Electronics Co., Ltd. Apparatus and Method for Analyzing Intention
US7930168B2 (en) 2005-10-04 2011-04-19 Robert Bosch Gmbh Natural language processing of disfluent sentences
US20110112921A1 (en) 2009-11-10 2011-05-12 Voicebox Technologies, Inc. System and method for providing a natural language content dedication service
US20110112827A1 (en) 2009-11-10 2011-05-12 Kennewick Robert A System and method for hybrid processing in a natural language voice services environment
US20110119049A1 (en) 2009-11-13 2011-05-19 Tatu Ylonen Oy Ltd Specializing disambiguation of a natural language expression
US7949529B2 (en) 2005-08-29 2011-05-24 Voicebox Technologies, Inc. Mobile systems and methods of supporting natural language human-machine interactions
US20110125540A1 (en) 2009-11-24 2011-05-26 Samsung Electronics Co., Ltd. Schedule management system using interactive robot and method and computer-readable medium thereof
US20110144999A1 (en) 2009-12-11 2011-06-16 Samsung Electronics Co., Ltd. Dialogue system and dialogue method thereof
US20110161076A1 (en) 2009-12-31 2011-06-30 Davis Bruce L Intuitive Computing Methods and Systems
US7974844B2 (en) 2006-03-24 2011-07-05 Kabushiki Kaisha Toshiba Apparatus, method and computer program product for recognizing speech
US7983997B2 (en) 2007-11-02 2011-07-19 Florida Institute For Human And Machine Cognition, Inc. Interactive complex task teaching system that allows for natural language input, recognizes a user's intent, and automatically performs tasks in document object model (DOM) nodes
WO2011088053A2 (en) 2010-01-18 2011-07-21 Apple Inc. Intelligent automated assistant
US20110175810A1 (en) 2010-01-15 2011-07-21 Microsoft Corporation Recognizing User Intent In Motion Capture System
US7987151B2 (en) 2001-08-10 2011-07-26 General Dynamics Advanced Info Systems, Inc. Apparatus and method for problem solving using intelligent agents
US20110184730A1 (en) 2010-01-22 2011-07-28 Google Inc. Multi-dimensional disambiguation of voice commands
KR20110113414A (en) 2010-04-09 2011-10-17 이초강 Empirical context aware computing method for robot
US8041570B2 (en) 2005-05-31 2011-10-18 Robert Bosch Corporation Dialogue management using scripts
US8055708B2 (en) 2007-06-01 2011-11-08 Microsoft Corporation Multimedia spaces
US20110279368A1 (en) 2010-05-12 2011-11-17 Microsoft Corporation Inferring user intent to engage a motion capture system
US8073681B2 (en) 2006-10-16 2011-12-06 Voicebox Technologies, Inc. System and method for a cooperative conversational voice user interface
US20110306426A1 (en) 2010-06-10 2011-12-15 Microsoft Corporation Activity Participation Based On User Intent
US20120002820A1 (en) 2010-06-30 2012-01-05 Google Removing Noise From Audio
US8095364B2 (en) 2004-06-02 2012-01-10 Tegic Communications, Inc. Multimodal disambiguation of speech recognition
US20120022787A1 (en) 2009-10-28 2012-01-26 Google Inc. Navigation Queries
US20120022870A1 (en) 2010-04-14 2012-01-26 Google, Inc. Geotagged environmental audio for enhanced speech recognition accuracy
US20120022860A1 (en) 2010-06-14 2012-01-26 Google Inc. Speech and Noise Models for Speech Recognition
US20120022869A1 (en) 2010-05-26 2012-01-26 Google, Inc. Acoustic model adaptation using geographic information
US20120022868A1 (en) 2010-01-05 2012-01-26 Google Inc. Word-Level Correction of Speech Input
US20120022874A1 (en) 2010-05-19 2012-01-26 Google Inc. Disambiguation of contact information using historical data
US20120023088A1 (en) 2009-12-04 2012-01-26 Google Inc. Location-Based Searching
US8107401B2 (en) 2004-09-30 2012-01-31 Avaya Inc. Method and apparatus for providing a virtual assistant to a communication participant
US20120034904A1 (en) 2010-08-06 2012-02-09 Google Inc. Automatically Monitoring for Voice Input Based on Context
US20120035924A1 (en) 2010-08-06 2012-02-09 Google Inc. Disambiguating input based on context
US20120035908A1 (en) 2010-08-05 2012-02-09 Google Inc. Translating Languages
US20120042343A1 (en) 2010-05-20 2012-02-16 Google Inc. Television Remote Control Data Transfer
US8165886B1 (en) 2007-10-04 2012-04-24 Great Northern Research LLC Speech interface system and method for control and interaction with applications on a computing system
US8289283B2 (en) 2008-03-04 2012-10-16 Apple Inc. Language input interface on a device
US8564541B2 (en) 2009-03-16 2013-10-22 Apple Inc. Zhuyin input interface on a device

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US77464A (en) * 1868-05-05 James p
US174333A (en) * 1876-02-29 Improvement in nozzles for oil and other cans
US226091A (en) * 1880-03-30 Circular-knitting machine

Patent Citations (329)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4974191A (en) 1987-07-31 1990-11-27 Syntellect Software Inc. Adaptive natural language computer interface system
US5282265A (en) 1988-10-04 1994-01-25 Canon Kabushiki Kaisha Knowledge information processing system
US5379057A (en) 1988-11-14 1995-01-03 Microslate, Inc. Portable computer with touch screen and computer system employing same
US5675362A (en) 1988-11-14 1997-10-07 Microslate, Inc. Portable computer with touch screen and computing system employing same
US5386556A (en) 1989-03-06 1995-01-31 International Business Machines Corporation Natural language analyzing apparatus and method
US5526259A (en) 1990-01-30 1996-06-11 Hitachi, Ltd. Method and apparatus for inputting text
US5128672A (en) 1990-10-30 1992-07-07 Apple Computer, Inc. Dynamic predictive keyboard
JP3314276B2 (en) 1991-09-03 2002-08-12 エドワード・ディ・リン Multi-state multi-function key and keyboard for data or signal input to circuit board
US7136710B1 (en) 1991-12-23 2006-11-14 Hoffberg Steven M Ergonomic man-machine interface incorporating adaptive pattern recognition based control system
US6081750A (en) 1991-12-23 2000-06-27 Hoffberg; Steven Mark Ergonomic man-machine interface incorporating adaptive pattern recognition based control system
US5434777A (en) 1992-05-27 1995-07-18 Apple Computer, Inc. Method and apparatus for processing natural language
US5608624A (en) 1992-05-27 1997-03-04 Apple Computer Inc. Method and apparatus for processing natural language
US5535119A (en) 1992-06-11 1996-07-09 Hitachi, Ltd. Character inputting method allowing input of a plurality of different types of character species, and information processing equipment adopting the same
US5479488A (en) 1993-03-15 1995-12-26 Bell Canada Method and apparatus for automation of directory assistance using speech recognition
US6052656A (en) 1994-06-21 2000-04-18 Canon Kabushiki Kaisha Natural language processing system and method for processing input information by predicting kind thereof
US6115053A (en) 1994-08-02 2000-09-05 New York University Computer animation method and system for synthesizing human-like gestures and actions
US5682539A (en) 1994-09-29 1997-10-28 Conrad; Donovan Anticipated meaning natural language interface
US5577241A (en) 1994-12-07 1996-11-19 Excite, Inc. Information retrieval system and method with implementation extensible query architecture
US5748974A (en) 1994-12-13 1998-05-05 International Business Machines Corporation Multimodal natural language interface for cross-application tasks
US5794050A (en) 1995-01-04 1998-08-11 Intelligent Text Processing, Inc. Natural language understanding system
JPH08272787A (en) 1995-03-29 1996-10-18 Sharp Corp Character processor
US5899972A (en) 1995-06-22 1999-05-04 Seiko Epson Corporation Interactive voice recognition method and apparatus using affirmative/negative content discrimination
US5987404A (en) 1996-01-29 1999-11-16 International Business Machines Corporation Statistical natural language understanding using hidden clumpings
US5826261A (en) 1996-05-10 1998-10-20 Spencer; Graham System and method for querying multiple, distributed databases by selective sharing of local relative significance information for terms related to the query
US5727950A (en) 1996-05-22 1998-03-17 Netsage Corporation Agent based instruction system and method
US6188999B1 (en) 1996-06-11 2001-02-13 At Home Corporation Method and system for dynamically synthesizing a computer program by differentially resolving atoms based on user context data
US5915249A (en) 1996-06-14 1999-06-22 Excite, Inc. System and method for accelerated query evaluation of very large full-text databases
JPH1049272A (en) 1996-08-05 1998-02-20 Hozumi Nishie Keyboard on which touch typing operation is easy
US5959629A (en) * 1996-11-25 1999-09-28 Sony Corporation Text input device and method
US6501937B1 (en) 1996-12-02 2002-12-31 Chi Fai Ho Learning method and system based on questioning
US6567549B1 (en) * 1996-12-05 2003-05-20 Palmsource Inc. Method and apparatus for immediate response handwriting recognition system that handles multiple character sets
US6286064B1 (en) 1997-01-24 2001-09-04 Tegic Communications, Inc. Reduced keyboard and method for simultaneous ambiguous and unambiguous text input
US5895466A (en) 1997-08-19 1999-04-20 At&T Corp Automated natural language understanding customer service system
US7127046B1 (en) 1997-09-25 2006-10-24 Verizon Laboratories Inc. Voice-activated call placement systems and methods
US6810272B2 (en) 1998-01-14 2004-10-26 Nokia Mobile Phones Limited Data entry by string of possible candidate information in a hand-portable communication terminal
EP0930760B1 (en) 1998-01-14 2009-03-11 Nokia Corporation Method and apparatus for inputting information
US6323846B1 (en) 1998-01-26 2001-11-27 University Of Delaware Method and apparatus for integrating manual input
US6888536B2 (en) 1998-01-26 2005-05-03 The University Of Delaware Method and apparatus for integrating manual input
US6233559B1 (en) 1998-04-01 2001-05-15 Motorola, Inc. Speech control of multiple applications using applets
US20020168107A1 (en) 1998-04-16 2002-11-14 International Business Machines Corporation Method and apparatus for recognizing handwritten chinese characters
US6735632B1 (en) 1998-04-24 2004-05-11 Associative Computing, Inc. Intelligent assistant for use with a local computer and with the internet
US6088731A (en) 1998-04-24 2000-07-11 Associative Computing, Inc. Intelligent assistant for use with a local computer and with the internet
US6334103B1 (en) 1998-05-01 2001-12-25 General Magic, Inc. Voice user interface with personality
US6144938A (en) 1998-05-01 2000-11-07 Sun Microsystems, Inc. Voice user interface with personality
US7526466B2 (en) 1998-05-28 2009-04-28 Qps Tech Limited Liability Company Method and system for analysis of intended meaning of natural language
US7711672B2 (en) 1998-05-28 2010-05-04 Lawrence Au Semantic network methods to disambiguate natural language meaning
US20050071332A1 (en) 1998-07-15 2005-03-31 Ortega Ruben Ernesto Search query processing to identify related search terms and to correct misspellings of search terms
US6490563B2 (en) 1998-08-17 2002-12-03 Microsoft Corporation Proofreading with text to speech feedback
US6434524B1 (en) 1998-09-09 2002-08-13 One Voice Technologies, Inc. Object interactive user interface using speech recognition and natural language processing
US6532444B1 (en) 1998-09-09 2003-03-11 One Voice Technologies, Inc. Network interactive user interface using speech recognition and natural language processing
US6499013B1 (en) 1998-09-09 2002-12-24 One Voice Technologies, Inc. Interactive user interface using speech recognition and natural language processing
US6792082B1 (en) 1998-09-11 2004-09-14 Comverse Ltd. Voice mail system with personal assistant provisioning
US8082153B2 (en) 1998-10-02 2011-12-20 International Business Machines Corporation Conversational computing via conversational virtual machine
US7729916B2 (en) 1998-10-02 2010-06-01 International Business Machines Corporation Conversational computing via conversational virtual machine
US7137126B1 (en) 1998-10-02 2006-11-14 International Business Machines Corporation Conversational computing via conversational virtual machine
JP2000112636A (en) 1998-10-07 2000-04-21 Kanazawa Engineering Systems:Kk Kana (japanese syllabary) input device
US6356866B1 (en) 1998-10-07 2002-03-12 Microsoft Corporation Method for converting a phonetic character string into the text of an Asian language
US6937975B1 (en) 1998-10-08 2005-08-30 Canon Kabushiki Kaisha Apparatus and method for processing natural language
US6928614B1 (en) 1998-10-13 2005-08-09 Visteon Global Technologies, Inc. Mobile office with speech recognition
US6453292B2 (en) 1998-10-28 2002-09-17 International Business Machines Corporation Command boundary identifier for conversational natural language
US6446076B1 (en) 1998-11-12 2002-09-03 Accenture Llp. Voice interactive web-based agent system responsive to a user location for prioritizing and formatting information
US7881936B2 (en) 1998-12-04 2011-02-01 Tegic Communications, Inc. Multimodal disambiguation of speech recognition
US6851115B1 (en) 1999-01-05 2005-02-01 Sri International Software-based architecture for communication and cooperation among distributed electronic agents
US6859931B1 (en) 1999-01-05 2005-02-22 Sri International Extensible software-based architecture for communication and cooperation within and between communities of distributed agents and distributed objects
US6757718B1 (en) 1999-01-05 2004-06-29 Sri International Mobile navigation of network-based electronic information using spoken input
US7036128B1 (en) 1999-01-05 2006-04-25 Sri International Offices Using a community of distributed electronic agents to support a highly mobile, ambient computing environment
US6523061B1 (en) 1999-01-05 2003-02-18 Sri International, Inc. System, method, and article of manufacture for agent-based navigation in a speech-based data navigation system
US6742021B1 (en) 1999-01-05 2004-05-25 Sri International, Inc. Navigating network-based electronic information using spoken input with multimodal error feedback
US6513063B1 (en) 1999-01-05 2003-01-28 Sri International Accessing network-based electronic information through scripted online interfaces using spoken input
US7069560B1 (en) 1999-01-05 2006-06-27 Sri International Highly scalable software-based architecture for communication and cooperation among distributed electronic agents
US6691151B1 (en) 1999-01-05 2004-02-10 Sri International Unified messaging methods and systems for communication and cooperation among distributed agents in a computing environment
US6278968B1 (en) 1999-01-29 2001-08-21 Sony Corporation Method and apparatus for adaptive speech recognition hypothesis construction and selection in a spoken language translation system
US20080030481A1 (en) 1999-03-18 2008-02-07 602531 British Columbia Ltd. Data entry for personal computing devices
WO2000074240A1 (en) 1999-05-27 2000-12-07 America Online Keyboard system with automatic correction
US20050174333A1 (en) 1999-05-27 2005-08-11 Robinson B. A. Keyboard system with automatic correction
US6598039B1 (en) 1999-06-08 2003-07-22 Albert-Inc. S.A. Natural language interface for searching database
US6421672B1 (en) 1999-07-27 2002-07-16 Verizon Services Corp. Apparatus for and method of disambiguation of directory listing searches utilizing multiple selectable secondary search keys
US6601026B2 (en) 1999-09-17 2003-07-29 Discern Communications, Inc. Information retrieval by natural language querying
US6822585B1 (en) 1999-09-17 2004-11-23 Nokia Mobile Phones, Ltd. Input of symbols
US6766179B1 (en) 1999-10-04 2004-07-20 Koninklijke Philips Electronics N.V. Cross-shape layout of chinese stroke labels with lyric
US6789231B1 (en) 1999-10-05 2004-09-07 Microsoft Corporation Method and system for providing alternatives for text derived from stochastic input sources
US7447635B1 (en) 1999-10-19 2008-11-04 Sony Corporation Natural language interface control system
US6807574B1 (en) 1999-10-22 2004-10-19 Tellme Networks, Inc. Method and apparatus for content personalization over a telephone interface
US6842767B1 (en) 1999-10-22 2005-01-11 Tellme Networks, Inc. Method and apparatus for content personalization over a telephone interface with adaptive personalization
JP2001125896A (en) 1999-10-26 2001-05-11 Victor Co Of Japan Ltd Natural language interactive system
US7403888B1 (en) * 1999-11-05 2008-07-22 Microsoft Corporation Language input user interface
US6848080B1 (en) 1999-11-05 2005-01-25 Microsoft Corporation Language input architecture for converting one text form to another text form with tolerance to spelling, typographical, and conversion errors
US7729904B2 (en) 1999-11-12 2010-06-01 Phoenix Solutions, Inc. Partial speech processing device and method for use in distributed systems
US7647225B2 (en) 1999-11-12 2010-01-12 Phoenix Solutions, Inc. Adjustable resource based speech recognition system
US7702508B2 (en) 1999-11-12 2010-04-20 Phoenix Solutions, Inc. System and method for natural language processing of query answers
US7831426B2 (en) 1999-11-12 2010-11-09 Phoenix Solutions, Inc. Network based interactive speech recognition system
US7277854B2 (en) 1999-11-12 2007-10-02 Phoenix Solutions, Inc Speech recognition system interactive agent
US20080021708A1 (en) 1999-11-12 2008-01-24 Bennett Ian M Speech recognition system interactive agent
US20050080625A1 (en) 1999-11-12 2005-04-14 Bennett Ian M. Distributed real time speech recognition system
US7873519B2 (en) 1999-11-12 2011-01-18 Phoenix Solutions, Inc. Natural language speech lattice containing semantic variants
US20080052063A1 (en) 1999-11-12 2008-02-28 Bennett Ian M Multi-language speech recognition system
EP1245023B1 (en) 1999-11-12 2011-03-02 Phoenix solutions, Inc. Distributed real time speech recognition system
US7225125B2 (en) 1999-11-12 2007-05-29 Phoenix Solutions, Inc. Speech recognition system trained with regional speech characteristics
US20050119897A1 (en) 1999-11-12 2005-06-02 Bennett Ian M. Multi-language speech recognition system
US7912702B2 (en) 1999-11-12 2011-03-22 Phoenix Solutions, Inc. Statistical language model trained with semantic variants
US7672841B2 (en) 1999-11-12 2010-03-02 Phoenix Solutions, Inc. Method for processing speech data for a distributed recognition system
US6665640B1 (en) 1999-11-12 2003-12-16 Phoenix Solutions, Inc. Interactive speech based learning/training system formulating search queries based on natural language parsing of recognized user queries
US20090157401A1 (en) 1999-11-12 2009-06-18 Bennett Ian M Semantic Decoding of User Queries
US20100235341A1 (en) 1999-11-12 2010-09-16 Phoenix Solutions, Inc. Methods and Systems for Searching Using Spoken Input and User Context Information
US7725321B2 (en) 1999-11-12 2010-05-25 Phoenix Solutions, Inc. Speech based query system using semantic decoding
US7725307B2 (en) 1999-11-12 2010-05-25 Phoenix Solutions, Inc. Query engine for processing voice based queries including semantic decoding
US7725320B2 (en) 1999-11-12 2010-05-25 Phoenix Solutions, Inc. Internet based speech recognition system with dynamic grammars
US7203646B2 (en) 1999-11-12 2007-04-10 Phoenix Solutions, Inc. Distributed internet based speech recognition system with natural language support
US20100228540A1 (en) 1999-11-12 2010-09-09 Phoenix Solutions, Inc. Methods and Systems for Query-Based Searching Using Spoken Input
US20080300878A1 (en) 1999-11-12 2008-12-04 Bennett Ian M Method For Transporting Speech Data For A Distributed Recognition System
US7657424B2 (en) 1999-11-12 2010-02-02 Phoenix Solutions, Inc. System and method for processing sentence based queries
US7050977B1 (en) 1999-11-12 2006-05-23 Phoenix Solutions, Inc. Speech-enabled server for internet website and method
US7555431B2 (en) 1999-11-12 2009-06-30 Phoenix Solutions, Inc. Method for processing speech using dynamic grammars
US7376556B2 (en) 1999-11-12 2008-05-20 Phoenix Solutions, Inc. Method for processing speech signal features for streaming transport
US7624007B2 (en) 1999-11-12 2009-11-24 Phoenix Solutions, Inc. System and method for natural language processing of sentence based queries
US6633846B1 (en) 1999-11-12 2003-10-14 Phoenix Solutions, Inc. Distributed realtime speech recognition system
US7392185B2 (en) 1999-11-12 2008-06-24 Phoenix Solutions, Inc. Speech based learning/training system using semantic decoding
US7139714B2 (en) 1999-11-12 2006-11-21 Phoenix Solutions, Inc. Adjustable resource based speech recognition system
US20100005081A1 (en) 1999-11-12 2010-01-07 Bennett Ian M Systems for natural language processing of sentence based queries
US6615172B1 (en) 1999-11-12 2003-09-02 Phoenix Solutions, Inc. Intelligent query engine for processing voice based queries
US7698131B2 (en) 1999-11-12 2010-04-13 Phoenix Solutions, Inc. Speech recognition system for client devices having differing computing capabilities
JP2003517158A (en) 1999-11-12 2003-05-20 フェニックス ソリューションズ インコーポレーテッド Distributed real-time speech recognition system
US6526395B1 (en) 1999-12-31 2003-02-25 Intel Corporation Application of personality models and interaction with synthetic characters in a computing system
US6895558B1 (en) 2000-02-11 2005-05-17 Microsoft Corporation Multi-access mode electronic personal assistant
US6895380B2 (en) 2000-03-02 2005-05-17 Electro Standards Laboratories Voice actuation with contextual learning for intelligent machine control
US7920678B2 (en) 2000-03-06 2011-04-05 Avaya Inc. Personal virtual assistant
US7539656B2 (en) 2000-03-06 2009-05-26 Consona Crm Inc. System and method for providing an intelligent multi-step dialog with a user
US6757362B1 (en) 2000-03-06 2004-06-29 Avaya Technology Corp. Personal virtual assistant
US8000453B2 (en) 2000-03-06 2011-08-16 Avaya Inc. Personal virtual assistant
US7415100B2 (en) 2000-03-06 2008-08-19 Avaya Technology Corp. Personal virtual assistant
US7062428B2 (en) 2000-03-22 2006-06-13 Canon Kabushiki Kaisha Natural language machine interface
US7177798B2 (en) 2000-04-07 2007-02-13 Rensselaer Polytechnic Institute Natural language interface using constrained intermediate dictionary of results
US7107204B1 (en) 2000-04-24 2006-09-12 Microsoft Corporation Computer-aided writing system and method with cross-language writing wizard
US7030863B2 (en) 2000-05-26 2006-04-18 America Online, Incorporated Virtual keyboard system with automatic correction
US6691111B2 (en) 2000-06-30 2004-02-10 Research In Motion Limited System and method for implementing a natural language user interface
JP2002024212A (en) 2000-07-12 2002-01-25 Mitsubishi Electric Corp Voice interaction system
US7379874B2 (en) 2000-07-20 2008-05-27 Microsoft Corporation Middleware layer between speech related applications and engines
US20060143007A1 (en) 2000-07-24 2006-06-29 Koh V E User interaction with voice information services
US7426467B2 (en) 2000-07-24 2008-09-16 Sony Corporation System and method for supporting interactive user interface operations and storage medium
US7092928B1 (en) 2000-07-31 2006-08-15 Quantum Leap Research, Inc. Intelligent portal engine
US6778951B1 (en) 2000-08-09 2004-08-17 Concerto Software, Inc. Information retrieval method with natural language interface
JP2002108543A (en) 2000-09-21 2002-04-12 Nokia Mobile Phones Ltd Method for inputting kana character
US7216080B2 (en) 2000-09-29 2007-05-08 Mindfabric Holdings Llc Natural-language voice-activated personal assistant
US7027974B1 (en) 2000-10-27 2006-04-11 Science Applications International Corporation Ontology-based parser for natural language processing
US20080015864A1 (en) 2001-01-12 2008-01-17 Ross Steven I Method and Apparatus for Managing Dialog Management in a Computer Conversation
US6677932B1 (en) 2001-01-28 2004-01-13 Finger Works, Inc. System and method for recognizing touch typing under limited tactile feedback conditions
US6964023B2 (en) 2001-02-05 2005-11-08 International Business Machines Corporation System and method for multi-modal focus detection, referential ambiguity resolution and mood classification using multi-modal input
US6570557B1 (en) 2001-02-10 2003-05-27 Finger Works, Inc. Multi-touch system and method for emulating modifier keys via fingertip chords
US7707267B2 (en) 2001-02-27 2010-04-27 Microsoft Corporation Intent based processing
US7349953B2 (en) 2001-02-27 2008-03-25 Microsoft Corporation Intent based processing
US7290039B1 (en) 2001-02-27 2007-10-30 Microsoft Corporation Intent based processing
US7840400B2 (en) 2001-03-13 2010-11-23 Intelligate, Ltd. Dynamic natural language understanding
US7216073B2 (en) 2001-03-13 2007-05-08 Intelligate, Ltd. Dynamic natural language understanding
US6996531B2 (en) 2001-03-30 2006-02-07 Comverse Ltd. Automated database assistance using a telephone for a speech based or text based multimedia communication mode
US20020167545A1 (en) 2001-04-26 2002-11-14 Lg Electronics Inc. Method and apparatus for assisting data input to a portable information terminal
US7147562B2 (en) 2001-04-27 2006-12-12 Sega Corporation Input character processing method
JP2002325965A (en) 2001-04-27 2002-11-12 Sega Corp Input character processing method
US7233904B2 (en) 2001-05-14 2007-06-19 Sony Computer Entertainment America, Inc. Menu-driven voice control of characters in a game environment
US20050024341A1 (en) 2001-05-16 2005-02-03 Synaptics, Inc. Touch screen with user interface enhancement
US7987151B2 (en) 2001-08-10 2011-07-26 General Dynamics Advanced Info Systems, Inc. Apparatus and method for problem solving using intelligent agents
US6661409B2 (en) 2001-08-22 2003-12-09 Motorola, Inc. Automatically scrolling handwritten input user interface for personal digital assistants and the like
US7917497B2 (en) 2001-09-24 2011-03-29 Iac Search & Media, Inc. Natural language query processing
US7403938B2 (en) 2001-09-24 2008-07-22 Iac Search & Media, Inc. Natural language query processing
US6650735B2 (en) 2001-09-27 2003-11-18 Microsoft Corporation Integrated voice access to a variety of personal information services
US8005679B2 (en) 2001-10-03 2011-08-23 Promptu Systems Corporation Global speech user interface
US20080120112A1 (en) 2001-10-03 2008-05-22 Adam Jordan Global speech user interface
US7324947B2 (en) 2001-10-03 2008-01-29 Promptu Systems Corporation Global speech user interface
US20080247519A1 (en) 2001-10-15 2008-10-09 At&T Corp. Method for dialog management
US20030160817A1 (en) 2002-01-28 2003-08-28 Takayuki Ishida Graphical user interface for an information mediation system
US20030216913A1 (en) 2002-05-14 2003-11-20 Microsoft Corporation Natural input recognition tool
US7096432B2 (en) 2002-05-14 2006-08-22 Microsoft Corporation Write anywhere tool
US20080034032A1 (en) 2002-05-28 2008-02-07 Healey Jennifer A Methods and Systems for Authoring of Mixed-Initiative Multi-Modal Interactions and Related Browsing Mechanisms
US7546382B2 (en) 2002-05-28 2009-06-09 International Business Machines Corporation Methods and systems for authoring of mixed-initiative multi-modal interactions and related browsing mechanisms
US8112275B2 (en) 2002-06-03 2012-02-07 Voicebox Technologies, Inc. System and method for user-specific speech recognition
US20100286985A1 (en) 2002-06-03 2010-11-11 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US7502738B2 (en) 2002-06-03 2009-03-10 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US7809570B2 (en) 2002-06-03 2010-10-05 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US7398209B2 (en) 2002-06-03 2008-07-08 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US20090171664A1 (en) 2002-06-03 2009-07-02 Kennewick Robert A Systems and methods for responding to natural language speech utterance
US8015006B2 (en) 2002-06-03 2011-09-06 Voicebox Technologies, Inc. Systems and methods for processing natural language speech utterances with context-specific domain agents
US20100204986A1 (en) 2002-06-03 2010-08-12 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US20040006458A1 (en) * 2002-07-03 2004-01-08 Vadim Fux Method and system of creating and using Chinese language data and user-corrected data
US20100145700A1 (en) 2002-07-15 2010-06-10 Voicebox Technologies, Inc. Mobile systems and methods for responding to natural language speech utterance
US7693720B2 (en) 2002-07-15 2010-04-06 Voicebox Technologies, Inc. Mobile systems and methods for responding to natural language speech utterance
US7137076B2 (en) 2002-07-30 2006-11-14 Microsoft Corporation Correcting recognition results associated with user input
US7783486B2 (en) 2002-11-22 2010-08-24 Roy Jonathan Rosser Response generator for mimicking human-computer natural language conversation
US7684985B2 (en) 2002-12-10 2010-03-23 Richard Dominach Techniques for disambiguating speech input using multimodal interfaces
US7386449B2 (en) 2002-12-11 2008-06-10 Voice Enabling Systems Technology Inc. Knowledge-based flexible natural speech dialogue system
US20040140956A1 (en) * 2003-01-16 2004-07-22 Kushler Clifford A. System and method for continuous stroke word-based text input
US6980949B2 (en) 2003-03-14 2005-12-27 Sonum Technologies, Inc. Natural language processor
US7119794B2 (en) 2003-04-30 2006-10-10 Microsoft Corporation Character and text unit input correction system
US20040230912A1 (en) 2003-05-13 2004-11-18 Microsoft Corporation Multiple input language selection
US7200559B2 (en) 2003-05-29 2007-04-03 Microsoft Corporation Semantic object synchronous understanding implemented with speech application language tags
WO2005008899A1 (en) 2003-07-17 2005-01-27 Xrgomics Pte Ltd Letter and word choice text input method for keyboards and reduced keyboard systems
US7475010B2 (en) 2003-09-03 2009-01-06 Lingospot, Inc. Adaptive and scalable method for resolving natural language ambiguities
JP2005092441A (en) 2003-09-16 2005-04-07 Aizu:Kk Character input method
US20050099408A1 (en) * 2003-11-10 2005-05-12 Microsoft Corporation Data input panel character conversion
WO2005064587A8 (en) 2003-12-22 2007-08-16 America Online Inc Virtual keyboard system with automatic correction
US20060274051A1 (en) 2003-12-22 2006-12-07 Tegic Communications, Inc. Virtual Keyboard Systems with Automatic Correction
US20050152600A1 (en) 2004-01-14 2005-07-14 International Business Machines Corporation Method and apparatus for performing handwriting recognition by analysis of stroke start and end points
US7454351B2 (en) 2004-01-29 2008-11-18 Harman Becker Automotive Systems Gmbh Speech dialogue system for dialogue interruption and continuation control
US7409337B1 (en) 2004-03-30 2008-08-05 Microsoft Corporation Natural language processing interface
US7616190B2 (en) 2004-05-26 2009-11-10 Microsoft Corporation Asian language input using keyboard
US8095364B2 (en) 2004-06-02 2012-01-10 Tegic Communications, Inc. Multimodal disambiguation of speech recognition
US7693552B2 (en) 2004-06-25 2010-04-06 Nokia Corporation Text messaging device
US7502632B2 (en) 2004-06-25 2009-03-10 Nokia Corporation Text messaging device
US7720674B2 (en) 2004-06-29 2010-05-18 Sap Ag Systems and methods for processing natural language queries
US20060053387A1 (en) 2004-07-30 2006-03-09 Apple Computer, Inc. Operation of a computer with touch screen interface
US20060085757A1 (en) 2004-07-30 2006-04-20 Apple Computer, Inc. Activating virtual keys of a touch-screen virtual keyboard
US7716056B2 (en) 2004-09-27 2010-05-11 Robert Bosch Corporation Method and system for interactive conversational dialogue for cognitively overloaded device users
US8107401B2 (en) 2004-09-30 2012-01-31 Avaya Inc. Method and apparatus for providing a virtual assistant to a communication participant
US7376648B2 (en) 2004-10-20 2008-05-20 Oracle International Corporation Computer-implemented methods and systems for entering and searching for non-Roman-alphabet characters and related search systems
US20060144211A1 (en) 2004-11-19 2006-07-06 Yoshimoto Inc. Data input device and data input method
US7702500B2 (en) 2004-11-24 2010-04-20 Blaedow Karen R Method and apparatus for determining the meaning of natural language
US7376645B2 (en) 2004-11-29 2008-05-20 The Intellection Group, Inc. Multimodal natural language query system and architecture for processing voice and proximity-based queries
US20060117067A1 (en) 2004-11-30 2006-06-01 Oculus Info Inc. System and method for interactive visual representation of information content and relationships using layout and gestures
US20060122834A1 (en) 2004-12-03 2006-06-08 Bennett Ian M Emotion detection device & method for use in distributed systems
US20100036660A1 (en) 2004-12-03 2010-02-11 Phoenix Solutions, Inc. Emotion Detection Device and Method for Use in Distributed Systems
US7873654B2 (en) 2005-01-24 2011-01-18 The Intellection Group, Inc. Multimodal natural language query system for processing and analyzing voice and proximity-based queries
US20080140657A1 (en) 2005-02-03 2008-06-12 Behnam Azvine Document Searching Tool and Method
EP1698982A2 (en) 2005-03-01 2006-09-06 Microsoft Corporation Grammatically correct contraction spelling suggestions for French
US7676026B1 (en) 2005-03-08 2010-03-09 Baxtech Asia Pte Ltd Desktop telephony system
US20060265668A1 (en) * 2005-05-23 2006-11-23 Roope Rainisto Electronic text input involving a virtual keyboard and word completion functionality on a touch-sensitive display screen
US8041570B2 (en) 2005-05-31 2011-10-18 Robert Bosch Corporation Dialogue management using scripts
US7640160B2 (en) 2005-08-05 2009-12-29 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US20110131045A1 (en) 2005-08-05 2011-06-02 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US7917367B2 (en) 2005-08-05 2011-03-29 Voicebox Technologies, Inc. Systems and methods for responding to natural language speech utterance
US20110131036A1 (en) 2005-08-10 2011-06-02 Voicebox Technologies, Inc. System and method of supporting adaptive misrecognition in conversational speech
US20100023320A1 (en) 2005-08-10 2010-01-28 Voicebox Technologies, Inc. System and method of supporting adaptive misrecognition in conversational speech
US7620549B2 (en) 2005-08-10 2009-11-17 Voicebox Technologies, Inc. System and method of supporting adaptive misrecognition in conversational speech
US7949529B2 (en) 2005-08-29 2011-05-24 Voicebox Technologies, Inc. Mobile systems and methods of supporting natural language human-machine interactions
US20110231182A1 (en) 2005-08-29 2011-09-22 Voicebox Technologies, Inc. Mobile systems and methods of supporting natural language human-machine interactions
US20110231188A1 (en) 2005-08-31 2011-09-22 Voicebox Technologies, Inc. System and method for providing an acoustic grammar to dynamically sharpen speech interpretation
US7983917B2 (en) 2005-08-31 2011-07-19 Voicebox Technologies, Inc. Dynamic speech sharpening
US20070055529A1 (en) 2005-08-31 2007-03-08 International Business Machines Corporation Hierarchical methods and apparatus for extracting user intent from spoken utterances
US7634409B2 (en) 2005-08-31 2009-12-15 Voicebox Technologies, Inc. Dynamic speech sharpening
US8069046B2 (en) 2005-08-31 2011-11-29 Voicebox Technologies, Inc. Dynamic speech sharpening
US20080221903A1 (en) 2005-08-31 2008-09-11 International Business Machines Corporation Hierarchical Methods and Apparatus for Extracting User Intent from Spoken Utterances
US20070100790A1 (en) 2005-09-08 2007-05-03 Adam Cheyer Method and apparatus for building an intelligent automated assistant
WO2007037809A1 (en) 2005-09-16 2007-04-05 Apple, Inc. Operation of a computer with touch screen interface
US7930168B2 (en) 2005-10-04 2011-04-19 Robert Bosch Gmbh Natural language processing of disfluent sentences
WO2007047188A2 (en) 2005-10-11 2007-04-26 Motorola Inc. Entering text into an electronic device
CN1949158A (en) 2005-10-11 2007-04-18 摩托罗拉公司 Input of text to electronic apparatus
US20070088556A1 (en) 2005-10-17 2007-04-19 Microsoft Corporation Flexible speech-activated command and control
EP1949158A1 (en) 2005-11-02 2008-07-30 Stratos International, Inc. Rugged mt-mt connector
US20070185917A1 (en) 2005-11-28 2007-08-09 Anand Prahlad Systems and methods for classifying and transferring information in a storage network
US20070120822A1 (en) 2005-11-30 2007-05-31 Kabushiki Kaisha Toshiba Information processing apparatus and change-over method
KR100810500B1 (en) 2005-12-08 2008-03-07 한국전자통신연구원 Method for enhancing usability in a spoken dialog system
WO2007070223A1 (en) 2005-12-15 2007-06-21 Microsoft Corporation Smart soft keyboard
US20070139382A1 (en) * 2005-12-15 2007-06-21 Microsoft Corporation Smart soft keyboard
US20100042400A1 (en) 2005-12-21 2010-02-18 Hans-Ulrich Block Method for Triggering at Least One First and Second Background Application via a Universal Language Dialog System
US7599918B2 (en) 2005-12-29 2009-10-06 Microsoft Corporation Dynamic search with implicit user intention mining
US20090030800A1 (en) 2006-02-01 2009-01-29 Dan Grois Method and System for Searching a Data Network by Using a Virtual Assistant and for Advertising by using the same
US7734461B2 (en) 2006-03-03 2010-06-08 Samsung Electronics Co., Ltd Apparatus for providing voice dialogue service and method of operating the same
US7752152B2 (en) 2006-03-17 2010-07-06 Microsoft Corporation Using predictive user models for language modeling on a personal device with user behavior models based on statistical modeling
US7974844B2 (en) 2006-03-24 2011-07-05 Kabushiki Kaisha Toshiba Apparatus, method and computer program product for recognizing speech
US7707027B2 (en) 2006-04-13 2010-04-27 Nuance Communications, Inc. Identification and rejection of meaningless input during natural language classification
US7801722B2 (en) 2006-05-23 2010-09-21 Microsoft Corporation Techniques for customization of phonetic schemes
US20070282595A1 (en) 2006-06-06 2007-12-06 Microsoft Corporation Natural language personal information management
US7483894B2 (en) 2006-06-07 2009-01-27 Platformation Technologies, Inc Methods and apparatus for entity search
US20090100049A1 (en) 2006-06-07 2009-04-16 Platformation Technologies, Inc. Methods and Apparatus for Entity Search
KR100776800B1 (en) 2006-06-16 2007-11-19 한국전자통신연구원 Method and system (apparatus) for user specific service using intelligent gadget
US7548895B2 (en) 2006-06-30 2009-06-16 Microsoft Corporation Communication-prompted user assistance
US20080094356A1 (en) 2006-09-06 2008-04-24 Bas Ording Methods for Determining a Cursor Position from a Finger Contact with a Touch Screen Display
US8073681B2 (en) 2006-10-16 2011-12-06 Voicebox Technologies, Inc. System and method for a cooperative conversational voice user interface
US20120022857A1 (en) 2006-10-16 2012-01-26 Voicebox Technologies, Inc. System and method for a cooperative conversational voice user interface
US20100299142A1 (en) 2007-02-06 2010-11-25 Voicebox Technologies, Inc. System and method for selecting and presenting advertisements based on natural language processing of voice-based input
US7818176B2 (en) 2007-02-06 2010-10-19 Voicebox Technologies, Inc. System and method for selecting and presenting advertisements based on natural language processing of voice-based input
US7822608B2 (en) 2007-02-27 2010-10-26 Nuance Communications, Inc. Disambiguating a speech recognition grammar in a multimodal application
US20080228496A1 (en) 2007-03-15 2008-09-18 Microsoft Corporation Speech-centric multimodal user interface design in mobile technology
CN101021763A (en) 2007-04-09 2007-08-22 庄德重 Soft keyboard layout fast inputting method on touch screen
US8055708B2 (en) 2007-06-01 2011-11-08 Microsoft Corporation Multimedia spaces
KR20080109322A (en) 2007-06-12 2008-12-17 엘지전자 주식회사 Method and apparatus for providing services by comprehended user's intuited intension
US20090006343A1 (en) 2007-06-28 2009-01-01 Microsoft Corporation Machine assisted query formulation
JP2009036999A (en) 2007-08-01 2009-02-19 Infocom Corp Interactive method using computer, interactive system, computer program and computer-readable storage medium
US20090037837A1 (en) * 2007-08-03 2009-02-05 Google Inc. Language Keyboard
US20090058823A1 (en) 2007-09-04 2009-03-05 Apple Inc. Virtual Keyboards in Multi-Language Environment
WO2009032483A1 (en) 2007-09-04 2009-03-12 Apple Inc. Virtual keyboards in multi-language environment
US20090077464A1 (en) 2007-09-13 2009-03-19 Apple Inc. Input methods for device having multi-language environment
KR100920267B1 (en) 2007-09-17 2009-10-05 한국전자통신연구원 System for voice communication analysis and method thereof
US20090076796A1 (en) 2007-09-18 2009-03-19 Ariadne Genomics, Inc. Natural language processing method
US8165886B1 (en) 2007-10-04 2012-04-24 Great Northern Research LLC Speech interface system and method for control and interaction with applications on a computing system
US7983997B2 (en) 2007-11-02 2011-07-19 Florida Institute For Human And Machine Cognition, Inc. Interactive complex task teaching system that allows for natural language input, recognizes a user's intent, and automatically performs tasks in document object model (DOM) nodes
US20090150156A1 (en) 2007-12-11 2009-06-11 Kennewick Michael R System and method for providing a natural language voice user interface in an integrated voice navigation services environment
US20090164441A1 (en) 2007-12-20 2009-06-25 Adam Cheyer Method and apparatus for searching using an active ontology
KR20090086805A (en) 2008-02-11 2009-08-14 이점식 Self-evolving artificial intelligent cyber robot system
WO2009111138A1 (en) 2008-03-04 2009-09-11 Apple Inc. Handwriting recognition interface on a device
US8289283B2 (en) 2008-03-04 2012-10-16 Apple Inc. Language input interface on a device
US20090226091A1 (en) 2008-03-04 2009-09-10 Apple Inc. Handwriting Recognition Interface On A Device
US20090265669A1 (en) 2008-04-22 2009-10-22 Yasuo Kida Language input interface on a device
US20090299745A1 (en) 2008-05-27 2009-12-03 Kennewick Robert A System and method for an integrated, multi-modal, multi-device natural language voice services environment
US20090295737A1 (en) 2008-05-30 2009-12-03 Deborah Eileen Goldsmith Identification of candidate characters for text input
US20100217604A1 (en) 2009-02-20 2010-08-26 Voicebox Technologies, Inc. System and method for processing multi-modal device interactions in a natural language voice services environment
US8564541B2 (en) 2009-03-16 2013-10-22 Apple Inc. Zhuyin input interface on a device
US20100277579A1 (en) 2009-04-30 2010-11-04 Samsung Electronics Co., Ltd. Apparatus and method for detecting voice based on motion information
US20100280983A1 (en) 2009-04-30 2010-11-04 Samsung Electronics Co., Ltd. Apparatus and method for predicting user's intention based on multimodal information
US20100312547A1 (en) 2009-06-05 2010-12-09 Apple Inc. Contextual voice commands
US20100318576A1 (en) 2009-06-10 2010-12-16 Samsung Electronics Co., Ltd. Apparatus and method for providing goal predictive interface
US20100332235A1 (en) 2009-06-29 2010-12-30 Abraham Ben David Intelligent home automation
US20110082688A1 (en) 2009-10-01 2011-04-07 Samsung Electronics Co., Ltd. Apparatus and Method for Analyzing Intention
US20120022876A1 (en) 2009-10-28 2012-01-26 Google Inc. Voice Actions on Computing Devices
US20120022787A1 (en) 2009-10-28 2012-01-26 Google Inc. Navigation Queries
US20110112827A1 (en) 2009-11-10 2011-05-12 Kennewick Robert A System and method for hybrid processing in a natural language voice services environment
US20110112921A1 (en) 2009-11-10 2011-05-12 Voicebox Technologies, Inc. System and method for providing a natural language content dedication service
US20110119049A1 (en) 2009-11-13 2011-05-19 Tatu Ylonen Oy Ltd Specializing disambiguation of a natural language expression
US20110125540A1 (en) 2009-11-24 2011-05-26 Samsung Electronics Co., Ltd. Schedule management system using interactive robot and method and computer-readable medium thereof
US20120023088A1 (en) 2009-12-04 2012-01-26 Google Inc. Location-Based Searching
US20110144999A1 (en) 2009-12-11 2011-06-16 Samsung Electronics Co., Ltd. Dialogue system and dialogue method thereof
US20110161076A1 (en) 2009-12-31 2011-06-30 Davis Bruce L Intuitive Computing Methods and Systems
US20120022868A1 (en) 2010-01-05 2012-01-26 Google Inc. Word-Level Correction of Speech Input
US20110175810A1 (en) 2010-01-15 2011-07-21 Microsoft Corporation Recognizing User Intent In Motion Capture System
US20120016678A1 (en) 2010-01-18 2012-01-19 Apple Inc. Intelligent Automated Assistant
WO2011088053A2 (en) 2010-01-18 2011-07-21 Apple Inc. Intelligent automated assistant
US20110184730A1 (en) 2010-01-22 2011-07-28 Google Inc. Multi-dimensional disambiguation of voice commands
KR20110113414A (en) 2010-04-09 2011-10-17 이초강 Empirical context aware computing method for robot
US20120022870A1 (en) 2010-04-14 2012-01-26 Google, Inc. Geotagged environmental audio for enhanced speech recognition accuracy
US20110279368A1 (en) 2010-05-12 2011-11-17 Microsoft Corporation Inferring user intent to engage a motion capture system
US20120022874A1 (en) 2010-05-19 2012-01-26 Google Inc. Disambiguation of contact information using historical data
US20120042343A1 (en) 2010-05-20 2012-02-16 Google Inc. Television Remote Control Data Transfer
US20120022869A1 (en) 2010-05-26 2012-01-26 Google, Inc. Acoustic model adaptation using geographic information
US20110306426A1 (en) 2010-06-10 2011-12-15 Microsoft Corporation Activity Participation Based On User Intent
US20120022860A1 (en) 2010-06-14 2012-01-26 Google Inc. Speech and Noise Models for Speech Recognition
US20120002820A1 (en) 2010-06-30 2012-01-05 Google Removing Noise From Audio
US20120020490A1 (en) 2010-06-30 2012-01-26 Google Inc. Removing Noise From Audio
US20120035908A1 (en) 2010-08-05 2012-02-09 Google Inc. Translating Languages
US20120035931A1 (en) 2010-08-06 2012-02-09 Google Inc. Automatically Monitoring for Voice Input Based on Context
US20120035932A1 (en) 2010-08-06 2012-02-09 Google Inc. Disambiguating Input Based on Context
US20120035924A1 (en) 2010-08-06 2012-02-09 Google Inc. Disambiguating input based on context
US20120034904A1 (en) 2010-08-06 2012-02-09 Google Inc. Automatically Monitoring for Voice Input Based on Context

Non-Patent Citations (112)

* Cited by examiner, † Cited by third party
Title
"Iphone is Big in Japan", Wall Street Journal May 17, 2000.
"Japan belongs to Apple: iPhone claims top 10 spots in total smartphone sales in November," Rocket News 24, Nov. 13, 2013.
Alfred App, 2011, http://www.alfredapp.com/, 5 pages.
Ambite, JL., et al., "Design and Implementation of the CALO Query Manager," Copyright .COPYRGT. 2006, American Association for Artificial Intelligence, (www.aaai.org), 8 pages.
Ambite, JL., et al., "Integration of Heterogeneous Knowledge Sources in the CALO Query Manager," 2005, The 4th International Conference on Ontologies, DataBases, and Applications of Semantics (ODBASE), Agia Napa, Cyprus, ttp://www.isi.edu/people/ambite/publications/integration.sub.--he-terogeneous.sub.--knowledge.sub.--sources.sub.--calo.sub.--query.sub.--man-ager, 18 pages.
Authorized officer Philippe Becamel, International Preliminary Report on Patentability in PCT/US2009/033696 mailed Sep. 16, 2010, 7 pages.
Belvin, R. et al., "Development of the HRL Route Navigation Dialogue System," 2001, in Proceedings of the First International Conference on Human Language Technology Research, Paper, Copyright .COPYRGT. 2001 HRL Laboratories, LLC, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.10.6538, 5 pages.
Berry, P. M., et al., "PTIME: Personalized Assistance for Calendaring," ACM Transactions on Intelligent Systems and Technology, vol. 2, No. 4, Article 40, Publication date: Jul. 2011, 40:1-22, 22 pages.
Butcher, M., "EVI arrives in town to go toe-to-toe with Siri," Jan. 23, 2012, http://techcrunch.com/2012/01/23/evi-arrives-in-town-to-go-toe-to-toe-with-siri/, 2 pages.
Chen, Y., "Multimedia Siri Finds and Plays Whatever You Ask for," Feb. 9, 2012, http://www.psfk.com/2012/02/nriultinnedia-siri.html, 9 pages.
Cheyer, A. et al., "Spoken Language and Multimodal Applications for Electronic Realties," .COPYRGT. Springer-Verlag London Ltd, Virtual Reality 1999, 3:1-15, 15 pages.
Chou, "Zhuyin Input Interface on a Device", U.S. Appl. No. 12/476,121, filed Jun. 1, 2009.
Cutkosky, M. R. et al., "PACT: An Experiment in Integrating Concurrent Engineering Systems," Journal, Computer, vol. 26 Issue 1, Jan. 1993, IEEE Computer Society Press Los Alamitos, CA, USA, http://dl.acm.org/citation.cfm?id=165320, 14 pages.
Elio, R. et al., (1999) "On Abstract Task Models and Conversation Policies," http://webdocs.cs.ualberta.ca/.about.ree/publications/papers2/ATS.AA99.pd- f, 10 pages.
Entry for "replace" from The American Heritage Dictionary 1048 (2nd ed. 1985).
Ericsson, S. et al., "Software illustrating a unified approach to multimodality and multilinguality in the in-home domain," Dec. 22, 2006, Talk and Look: Tools for Ambient Linguistic Knowledge, http://www.talk-project.eurice.eu/fileadmin/talk/publications.sub.--publi-c/deliverables.sub.--public/D1.sub.--6.pdf, 127 pages.
Escerpt from Microsoft Computer Dictionary Release date: Mar. 22, 2002 ISBN: 0735614954.
Evi, "Meet Evi: the one mobile app that provides solutions for your everyday problems," Feb. 8, 2012, http://www.evi.com/, 3 pages.
Excerpt from Webster's New World Computer Dictionary, 10th Edition release date: Apr. 18, 2003 ISBN: 076452478X.
Excerpt of Inside Macintosh, vol. 1, Addison-Wesley, Copyright 1985, ISBN 0-201-17731-5.
Excerpt of Running Microsoft Word 97 for Windows 95 and Windows 4.0, by Russell Borland, Microsoft Press, Copyright 1997.
Excerpt of Smalltalk-80: The Interactive Programming Environment, by Adele Goldberg, Addison-Wesley, Copyright 1984, ISBN 0-201-17732-4.
Feigenbaum, E., et al., "Computer-assisted Semantic Annotation of Scientific Life Works," 2007, http://tomgruber.org/writing/stanford-cs300.pdf, 22 pages.
Gannes, L., "Alfred App Gives Personalized Restaurant Recommendations," allthingsd.com, Jul. 18, 2011, http://allthingsd.com/20110718/alfred-app-gives-personalized-restaurant-recommendations/, 3 pages.
Gautier, P. O., et al. "Generating Explanations of Device Behavior Using Compositional Modeling and Causal Ordering," 1993, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.42.8394, 9 pages.
Gervasio, M. T., et al., Active Preference Learning for Personalized Calendar Scheduling Assistancae, Copyright .COPYRGT. 2005, http://www.ai.sri.com/.about.gervasio/pubs/gervasio-iui05.pdf, 8 pages.
Glass, A., "Explaining Preference Learning," 2006, http://cs229.stanford.edu/proj2006/GlassExplainingPreferenceLearning.pdf, 5 pages.
Glass, J., et al., "Multilingual Spoken-Language Understanding in the MIT Voyager System," Aug. 1995, http://groups.csail.mitedu/sis/publications/1995/speechcomm95-voyager.pdf, 29 pages.
Goddeau, D., et al., "A Form-Based Dialogue Manager for Spoken Language Applications," Oct. 1996, http://phasedance.com/pdf/icslp96.pdf, 4 pages.
Goddeau, D., et al., "Galaxy: A Human-Language Interface to On-Line Travel Information," 1994 International Conference on Spoken Language Processing, Sep. 18-22, 1994, Pacific Convention Plaza Yokohama, Japan, 6 pages.
Goldsmith et al., "Identification of Candidate Characters for Text Input", U.S. Appl. No. 12/167,044, filed Jul. 2, 2008.
Gruber, T. R., "(Avoiding) the Travesty of the Commons," Presentation at NPUC 2006, New Paradigms for User Computing, IBM Almaden Research Center, Jul. 24, 2006. http://tomgruber.org/writing/avoiding-travestry.htm, 52 pages.
Gruber, T. R., "2021: Mass Collaboration and the Really New Economy," TNTY Futures, the newsletter of the Next Twenty Years series, vol. 1, Issue 6, Aug. 2001, http://www.tnty.com/newsletter/futures/archive/v01-05business.html, 5 pages.
Gruber, T. R., "A Translation Approach to Portable Ontology Specifications," Knowledge Systems Laboratory, Stanford University, Sep. 1992, Technical Report KSL 92-71, Revised Apr. 1993, 27 pages.
Gruber, T. R., "Automated Knowledge Acquisition for Strategic Knowledge," Knowledge Systems Laboratory, Machine Learning, 4, 293-336 (1989), 44 pages.
Gruber, T. R., "Big Think Small Screen: How semantic computing in the cloud will revolutionize the consumer experience on the phone," Keynote presentation at Web 3.0 conference, Jan. 27, 2010, http://tomgruber.org/writing/web30jan2010.htm, 41 pages.
Gruber, T. R., "Collaborating around Shared Content on the WWW," W3C Workshop on WWW and Collaboration, Cambridge, MA, Sep. 11, 1995, http://www.w3.org/Collaboration/Workshop/Proceedings/P9.html, 1 page.
Gruber, T. R., "Collective Knowledge Systems: Where the Social Web meets the Semantic Web," Web Semantics: Science, Services and Agents on the World Wide Web (2007), doi:10.1016/j.websem.2007.11.011, keynote presentation given at the 5th International Semantic Web Conference, Nov. 7, 2006, 19 pages.
Gruber, T. R., "Despite our Best Efforts, Ontologies are not the Problem," AAAI Spring Symposium, Mar. 2008, http://tomgruber.org/writing/aaai-ss08.htm, 40 pages.
Gruber, T. R., "Enterprise Collaboration Management with Intraspect," Intraspect Software, Inc., Intraspect Technical White Paper Jul. 2001, 24 pages.
Gruber, T. R., "Every ontology is a treaty-a social agreement-among people with some common motive in sharing," Interview by Dr. Miltiadis D. Lytras, Official Quarterly Bulletin of AIS Special Interest Group on Semantic Web and Information Systems, vol. 1, Issue 3, 2004, http://www.sigsemis.org 1, 5 pages.
Gruber, T. R., "Helping Organizations Collaborate, Communicate, and Learn," Presentation to NASA Ames Research, Mountain View, CA, Mar. 2003, http://tomgruber.org/writing/organizational-intelligence-talk.htm, 30 pages.
Gruber, T. R., "Intelligence at the Interface: Semantic Technology and the Consumer Internet Experience," Presentation at Semantic Technologies conference (SemTech08), May 20, 2008, http://tomgruber.org/writing.htm, 40 pages.
Gruber, T. R., "It Is What It Does: The Pragmatics of Ontology for Knowledge Sharing," (c) 2000, 2003, http://www.cidoc-crm.org/docs/symposium.sub.--presentations/gruber.sub.---cidoc-ontology-2003.pdf, 21 pages.
Gruber, T. R., "Ontologies, Web 2.0 and Beyond," Apr. 24, 2007, Ontology Summit 2007, http://tomgruber.org/writing/ontolog-social-web-keynote.pdf, 17 pages.
Gruber, T. R., "Ontology of Folksonomy: A Mash-up of Apples and Oranges," Originally published to the web in 2005, Int'l Journal on Semantic Web & Information Systems, 3(2), 2007, 7 pages.
Gruber, T. R., "Siri, a Virtual Personal Assistant-Bringing Intelligence to the Interface," Jun. 16, 2009, Keynote presentation at Semantic Technologies conference, Jun. 2009. http://tomgruber.org/writing/semtech09.htm, 22 pages.
Gruber, T. R., "TagOntology," Presentation to Tag Camp, www.tagcamp.org, Oct. 29, 2005, 20 pages.
Gruber, T. R., "Toward Principles for the Design of Ontologies Used for Knowledge Sharing," in International Journal Human-Computer Studies 43, p. 907-928, substantial revision of paper presented at the International Workshop on Formal Ontology, Mar. 1993, Padova, Italy, available as Technical Report KSL 93-04, Knowledge Systems Laboratory, Stanford University, further revised Aug. 23, 1993, 23 pages.
Gruber, T. R., "Where the Social Web meets the Semantic Web," Presentation at the 5th International Semantic Web Conference, Nov. 7, 2006, 38 pages.
Gruber, T. R., et al., "An Ontology for Engineering Mathematics," in Jon Doyle, Piero Torasso, & Erik Sandewall, Eds., Fourth International Conference on Principles of Knowledge Representation and Reasoning, Gustav Stresemann Institut, Bonn, Germany, Morgan Kaufmann, 1994, http://www-ksl.stanford.edu/knowledge-sharing/papers/engmath.html, 22 pages.
Gruber, T. R., et al., "Generative Design Rationale: Beyond the Record and Replay Paradigm," Knowledge Systems Laboratory, Stanford University, Dec. 1991, Technical Report KSL 92-59, Updated Feb. 1993, 24 pages.
Gruber, T. R., et al., "Machine-generated Explanations of Engineering Models: A Compositional Modeling Approach," (1993) in Proc. International Joint Conference on Artificial Intelligence, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.34.930, 7 pages.
Gruber, T. R., et al., "Toward a Knowledge Medium for Collaborative Product Development," in Artificial Intelligence in Design 1992, from Proceedings of the Second International Conference on Artificial Intelligence in Design, Pittsburgh, USA, Jun. 22-25, 1992, 19 pages.
Gruber, T. R., et al.,"Nike: A National Infrastructure for Knowledge Exchange," Oct. 1994, http://www.eit.com/papers/nike/nike.html and nike.ps, 10 pages.
Gruber, T. R., Interactive Acquisition of Justifications: Learning "Why" by Being Told "What" Knowledge Systems Laboratory, Stanford University, Oct. 1990, Technical Report KSL 91-17, Revised Feb. 1991, 24 pages.
Guzzoni, D., et al., "Active, A Platform for Building Intelligent Operating Rooms," Surgetica 2007 Computer-Aided Medical Interventions: tools and applications, pp. 191-198, Paris, 2007, Sauramps Medical, http://lsro.epfl.ch/page-68384-en.html, 8 pages.
Guzzoni, D., et al., "Active, A Tool for Building Intelligent User Interfaces," ASC 2007, Palma de Mallorca, http://lsro.epfl.ch/page-34241.html, 6 pages.
Guzzoni, D., et al., "Modeling Human-Agent Interaction with Active Ontologies," 2007, AAAI Spring Symposium, Interaction Challenges for Intelligent Assistants, Stanford University, Palo Alto, California, 8 pages.
H. Sacher, "Interactions in Chinese: Designing Interfaces for Asian Languages," Interactions Magazine, vol. 5, Issue 5, Sep.-Oct. 1998, pp. 28-38.
Hardawar, D., "Driving app Waze builds its own Siri for hands-free voice control," Feb. 9, 2012, http://venturebeat.com/2012/02/09/driving-app-waze-builds-its-own-siri-fo-r-hands-free-voice-control/, 4 pages.
International Preliminary Report on Patentability in International Application No. PCT/US2008/072803 mailed Mar. 18, 2010.
International Preliminary Report on Patentability in PCT/US2009/033696 mailed Sep. 16, 2010, 6 pages.
International Search Report and Written Opinion dated Nov. 29, 2011, received in International Application No. PCT/US2011/20861, which corresponds to U.S. Appl. No. 12/987,982, 15 pages. (Thomas Robert Gruber).
International Search Report and Written Opinion, dated Apr. 29, 2009, issued in International Application No. PCT/US2009/033696.
International Search Report and Written Opinion, dated Feb. 18, 2009, issued in International Application No. PCT/US2008/072803.
Intraspect Software, "The Intraspect Knowledge Management Solution: Technical Overview," http://tomgruber.org/writing/intraspect-whitepaper-1998.pdf, 18 pages.
Invitation to Pay Fees and Partial International Search Report, dated Nov. 11, 2008, issued in International Application No. PCT/US2008/072803.
Invitation to Pay Fees and Partial International Search Report, dated Nov. 11, 2008, issued in International Application no. PCT/US2009/072803.
Julia, L., et al., Un editeur interactif de tableaux dessines a main levee (An Interactive Editor for Hand-Sketched Tables), Traitement du Signal 1995, vol. 12, No. 6, 8 pages. No English Translation Available.
Karp, P. D., "A Generic Knowledge-Base Access Protocol," May 12, 1994, http://lecture.cs.buu.ac.th/.about.f50353/Document/gfp.pdf, 66 pages.
Kida et al., "Language Input Interface on a Device", U.S. Appl. No. 12/107,711, filed Apr. 22, 2008.
Lemon, O., et al., "Multithreaded Context for Robust Conversational Interfaces: Context-Sensitive Speech Recognition and Interpretation of Corrective Fragments," Sep. 2004, ACM Transactions on Computer-Human Interaction, vol. 11, No. 3, 27 pages.
Leong, L., et al., "CASIS: A Context-Aware Speech Interface System," IUI'05, Jan. 9-12, 2005, Proceedings of the 10th international conference on Intelligent user interfaces, San Diego, California, USA, 8 pages.
Lieberman, H., et al., "Out of context: Computer systems that adapt to, and learn from, context," 2000, IBM Systems Journal, vol. 39, Nos. 3/4, 2000, 16 pages.
Lin, B., et al., "A Distributed Architecture for Cooperative Spoken Dialogue Agents with Coherent Dialogue State and History," 1999, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.42.272, 4 pages.
Liu et al., "Online Recognition of Chinese Characters: The State-of-the-Art," IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 26, No. 2, Feb. 2004, pp. 198-213.
Masui, "An Efficient Text Input Method for Pen-based Computers," Proceedings of the ACM Conference on Human Factors in Computing System (CHI '98), Apr. 1998, ACM press, pp. 328-335.
Masui, POBox: "An Efficient Text Input Method for Handheld and Ubiquitous Computers," Proceedings of the Internation Symposium on Handheld and Ubiquitous Computer (HUC '99), Sep. 1999, pp. 289-300.
McGuire, J., et al., "Shade: Technology for Knowledge-Based Collaborative Engineering," 1993, Journal of Concurrent Engineering: Applications and Research (CERA), 18 pages.
Meng, H., et al., "Wheels: A Conversational System in the Automobile Classified Domain," Oct. 1996, httphttp://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.16.3022, 4 pages.
Milward, D., et al., "D2.2: Dynamic Multimodal Interface Reconfiguration," Talk and Look: Tools for Ambient Linguistic Knowledge, Aug. 8, 2006, http://www.ihmc.us/users/nblaylock/Pubs/Files/talk.sub.--d2.2.pdf, 69 pages.
Mitra, P., et al., "A Graph-Oriented Model for Articulation of Ontology Interdependencies," 2000, http://ilpubs.stanford.edu:8090/442/1/2000-20.pdf, 15 pages.
Moran, D. B., et al., "Multimodal User Interfaces in the Open Agent Architecture," Proc. of the 1997 International Conference on Intelligent User Interfaces (IUI97), 8 pages.
Mozer, M., "An Intelligent Environment Must be Adaptive," Mar./Apr. 1999, IEEE Intelligent Systems, 3 pages.
Muhlhauser, M., "Context Aware Voice User Interfaces for Workflow Support," Darmstadt 2007, http://tuprints.ulb.tu-darmstadt.de/876/1/PhD.pdf, 254 pages.
Naone, E., "Trio: Intelligent Software Assistant," Mar.-Apr. 2009, Technology Review, http://www.technologyreview.com/printer.sub.--friendly.sub.--article.aspx- ?id=22117, 2 pages.
Neches, R., "Enabling Technology for Knowledge Sharing," Fall 1991, AI Magazine, pp. 37-56, (21 pages).
Noth, E., et al., "Verbmobil: The Use of Prosody in the Linguistic Components of a Speech Understanding System," IEEE Transactions on Speech and Audio Processing, vol. 8, No. 5, Sep. 2000, 14 pages.
Phoenix Solutions, Inc. v. West Interactive Corp., Document 40, Declaration of Christopher Schmandt Regarding the MIT Galaxy System dated Jul. 2, 2010, 162 pages.
Rice, J., et al., (1995) "Monthly Program: Nov. 14, 1995," The San Francisco Bay Area Chapter of ACM SIGCHI, http://www.baychi.org/calendar/19951114/, 2 pages.
Rice, J., et al., (1996) "Using the Web Instead of a Window System," Knowledge Systems Laboratory, Stanford University, http://tomgruber.org/writing/ksl-95-69.pdf, 14 pages.
Rivlin, Z., et al., "Maestro: Conductor of Multimedia Analysis Technologies," 1999 SRI International, Communications of the Association for Computing Machinery (CACM), 7 pages.
Sacher, "Interactions in Chinese: Designing Interfaces for Asian Languages," Interactions Magazine, vol. 5, Issue 5, Sep.-Oct. 1998, pp. 28-38.
Seneff, S., et al., "A New Restaurant Guide Conversational System: Issues in Rapid Prototyping for Specialized Domains," Oct. 1996, citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.16...rep . . . , 4 pages.
Sheth, A., et al., "Relationships at the Heart of Semantic Web: Modeling, Discovering, and Exploiting Complex Semantic Relationships," Oct. 13, 2002, Enhancing the Power of the Internet: Studies in Fuzziness and Soft Computing, SpringerVerlag, 38 pages.
Simonite, T., "One Easy Way to Make Siri Smarter," Oct. 18, 2011, Technology Review, http://www.technologyreview.com/printersub.--friendly.sub.--article.aspx?id=389- 15, 2 pages.
Stent, A., et al., "The CommandTalk Spoken Dialogue System," 1999, http://acl.ldc.upenn.edu/P/P99/P99-1024.pdf, 8 pages.
Tofel, K., et al., "SpeakTolt: A personal assistant for older iPhones, iPads," Feb. 9, 2012, http://gigaom.com/apple/speaktoit-siri-for-older-iphones-ipads/, 7 pages.
Translated First Office Action dated Jul. 29, 2010, issued in Chinese Patent Application No. 200910118235.X, 9 pages.
Tucker, J., "Too lazy to grab your TV remote? Use Siri instead," Nov. 30, 2011, http://www.engadget.com/2011/11/30/too-lazy-to-grab-your-tv-remote--use-siri-instead/, 8 pages.
Tur, G., et al., "The-CALO-Meeting-Assistant System," IEEE Transactions on Audio, Speech, and Language Processing, vol. 18, No. 6, Aug. 2010, 11 pages.
Tur, G., et al., "The CALO Meeting Speech Recognition and Understanding System," 2008, Proc. IEEE Spoken Language Technology Workshop, 4 pages.
Vlingo InCar, "Distracted Driving Solution with Vlingo InCar," 2:38 minute video uploaded to YouTube by Vlingo Voice on Oct. 6, 2010, http://www.youtube.com/watch?v=Vqs8XfXxgz4, 2 pages.
Vlingo, "Vlingo Launches Voice Enablement Application on Apple App Store," Vlingo press release dated Dec. 3, 2008, 2 pages.
YouTube, "Knowledge Navigator," 5:34 minute video uploaded to YouTube by Knownav on Apr. 29, 2008, http://www.youtube.com/watch?v=QRH8eimU.sub.--20on Aug. 3, 2006, 1 page.
YouTube, "Send Text, Listen to and Send E-Mail 'By Voice' www.voiceassist.com," 2:11 minute video uploaded to YouTube by VoiceAssist on Jul. 30, 2009, http://www.youtube.com/watch?v=0tEU61nHHA4, 1 page.
YouTube, "Text'nDrive App Demo-Listen and Reply to your Messages by Voice while Driving!," 1:57 minute video uploaded to YouTube by TextnDrive on Apr 27, 2010, http://www.youtube.com/watch?v=WaGfzoHsAMw, 1 page.
YouTube, "Text'nDrive App Demo—Listen and Reply to your Messages by Voice while Driving!," 1:57 minute video uploaded to YouTube by TextnDrive on Apr. 27, 2010, http://www.youtube.com/watch?=WaGfzoHsAMw, 1 page.
YouTube, "Voice on the Go (BlackBerry)," 2:51 minute video uploaded to YouTube by VoiceOnTheGo on Jul. 27, 2009, http://www.youtube.com/watch?v=pJqpWgQS98w, 1 page.
Zue, V. W., "Toward Systems that Understand Spoken Language," Feb. 1994, ARPA Strategic Computing Institute, .COPYRGT.1994 IEEE, 9 pages.
Zue, V., "Conversational Interfaces: Advances and Challenges," Sep. 1997, http://www.cs.cmu.edu/.about.dod/papers/zue97.pdf, 10 pages.

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11341962B2 (en) 2010-05-13 2022-05-24 Poltorak Technologies Llc Electronic personal interactive device
US11367435B2 (en) 2010-05-13 2022-06-21 Poltorak Technologies Llc Electronic personal interactive device
US20190332255A1 (en) * 2016-03-25 2019-10-31 Huawei Technologies Co., Ltd. Character Input Method and Apparatus, and Terminal
US10635305B2 (en) * 2018-02-01 2020-04-28 Microchip Technology Incorporated Touchscreen user interface with multi-language support

Also Published As

Publication number Publication date
CN101526879B (en) 2012-12-19
CN101526879A (en) 2009-09-09
US8289283B2 (en) 2012-10-16
HK1137525A1 (en) 2010-07-30
US20090225041A1 (en) 2009-09-10
US20160370996A1 (en) 2016-12-22

Similar Documents

Publication Publication Date Title
USRE46139E1 (en) Language input interface on a device
US10871897B2 (en) Identification of candidate characters for text input
US8908973B2 (en) Handwritten character recognition interface
US8564541B2 (en) Zhuyin input interface on a device
US8949743B2 (en) Language input interface on a device
US20090225034A1 (en) Japanese-Language Virtual Keyboard
US8605039B2 (en) Text input
US20130263039A1 (en) Character string shortcut key
KR20180101723A (en) Semantic zoom animations
KR20140074889A (en) Semantic zoom
KR20140074888A (en) Semantic zoom gestures
US8806384B2 (en) Keyboard gestures for character string replacement
US10241670B2 (en) Character entry apparatus and associated methods
US20140164981A1 (en) Text entry
KR20160009054A (en) Multiple graphical keyboards for continuous gesture input
WO2010109294A1 (en) Method and apparatus for text input
WO2009074278A1 (en) Device and method for inputting combined characters
US11086410B2 (en) Apparatus for text entry and associated methods
US9996213B2 (en) Apparatus for a user interface and associated methods
EP2765486B1 (en) Method and apparatus for using persistent directional gestures for localization input

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

CC Certificate of correction
MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8