Nothing Special   »   [go: up one dir, main page]

US20080208568A1 - System and method for providing context to an input method by tagging existing applications - Google Patents

System and method for providing context to an input method by tagging existing applications Download PDF

Info

Publication number
US20080208568A1
US20080208568A1 US12/115,427 US11542708A US2008208568A1 US 20080208568 A1 US20080208568 A1 US 20080208568A1 US 11542708 A US11542708 A US 11542708A US 2008208568 A1 US2008208568 A1 US 2008208568A1
Authority
US
United States
Prior art keywords
input
scope
field
text
context
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.)
Abandoned
Application number
US12/115,427
Inventor
Patrick Haluptzok
Yutaka Suzue
Angshuman Guha
Anuradha N. Padte
Vamshidhar G. Reddy
Mukundan Bhoovaraghavan
Ranjit Kumar Gupta
Joshua A. Clow
Robert Lewis Chambers
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.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Corp
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 Microsoft Corp filed Critical Microsoft Corp
Priority to US12/115,427 priority Critical patent/US20080208568A1/en
Assigned to MICROSOFT CORPORATION reassignment MICROSOFT CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BHOOVARAGHAVAN, MUKUNDAN, CLOW, JOSHUA A., GUHA, ANGSHUMAN, GUPTA, RANJIT KUMAR, PADTE, ANURADHA N., REDDY, VAMSHIDHAR G., HALUPTZOK, PATRICK, SUZUE, YUTAKA, CHAMBERS, ROBERT LEWIS
Publication of US20080208568A1 publication Critical patent/US20080208568A1/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
Abandoned legal-status Critical Current

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/02Input arrangements using manually operated switches, e.g. using keyboards or dials
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • G06F9/453Help systems

Definitions

  • the invention relates generally to computer systems, and more particularly to an improved system and method for providing context to an input method.
  • Advanced text input methods such as handwriting, speech, and Input Method Editors (IMEs) are often limited to leveraging language rules and a language dictionary as the primary forms of context used to achieve accuracy in recognition of text input.
  • Contextual information such as unigrams or n-grams has been traditionally provided as part of the language model to such input methods to increase accuracy in recognition of natural language input.
  • an email field may expect an email address as input.
  • email addresses do not conform to the language rules or vocabulary of a specific language.
  • English language rules which require, for example, a space between words do not apply to an email address.
  • a field may expect a Uniform Resource Locator (URL), which also may not conform to the language rules or vocabulary of a specific language.
  • URL Uniform Resource Locator
  • Such input methods may be severely limited in their ability to accurately recognize input for these types of fields. Users consequently may have an unsatisfactory experience when using such input methods that result in poor recognition accuracy for these types of fields.
  • the present invention provides an improved system and method for providing context information of executable code to an input method.
  • Advanced text input methods may be made aware of the type of text expected to be received as input so that such input methods may achieve a higher accuracy in recognition of text input.
  • an architecture is provided with a generic interface for supplying context information so that applications can provide input scope for any of their fields expecting text input.
  • any input method may use the context information provided by an application. Consequently, users may switch between input methods to input information to the application without loss of the context information.
  • the present invention additionally provides a system of components including a context component with generic interfaces and a context tagging utility.
  • the generic interfaces provide a framework for supporting application authoring platforms to allow application developers to easily specify context information to the system and have it reliably forwarded to the correct input methods.
  • context information may include a common input scope, a set of input scopes, a word or phrase list, a custom input scope defined by a regular expression or other grammar.
  • the present invention may also support existing applications without needing to modify the application itself by providing a context tagging tool for associating specific text input fields of an application with an input scope.
  • the context tagging tool may create a manifest that contains tags associating the specific text input fields with an input scope.
  • Such a manifest may be stored along with the program files. Any advanced input methods use by the application may be updated with instructions for accessing the context information stored in the manifest.
  • existing applications may also benefit from use of the present invention for increasing accuracy of recognition for text input fields by advanced input methods.
  • the context tagging tool includes a user interface for tagging text input fields or controls of an existing application or executable code with an input scope.
  • the user interface allows a text input field or control and an input scope to be selected, and their resulting association to be added to the manifest.
  • the user interface may include a phrase list editor and a custom input scope editor for creating, editing and managing a phrase list and a custom input scope respectively.
  • FIG. 1 is a block diagram generally representing a computer system into which the present invention may be incorporated;
  • FIG. 2 is a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method, in accordance with an aspect of the present invention
  • FIG. 3 is a flowchart generally representing example steps undertaken by the system for providing context information of executable code to an input method, in accordance with an aspect of the present invention
  • FIG. 4 is a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method using a context tagging utility, in accordance with an aspect of the present invention
  • FIG. 5 is a flowchart generally representing example steps undertaken by the system for providing context information of executable code to an input method using a context tagging utility, in accordance with an aspect of the present invention
  • FIG. 6 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging utility for selecting an application or executable code, in accordance with an aspect of the present invention
  • FIG. 7 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging utility for tagging a field or control with an input scope, in accordance with an aspect of the present invention
  • FIG. 8 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for selecting a field or control, in accordance with an aspect of the present invention
  • FIG. 9 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a phrase list, in accordance with an aspect of the present invention.
  • FIG. 10 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a custom scope, in accordance with an aspect of the present invention.
  • FIG. 1 illustrates an example of a suitable computing system environment 100 on which the invention may be implemented.
  • the computing system environment 100 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Neither should the computing environment 100 be interpreted as having any dependency or requirement relating to anyone or combination of components illustrated in the exemplary operating environment 100 .
  • the invention is operational with numerous other general purpose or special purpose computing system environments or configurations.
  • Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to: personal computers, server computers, hand-held or laptop devices, tablet devices, headless servers, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • the invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer.
  • program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types.
  • the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
  • program modules may be located in local and/or remote computer storage media including memory storage devices.
  • an exemplary system for implementing the invention includes a general purpose computing device in the form of a computer 110 .
  • Components of the computer 110 may include, but are not limited to, a processing unit 120 , a system memory 130 , and a system bus 121 that couples various system components including the system memory to the processing unit 120 .
  • the system bus 121 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
  • such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced rSA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCr) bus also known as Mezzanine bus.
  • ISA Industry Standard Architecture
  • MCA Micro Channel Architecture
  • EISA Enhanced rSA
  • VESA Video Electronics Standards Association
  • PCr Peripheral Component Interconnect
  • the computer 110 typically includes a variety of computer-readable media.
  • Computer-readable media can be any available media that can be accessed by the computer 110 and includes both volatile and nonvolatile media, and removable and non-removable media.
  • Computer-readable media may comprise computer storage media and communication media.
  • Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data.
  • Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by the computer 110 .
  • Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media.
  • modulated data signal means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal.
  • communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer-readable media.
  • the system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132 .
  • ROM read only memory
  • RAM random access memory
  • BIOS basic input/output system
  • RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120 .
  • FIG. 1 illustrates operating system 134 , application programs 135 , other program modules 136 and program data 137 .
  • the computer 110 may also include other removable/nonremovable, volatile/nonvolatile computer storage media.
  • FIG. 1 illustrates a hard disk drive 141 that reads from or writes to non-removable, nonvolatile magnetic media, a magnetic disk drive 151 that reads from or writes to a removable, nonvolatile magnetic disk 152 , and an optical disk drive 155 that reads from or writes to a removable, nonvolatile optical disk 156 such as a CD ROM or other optical media.
  • removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like.
  • the hard disk drive 141 is typically connected to the system bus 121 through a nonremovable memory interface such as interface 140
  • magnetic disk drive 151 and optical disk drive 155 are typically connected to the system bus 121 by a removable memory interface, such as interface 150 .
  • hard disk drive 141 is illustrated as storing operating system 144 , application programs 145 , other program modules 146 and program data 147 . Note that these components can either be the same as or different from operating system 134 , application programs 135 , other program modules 136 , and program data 137 . Operating system 144 , application programs 145 , other program modules 146 , and program data 147 are given different numbers herein to illustrate that, at a minimum, they are different copies.
  • a user may enter commands and information into the computer 110 through input devices such as a tablet, or electronic digitizer, 164 , a microphone 163 , a keyboard 162 and pointing device 161 , commonly referred to as mouse, trackball or touch pad.
  • input devices such as a tablet, or electronic digitizer, 164 , a microphone 163 , a keyboard 162 and pointing device 161 , commonly referred to as mouse, trackball or touch pad.
  • Other input devices not shown in FIG. 1 may include a joystick, game pad, satellite dish, scanner, or other devices including a device that contains a biometric sensor, environmental sensor, position sensor, or other type of sensor.
  • These and other input devices are often connected to the processing unit 120 through a user input interface 160 that is coupled to the system bus, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB).
  • USB universal serial bus
  • a monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190 .
  • the monitor 191 may also be integrated with a touch-screen panel or the like. Note that the monitor and/or touch screen panel can be physically coupled to a housing in which the computing device 110 is incorporated, such as in a tablet-type personal computer.
  • computers such as the computing device 110 may also include other peripheral output devices such as speakers 195 and printer 196 , which may be connected through an output peripheral interface 194 or the like.
  • the computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180 .
  • the remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110 , although only a memory storage device 181 has been illustrated in FIG. 1 .
  • the logical connections depicted in FIG. 1 include a local area network (LAN) 171 and a wide area network (WAN) 173 , but may also include other networks.
  • LAN local area network
  • WAN wide area network
  • Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.
  • the computer 110 When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170 .
  • the computer 110 When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173 , such as the Internet.
  • the modem 172 which may be internal or external, may be connected to the system bus 121 via the user input interface 160 or other appropriate mechanism.
  • program modules depicted relative to the computer 110 may be stored in the remote memory storage device.
  • FIG. 1 illustrates remote application programs 185 as residing on memory device 181 . It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
  • context information generally means an input scope.
  • An input scope is a subset of a language that is used to define what words, numbers, and punctuation can be written and may also specify in what order they may be written.
  • An input scope can be used by applications to restrict the language model used by a recognizer of an input method to the type of text input an application is expecting in a text field.
  • the invention may enable advanced input methods to achieve a higher accuracy recognition rate for text input to application fields by providing an architecture that supports applications or forms to specify what type of text input they are expecting in their text fields.
  • Many text input fields in forms and dialogs are strongly typed, like the fields in a web order form or in a dialog window for updating personal contacts. The information about the type of text expected can greatly improve accuracy when specified to the recognition engines of the advanced input methods.
  • the architecture of the present invention allows applications that expect text input to fields or forms to provide this context information in a general way without interacting directly with the advanced input methods.
  • the architecture provides a generic interface for supplying context information so that applications can provide input scope for any of their fields expecting text input.
  • the system and method also provide a generic API to allow any input method to use the context information provided by the application to improve recognition accuracy.
  • any input method may use the context information provided by the application, a user may switch between input methods to input information to the application without loss of the context information.
  • the various block diagrams, flow charts and scenarios described herein are only examples, and there are many other scenarios to which the present invention will apply.
  • FIG. 2 of the drawings there is shown a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method.
  • Those skilled in the art will appreciate that the functionality implemented within the blocks illustrated in the diagram may be implemented as separate components or the functionality of several or all of the blocks may be implemented within a single component.
  • the functionality of the context component 202 may be included in the context client 208 .
  • the functionality for the InputScopeCollection interface in the context component 202 may be implemented in a separate component.
  • Any executable code 135 that expects text input to a field may provide context information for that field to a context component 202 by invoking an interface, such as SetInputScope Interface 204 .
  • the executable code 135 may be any type of executable software code such as a kernel component, an application program, a dialog box or form, a script, a linked library, a linked or embedded object, and so forth.
  • the context component 202 includes an interface, such as a SetInputScope Interface 204 , for setting an input scope of executable code 135 , and also an interface, such as a InputScopeCollection Interface, for obtaining an input scope that has been set for a text input field of executable code 135 .
  • the context component may be any executable software code including a kernel component, an application component, a component of a linked library, an object, and so forth.
  • a context client 208 such as one or more Input Method Editors 210 , a Handwriting Recognizer 212 , a Speech Recognizer 214 , or other recognizer of any additional type of input method, may query the InputScopeCollection interface 206 included as part of the context component 202 to obtain an input scope set for executable code 135 .
  • This architecture may allow applications or other executable code that expect text input to fields or forms to provide context of input scope in a general way without interacting directly with the advanced input methods.
  • the SetInputScope Interface 204 shown in FIG. 2 may be an API, an object, a control or other executable code.
  • the SetInputScope Interface 204 may be an API named SetInputScopen.
  • the SetInputScope API may associate a control or text input field with one common input scope or one wordlist.
  • the SetInputScope API may have the following programming language declaration:
  • This API may expect a window handle and a pointer to a list of input scopes.
  • This API may be used to set a common input scope defined by a parameter of type InputScope by invoking the API as SetInputScope (hwndMe, IS_URL), where IS URL may be a parameter signifying an internally defined format with an associated fixed list of characters.
  • this API may be used to set a word list by passing the word list as a parameter of type InputScope by invoking the API as SetInputScope (hwndMe, ⁇ “male”, “female” ⁇ ).
  • the SetInputScope Interface 204 may be an API named “SetInputScopes”.
  • the SetInputScopes API may associate a control or text input field with one common input scope, multiple common input scopes, one word list, or one custom input scope.
  • the custom input scope may be defined by a regular expression or any other way including a grammar like that specified in W3C Speech Recognition Grammar Specification (SRGS).
  • SRGS Speech Recognition Grammar Specification
  • the SetInputScopes API may have the following programming language declaration:
  • This API may expect a window handle, a pointer to a list of input scopes, the number of input scopes in the list, a pointer to a phrase list, the number of phrases in the list, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope.
  • This API may be used to set several common input scopes passed by a parameter list of input scopes by invoking the API as SetInputScopes (hwndMe, ⁇ IS_DEFAULT, Is PersonalName_FullName, I S_EMAIL_USERNAME, IS_EMAIL SMTPEMAILADDRESS ⁇ , 4 , NULL, NULL, NULL, NULL) where IS_DEFAULT, IS_PERSONALNAME_FULLNAME, IS_EMAIL_USERNAME, and IS EMAIL_SMTPEMAILADDRESS may each signify an internally defined format with an associated fixed list of characters.
  • this API may be used to set a list of words or phrases by passing the list as a parameter of type InputScope by invoking the API as SetInputScopes (hwndMe, ⁇ IS PHRASELIST, IS_DEFAULT ⁇ , 2, ⁇ “male”, “female” ⁇ , 2, NULL, NULL). Additionally, this API may be used to set a custom scope of input defined by a regular expression, grammar, or other definition, such as by invoking the API as SetInputScopes (hwndMe, IS SSN, 2, NULL, NULL, IS DIGITS. “ ⁇ ”.IS DIGITS.“ ”.IS_DIGITS, NULL).
  • such an API may support coercion of the input according to the definition of the input scope.
  • Coercion means herein to constrain the recognition of the input to the definition of the input scope.
  • a recognizer of an input method is constrained to conform to the exact definition of the input scope and may not use another definition of input scope. If coercion of the input is not specified, a recognizer of an input method may interpret the input scope specified as a recommendation, but may not constrain recognition to just that definition.
  • the definition of custom input scope may take precedence over the common input scope of wordlist.
  • an input scope may be set using an API that defines an XML schema such as:
  • the InputScopeCollection Interface 206 shown in FIG. 2 may be an API, an object, a control or other executable code.
  • the InputScopeCollection Interface 206 may be an object with methods that may be invoked by an input method for obtaining the input scope for a text input field specified by any executable code.
  • the recognizer of an input method may call a constructor of the object with a valid window handle for the application and then may access the public properties and may also call the public methods to access the different input scopes associated with the window handle for the application.
  • the object may get a set of input scopes associated with a control, the individual input scopes from the set associated with the control, a regular expression from the set associated with the control, and a list of phrases from the set associated with the control.
  • the class definition for an instance of such an object may be for example:
  • the constructor “InputScopeCollection” may take a handle to a window and may find a set of input scopes that may be associated with it.
  • the public property “HasInputScopes” may determine whether there is any input scope associated with the control.
  • the public property “Count” may return the number of input scopes that may be associated with the control.
  • the public property “InputScopes” may return an array containing a set of input scopes that may be associated with the control.
  • the public property “RegularExpression” may return a regular expression associated with the control.
  • the public property “Phrases” may return a string array containing the phrases associated with the control.
  • any number of methods may be provided by an object that is an embodiment of the InputScopeCollection Interface 206 for obtaining the input scope for a text input field.
  • the method “Phrase(int index)” may return a phrase that is indexed by a requested index.
  • the method “InputScopes(int index)” may return an input scope that is indexed by a requested index.
  • the method “InputScopeEnumName (int index)” may return a name of an input scope at a specific location index.
  • the method “ToString ( )” may return a string representation of an input scope for a specific instance.
  • the interfaces represented in FIG. 2 are exemplary representations and that the present invention may be practiced using other interfaces defined for setting input scope and obtaining context information.
  • FIG. 3 is a flowchart generally representing the steps undertaken by the system for providing context information of executable code to an input method.
  • any executable code may invoke an interface for setting a scope of input for a text field at step 302 .
  • Included among the settings in an interface for a scope of input may be a list of input scopes, a list of words or phrases, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope.
  • the input scope requested is set for a text field of executable code at step 304 .
  • the input scope may be stored in a temporary data structure or may be persisted on permanent storage.
  • an interface may be invoked at step 306 to discover what input scopes were set and are available for use. For example, an advanced input method may discover whether there is any input scope set for a particular text field of executable code.
  • an input method may get an available input scope such as an individual input scope, a set of input scopes, a regular expression defining an input scope, or a list of words or phrases for that text field of executable code.
  • the input scope obtained may be used at step 310 for recognizing input for the text field of the executable software code. By restricting the language model used by a recognizer of an input method to the type of text input expected by the executable code for the text field, higher accuracy for the recognition rate may be achieved.
  • a developer of executable code may use the present invention to tag text input fields of executable code to achieve a higher recognition rate by advanced input methods. For example, a developer may choose to create a Real Estate Request form designed for use with a tablet personal computer that recognizes handwriting to allow real estate agents to complete such a form using handwriting.
  • the developer may review the available interfaces of the present invention for setting input scope and the pre-defined formats of input scope for different types of text input fields.
  • the developer may tag the input text fields and controls in the request form.
  • the developer may be pleased to find that he can also easily combine predefined formats such as a format for the date and a format for the time for use by a “Date/Time” field. Additionally, the developer may find that he can add in a list for a given field. Note that the list may improve recognition for input into the given field and may also be used by a real estate agent to select an item from the displayed list for input into a field of the form. For any fields that may require a custom format of input scope, the developer may define such a custom input scope using a regular expression. For easy use and access by developers of such applications, the interfaces and predefined formats for input scope of the present invention may be packaged in a software development kit (SDK) or other form of distribution.
  • SDK software development kit
  • the present invention may also provide a way for an application to supply context information for its specific text input fields without needing to modify the application itself.
  • context information may be provided by using a context tagging utility so that existing applications may be able to benefit from use of the present invention for increasing accuracy of recognition for text input fields by advanced input methods.
  • Context tagging as used herein means associating an input scope with a text input field or control of an application or executable code.
  • the context information tagged may be loaded for the existing applications and any advanced input methods used for input recognition may be updated for using the loaded context information.
  • the existing application or executable code may be left unmodified but may still enjoy the benefit of the present invention by means external to the application or executable code.
  • a manifest file may be created that may contain input scope information for the application or executable code.
  • the context tagging tool may be used in this embodiment to tag a specific text input field in executable code with an input scope.
  • the tool may then create and write this mapping in turn into a manifest file.
  • the tool may additionally ensure that the manifest file is stored in the right location for the specific application or executable code.
  • Application developers may alternatively create this manifest file directly and may also edit a manifest file.
  • An advanced input method may be updated with instructions to look for a manifest file associated with the executable code and to look within the manifest file for an input scope associated with a specific text input field.
  • an advanced input method may read the context information and then pass the context information on to a recognizer for use in recognition of input by the advanced input method for the text input field.
  • FIG. 4 of the drawings there is shown a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method using a context tagging utility.
  • Those skilled in the art will appreciate that the functionality implemented within the blocks illustrated in the diagram may be implemented as separate components or the functionality of several or all of the blocks may be implemented within a single component.
  • the functionality of the context component 202 may be included in the context client 208 .
  • part of the functionality for the manifest interface in the context tagging tool 402 may be implemented in a separate component.
  • Any executable code 135 that expects text input to a field may have context information for that field tagged by a context tagging tool 402 .
  • the context tagging tool 402 may be any type of executable software code such as a kernel component, an application program, a linked library, and so forth.
  • the context tagging tool 402 may tag a specific text input field in executable code with an input scope.
  • the context tagging tool 402 may include a user interface 404 , a control interface 406 , and a manifest interface 408 .
  • the user interface 404 may include a screen for selecting executable code to tag, a tag control screen, a select control screen, a screen to manage a phrase list, and a screen to manage custom input scope.
  • the control interface 406 may include an interface, such as a SetInputScope Interface 204 , for setting an input scope for a specific text input field of executable code 135 .
  • the manifest interface 408 may create or open a manifest 410 and write the mapping of an input scope for a specific text input field into the manifest 410 .
  • the manifest interface 408 may additionally ensure that the manifest 410 is stored along with the program files for the specific application or executable code 135 .
  • the manifest 410 may be a file, such as an XML file, or other storage object that contains context information for a text input field. For example, an email name field may be defined as a URL input scope in a manifest 410 .
  • a context component 202 may access context information in the manifest 410 by invoking an interface, such as InputScopeCollection Interface 206 .
  • the context component 202 includes an interface, such as an InputScopeCollection Interface 206 , for accessing an input scope for a text input field of executable code 135 that is stored in the manifest 410 .
  • the context component may be any executable software code including a kernel component, an application component, a component of a linked library, an object, and so forth.
  • a context client 208 such as one or more Input Method Editors 210 , a Handwriting Recognizer 212 , a Speech Recognizer 214 , or other recognizer of any additional type of input method, may query the InputScopeCollection Interface 206 included as part of the context component 202 to obtain an input scope set for executable code 135 .
  • This architecture may allow an existing application or other executable code that expects text input to fields or forms to provide context of input scope in a general way without interacting directly with the advanced input methods and without requiring modification of the existing application or executable code.
  • FIG. 5 is a flowchart generally representing the steps undertaken by the system for providing context information of executable code to an input method using a context tagging utility.
  • an application or executable code is selected for tagging its text input fields with an input scope at step 502 .
  • the context tagging tool 402 may be launched and an application or executable code 135 may be selected to have its text input fields tagged with an input scope.
  • a field or control of the executable code may be selected for tagging with an input scope at step 504 .
  • an input scope may be selected at step 506 for associating with the field or control.
  • the input scope selected may be a list of input scopes, a list of words or phrases, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope.
  • a tag associating the selected field or control with the selected input scope is added to a manifest 410 .
  • an advanced input method may obtain the tag associating a field or control with an input scope from the manifest.
  • an advanced input method may query the InputScopeCollection Interface 206 included as part of the context component 202 to obtain the tag from the manifest.
  • the input scope obtained may be applied at step 512 for recognizing input for the text field of the executable software code.
  • the input scope may be an individual input scope, a set of input scopes, a regular expression defining an input scope, or a list of words or phrases.
  • Application of the input scope by the recognizer may restrict the language model used to the type of text input expected by the executable code for the text field to achieve higher accuracy in recognition of the input.
  • the context tagging tool 402 may include a user interface 404 for tagging text input fields or controls of an existing application or executable code with an input scope.
  • FIG. 6 is an exemplary illustration generally representing an embodiment of a screen of the user interface 404 for selecting an application or executable code.
  • the welcome screen 602 may include a scrollable list of installed applications or executable code 604 from which an application may be selected (by a touch pad or mouse or any other way) for tagging its text input fields or controls with an input scope.
  • FIG. 7 is an exemplary illustration generally representing an embodiment of a screen of the user interface 404 for tagging a field or control with an input scope.
  • the screen 702 labeled “Tag Controls” may generally include a display area 704 for selecting a control to tag.
  • the select control screen 802 of FIG. 8 may be displayed.
  • FIG. 8 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for selecting a field or control.
  • the select control screen 802 may include a display area 804 for viewing control information from the application selected in the welcome screen 602 .
  • a field or control may be marked for tagging via screen 802 by activating the “Ok” button in display area 804 to select a control or field.
  • a display area 708 for selecting one or more input scopes to be associated with the control or field previously selected in display area 704 .
  • the associated context tag may be added or updated in the manifest 410 by activating the “Add” button illustrated in display area 710 .
  • Controls or fields that have been added or updated in the manifest 410 may be listed in the display area 706 labeled “Tagged Controls”.
  • the user interface 404 may include a phrase list editor as shown on the “Manage Phrase List” screen 902 of FIG. 9 .
  • FIG. 9 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a phrase list.
  • a phrase list editor 904 may be used to create, edit and manage phrase lists that may be available as an input scope in display area 708 for a text input field or control. Available phrase lists may be displayed in display area 906 for convenience in deleting an existing phrase list or creating a new phrase list.
  • the user interface 404 may include a custom input scope editor as shown on the “Manage Custom Scopes” screen 1002 of FIG. 10 .
  • FIG. 10 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a phrase list.
  • a phrase list editor 904 may be used to create, edit and manage phrase lists that may be available as an input scope in display area 708 for a text input field or control. Available phrase
  • a custom input scope editor 1004 may be used to define, edit and manage custom input scopes that may be available as an input scope in display area 708 for a text input field or control. Available custom input scopes may be displayed in display area 1006 for convenience in deleting an existing custom input scope or creating a new custom input scope.
  • the user interface 404 of the context tagging tool described enables any executable code or application to benefit from use of the present invention for increasing accuracy of recognition without needing to modify the application or executable code itself.
  • the present invention may be enhance any executable code or application such as real estate request forms, online registration forms, ecommerce order forms, online payment forms, and so forth. It provides a format for context information that may include a combination of input scopes, word lists, and regular expressions along with an interface for attaching it to a text input field of executable code.
  • the present invention provides an improved system and method for providing context information of executable code to an input method.
  • the architecture of the present invention defines a common and unified context representation that applications may use to specify context properties for text input fields to improve the user experience for entry of text input via advanced input methods such as handwriting, speech, input method editors and so forth.
  • the context information is extensible and developers can provide more detailed context constraints as desired.
  • the present invention provides a framework with interfaces for supporting application authoring platforms to allow application developers to easily specify such context information to the system and have it reliably forwarded to the correct input methods. The method and system thus provide significant advantages and benefits needed in contemporary computing.
  • the present invention also provides a solution for providing context information of existing executable code or applications by using a context tagging tool that does not need to modify the executable code or applications.
  • a manifest may be stored along with the program files and any advanced input methods use by the executable code or program may be updated with instructions for accessing the context information stored in the manifest.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • User Interface Of Digital Computer (AREA)
  • Stored Programmes (AREA)
  • Input From Keyboards Or The Like (AREA)

Abstract

An improved system and method for providing context information of executable code to an input method is provided. Advanced text input methods may be made aware of the type of text expected to be received as input so that input methods may achieve a higher accuracy in recognition of text input. Generic interfaces provide a framework for supporting application authoring platforms to allow application developers to easily specify context information to the system and have it reliably forwarded to the correct input methods. Additionally, a context tagging tool may associate specific text input fields of an existing application with a n input scope without modifying the application itself. The context tagging tool may create a manifest that contains tags associating the specific text input fields with an input scope. Any advanced input methods use by the application may be updated with instructions for accessing the context information stored in the manifest.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application is a divisional of U.S. patent application Ser. No. 10/850,844, filed May 21, 2004, entitled SYSTEM AND METHOD FOR PROVIDING CONTEXT TO AN INPUT METHOD BY TAGGING EXISTING APPLICATIONS, which is a divisional of U.S. patent application Ser. No. 10/693,330, filed Oct. 24, 2003, entitled SYSTEM AND METHOD FOR PROVIDING CONTEXT TO AN INPUT METHOD, and incorporates the foregoing applications by reference in their entirety.
  • FIELD OF THE INVENTION
  • The invention relates generally to computer systems, and more particularly to an improved system and method for providing context to an input method.
  • BACKGROUND OF THE INVENTION
  • Advanced text input methods such as handwriting, speech, and Input Method Editors (IMEs) are often limited to leveraging language rules and a language dictionary as the primary forms of context used to achieve accuracy in recognition of text input. Contextual information such as unigrams or n-grams has been traditionally provided as part of the language model to such input methods to increase accuracy in recognition of natural language input. Unfortunately, some of the most common fields of applications and of forms expect input that may not conform to the language rules of a specific language and may not even conform to the vocabulary of a specific language. For example, an email field may expect an email address as input. Most, if not all, email addresses do not conform to the language rules or vocabulary of a specific language. English language rules which require, for example, a space between words do not apply to an email address.
  • Similarly, a field may expect a Uniform Resource Locator (URL), which also may not conform to the language rules or vocabulary of a specific language. As a result, such input methods may be severely limited in their ability to accurately recognize input for these types of fields. Users consequently may have an unsatisfactory experience when using such input methods that result in poor recognition accuracy for these types of fields.
  • Furthermore, in applications where the vocabulary may be restricted, such as in command and control applications, the context has been traditionally constrained by restricting the dictionary of the language to fewer words. However, this technique has been limited in its use by a single application for a specific input method. Multiple input methods could not use this technique for constraining context without implementing the technique for each separate input method.
  • What is needed is a way for advanced text input methods to be made aware of the type of text expected to be received as input so that higher accuracy in recognition of text input may be achieved. Additionally, such a system should allow any input method to use the context provided by an application so that the user may switch between input methods to input the information for the field.
  • SUMMARY OF THE INVENTION
  • Briefly, the present invention provides an improved system and method for providing context information of executable code to an input method. Advanced text input methods may be made aware of the type of text expected to be received as input so that such input methods may achieve a higher accuracy in recognition of text input. To this end, an architecture is provided with a generic interface for supplying context information so that applications can provide input scope for any of their fields expecting text input. Furthermore, any input method may use the context information provided by an application. Consequently, users may switch between input methods to input information to the application without loss of the context information.
  • The present invention additionally provides a system of components including a context component with generic interfaces and a context tagging utility. The generic interfaces provide a framework for supporting application authoring platforms to allow application developers to easily specify context information to the system and have it reliably forwarded to the correct input methods. Such context information may include a common input scope, a set of input scopes, a word or phrase list, a custom input scope defined by a regular expression or other grammar.
  • In addition to providing a system and method for development of new applications, the present invention may also support existing applications without needing to modify the application itself by providing a context tagging tool for associating specific text input fields of an application with an input scope. The context tagging tool may create a manifest that contains tags associating the specific text input fields with an input scope. Such a manifest may be stored along with the program files. Any advanced input methods use by the application may be updated with instructions for accessing the context information stored in the manifest. Thus, existing applications may also benefit from use of the present invention for increasing accuracy of recognition for text input fields by advanced input methods.
  • Advantageously, the context tagging tool includes a user interface for tagging text input fields or controls of an existing application or executable code with an input scope. The user interface allows a text input field or control and an input scope to be selected, and their resulting association to be added to the manifest. Additionally, the user interface may include a phrase list editor and a custom input scope editor for creating, editing and managing a phrase list and a custom input scope respectively.
  • Other advantages will become apparent from the following detailed description when taken in conjunction with the drawings, in which:
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram generally representing a computer system into which the present invention may be incorporated;
  • FIG. 2 is a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method, in accordance with an aspect of the present invention;
  • FIG. 3 is a flowchart generally representing example steps undertaken by the system for providing context information of executable code to an input method, in accordance with an aspect of the present invention;
  • FIG. 4 is a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method using a context tagging utility, in accordance with an aspect of the present invention;
  • FIG. 5 is a flowchart generally representing example steps undertaken by the system for providing context information of executable code to an input method using a context tagging utility, in accordance with an aspect of the present invention;
  • FIG. 6 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging utility for selecting an application or executable code, in accordance with an aspect of the present invention;
  • FIG. 7 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging utility for tagging a field or control with an input scope, in accordance with an aspect of the present invention;
  • FIG. 8 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for selecting a field or control, in accordance with an aspect of the present invention;
  • FIG. 9 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a phrase list, in accordance with an aspect of the present invention; and
  • FIG. 10 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a custom scope, in accordance with an aspect of the present invention.
  • DETAILED DESCRIPTION Exemplary Operating Environment
  • FIG. 1 illustrates an example of a suitable computing system environment 100 on which the invention may be implemented. The computing system environment 100 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Neither should the computing environment 100 be interpreted as having any dependency or requirement relating to anyone or combination of components illustrated in the exemplary operating environment 100.
  • The invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to: personal computers, server computers, hand-held or laptop devices, tablet devices, headless servers, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in local and/or remote computer storage media including memory storage devices.
  • With reference to FIG. 1, an exemplary system for implementing the invention includes a general purpose computing device in the form of a computer 110. Components of the computer 110 may include, but are not limited to, a processing unit 120, a system memory 130, and a system bus 121 that couples various system components including the system memory to the processing unit 120. The system bus 121 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced rSA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCr) bus also known as Mezzanine bus.
  • The computer 110 typically includes a variety of computer-readable media. Computer-readable media can be any available media that can be accessed by the computer 110 and includes both volatile and nonvolatile media, and removable and non-removable media. By way of example, and not limitation, computer-readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by the computer 110. Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer-readable media.
  • The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation, FIG. 1 illustrates operating system 134, application programs 135, other program modules 136 and program data 137.
  • The computer 110 may also include other removable/nonremovable, volatile/nonvolatile computer storage media. By way of example only, FIG. 1 illustrates a hard disk drive 141 that reads from or writes to non-removable, nonvolatile magnetic media, a magnetic disk drive 151 that reads from or writes to a removable, nonvolatile magnetic disk 152, and an optical disk drive 155 that reads from or writes to a removable, nonvolatile optical disk 156 such as a CD ROM or other optical media. Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The hard disk drive 141 is typically connected to the system bus 121 through a nonremovable memory interface such as interface 140, and magnetic disk drive 151 and optical disk drive 155 are typically connected to the system bus 121 by a removable memory interface, such as interface 150.
  • The drives and their associated computer storage media, discussed above and illustrated in FIG. 1, provide storage of computer-readable instructions, data structures, program modules and other data for the computer 110. In FIG. 1, for example, hard disk drive 141 is illustrated as storing operating system 144, application programs 145, other program modules 146 and program data 147. Note that these components can either be the same as or different from operating system 134, application programs 135, other program modules 136, and program data 137. Operating system 144, application programs 145, other program modules 146, and program data 147 are given different numbers herein to illustrate that, at a minimum, they are different copies. A user may enter commands and information into the computer 110 through input devices such as a tablet, or electronic digitizer, 164, a microphone 163, a keyboard 162 and pointing device 161, commonly referred to as mouse, trackball or touch pad. Other input devices not shown in FIG. 1 may include a joystick, game pad, satellite dish, scanner, or other devices including a device that contains a biometric sensor, environmental sensor, position sensor, or other type of sensor. These and other input devices are often connected to the processing unit 120 through a user input interface 160 that is coupled to the system bus, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB). A monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190. The monitor 191 may also be integrated with a touch-screen panel or the like. Note that the monitor and/or touch screen panel can be physically coupled to a housing in which the computing device 110 is incorporated, such as in a tablet-type personal computer. In addition, computers such as the computing device 110 may also include other peripheral output devices such as speakers 195 and printer 196, which may be connected through an output peripheral interface 194 or the like.
  • The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in FIG. 1. The logical connections depicted in FIG. 1 include a local area network (LAN) 171 and a wide area network (WAN) 173, but may also include other networks. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160 or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation, FIG. 1 illustrates remote application programs 185 as residing on memory device 181. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
  • Providing Context to an Input Method
  • The present invention is generally directed towards a method and system for providing context information of executable code to an input method. As used herein, context information generally means an input scope. An input scope is a subset of a language that is used to define what words, numbers, and punctuation can be written and may also specify in what order they may be written. An input scope can be used by applications to restrict the language model used by a recognizer of an input method to the type of text input an application is expecting in a text field. As will be seen, the invention may enable advanced input methods to achieve a higher accuracy recognition rate for text input to application fields by providing an architecture that supports applications or forms to specify what type of text input they are expecting in their text fields. Many text input fields in forms and dialogs are strongly typed, like the fields in a web order form or in a dialog window for updating personal contacts. The information about the type of text expected can greatly improve accuracy when specified to the recognition engines of the advanced input methods.
  • The architecture of the present invention allows applications that expect text input to fields or forms to provide this context information in a general way without interacting directly with the advanced input methods. To this end, the architecture provides a generic interface for supplying context information so that applications can provide input scope for any of their fields expecting text input. The system and method also provide a generic API to allow any input method to use the context information provided by the application to improve recognition accuracy. Furthermore, since any input method may use the context information provided by the application, a user may switch between input methods to input information to the application without loss of the context information. As will be understood, the various block diagrams, flow charts and scenarios described herein are only examples, and there are many other scenarios to which the present invention will apply.
  • Turning to FIG. 2 of the drawings, there is shown a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method. Those skilled in the art will appreciate that the functionality implemented within the blocks illustrated in the diagram may be implemented as separate components or the functionality of several or all of the blocks may be implemented within a single component. For example, the functionality of the context component 202 may be included in the context client 208. Or the functionality for the InputScopeCollection interface in the context component 202 may be implemented in a separate component.
  • Any executable code 135 that expects text input to a field may provide context information for that field to a context component 202 by invoking an interface, such as SetInputScope Interface 204. The executable code 135 may be any type of executable software code such as a kernel component, an application program, a dialog box or form, a script, a linked library, a linked or embedded object, and so forth. The context component 202 includes an interface, such as a SetInputScope Interface 204, for setting an input scope of executable code 135, and also an interface, such as a InputScopeCollection Interface, for obtaining an input scope that has been set for a text input field of executable code 135. The context component may be any executable software code including a kernel component, an application component, a component of a linked library, an object, and so forth. A context client 208 such as one or more Input Method Editors 210, a Handwriting Recognizer 212, a Speech Recognizer 214, or other recognizer of any additional type of input method, may query the InputScopeCollection interface 206 included as part of the context component 202 to obtain an input scope set for executable code 135. This architecture may allow applications or other executable code that expect text input to fields or forms to provide context of input scope in a general way without interacting directly with the advanced input methods.
  • The SetInputScope Interface 204 shown in FIG. 2 may be an API, an object, a control or other executable code. For example, in one embodiment the SetInputScope Interface 204 may be an API named SetInputScopen. In this embodiment, the SetInputScope API may associate a control or text input field with one common input scope or one wordlist. For example, the SetInputScope API may have the following programming language declaration:
  • HRESULT SetInputScope (
      • [in] HWND hwnd;
      • [in] InputScope inputscope).
  • This API may expect a window handle and a pointer to a list of input scopes. This API may be used to set a common input scope defined by a parameter of type InputScope by invoking the API as SetInputScope (hwndMe, IS_URL), where IS URL may be a parameter signifying an internally defined format with an associated fixed list of characters. Additionally, this API may used to set a word list by passing the word list as a parameter of type InputScope by invoking the API as SetInputScope (hwndMe, {“male”, “female”}).
  • In another embodiment, the SetInputScope Interface 204 may be an API named “SetInputScopes”. In this embodiment, the SetInputScopes API may associate a control or text input field with one common input scope, multiple common input scopes, one word list, or one custom input scope. The custom input scope may be defined by a regular expression or any other way including a grammar like that specified in W3C Speech Recognition Grammar Specification (SRGS). For example, the SetInputScopes API may have the following programming language declaration:
  • HRESULT SetInputScope (
      • [in] HWND hwnd;
      • [in] const InputScope *pInputScopes;
      • [in] UINT cInputScopes;
      • [in] WCHAR **ppszPhraseList;
      • [in] UINT cPhrases;
      • [in] WCHAR *pszRegExp;
      • [in] WCHAR *pszSRGS).
  • This API may expect a window handle, a pointer to a list of input scopes, the number of input scopes in the list, a pointer to a phrase list, the number of phrases in the list, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope. This API may be used to set several common input scopes passed by a parameter list of input scopes by invoking the API as SetInputScopes (hwndMe, {IS_DEFAULT, Is PersonalName_FullName, I S_EMAIL_USERNAME, IS_EMAIL SMTPEMAILADDRESS}, 4, NULL, NULL, NULL, NULL) where IS_DEFAULT, IS_PERSONALNAME_FULLNAME, IS_EMAIL_USERNAME, and IS EMAIL_SMTPEMAILADDRESS may each signify an internally defined format with an associated fixed list of characters. Additionally, this API may used to set a list of words or phrases by passing the list as a parameter of type InputScope by invoking the API as SetInputScopes (hwndMe, {IS PHRASELIST, IS_DEFAULT}, 2, {“male”, “female”}, 2, NULL, NULL). Additionally, this API may be used to set a custom scope of input defined by a regular expression, grammar, or other definition, such as by invoking the API as SetInputScopes (hwndMe, IS SSN, 2, NULL, NULL, IS DIGITS. “−”.IS DIGITS.“ ”.IS_DIGITS, NULL).
  • In either embodiment, such an API may support coercion of the input according to the definition of the input scope. Coercion means herein to constrain the recognition of the input to the definition of the input scope. In this case, a recognizer of an input method is constrained to conform to the exact definition of the input scope and may not use another definition of input scope. If coercion of the input is not specified, a recognizer of an input method may interpret the input scope specified as a recommendation, but may not constrain recognition to just that definition. In yet another embodiment, if a custom input scope definition conflicts with a common input scope or a wordlist, the definition of custom input scope may take precedence over the common input scope of wordlist.
  • The present invention is advantageously extensible so that additional APIs may be added. For instance, an input scope may be set using an API that defines an XML schema such as:
  • HRESULT SetInputScopeXML (
      • [in] HWND hwnd
      • [in] WCHAR *pszXML).
  • The InputScopeCollection Interface 206 shown in FIG. 2 may be an API, an object, a control or other executable code. For example, in one embodiment the InputScopeCollection Interface 206 may be an object with methods that may be invoked by an input method for obtaining the input scope for a text input field specified by any executable code. In this exemplary embodiment, the recognizer of an input method may call a constructor of the object with a valid window handle for the application and then may access the public properties and may also call the public methods to access the different input scopes associated with the window handle for the application. The object may get a set of input scopes associated with a control, the individual input scopes from the set associated with the control, a regular expression from the set associated with the control, and a list of phrases from the set associated with the control. The class definition for an instance of such an object may be for example:
  • Class Name
  • public InputScopeCollection
  • Public InputScopeCollection (IntPtr hwnd);
  • Public bool HasInputScopes;
  • Public int Count;
  • Public InputScope [ ] InputScopes;
  • Public string RegularExpression;
  • Public string [ ] Phrases;
  • methods
  • public string Phrase (int index)
  • public int InputScopes (int index)
  • public string InputScopeEnumName (int index)
  • public override string ToString ( )
  • The constructor “InputScopeCollection” may take a handle to a window and may find a set of input scopes that may be associated with it. The public property “HasInputScopes” may determine whether there is any input scope associated with the control. The public property “Count” may return the number of input scopes that may be associated with the control. The public property “InputScopes” may return an array containing a set of input scopes that may be associated with the control. The public property “RegularExpression” may return a regular expression associated with the control. And the public property “Phrases” may return a string array containing the phrases associated with the control.
  • Any number of methods may be provided by an object that is an embodiment of the InputScopeCollection Interface 206 for obtaining the input scope for a text input field. For example, in the exemplary class definition of InputScopeCollection above, the method “Phrase(int index)” may return a phrase that is indexed by a requested index. The method “InputScopes(int index)” may return an input scope that is indexed by a requested index. The method “InputScopeEnumName (int index)” may return a name of an input scope at a specific location index. And the method “ToString ( )” may return a string representation of an input scope for a specific instance. Those skilled in the art will appreciate that the interfaces represented in FIG. 2 are exemplary representations and that the present invention may be practiced using other interfaces defined for setting input scope and obtaining context information.
  • FIG. 3 is a flowchart generally representing the steps undertaken by the system for providing context information of executable code to an input method. First, any executable code may invoke an interface for setting a scope of input for a text field at step 302. Included among the settings in an interface for a scope of input may be a list of input scopes, a list of words or phrases, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope. Upon invoking such an interface, the input scope requested is set for a text field of executable code at step 304. The input scope may be stored in a temporary data structure or may be persisted on permanent storage. After the input scope is set, an interface may be invoked at step 306 to discover what input scopes were set and are available for use. For example, an advanced input method may discover whether there is any input scope set for a particular text field of executable code. At step 308, an input method may get an available input scope such as an individual input scope, a set of input scopes, a regular expression defining an input scope, or a list of words or phrases for that text field of executable code. Finally, the input scope obtained may be used at step 310 for recognizing input for the text field of the executable software code. By restricting the language model used by a recognizer of an input method to the type of text input expected by the executable code for the text field, higher accuracy for the recognition rate may be achieved.
  • A developer of executable code may use the present invention to tag text input fields of executable code to achieve a higher recognition rate by advanced input methods. For example, a developer may choose to create a Real Estate Request form designed for use with a tablet personal computer that recognizes handwriting to allow real estate agents to complete such a form using handwriting. During design and development of the executable code for this application, the developer may review the available interfaces of the present invention for setting input scope and the pre-defined formats of input scope for different types of text input fields. Upon discovering that there are available predefined formats suitable for text input fields, the developer may tag the input text fields and controls in the request form. The developer may be pleased to find that he can also easily combine predefined formats such as a format for the date and a format for the time for use by a “Date/Time” field. Additionally, the developer may find that he can add in a list for a given field. Note that the list may improve recognition for input into the given field and may also be used by a real estate agent to select an item from the displayed list for input into a field of the form. For any fields that may require a custom format of input scope, the developer may define such a custom input scope using a regular expression. For easy use and access by developers of such applications, the interfaces and predefined formats for input scope of the present invention may be packaged in a software development kit (SDK) or other form of distribution.
  • Context Tagging Tool for Providing Context to an Input METHOD
  • In another embodiment, the present invention may also provide a way for an application to supply context information for its specific text input fields without needing to modify the application itself. Such context information may be provided by using a context tagging utility so that existing applications may be able to benefit from use of the present invention for increasing accuracy of recognition for text input fields by advanced input methods. Context tagging as used herein means associating an input scope with a text input field or control of an application or executable code. In this embodiment, the context information tagged may be loaded for the existing applications and any advanced input methods used for input recognition may be updated for using the loaded context information. Advantageously, the existing application or executable code may be left unmodified but may still enjoy the benefit of the present invention by means external to the application or executable code.
  • In one embodiment for providing context information through external means, a manifest file may be created that may contain input scope information for the application or executable code. There may be a manifest file created in this embodiment by a context tagging tool for each application or executable code and each manifest file may be stored along with other program files of the application or executable code. The context tagging tool may be used in this embodiment to tag a specific text input field in executable code with an input scope. The tool may then create and write this mapping in turn into a manifest file. The tool may additionally ensure that the manifest file is stored in the right location for the specific application or executable code. Application developers may alternatively create this manifest file directly and may also edit a manifest file.
  • An advanced input method may be updated with instructions to look for a manifest file associated with the executable code and to look within the manifest file for an input scope associated with a specific text input field. Upon finding an input scope associated with a specific text input field, an advanced input method may read the context information and then pass the context information on to a recognizer for use in recognition of input by the advanced input method for the text input field.
  • Turning to FIG. 4 of the drawings, there is shown a block diagram generally representing an exemplary architecture of system components for providing context information of executable code to an input method using a context tagging utility. Those skilled in the art will appreciate that the functionality implemented within the blocks illustrated in the diagram may be implemented as separate components or the functionality of several or all of the blocks may be implemented within a single component. For example, the functionality of the context component 202 may be included in the context client 208. Or part of the functionality for the manifest interface in the context tagging tool 402 may be implemented in a separate component.
  • Any executable code 135 that expects text input to a field may have context information for that field tagged by a context tagging tool 402. The context tagging tool 402 may be any type of executable software code such as a kernel component, an application program, a linked library, and so forth. The context tagging tool 402 may tag a specific text input field in executable code with an input scope. The context tagging tool 402 may include a user interface 404, a control interface 406, and a manifest interface 408. The user interface 404 may include a screen for selecting executable code to tag, a tag control screen, a select control screen, a screen to manage a phrase list, and a screen to manage custom input scope. The control interface 406 may include an interface, such as a SetInputScope Interface 204, for setting an input scope for a specific text input field of executable code 135. And the manifest interface 408 may create or open a manifest 410 and write the mapping of an input scope for a specific text input field into the manifest 410. The manifest interface 408 may additionally ensure that the manifest 410 is stored along with the program files for the specific application or executable code 135. The manifest 410 may be a file, such as an XML file, or other storage object that contains context information for a text input field. For example, an email name field may be defined as a URL input scope in a manifest 410. A context component 202 may access context information in the manifest 410 by invoking an interface, such as InputScopeCollection Interface 206. In this embodiment, the context component 202 includes an interface, such as an InputScopeCollection Interface 206, for accessing an input scope for a text input field of executable code 135 that is stored in the manifest 410. The context component may be any executable software code including a kernel component, an application component, a component of a linked library, an object, and so forth. A context client 208 such as one or more Input Method Editors 210, a Handwriting Recognizer 212, a Speech Recognizer 214, or other recognizer of any additional type of input method, may query the InputScopeCollection Interface 206 included as part of the context component 202 to obtain an input scope set for executable code 135. This architecture may allow an existing application or other executable code that expects text input to fields or forms to provide context of input scope in a general way without interacting directly with the advanced input methods and without requiring modification of the existing application or executable code.
  • FIG. 5 is a flowchart generally representing the steps undertaken by the system for providing context information of executable code to an input method using a context tagging utility. First, an application or executable code is selected for tagging its text input fields with an input scope at step 502. For this purpose, the context tagging tool 402 may be launched and an application or executable code 135 may be selected to have its text input fields tagged with an input scope. Next, a field or control of the executable code may be selected for tagging with an input scope at step 504. After the field or control is selected, an input scope may be selected at step 506 for associating with the field or control. The input scope selected may be a list of input scopes, a list of words or phrases, a regular expression defining an input scope, or a grammar such as SRGS defining an input scope. At step 508 a tag associating the selected field or control with the selected input scope is added to a manifest 410. After a field or control is tagged with an input scope and stored in the manifest, an advanced input method may obtain the tag associating a field or control with an input scope from the manifest. For example, an advanced input method may query the InputScopeCollection Interface 206 included as part of the context component 202 to obtain the tag from the manifest. Finally, the input scope obtained may be applied at step 512 for recognizing input for the text field of the executable software code. As noted previously, the input scope may be an individual input scope, a set of input scopes, a regular expression defining an input scope, or a list of words or phrases. Application of the input scope by the recognizer may restrict the language model used to the type of text input expected by the executable code for the text field to achieve higher accuracy in recognition of the input.
  • The context tagging tool 402 may include a user interface 404 for tagging text input fields or controls of an existing application or executable code with an input scope. FIG. 6 is an exemplary illustration generally representing an embodiment of a screen of the user interface 404 for selecting an application or executable code. The welcome screen 602 may include a scrollable list of installed applications or executable code 604 from which an application may be selected (by a touch pad or mouse or any other way) for tagging its text input fields or controls with an input scope.
  • FIG. 7 is an exemplary illustration generally representing an embodiment of a screen of the user interface 404 for tagging a field or control with an input scope. The screen 702 labeled “Tag Controls” may generally include a display area 704 for selecting a control to tag. Upon activating a select control button as illustrated in display area 704 of the tag control screen 702, the select control screen 802 of FIG. 8 may be displayed. FIG. 8 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for selecting a field or control. The select control screen 802 may include a display area 804 for viewing control information from the application selected in the welcome screen 602. A field or control may be marked for tagging via screen 802 by activating the “Ok” button in display area 804 to select a control or field.
  • Returning to the tag control screen 702 of FIG. 7, there is also shown a display area 708 for selecting one or more input scopes to be associated with the control or field previously selected in display area 704. Once the input scope has been selected and thereby associated with the previously selected control or field, the associated context tag may be added or updated in the manifest 410 by activating the “Add” button illustrated in display area 710. Controls or fields that have been added or updated in the manifest 410 may be listed in the display area 706 labeled “Tagged Controls”.
  • Additionally, the user interface 404 may include a phrase list editor as shown on the “Manage Phrase List” screen 902 of FIG. 9. FIG. 9 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a phrase list. A phrase list editor 904 may be used to create, edit and manage phrase lists that may be available as an input scope in display area 708 for a text input field or control. Available phrase lists may be displayed in display area 906 for convenience in deleting an existing phrase list or creating a new phrase list. Similarly, the user interface 404 may include a custom input scope editor as shown on the “Manage Custom Scopes” screen 1002 of FIG. 10. FIG. 10 is an exemplary illustration generally representing a screen of a graphical user interface of a context tagging tool for managing a custom scope. A custom input scope editor 1004 may be used to define, edit and manage custom input scopes that may be available as an input scope in display area 708 for a text input field or control. Available custom input scopes may be displayed in display area 1006 for convenience in deleting an existing custom input scope or creating a new custom input scope.
  • Advantageously, the user interface 404 of the context tagging tool described enables any executable code or application to benefit from use of the present invention for increasing accuracy of recognition without needing to modify the application or executable code itself. The present invention may be enhance any executable code or application such as real estate request forms, online registration forms, ecommerce order forms, online payment forms, and so forth. It provides a format for context information that may include a combination of input scopes, word lists, and regular expressions along with an interface for attaching it to a text input field of executable code.
  • As can be seen from the foregoing detailed description, the present invention provides an improved system and method for providing context information of executable code to an input method. The architecture of the present invention defines a common and unified context representation that applications may use to specify context properties for text input fields to improve the user experience for entry of text input via advanced input methods such as handwriting, speech, input method editors and so forth. The context information is extensible and developers can provide more detailed context constraints as desired. As is now understood, the present invention provides a framework with interfaces for supporting application authoring platforms to allow application developers to easily specify such context information to the system and have it reliably forwarded to the correct input methods. The method and system thus provide significant advantages and benefits needed in contemporary computing. Moreover, the present invention also provides a solution for providing context information of existing executable code or applications by using a context tagging tool that does not need to modify the executable code or applications. A manifest may be stored along with the program files and any advanced input methods use by the executable code or program may be updated with instructions for accessing the context information stored in the manifest.
  • While the invention is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.

Claims (21)

1. A method for providing context information to an input method, comprising the steps of:
selecting a text input field of executable software code;
selecting a scope of input for the text field of the executable software code;
adding a tag associating the selected field with the selected input scope to a manifest; and
persistently storing the manifest.
2. The method of claim 1 further comprising selecting executable software code having the text input field.
3. The method of claim 2 wherein selecting executable software code having the text input field comprises runtime identification of a text input control.
4. The method of claim 1 wherein selecting the scope of input comprises selecting a list of input scopes.
5. The method of claim 1 wherein selecting the scope of input comprises selecting a list of words or phrases.
6. The method of claim 1 wherein selecting the scope of input comprises selecting a regular expression defining the input scope.
7. The method of claim 1 wherein selecting the scope of input comprises selecting a grammar such as SRGS defining the input scope.
8. The method of claim 1 wherein selecting the scope of input comprises invoking an application programming interface for setting the scope of input for the text field of executable software code.
9. The method of claim 8 wherein invoking an application programming interface for setting a scope of input for a text field of executable software code comprises passing a common input scope.
10. The method of claim 9 wherein passing a common input scope comprises passing an identifier for a defined format with an associated fixed list of characters.
11. The method of claim 1 further comprising getting the tag associating the selected field with the selected input scope from the manifest.
12. The method of claim 11 wherein getting the tag comprises invoking an application programming interface for obtaining the scope of input set for the selected field.
13. The method of claim 1 further comprising applying the input scope for recognizing input for the text field.
14. The method of claim 13 wherein applying the input scope for recognizing input for the text field comprises restricting the language model used for recognizing input to the type of text input expected by the executable software code.
15. A computer-readable storage medium having stored computer-executable instructions for performing the method of claim 1.
16. A computer-readable medium having computer-executable components, comprising:
executable software code having a text input field;
a recognizer for an input method, the recognizer operably coupled to the executable software code for providing input to the text input field;
a context component operably coupled to the recognizer, the context component having an interface for obtaining a scope of input set by a context tagging tool for the text input field of the executable software.
17. A computer-readable medium having computer-executable components, comprising:
a context tagging tool for associating a text input field of executable software code with an input scope;
a context component having an interface for obtaining the input scope associated with the text input field of the executable software; and
a recognizer for an input method, the recognizer operably coupled to the context component for invoking the interface for obtaining the input scope associated with the text input field of the executable software.
18. A computer system for providing context information to an input method, comprising:
means for selecting a scope of input for a text field of executable software code;
means for adding a tag associating the selected field with the selected input scope to a manifest; and
means for persistently storing the manifest.
19. The computer system of claim 18 further comprising means for getting the tag associating the selected field with the selected input scope from the manifest.
20. The computer system of claim 19 further comprising means for obtaining the selected input scope for the selected field.
21. The computer system of claim 20 further comprising means for applying the input scope for recognizing input for the selected field.
US12/115,427 2003-10-24 2008-05-05 System and method for providing context to an input method by tagging existing applications Abandoned US20080208568A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/115,427 US20080208568A1 (en) 2003-10-24 2008-05-05 System and method for providing context to an input method by tagging existing applications

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/693,330 US7634720B2 (en) 2003-10-24 2003-10-24 System and method for providing context to an input method
US10/850,844 US7370275B2 (en) 2003-10-24 2004-05-21 System and method for providing context to an input method by tagging existing applications
US12/115,427 US20080208568A1 (en) 2003-10-24 2008-05-05 System and method for providing context to an input method by tagging existing applications

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/850,844 Division US7370275B2 (en) 2003-10-24 2004-05-21 System and method for providing context to an input method by tagging existing applications

Publications (1)

Publication Number Publication Date
US20080208568A1 true US20080208568A1 (en) 2008-08-28

Family

ID=34435464

Family Applications (3)

Application Number Title Priority Date Filing Date
US10/693,330 Expired - Fee Related US7634720B2 (en) 2003-10-24 2003-10-24 System and method for providing context to an input method
US10/850,844 Expired - Fee Related US7370275B2 (en) 2003-10-24 2004-05-21 System and method for providing context to an input method by tagging existing applications
US12/115,427 Abandoned US20080208568A1 (en) 2003-10-24 2008-05-05 System and method for providing context to an input method by tagging existing applications

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US10/693,330 Expired - Fee Related US7634720B2 (en) 2003-10-24 2003-10-24 System and method for providing context to an input method
US10/850,844 Expired - Fee Related US7370275B2 (en) 2003-10-24 2004-05-21 System and method for providing context to an input method by tagging existing applications

Country Status (5)

Country Link
US (3) US7634720B2 (en)
EP (1) EP1533694A3 (en)
JP (1) JP2005135398A (en)
KR (1) KR20050039536A (en)
CN (1) CN1609764A (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090216690A1 (en) * 2008-02-26 2009-08-27 Microsoft Corporation Predicting Candidates Using Input Scopes
US7634720B2 (en) 2003-10-24 2009-12-15 Microsoft Corporation System and method for providing context to an input method
US9672083B2 (en) 2012-07-12 2017-06-06 International Business Machines Corporation Operating a program code object in conjunction with an application context

Families Citing this family (62)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7941744B2 (en) * 2005-04-25 2011-05-10 Adp, Inc. System and method for electronic document generation and delivery
US8024349B1 (en) * 2005-07-25 2011-09-20 Shao Henry K String-based systems and methods for searching for real estate properties
US8452594B2 (en) * 2005-10-27 2013-05-28 Nuance Communications Austria Gmbh Method and system for processing dictated information
US7502788B2 (en) * 2005-11-08 2009-03-10 International Business Machines Corporation Method for retrieving constant values using regular expressions
US8670393B2 (en) 2006-04-20 2014-03-11 Qualcomm Incorporated Tagging language for broadcast radio
US20080043289A1 (en) * 2006-08-16 2008-02-21 Epip Pty Ltd. Regular Expressions for Electronic Submission of Documents
US8234623B2 (en) * 2006-09-11 2012-07-31 The Mathworks, Inc. System and method for using stream objects to perform stream processing in a text-based computing environment
US8635243B2 (en) * 2007-03-07 2014-01-21 Research In Motion Limited Sending a communications header with voice recording to send metadata for use in speech recognition, formatting, and search mobile search application
US8886545B2 (en) * 2007-03-07 2014-11-11 Vlingo Corporation Dealing with switch latency in speech recognition
US20110060587A1 (en) * 2007-03-07 2011-03-10 Phillips Michael S Command and control utilizing ancillary information in a mobile voice-to-speech application
US8838457B2 (en) * 2007-03-07 2014-09-16 Vlingo Corporation Using results of unstructured language model based speech recognition to control a system-level function of a mobile communications facility
US8886540B2 (en) * 2007-03-07 2014-11-11 Vlingo Corporation Using speech recognition results based on an unstructured language model in a mobile communication facility application
US20110054896A1 (en) * 2007-03-07 2011-03-03 Phillips Michael S Sending a communications header with voice recording to send metadata for use in speech recognition and formatting in mobile dictation application
US8949130B2 (en) 2007-03-07 2015-02-03 Vlingo Corporation Internal and external speech recognition use with a mobile communication facility
US20110054899A1 (en) * 2007-03-07 2011-03-03 Phillips Michael S Command and control utilizing content information in a mobile voice-to-speech application
US20110054900A1 (en) * 2007-03-07 2011-03-03 Phillips Michael S Hybrid command and control between resident and remote speech recognition facilities in a mobile voice-to-speech application
US20080221884A1 (en) * 2007-03-07 2008-09-11 Cerra Joseph P Mobile environment speech processing facility
US10056077B2 (en) 2007-03-07 2018-08-21 Nuance Communications, Inc. Using speech recognition results based on an unstructured language model with a music system
US20090030691A1 (en) * 2007-03-07 2009-01-29 Cerra Joseph P Using an unstructured language model associated with an application of a mobile communication facility
US20080221902A1 (en) * 2007-03-07 2008-09-11 Cerra Joseph P Mobile browser environment speech processing facility
US8949266B2 (en) * 2007-03-07 2015-02-03 Vlingo Corporation Multiple web-based content category searching in mobile search application
US8744337B2 (en) 2007-06-18 2014-06-03 Qualcomm Incorporated Apparatus and methods of enhancing radio programming
US8638219B2 (en) 2007-06-18 2014-01-28 Qualcomm Incorporated Device and methods of providing radio data system information alerts
US20090083768A1 (en) * 2007-09-20 2009-03-26 Hatalkar Atul N Context platform framework for aggregation, analysis and use of contextual information
US20090172637A1 (en) * 2007-12-28 2009-07-02 Microsoft Corporation Markup-based language for manifests
WO2011004367A1 (en) * 2009-07-09 2011-01-13 Eliyahu Mashiah Content sensitive system and method for automatic input language selection
EP4318463A3 (en) * 2009-12-23 2024-02-28 Google LLC Multi-modal input on an electronic device
US11416214B2 (en) 2009-12-23 2022-08-16 Google Llc Multi-modal input on an electronic device
US20110184723A1 (en) * 2010-01-25 2011-07-28 Microsoft Corporation Phonetic suggestion engine
US8782556B2 (en) 2010-02-12 2014-07-15 Microsoft Corporation User-centric soft keyboard predictive technologies
US9002924B2 (en) 2010-06-17 2015-04-07 Microsoft Technology Licensing, Llc Contextual based information aggregation system
CN102314222A (en) * 2010-06-30 2012-01-11 百度在线网络技术(北京)有限公司 Self-adaptive input method, equipment and system
US8732697B2 (en) 2010-08-04 2014-05-20 Premkumar Jonnala System, method and apparatus for managing applications on a device
US8352245B1 (en) 2010-12-30 2013-01-08 Google Inc. Adjusting language models
US8296142B2 (en) 2011-01-21 2012-10-23 Google Inc. Speech recognition using dock context
US9524531B2 (en) 2011-05-09 2016-12-20 Microsoft Technology Licensing, Llc Extensibility features for electronic communications
US8583948B2 (en) * 2011-07-01 2013-11-12 Intel Corporation Method, apparatus and system for determining an interface during a power state transition
US8224836B1 (en) 2011-11-02 2012-07-17 Google Inc. Searching in multiple languages
US9348479B2 (en) 2011-12-08 2016-05-24 Microsoft Technology Licensing, Llc Sentiment aware user interface customization
US8234350B1 (en) * 2011-12-19 2012-07-31 Seachange International, Inc. Systems and methods for generating targeted manifest files
US9378290B2 (en) 2011-12-20 2016-06-28 Microsoft Technology Licensing, Llc Scenario-adaptive input method editor
US8775165B1 (en) 2012-03-06 2014-07-08 Google Inc. Personalized transliteration interface
US9092728B2 (en) 2012-04-19 2015-07-28 Microsoft Technology Licensing, Llc Providing rule based analysis of content to manage activation of web extension
US10949230B2 (en) 2012-05-31 2021-03-16 Microsoft Technology Licensing, Llc Language lists for resource selection based on language text direction
US9639676B2 (en) 2012-05-31 2017-05-02 Microsoft Technology Licensing, Llc Login interface selection for computing environment user login
CN104428734A (en) * 2012-06-25 2015-03-18 微软公司 Input method editor application platform
JP5998690B2 (en) * 2012-07-10 2016-09-28 富士ゼロックス株式会社 Information processing apparatus and program
US8959109B2 (en) 2012-08-06 2015-02-17 Microsoft Corporation Business intelligent in-document suggestions
US9767156B2 (en) 2012-08-30 2017-09-19 Microsoft Technology Licensing, Llc Feature-based candidate selection
EP3030982A4 (en) 2013-08-09 2016-08-03 Microsoft Technology Licensing Llc Input method editor providing language assistance
US9842592B2 (en) 2014-02-12 2017-12-12 Google Inc. Language models using non-linguistic context
US9412365B2 (en) 2014-03-24 2016-08-09 Google Inc. Enhanced maximum entropy models
US20170046330A1 (en) * 2014-04-28 2017-02-16 Google Inc. Context specific language model for input method editor
CN105446711B (en) * 2014-08-08 2018-10-02 国际商业机器公司 Obtain the method and device of the contextual information for software development task
US9928232B2 (en) * 2015-02-27 2018-03-27 Microsoft Technology Licensing, Llc Topically aware word suggestions
US10134394B2 (en) 2015-03-20 2018-11-20 Google Llc Speech recognition using log-linear model
US9990341B2 (en) 2015-12-04 2018-06-05 International Business Machines Corporation Predictive approach to URL determination
US9978367B2 (en) 2016-03-16 2018-05-22 Google Llc Determining dialog states for language models
US10832664B2 (en) 2016-08-19 2020-11-10 Google Llc Automated speech recognition using language models that selectively use domain-specific model components
US10175770B2 (en) 2016-10-13 2019-01-08 International Business Machines Corporation Proactive input method editor switching
US10311860B2 (en) 2017-02-14 2019-06-04 Google Llc Language model biasing system
US10572826B2 (en) * 2017-04-18 2020-02-25 International Business Machines Corporation Scalable ground truth disambiguation

Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5936614A (en) * 1991-04-30 1999-08-10 International Business Machines Corporation User defined keyboard entry system
US5956423A (en) * 1991-06-17 1999-09-21 Microsoft Corporation Method and system for data entry of handwritten symbols
US6003050A (en) * 1997-04-02 1999-12-14 Microsoft Corporation Method for integrating a virtual machine with input method editors
US6281886B1 (en) * 1998-07-30 2001-08-28 International Business Machines Corporation Touchscreen keyboard support for multi-byte character languages
US6356866B1 (en) * 1998-10-07 2002-03-12 Microsoft Corporation Method for converting a phonetic character string into the text of an Asian language
US20030074647A1 (en) * 2001-10-12 2003-04-17 Andrew Felix G.T.I. Automatic software input panel selection based on application program state
US6654038B1 (en) * 2000-06-02 2003-11-25 Sun Microsystems, Inc. Keyboard navigation of non-focusable components
US20040225965A1 (en) * 2003-05-06 2004-11-11 Microsoft Corporation Insertion location tracking for controlling a user interface
US6826551B1 (en) * 2000-05-10 2004-11-30 Advanced Digital Systems, Inc. System, computer software program product, and method for producing a contextual electronic message from an input to a pen-enabled computing system
US20050086057A1 (en) * 2001-11-22 2005-04-21 Tetsuo Kosaka Speech recognition apparatus and its method and program
US7047200B2 (en) * 2002-05-24 2006-05-16 Microsoft, Corporation Voice recognition status display
US7251667B2 (en) * 2002-03-21 2007-07-31 International Business Machines Corporation Unicode input method editor
US7363228B2 (en) * 2003-09-18 2008-04-22 Interactive Intelligence, Inc. Speech recognition system and method
US7370275B2 (en) * 2003-10-24 2008-05-06 Microsoft Corporation System and method for providing context to an input method by tagging existing applications
US7496511B2 (en) * 2003-01-14 2009-02-24 Oracle International Corporation Method and apparatus for using locale-specific grammars for speech recognition
US7599837B2 (en) * 2004-09-15 2009-10-06 Microsoft Corporation Creating a speech recognition grammar for alphanumeric concepts

Family Cites Families (49)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE9100665U1 (en) 1991-01-21 1992-07-16 TELBUS Gesellschaft für elektronische Kommunikations-Systeme mbH, 85391 Allershausen Carrier element for integrated semiconductor circuits, especially for installation in chip cards
CA2089784C (en) * 1992-04-15 1996-12-24 William Joseph Anderson Apparatus and method for disambiguating an input stream generated by a stylus-based user interface
US5233681A (en) 1992-04-24 1993-08-03 International Business Machines Corporation Context-dependent speech recognizer using estimated next word context
US5390281A (en) 1992-05-27 1995-02-14 Apple Computer, Inc. Method and apparatus for deducing user intent and providing computer implemented services
JP3362913B2 (en) * 1993-05-27 2003-01-07 松下電器産業株式会社 Handwritten character input device
JP3423413B2 (en) 1994-06-21 2003-07-07 キヤノン株式会社 Handwritten information recognition apparatus and method
US5623406A (en) 1995-03-06 1997-04-22 Jean D. Ichbiah Method and system for entering text in computer equipment
JPH08329004A (en) * 1995-05-31 1996-12-13 Mitsubishi Electric Corp Method for improving terminal operability of application program use
US5864340A (en) 1996-08-22 1999-01-26 International Business Machines Corporation Mobile client computer programmed to predict input
US5899976A (en) * 1996-10-31 1999-05-04 Microsoft Corporation Method and system for buffering recognized words during speech recognition
US6654955B1 (en) * 1996-12-19 2003-11-25 International Business Machines Corporation Adding speech recognition libraries to an existing program at runtime
CA2311767C (en) * 1997-12-16 2008-01-29 Microsoft Corporation Soft input panel system and method
US6233559B1 (en) * 1998-04-01 2001-05-15 Motorola, Inc. Speech control of multiple applications using applets
US6438523B1 (en) * 1998-05-20 2002-08-20 John A. Oberteuffer Processing handwritten and hand-drawn input and speech input
US6359572B1 (en) 1998-09-03 2002-03-19 Microsoft Corporation Dynamic keyboard
US7679534B2 (en) 1998-12-04 2010-03-16 Tegic Communications, Inc. Contextual prediction of user words and user actions
US6167376A (en) * 1998-12-21 2000-12-26 Ditzik; Richard Joseph Computer system with integrated telephony, handwriting and speech recognition functions
US6552719B2 (en) 1999-01-07 2003-04-22 Microsoft Corporation System and method for automatically switching between writing and text input modes
US6401067B2 (en) * 1999-01-28 2002-06-04 International Business Machines Corporation System and method for providing user-directed constraints for handwriting recognition
US6970599B2 (en) 2002-07-25 2005-11-29 America Online, Inc. Chinese character handwriting recognition system
US7159183B1 (en) * 1999-08-19 2007-01-02 National Instruments Corporation System and method for programmatically creating a graphical program
US6789231B1 (en) * 1999-10-05 2004-09-07 Microsoft Corporation Method and system for providing alternatives for text derived from stochastic input sources
US6581033B1 (en) 1999-10-19 2003-06-17 Microsoft Corporation System and method for correction of speech recognition mode errors
US6456978B1 (en) * 2000-01-31 2002-09-24 Intel Corporation Recording information in response to spoken requests
US6810429B1 (en) * 2000-02-03 2004-10-26 Mitsubishi Electric Research Laboratories, Inc. Enterprise integration system
EP1143334A3 (en) * 2000-04-06 2005-03-30 Microsoft Corporation Theme aware graphical user interface
US7451389B2 (en) 2000-06-06 2008-11-11 Microsoft Corporation Method and system for semantically labeling data and providing actions based on semantically labeled data
US20020103881A1 (en) 2000-09-11 2002-08-01 Francois Granade Method and system for integrating applications and mobile networks
JP3494292B2 (en) 2000-09-27 2004-02-09 インターナショナル・ビジネス・マシーンズ・コーポレーション Error correction support method for application data, computer device, application data providing system, and storage medium
US6788815B2 (en) * 2000-11-10 2004-09-07 Microsoft Corporation System and method for accepting disparate types of user input
US7778816B2 (en) 2001-04-24 2010-08-17 Microsoft Corporation Method and system for applying input mode bias
EP1256875A1 (en) 2001-05-10 2002-11-13 Nokia Corporation Method and device for context dependent user input prediction
US20030023641A1 (en) * 2001-07-27 2003-01-30 Gorman William Phillip Web page authoring tool
US20030071850A1 (en) 2001-10-12 2003-04-17 Microsoft Corporation In-place adaptive handwriting input method and system
US7031907B1 (en) * 2001-10-15 2006-04-18 Nortel Networks Limited Tool for constructing voice recognition grammars
US6744423B2 (en) 2001-11-19 2004-06-01 Nokia Corporation Communication terminal having a predictive character editor application
US7149550B2 (en) 2001-11-27 2006-12-12 Nokia Corporation Communication terminal having a text editor application with a word completion feature
US7111248B2 (en) 2002-01-15 2006-09-19 Openwave Systems Inc. Alphanumeric information input method
US20030189603A1 (en) * 2002-04-09 2003-10-09 Microsoft Corporation Assignment and use of confidence levels for recognized text
US20040044422A1 (en) * 2002-07-03 2004-03-04 Vadim Fux System and method for intelligent text input
US20040111259A1 (en) * 2002-12-10 2004-06-10 Miller Edward S. Speech recognition system having an application program interface
US20040243415A1 (en) * 2003-06-02 2004-12-02 International Business Machines Corporation Architecture for a speech input method editor for handheld portable devices
DE10357475A1 (en) 2003-12-09 2005-07-07 Siemens Ag Communication device and method for entering and predicting text
US20050188330A1 (en) 2004-02-20 2005-08-25 Griffin Jason T. Predictive text input system for a mobile communication device
US20050190970A1 (en) 2004-02-27 2005-09-01 Research In Motion Limited Text input system for a mobile electronic device and methods thereof
US20060063558A1 (en) 2004-09-21 2006-03-23 Research In Motion Limited Mobile wireless communications device providing enhanced predictive word entry and related methods
US20070016862A1 (en) 2005-07-15 2007-01-18 Microth, Inc. Input guessing systems, methods, and computer program products
IL174522A0 (en) 2006-03-23 2006-08-01 Jonathan Agmon Method for predictive typing
US8015174B2 (en) * 2007-02-28 2011-09-06 Websense, Inc. System and method of controlling access to the internet

Patent Citations (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5936614A (en) * 1991-04-30 1999-08-10 International Business Machines Corporation User defined keyboard entry system
US5956423A (en) * 1991-06-17 1999-09-21 Microsoft Corporation Method and system for data entry of handwritten symbols
US6269187B1 (en) * 1991-06-17 2001-07-31 Microsoft Corporation Method and system for data entry of handwritten symbols
US6003050A (en) * 1997-04-02 1999-12-14 Microsoft Corporation Method for integrating a virtual machine with input method editors
US6281886B1 (en) * 1998-07-30 2001-08-28 International Business Machines Corporation Touchscreen keyboard support for multi-byte character languages
US6356866B1 (en) * 1998-10-07 2002-03-12 Microsoft Corporation Method for converting a phonetic character string into the text of an Asian language
US6826551B1 (en) * 2000-05-10 2004-11-30 Advanced Digital Systems, Inc. System, computer software program product, and method for producing a contextual electronic message from an input to a pen-enabled computing system
US6654038B1 (en) * 2000-06-02 2003-11-25 Sun Microsystems, Inc. Keyboard navigation of non-focusable components
US20030074647A1 (en) * 2001-10-12 2003-04-17 Andrew Felix G.T.I. Automatic software input panel selection based on application program state
US20050086057A1 (en) * 2001-11-22 2005-04-21 Tetsuo Kosaka Speech recognition apparatus and its method and program
US7251667B2 (en) * 2002-03-21 2007-07-31 International Business Machines Corporation Unicode input method editor
US7047200B2 (en) * 2002-05-24 2006-05-16 Microsoft, Corporation Voice recognition status display
US7496511B2 (en) * 2003-01-14 2009-02-24 Oracle International Corporation Method and apparatus for using locale-specific grammars for speech recognition
US20040225965A1 (en) * 2003-05-06 2004-11-11 Microsoft Corporation Insertion location tracking for controlling a user interface
US7363228B2 (en) * 2003-09-18 2008-04-22 Interactive Intelligence, Inc. Speech recognition system and method
US7370275B2 (en) * 2003-10-24 2008-05-06 Microsoft Corporation System and method for providing context to an input method by tagging existing applications
US7634720B2 (en) * 2003-10-24 2009-12-15 Microsoft Corporation System and method for providing context to an input method
US7599837B2 (en) * 2004-09-15 2009-10-06 Microsoft Corporation Creating a speech recognition grammar for alphanumeric concepts

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7634720B2 (en) 2003-10-24 2009-12-15 Microsoft Corporation System and method for providing context to an input method
US20090216690A1 (en) * 2008-02-26 2009-08-27 Microsoft Corporation Predicting Candidates Using Input Scopes
US8010465B2 (en) 2008-02-26 2011-08-30 Microsoft Corporation Predicting candidates using input scopes
US8126827B2 (en) 2008-02-26 2012-02-28 Microsoft Corporation Predicting candidates using input scopes
US9672083B2 (en) 2012-07-12 2017-06-06 International Business Machines Corporation Operating a program code object in conjunction with an application context

Also Published As

Publication number Publication date
JP2005135398A (en) 2005-05-26
EP1533694A2 (en) 2005-05-25
KR20050039536A (en) 2005-04-29
US20050091037A1 (en) 2005-04-28
US7370275B2 (en) 2008-05-06
CN1609764A (en) 2005-04-27
EP1533694A3 (en) 2007-08-01
US20050091032A1 (en) 2005-04-28
US7634720B2 (en) 2009-12-15

Similar Documents

Publication Publication Date Title
US7370275B2 (en) System and method for providing context to an input method by tagging existing applications
JP4202041B2 (en) Method and system for applying input mode bias
US6957439B1 (en) Method, system, and program for mapping objects in different language formats
US6854123B1 (en) Method, system, and program for mapping standard application program interfaces (APIs) to user interface APIs
US7739588B2 (en) Leveraging markup language data for semantically labeling text strings and data and for providing actions based on semantically labeled text strings and data
US7937688B2 (en) System and method for context-sensitive help in a design environment
RU2332728C2 (en) Provision of context-sensitive tools and reference information filling in documents created on computer
JP4366065B2 (en) Resource file builder tool and computer readable code
US6675230B1 (en) Method, system, and program for embedding a user interface object in another user interface object
CN100485616C (en) Graphical assistant method and system for generating object setup scripts
US7581177B1 (en) Conversion of structured documents
TWI590082B (en) Sharable distributed dictionary for applications
EP1320038A2 (en) Services for context sensitive flagging of information in natural language text and central management of metadata relating to that information over a computer network
US7634722B2 (en) Reversible logic for widget and markup language generation
MXPA06002683A (en) Method and system for creating, storing, managing and consuming culture specific data.
KR20050039551A (en) Programming interface for a computer platform
JP2006228210A (en) Using existing content to generate active content wizard executable file for execution of task
US6941520B1 (en) Method, system, and program for using a user interface program to generate a user interface for an application program
JP2000048016A (en) Format and display method for text executable on computer processor, computer device capable of formatting and displaying text and computer readable storage medium storing program capable of formatting and displaying text, and method for adding new style to text editor capable of formatting and displaying text
EP1701255A1 (en) Authoring implementing application localization rules
US8037407B2 (en) Method and computer system for creating and processing a browser compliant human interface description
US7694315B2 (en) Schema-based machine generated programming models
US7966562B1 (en) System and method for providing domain-sensitive help
US7657869B2 (en) Integration of external tools into an existing design environment
US6983468B1 (en) Automated interface generation for computer programs in different environments

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT CORPORATION,WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HALUPTZOK, PATRICK;SUZUE, YUTAKA;GUHA, ANGSHUMAN;AND OTHERS;SIGNING DATES FROM 20040315 TO 20040317;REEL/FRAME:020921/0732

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034766/0001

Effective date: 20141014