US7996783B2 - Widget searching utilizing task framework - Google Patents

Widget searching utilizing task framework Download PDF

Info

Publication number
US7996783B2
US7996783B2 US11/367,292 US36729206A US7996783B2 US 7996783 B2 US7996783 B2 US 7996783B2 US 36729206 A US36729206 A US 36729206A US 7996783 B2 US7996783 B2 US 7996783B2
Authority
US
United States
Prior art keywords
widget
task
widgets
user
query
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US11/367,292
Other versions
US20070209013A1 (en
Inventor
William D. Ramsey
Sanjeev Katariya
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 US11/367,292 priority Critical patent/US7996783B2/en
Assigned to MICROSOFT CORPORATION reassignment MICROSOFT CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KATARIYA, SANJEEV, RAMSEY, WILLIAM D.
Publication of US20070209013A1 publication Critical patent/US20070209013A1/en
Application granted granted Critical
Publication of US7996783B2 publication Critical patent/US7996783B2/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • G06F16/972Access to data in other repository systems, e.g. legacy data or dynamic Web page generation

Definitions

  • Computers have become an integral part of modern society. They can be found in almost all businesses and homes today, helping to reduce the burdens of repetitive tasks, allowing more time for other more productive activities.
  • a program or application is created in software that runs on a computer to accomplish the task that was once required to be performed by humans.
  • applications can be utilized in place of manual labor, often yielding superior results in a much shorter amount of time.
  • the size of these applications have grown exponentially over time and some are quite complex.
  • additional computer resources are required such as computational resources and memory.
  • the increases in application sizes and resource utilization have also yielded increased startup times and processing times.
  • a user may desire to write a quick note to send out to a friend.
  • the user could use a word processing application to accomplish this.
  • modern word processing applications are often packed with additional features that allow them to be utilized in many different tasks. They may have spreadsheet interaction capabilities, drawing package attributes, database management tools, format conversion capabilities, advanced math symbology, multiple font selections, advanced text formatting tools, page formatting options, printing preview tools, etc. All of these capabilities might be unnecessary to send a quick note to a friend.
  • the user most likely would prefer launching a small application, typing the short note, and sending it to their friend. If the user has to wait for the entire word processor application to load into the computer, they may decide that it takes too long and not write the note.
  • widgets As a way to speed up applications, significantly smaller-sized applications called “widgets” were created that allowed a user to accomplish tasks in a much shorter time. These widgets are small purpose-built applications that typically accomplish singular tasks. In general, a widget does not require the same level of system resources to run as a full application does and can be started quickly. Widgets have become very popular, even too popular. Today there appears to be a widget for every task imaginable. Users typically download these widgets to their desktops so that they can quickly find and start them. The “store on the desktop” schema works well when a user has only a few widgets. However, as users download more and more widgets, this schema often causes widgets to overrun a user's desktop.
  • the subject matter relates generally to search engines, and more particularly to systems and methods for enhancing searching and/or slot filling of widgets.
  • a task framework and an adaptive semantic reasoning engine are combined to provide a scalable mechanism for dealing with extremely large numbers of widgets, allowing users to both find a widget and automatically fill-in whatever functionality is available on the widget.
  • Calling applications are employed to obtain task information from each widget.
  • the calling application also receives user queries that can be resolved by a widget.
  • a task reasoning process based on an adaptive semantic reasoning engine utilizes the task information to select a widget best suited to respond to a user's query.
  • the task reasoning process can also be employed to determine “best-guess” slot filling of the selected widget.
  • the calling application can then invoke the selected widget and, if available, fill appropriate slots with information to facilitate user interaction with the selected widget.
  • Instances can be client-side and/or server-side based. This allows, for example, Web browser based widget searching of widgets on a remote server and the like. Other instances incorporate user feedback with regard to the appropriateness of the selected widget and/or the slot filling. The user feedback can then be utilized by the task reasoning process to improve subsequent widget selections for that user. Thus, substantial improvements in quickly locating appropriate widgets and filling in information automatically allows users to effortlessly employ widgets to find related information, foregoing the previous inherent difficulties of searching through large numbers of widgets.
  • FIG. 1 is a block diagram of a widget search system in accordance with an aspect of an embodiment.
  • FIG. 2 is another block diagram of a widget search system in accordance with an aspect of an embodiment.
  • FIG. 3 is a block diagram of a browser-based widget search system in accordance with an aspect of an embodiment.
  • FIG. 4 is a block diagram of a widget search system with user feedback in accordance with an aspect of an embodiment.
  • FIG. 5 is an illustration of examples of widgets in accordance with an aspect of an embodiment.
  • FIG. 6 is an illustration of an example of a browser-based widget in accordance with an aspect of an embodiment.
  • FIG. 7 is an illustrative example of data flow between a task reasoning system and a widget in accordance with an aspect of an embodiment.
  • FIG. 8 is an illustrative example of data flow between a task reasoning system, a calling application, and a widget in accordance with an aspect of an embodiment.
  • FIG. 9 is an illustrative example of data flow between a task reasoning system, a calling application, a browser, and a widget in accordance with an aspect of an embodiment.
  • FIG. 10 is a flow diagram of a method of facilitating widget searching in accordance with an aspect of an embodiment.
  • FIG. 11 is another flow diagram of a method of facilitating widget searching in accordance with an aspect of an embodiment.
  • FIG. 12 is a flow diagram of a method of facilitating widget searching utilizing user feedback in accordance with an aspect of an embodiment.
  • FIG. 13 illustrates an example operating environment in which an embodiment can function.
  • FIG. 14 illustrates another example operating environment in which an embodiment can function.
  • a component is intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution.
  • a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer.
  • an application running on a server and the server can be a computer component.
  • One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
  • “Widgets” are small programs that perform very specific functions and can reside on a client and/or a server. They can be used, for example, to show the time, find the cheapest gas near a particular zip code, show the weather forecast near a city, find flights from a particular airline, show sports scores, or compare prices on a particular product or service and the like.
  • the number of applications of widgets is virtually unlimited, both on the client and the server.
  • finding a particular widget when the user wants it and allowing a user to execute pieces of functionality from the widget directly using natural language queries as an input mechanism.
  • having an efficient mechanism for searching for widgets is critical. Additionally, there currently is no way to generically pass parameter information to a widget that allows it to be driven externally to allow a user to request, for example, “weather in Seattle.”
  • ADAPTIVE TASK FRAMEWORK mechanisms U.S. patent application Ser. Nos. 11/270,393 and 11/270,407 and ADAPTIVE SEMANTIC REASONING ENGINE mechanisms (U.S. patent application Ser. No. 11/290,076) provide approaches that facilitate modeling advanced semantic constructs such as “tasks” whereby a task is something that users want to do and may or may not take parameters as input. These framework mechanisms allow a system to respond to users' behavior and improve the ranking and slot-filling models, thus, enhancing the user experience over time.
  • Instances of the systems and methods herein provide mechanisms that reason over widgets and perform searching by utilizing the infrastructure provided by the ADAPTIVE TASK FRAMEWORK and ADAPTIVE SEMANTIC REASONING ENGINE mechanisms.
  • FIG. 1 a block diagram of a widget search system 100 in accordance with an aspect of an embodiment is shown.
  • the widget search system 100 is comprised of a widget search component 102 that receives an input 104 and provides an output 106 .
  • the input 104 can include, but is not limited to, a query that can be responded to via a widget and/or parametric task data from various widgets to facilitate widget selection.
  • the widget search component 102 employs widget parametric task data in its task models to facilitate in selecting appropriate widgets for a given user query.
  • the task data can include, but is not limited to, general task capabilities, types of acceptable inputs (i.e., “slots”), and/or information that can facilitate the widget search component 102 to properly select the widget and/or fill slots when appropriate.
  • the query can be received by the widget search component 102 directly from a user and/or via an intermediate means such as, for example, a Web browser.
  • This flexibility allows the widget search system 100 to reside client-side and/or server-side to support searching of widgets located at the client and/or at the server.
  • the query itself can be, but is not required to be, a natural language query and the like. This allows a simplistic user interface for accepting query inputs.
  • the input 104 is modality independent and can include, but is not limited to, audible inputs, keyboard inputs, and/or mouse inputs and the like.
  • the widget search component 102 employs widget parametric task data to select an appropriate widget based on a given query.
  • the query itself can contain “slot data” that the widget search component 102 processes to determine a “best-guess” slot match for the data. This enables the widget search component 102 to provide information that can be utilized to pre-fill slots for a selected widget, reducing the amount of data required to be entered by a user for the selected widget. If a user desires to know “how many Yen are in a $100 dollars,” the widget search component 102 can select a currency converter widget and send slot data matched to a dollar slot for the widget.
  • the output 106 can then include, but is not limited to, widget selections, widget slot data, and/or widget invoking/calling commands and the like. Thus, the output 106 can be utilized to identify an appropriate widget based on a given query and/or to facilitate in invoking the appropriate widget with or without slots being filled and the like.
  • the widget search component 102 employs the Task Framework and adaptive semantic reasoning engine to facilitate mapping of queries to an appropriate task.
  • the Task Framework provides a schema for having a widget specify what information can be utilized to find it and what parameter values it can accept.
  • the appropriate task can then be matched to a widget given the widget's task data by an adaptive semantic reasoning engine.
  • the combination of these two mechanisms allows the widget search system 100 to substantially outperform existing widget search functions, both in scalability and accuracy. It also allows a user to not only search for a specific widget, but also to merely ask questions and have the appropriate widget automatically provided to them. For example, a user can ask “where is the cheapest local gas,” and the widget search system 100 can provide a gas price widget with the user's area code pre-filled so that the gas price widget displays local gas prices when it is automatically invoked.
  • FIG. 2 another block diagram of a widget search system 200 in accordance with an aspect of an embodiment is illustrated.
  • the widget search system 200 is comprised of a widget search component 202 that receives a user query 204 and provides a selected widget call 206 .
  • the widget search component 202 is comprised of a calling application 208 and an adaptive task reasoning component 210 .
  • the adaptive task reasoning component 210 can also be referred to as a “semantic reasoning component” that employs aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076).
  • the calling application 208 interfaces with widgets 212 .
  • the calling application 208 typically interfaces with widgets 212 to initially obtain widget task data that the calling application 208 then passes to the adaptive task reasoning component 210 to facilitate in widget selection.
  • the calling application 208 passes the user query 204 to the adaptive task reasoning component 210 .
  • the calling application 208 can include, but is not limited to, applications such as search engines and/or toolbars and the like.
  • the adaptive task reasoning component 210 selects an appropriate widget to respond to the user query 204 .
  • the adaptive task reasoning component 210 employs the widget task data to facilitate selection of the widget and/or to determine slot filling for the widget. The selected widget information and/or slot fill information is then passed to the calling application 208 .
  • the calling application 208 provides a selected widget call 206 which can include slot fill information when applicable.
  • the selected widget call 206 is illustrated apart from the widgets 212 for clarification, the selected widget call 206 is sent to the appropriate widget which can be one of the widgets 212 .
  • the widget search system 300 is comprised of a widget search component 302 that receives a user query 304 via a Web browser 306 and provides a selected widget call 308 .
  • the widget search component 302 is comprised of a calling application 310 and an adaptive task reasoning component 312 .
  • the adaptive task reasoning component 312 can also be referred to as an adaptive “semantic reasoning component” that employs aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076).
  • the calling application 310 interfaces with widgets 314 .
  • the calling application 310 can include, but is not limited to, applications such as search engines and/or toolbars and the like.
  • the Web browser 306 resides on the client-side and is utilized to interface with a user to accept the user query 304 .
  • This provides a user interface on the client-side while the widgets 314 reside on the server-side.
  • the widgets 314 can also reside solely on the client-side or even on both the client-side and server-side and, thus, these embodiments are also within the scope of the systems and methods herein.
  • the widget search component 302 can reside on the client-side while the widgets 314 reside on the client-side and/or the server side.
  • the Web browser 306 can be utilized to accept the user query 304 and/or display a selected widget to the user.
  • the Web browser 306 passes the user query 304 to the calling application 310 .
  • a Web browser i.e., intermediate application
  • the user query 304 can pass directly to the calling application 310 .
  • the calling application 310 typically interfaces with widgets 314 to initially obtain widget task data that the calling application 310 then passes to the adaptive task reasoning component 312 to facilitate in widget selection.
  • the calling application 310 passes the user query 304 to the adaptive task reasoning component 312 .
  • the adaptive task reasoning component 312 selects an appropriate widget to respond to the user query 304 .
  • the adaptive task reasoning component 312 employs the widget task data to facilitate selection of the widget and/or to determine slot filling for the widget.
  • the selected widget information and/or slot fill information is then passed to the calling application 310 .
  • the calling application 310 provides a selected widget call 308 which can include slot fill information when applicable.
  • the selected widget call 308 is illustrated apart from the widgets 314 for clarification, the selected widget call 308 is sent to the appropriate widget which can be one of the widgets 314 .
  • the widget search system 400 is comprised of a widget search component 402 .
  • the widget search component 402 receives a user query 404 from a user 406 and provides a call selected widget to widgets 408 .
  • a selected widget 410 is then launched and displayed to the user 406 .
  • the user 406 then interfaces with the selected widget 410 .
  • the selected widget 410 can then relay various aspects of the interaction with the user 406 to the widget search component 420 as user feedback relating to the widget selection process.
  • the widget search component 402 can utilize aspects of an ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No.
  • the adaptive reasoning engine can employ statistical learning models (e.g., Hidden Markov Models (HMM) for semantic slot-filling, Na ⁇ ve Bayesian models for Information Retrieval (IR), Max Entropy Minimum Divergence (MEMD) for ranking and/or query and context to asset mapping).
  • HMM Hidden Markov Models
  • IR Information Retrieval
  • MEMD Max Entropy Minimum Divergence
  • the Task Framework/adaptive semantic reason engine-based systems and methods can first find the appropriate widgets (e.g., a flight finding or vacation booking widgets) and can also allow any parametric or slot information to be filled. This ability increases the value of widget searching systems that employ the systems and methods herein and would yield a competitive advantage over other searching engines.
  • widgets e.g., a flight finding or vacation booking widgets
  • FIG. 5 an illustration 500 of examples of widgets 502 - 506 in accordance with an aspect of an embodiment is shown.
  • the illustration 500 shows a few examples of widgets that are freely available to do things like compare current exchange rates using the Currency Comparer 502 , find chords using the Chord Finder 504 , or just check the news from a particular source using the CNN Widget 506 .
  • the widgets exist like any other application and can be shown on the desktop much in the way a regular-sized application is shown.
  • the desktop will quickly become cluttered and unmanageable.
  • users attempt to file the widgets in some logical manner. However, this only slightly decreases the time it takes a user to hunt down an appropriate widget when they need it to perform a task.
  • FIG. 6 depicts an illustration 600 of such an example of a browser-based widget 602 .
  • Having a broad range of server-side widgets allows users to have access to functionality they may only use once or twice with a minimum of effort.
  • finding the appropriate widget(s) at the appropriate time becomes more and more of a challenge.
  • the Task Framework is described in depth in ADAPTIVE TASK FRAMEWORK (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407) and is briefly described here.
  • the central construct is the notion of a “Task” where a task provides various metadata and slot information to describe an action.
  • the “FlightFinder” task below illustrates some of the elements that might be seen in a task:
  • a system implementing the Task Framework/adaptive semantic reasoning engine is responsible for taking an input query, finding a set of likely Tasks given the input query, filling out slot values given a Task and the input query, retrieving the most likely Tasks with the most likely slot values, and/or optionally receiving feedback data to learn from the user feedback.
  • Widgets are incredibly useful at encapsulating a piece of functionality within a pseudo-application.
  • the number of potential widgets is incredibly large.
  • finding an appropriate widget at an appropriate time becomes a substantial problem with existing solutions.
  • instances of the systems and methods herein have the added benefit of scaling to large numbers of tasks easily.
  • Each widget is responsible for exposing metadata and methods used by the Task Framework.
  • the widget is created, the task metadata must be created with it through a well-defined task API.
  • a widget By adhering to a strict task API, a widget is capable of being found and having its slots filled using a centralized Task Reasoning entity (i.e., adaptive semantic reasoning engine). This ensures consistency of the ranking algorithms, and the ability to find the best task at the appropriate time.
  • FIG. 7 illustrates an example data flow 700 between a task reasoning system 702 and a widget 704 .
  • FIG. 8 illustrates an example data flow 800 between a task reasoning system 802 , a calling application 804 , and a widget 806 .
  • FIG. 9 illustrates an example data flow 900 between a task reasoning system 902 , a calling application 904 , a browser 906 , and a widget 908 .
  • One instance of a Task Framework/adaptive semantic reasoning engine-based widget searching system can function as follows:
  • the widget is responsible for that process.
  • the embodiments may be described in the general context of computer-executable instructions, such as program modules, executed by one or more components.
  • program modules include routines, programs, objects, data structures, etc., that perform particular tasks or implement particular abstract data types.
  • functionality of the program modules may be combined or distributed as desired in various instances of the embodiments.
  • FIG. 10 a flow diagram of a method 1000 of facilitating widget searching in accordance with an aspect of an embodiment is shown.
  • the method 1000 starts 1002 by obtaining task associated data from at least one widget 1004 .
  • the task associated data can include, but is not limited to, widget task capabilities and/or widget slot information for performing a task and the like and is based upon aspects of ADAPTIVE TASK FRAMEWORK mechanisms (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407).
  • the task associated data is employed to facilitate in selecting an appropriate widget for a given user widget-associated query 1006 . Semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No.
  • 11/290,076) are typically utilized to facilitate this process.
  • the query is processed to determine an appropriate task and/or slot information that can be utilized to pre-fill widget slots.
  • the task associated data is then utilized to determine “best-guess” slot filling for the selected widget 1008 .
  • the selected widget with appropriate slots filled is then called 1010 , ending the flow 1012 .
  • FIG. 11 another flow diagram of a method 1100 of facilitating widget searching in accordance with an aspect of an embodiment is depicted.
  • the method 1100 starts 1102 by utilizing a calling application to obtain task associated data from at least one widget 1104 .
  • a calling application can include, but is not limited to, applications such as search engines and/or toolbars and the like.
  • the task associated data can include, but is not limited to, widget task capabilities and/or widget slot information for performing a task and the like and is based upon aspects of ADAPTIVE TASK FRAMEWORK mechanisms (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407).
  • the task associated data is then passed from the calling application to an adaptive task reasoning entity 1106 .
  • the adaptive task reasoning entity utilizes, at least in part, semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076).
  • the adaptive task reasoning entity can be, but is not limited to, a component and/or a system that performs task reasoning.
  • the adaptive task reasoning entity is then employed to facilitate in selecting an appropriate widget for a given user widget-associated query and to determine “best-guess” slot filling for the selected widget 1108 .
  • the selected widget and “best-guess” slot filling from the adaptive task reasoning entity is then passed to the calling application 1110 .
  • the selected widget with filled slots is then invoked via the calling application 1112 , ending the flow 1114 .
  • FIG. 12 a flow diagram of a method 1200 of facilitating widget searching utilizing user feedback in accordance with an aspect of an embodiment is illustrated.
  • the method 1200 starts 1202 by obtaining a widget-associated query from a user 1204 .
  • the query can be obtained directly and/or indirectly (e.g., via a Web browser, etc.) from the user.
  • Adaptive task reasoning is then employed to facilitate in determining an appropriate widget selection for the query and widget “best guess” slot filling 1206 .
  • the adaptive task reasoning is based on, at least in part, semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076).
  • the selected widget with filled slots is then invoked for utilization by the user 1208 .
  • User feedback regarding the selected widget and/or the slot filling is then obtained to improve adaptive task reasoning widget selection and/or slot filling 1210 , ending the flow 1212 .
  • An adaptive semantic reasoning engine can be utilized to facilitate performance improvements on the widget selection process and/or the widget slot matching/filling process.
  • the adaptive reasoning engine can employ statistical learning models (e.g., Hidden Markov Models (HMM) for semantic slot-filling, Na ⁇ ve Bayesian models for Information Retrieval (IR), Max Entropy Minimum Divergence (MEMD) for ranking and/or query and context to asset mapping).
  • HMM Hidden Markov Models
  • IR Information Retrieval
  • MEMD Max Entropy Minimum Divergence
  • FIG. 13 and the following discussion is intended to provide a brief, general description of a suitable computing environment 1300 in which the various aspects of the embodiments can be performed. While the embodiments have been described above in the general context of computer-executable instructions of a computer program that runs on a local computer and/or remote computer, those skilled in the art will recognize that the embodiments can also be performed in combination with other program modules. Generally, program modules include routines, programs, components, data structures, etc., that perform particular tasks and/or implement particular abstract data types.
  • inventive methods can be practiced with other computer system configurations, including single-processor or multi-processor computer systems, minicomputers, mainframe computers, as well as personal computers, hand-held computing devices, microprocessor-based and/or programmable consumer electronics, and the like, each of which can operatively communicate with one or more associated devices.
  • the illustrated aspects of the embodiments can also be practiced in distributed computing environments where certain tasks are performed by remote processing devices that are linked through a communications network. However, some, if not all, aspects of the embodiments can be practiced on stand-alone computers.
  • program modules can be located in local and/or remote memory storage devices.
  • an exemplary system environment 1300 for performing the various aspects of the embodiments include a conventional computer 1302 , including a processing unit 1304 , a system memory 1306 , and a system bus 1308 that couples various system components, including the system memory, to the processing unit 1304 .
  • the processing unit 1304 can be any commercially available or proprietary processor.
  • the processing unit can be implemented as multi-processor formed of more than one processor, such as can be connected in parallel.
  • the system bus 1308 can be any of several types of bus structure including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of conventional bus architectures such as PCI, VESA, Microchannel, ISA, and EISA, to name a few.
  • the system memory 1306 includes read only memory (ROM) 1310 and random access memory (RAM) 1312 .
  • ROM read only memory
  • RAM random access memory
  • a basic input/output system (BIOS) 1314 containing the basic routines that help to transfer information between elements within the computer 1302 , such as during start-up, is stored in ROM 1310 .
  • the computer 1302 also can include, for example, a hard disk drive 1316 , a magnetic disk drive 1318 , e.g., to read from or write to a removable disk 1320 , and an optical disk drive 1322 , e.g., for reading from or writing to a CD-ROM disk 1324 or other optical media.
  • the hard disk drive 1316 , magnetic disk drive 1318 , and optical disk drive 1322 are connected to the system bus 1308 by a hard disk drive interface 1326 , a magnetic disk drive interface 1328 , and an optical drive interface 1330 , respectively.
  • the drives 1316 - 1322 and their associated computer-readable media provide nonvolatile storage of data, data structures, computer-executable instructions, etc. for the computer 1302 .
  • computer-readable media refers to a hard disk, a removable magnetic disk and a CD
  • other types of media which are readable by a computer such as magnetic cassettes, flash memory, digital video disks, Bernoulli cartridges, and the like, can also be used in the exemplary operating environment 1300 , and further that any such media can contain computer-executable instructions for performing the methods of the embodiments.
  • a number of program modules can be stored in the drives 1316 - 1322 and RAM 1312 , including an operating system 1332 , one or more application programs 1334 , other program modules 1336 , and program data 1338 .
  • the operating system 1332 can be any suitable operating system or combination of operating systems.
  • the application programs 1334 and program modules 1336 can include a widget searching scheme in accordance with an aspect of an embodiment.
  • a user can enter commands and information into the computer 1302 through one or more user input devices, such as a keyboard 1340 and a pointing device (e.g., a mouse 1342 ).
  • Other input devices can include a microphone, a joystick, a game pad, a satellite dish, a wireless remote, a scanner, or the like.
  • These and other input devices are often connected to the processing unit 1304 through a serial port interface 1344 that is coupled to the system bus 1308 , but can be connected by other interfaces, such as a parallel port, a game port or a universal serial bus (USB).
  • a monitor 1346 or other type of display device is also connected to the system bus 1308 via an interface, such as a video adapter 1348 .
  • the computer 1302 can include other peripheral output devices (not shown), such as speakers, printers, etc.
  • the computer 1302 can operate in a networked environment using logical connections to one or more remote computers 1360 .
  • the remote computer 1360 can be a workstation, a server computer, a router, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 1302 , although for purposes of brevity, only a memory storage device 1362 is illustrated in FIG. 13 .
  • the logical connections depicted in FIG. 13 can include a local area network (LAN) 1364 and a wide area network (WAN) 1366 .
  • LAN local area network
  • WAN wide area network
  • the computer 1302 When used in a LAN networking environment, for example, the computer 1302 is connected to the local network 1364 through a network interface or adapter 1368 .
  • the computer 1302 When used in a WAN networking environment, the computer 1302 typically includes a modem (e.g., telephone, DSL, cable, etc.) 1370 , or is connected to a communications server on the LAN, or has other means for establishing communications over the WAN 1366 , such as the Internet.
  • the modem 1370 which can be internal or external relative to the computer 1302 , is connected to the system bus 1308 via the serial port interface 1344 .
  • program modules including application programs 1334
  • program data 1338 can be stored in the remote memory storage device 1362 . It will be appreciated that the network connections shown are exemplary and other means (e.g., wired or wireless) of establishing a communications link between the computers 1302 and 1360 can be used when carrying out an aspect of an embodiment.
  • the embodiments have been described with reference to acts and symbolic representations of operations that are performed by a computer, such as the computer 1302 or remote computer 1360 , unless otherwise indicated. Such acts and operations are sometimes referred to as being computer-executed. It will be appreciated that the acts and symbolically represented operations include the manipulation by the processing unit 1304 of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory system (including the system memory 1306 , hard drive 1316 , floppy disks 1320 , CD-ROM 1324 , and remote memory 1362 ) to thereby reconfigure or otherwise alter the computer system's operation, as well as other processing of signals.
  • the memory locations where such data bits are maintained are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits.
  • FIG. 14 is another block diagram of a sample computing environment 1400 with which embodiments can interact.
  • the system 1400 further illustrates a system that includes one or more client(s) 1402 .
  • the client(s) 1402 can be hardware and/or software (e.g., threads, processes, computing devices).
  • the system 1400 also includes one or more server(s) 1404 .
  • the server(s) 1404 can also be hardware and/or software (e.g., threads, processes, computing devices).
  • One possible communication between a client 1402 and a server 1404 can be in the form of a data packet adapted to be transmitted between two or more computer processes.
  • the system 1400 includes a communication framework 1408 that can be employed to facilitate communications between the client(s) 1402 and the server(s) 1404 .
  • the client(s) 1402 are connected to one or more client data store(s) 1410 that can be employed to store information local to the client(s) 1402 .
  • the server(s) 1404 are connected to one or more server data store(s) 1406 that can be employed to store information local to the server(s) 1404 .
  • systems and/or methods of the embodiments can be utilized in widget search facilitating computer components and non-computer related components alike. Further, those skilled in the art will recognize that the systems and/or methods of the embodiments are employable in a vast array of electronic related technologies, including, but not limited to, computers, servers and/or handheld electronic devices, and the like.

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

A task framework and a semantic reasoning engine are combined to provide a scalable mechanism for dealing with extremely large numbers of widgets, allowing users to both find a widget and automatically fill-in whatever functionality is available on the widget. Calling applications are employed to obtain task information from each widget. The calling application also receives user queries that can be resolved by a widget. A task reasoning process based on an adaptive semantic reasoning engine utilizes the task information to select a widget best suited to respond to a user's query. The task reasoning process can also be employed to determine “best-guess” slot filling of the selected widget. The calling application can then invoke the selected widget and, if available, fill appropriate slots with information to facilitate user interaction with the selected widget. Instances can be client- and/or server-side based.

Description

RELATED APPLICATIONS
This application is related to co-pending U.S. patent application Ser. No. 11/270,393, filed Nov. 9, 2005, and entitled, “ADAPTIVE TASK FRAMEWORK”, co-pending U.S. patent application Ser. No. 11/270,407, filed Nov. 9, 2005, and entitled, “ADAPTIVE TASK FRAMEWORK”, co-pending U.S. patent application Ser. No. 11/290,076, filed Nov. 30, 2005, and entitled, “ADAPTIVE SEMANTIC REASONING ENGINE”, and co-pending U.S. patent application Ser. No. 11/294,265, filed Dec. 5, 2005, and entitled, “EMPLOYMENT OF TASK FRAMEWORK FOR ADVERTISING”. These applications are incorporated herein by reference.
BACKGROUND
Computers have become an integral part of modern society. They can be found in almost all businesses and homes today, helping to reduce the burdens of repetitive tasks, allowing more time for other more productive activities. Typically, a program or application is created in software that runs on a computer to accomplish the task that was once required to be performed by humans. Thus, applications can be utilized in place of manual labor, often yielding superior results in a much shorter amount of time. The size of these applications have grown exponentially over time and some are quite complex. In order to support more powerful applications, additional computer resources are required such as computational resources and memory. The increases in application sizes and resource utilization have also yielded increased startup times and processing times.
For example, a user may desire to write a quick note to send out to a friend. The user could use a word processing application to accomplish this. However, modern word processing applications are often packed with additional features that allow them to be utilized in many different tasks. They may have spreadsheet interaction capabilities, drawing package attributes, database management tools, format conversion capabilities, advanced math symbology, multiple font selections, advanced text formatting tools, page formatting options, printing preview tools, etc. All of these capabilities might be unnecessary to send a quick note to a friend. The user most likely would prefer launching a small application, typing the short note, and sending it to their friend. If the user has to wait for the entire word processor application to load into the computer, they may decide that it takes too long and not write the note.
As a way to speed up applications, significantly smaller-sized applications called “widgets” were created that allowed a user to accomplish tasks in a much shorter time. These widgets are small purpose-built applications that typically accomplish singular tasks. In general, a widget does not require the same level of system resources to run as a full application does and can be started quickly. Widgets have become very popular, even too popular. Today there appears to be a widget for every task imaginable. Users typically download these widgets to their desktops so that they can quickly find and start them. The “store on the desktop” schema works well when a user has only a few widgets. However, as users download more and more widgets, this schema often causes widgets to overrun a user's desktop. So, eventually users have to organize their widgets in some form of hierarchy such as in folders and databases. And, although they may be stored in an orderly fashion, it is now more difficult to quickly find and start an appropriate widget when a task becomes desirable. This difficulty will continually increase as the number of widgets increases. Since widgets are becoming more popular each day, more and more users will become frustrated with trying to locate and employ their favorite widgets.
SUMMARY
The following presents a simplified summary of the subject matter in order to provide a basic understanding of some aspects of subject matter embodiments. This summary is not an extensive overview of the subject matter. It is not intended to identify key/critical elements of the embodiments or to delineate the scope of the subject matter. Its sole purpose is to present some concepts of the subject matter in a simplified form as a prelude to the more detailed description that is presented later.
The subject matter relates generally to search engines, and more particularly to systems and methods for enhancing searching and/or slot filling of widgets. A task framework and an adaptive semantic reasoning engine are combined to provide a scalable mechanism for dealing with extremely large numbers of widgets, allowing users to both find a widget and automatically fill-in whatever functionality is available on the widget. Calling applications are employed to obtain task information from each widget. The calling application also receives user queries that can be resolved by a widget. A task reasoning process based on an adaptive semantic reasoning engine utilizes the task information to select a widget best suited to respond to a user's query. The task reasoning process can also be employed to determine “best-guess” slot filling of the selected widget. The calling application can then invoke the selected widget and, if available, fill appropriate slots with information to facilitate user interaction with the selected widget.
Instances can be client-side and/or server-side based. This allows, for example, Web browser based widget searching of widgets on a remote server and the like. Other instances incorporate user feedback with regard to the appropriateness of the selected widget and/or the slot filling. The user feedback can then be utilized by the task reasoning process to improve subsequent widget selections for that user. Thus, substantial improvements in quickly locating appropriate widgets and filling in information automatically allows users to effortlessly employ widgets to find related information, foregoing the previous inherent difficulties of searching through large numbers of widgets.
To the accomplishment of the foregoing and related ends, certain illustrative aspects of embodiments are described herein in connection with the following description and the annexed drawings. These aspects are indicative, however, of but a few of the various ways in which the principles of the subject matter may be employed, and the subject matter is intended to include all such aspects and their equivalents. Other advantages and novel features of the subject matter may become apparent from the following detailed description when considered in conjunction with the drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of a widget search system in accordance with an aspect of an embodiment.
FIG. 2 is another block diagram of a widget search system in accordance with an aspect of an embodiment.
FIG. 3 is a block diagram of a browser-based widget search system in accordance with an aspect of an embodiment.
FIG. 4 is a block diagram of a widget search system with user feedback in accordance with an aspect of an embodiment.
FIG. 5 is an illustration of examples of widgets in accordance with an aspect of an embodiment.
FIG. 6 is an illustration of an example of a browser-based widget in accordance with an aspect of an embodiment.
FIG. 7 is an illustrative example of data flow between a task reasoning system and a widget in accordance with an aspect of an embodiment.
FIG. 8 is an illustrative example of data flow between a task reasoning system, a calling application, and a widget in accordance with an aspect of an embodiment.
FIG. 9 is an illustrative example of data flow between a task reasoning system, a calling application, a browser, and a widget in accordance with an aspect of an embodiment.
FIG. 10 is a flow diagram of a method of facilitating widget searching in accordance with an aspect of an embodiment.
FIG. 11 is another flow diagram of a method of facilitating widget searching in accordance with an aspect of an embodiment.
FIG. 12 is a flow diagram of a method of facilitating widget searching utilizing user feedback in accordance with an aspect of an embodiment.
FIG. 13 illustrates an example operating environment in which an embodiment can function.
FIG. 14 illustrates another example operating environment in which an embodiment can function.
DETAILED DESCRIPTION
The subject matter is now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the subject matter. It may be evident, however, that subject matter embodiments may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate describing the embodiments.
As used in this application, the term “component” is intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a computer component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
“Widgets” are small programs that perform very specific functions and can reside on a client and/or a server. They can be used, for example, to show the time, find the cheapest gas near a particular zip code, show the weather forecast near a city, find flights from a particular airline, show sports scores, or compare prices on a particular product or service and the like. The number of applications of widgets is virtually unlimited, both on the client and the server. Thus, with the proliferation of widgets, a larger problem is manifested: finding a particular widget when the user wants it and allowing a user to execute pieces of functionality from the widget directly using natural language queries as an input mechanism. Thus, having an efficient mechanism for searching for widgets is critical. Additionally, there currently is no way to generically pass parameter information to a widget that allows it to be driven externally to allow a user to request, for example, “weather in Seattle.”
ADAPTIVE TASK FRAMEWORK mechanisms (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407) and ADAPTIVE SEMANTIC REASONING ENGINE mechanisms (U.S. patent application Ser. No. 11/290,076) provide approaches that facilitate modeling advanced semantic constructs such as “tasks” whereby a task is something that users want to do and may or may not take parameters as input. These framework mechanisms allow a system to respond to users' behavior and improve the ranking and slot-filling models, thus, enhancing the user experience over time. Instances of the systems and methods herein provide mechanisms that reason over widgets and perform searching by utilizing the infrastructure provided by the ADAPTIVE TASK FRAMEWORK and ADAPTIVE SEMANTIC REASONING ENGINE mechanisms. This combination of approaches provides leveraging of the work done for semantic processing with a new paradigm of widgets that, for example, allows a user to enter a query such as “weather in Seattle,” find the appropriate widget (e.g., the weather widget), pass information to the widget (e.g., City=“Seattle”), and then show the widget with Seattle's forecast already loaded.
In FIG. 1, a block diagram of a widget search system 100 in accordance with an aspect of an embodiment is shown. The widget search system 100 is comprised of a widget search component 102 that receives an input 104 and provides an output 106. The input 104 can include, but is not limited to, a query that can be responded to via a widget and/or parametric task data from various widgets to facilitate widget selection. The widget search component 102 employs widget parametric task data in its task models to facilitate in selecting appropriate widgets for a given user query. The task data can include, but is not limited to, general task capabilities, types of acceptable inputs (i.e., “slots”), and/or information that can facilitate the widget search component 102 to properly select the widget and/or fill slots when appropriate. The query can be received by the widget search component 102 directly from a user and/or via an intermediate means such as, for example, a Web browser. This flexibility allows the widget search system 100 to reside client-side and/or server-side to support searching of widgets located at the client and/or at the server. The query itself can be, but is not required to be, a natural language query and the like. This allows a simplistic user interface for accepting query inputs. The input 104 is modality independent and can include, but is not limited to, audible inputs, keyboard inputs, and/or mouse inputs and the like. One skilled in the art can appreciate that as technology develops additional input techniques will also be created and are within the scope of the systems and methods herein.
The widget search component 102 employs widget parametric task data to select an appropriate widget based on a given query. The query itself can contain “slot data” that the widget search component 102 processes to determine a “best-guess” slot match for the data. This enables the widget search component 102 to provide information that can be utilized to pre-fill slots for a selected widget, reducing the amount of data required to be entered by a user for the selected widget. If a user desires to know “how many Yen are in a $100 dollars,” the widget search component 102 can select a currency converter widget and send slot data matched to a dollar slot for the widget. The output 106 can then include, but is not limited to, widget selections, widget slot data, and/or widget invoking/calling commands and the like. Thus, the output 106 can be utilized to identify an appropriate widget based on a given query and/or to facilitate in invoking the appropriate widget with or without slots being filled and the like.
The widget search component 102 employs the Task Framework and adaptive semantic reasoning engine to facilitate mapping of queries to an appropriate task. The Task Framework provides a schema for having a widget specify what information can be utilized to find it and what parameter values it can accept. The appropriate task can then be matched to a widget given the widget's task data by an adaptive semantic reasoning engine. The combination of these two mechanisms allows the widget search system 100 to substantially outperform existing widget search functions, both in scalability and accuracy. It also allows a user to not only search for a specific widget, but also to merely ask questions and have the appropriate widget automatically provided to them. For example, a user can ask “where is the cheapest local gas,” and the widget search system 100 can provide a gas price widget with the user's area code pre-filled so that the gas price widget displays local gas prices when it is automatically invoked.
Turning to FIG. 2, another block diagram of a widget search system 200 in accordance with an aspect of an embodiment is illustrated. The widget search system 200 is comprised of a widget search component 202 that receives a user query 204 and provides a selected widget call 206. The widget search component 202 is comprised of a calling application 208 and an adaptive task reasoning component 210. The adaptive task reasoning component 210 can also be referred to as a “semantic reasoning component” that employs aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076). The calling application 208 interfaces with widgets 212. The calling application 208 typically interfaces with widgets 212 to initially obtain widget task data that the calling application 208 then passes to the adaptive task reasoning component 210 to facilitate in widget selection. When a user query 204 is received, the calling application 208 passes the user query 204 to the adaptive task reasoning component 210. The calling application 208 can include, but is not limited to, applications such as search engines and/or toolbars and the like. The adaptive task reasoning component 210 selects an appropriate widget to respond to the user query 204. The adaptive task reasoning component 210 employs the widget task data to facilitate selection of the widget and/or to determine slot filling for the widget. The selected widget information and/or slot fill information is then passed to the calling application 208. In this instance the calling application 208 provides a selected widget call 206 which can include slot fill information when applicable. Although the selected widget call 206 is illustrated apart from the widgets 212 for clarification, the selected widget call 206 is sent to the appropriate widget which can be one of the widgets 212.
Referring to FIG. 3, a block diagram of a browser-based widget search system 300 in accordance with an aspect of an embodiment is depicted. The widget search system 300 is comprised of a widget search component 302 that receives a user query 304 via a Web browser 306 and provides a selected widget call 308. The widget search component 302 is comprised of a calling application 310 and an adaptive task reasoning component 312. The adaptive task reasoning component 312 can also be referred to as an adaptive “semantic reasoning component” that employs aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076). The calling application 310 interfaces with widgets 314. The calling application 310 can include, but is not limited to, applications such as search engines and/or toolbars and the like. In this instance, the Web browser 306 resides on the client-side and is utilized to interface with a user to accept the user query 304. This provides a user interface on the client-side while the widgets 314 reside on the server-side. One skilled in the art can appreciate that the widgets 314 can also reside solely on the client-side or even on both the client-side and server-side and, thus, these embodiments are also within the scope of the systems and methods herein. Likewise, the widget search component 302 can reside on the client-side while the widgets 314 reside on the client-side and/or the server side. The Web browser 306 can be utilized to accept the user query 304 and/or display a selected widget to the user. The Web browser 306 passes the user query 304 to the calling application 310. In other instances a Web browser (i.e., intermediate application) is not necessary, and the user query 304 can pass directly to the calling application 310.
The calling application 310 typically interfaces with widgets 314 to initially obtain widget task data that the calling application 310 then passes to the adaptive task reasoning component 312 to facilitate in widget selection. When a user query 304 is received from the Web browser 306, the calling application 310 passes the user query 304 to the adaptive task reasoning component 312. The adaptive task reasoning component 312 selects an appropriate widget to respond to the user query 304. The adaptive task reasoning component 312 employs the widget task data to facilitate selection of the widget and/or to determine slot filling for the widget. The selected widget information and/or slot fill information is then passed to the calling application 310. In this instance, the calling application 310 provides a selected widget call 308 which can include slot fill information when applicable. Although the selected widget call 308 is illustrated apart from the widgets 314 for clarification, the selected widget call 308 is sent to the appropriate widget which can be one of the widgets 314.
Looking at FIG. 4, a block diagram of a widget search system 400 with user feedback in accordance with an aspect of an embodiment is shown. The widget search system 400 is comprised of a widget search component 402. The widget search component 402 receives a user query 404 from a user 406 and provides a call selected widget to widgets 408. A selected widget 410 is then launched and displayed to the user 406. The user 406 then interfaces with the selected widget 410. The selected widget 410 can then relay various aspects of the interaction with the user 406 to the widget search component 420 as user feedback relating to the widget selection process. The widget search component 402 can utilize aspects of an ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/294,265) to facilitate performance improvements on the widget selection process and/or the widget slot matching/filling process. The adaptive reasoning engine can employ statistical learning models (e.g., Hidden Markov Models (HMM) for semantic slot-filling, Naïve Bayesian models for Information Retrieval (IR), Max Entropy Minimum Divergence (MEMD) for ranking and/or query and context to asset mapping).
Thus, with the proliferation of widgets (i.e., small, often singular purposed applications) on both server and client sides, finding and executing widget functionality becomes substantially more problematic without utilization of the above systems. For users running tens or hundreds of client-side widgets, managing the widgets becomes increasingly more difficult. Similarly, in server-side widget scenarios, the number of widgets is potentially huge making it more difficult for users to find the appropriate widget and perform a task. The Task Framework/adaptive semantic reason engine-based systems and methods provide scalable mechanisms for dealing with extremely large numbers of widgets, allowing users to both find a widget and execute whatever functionality is available on the widget. For example, if a user enters a request for “find flights from Boston to Seattle” the Task Framework/adaptive semantic reason engine-based systems and methods can first find the appropriate widgets (e.g., a flight finding or vacation booking widgets) and can also allow any parametric or slot information to be filled. This ability increases the value of widget searching systems that employ the systems and methods herein and would yield a competitive advantage over other searching engines.
Widgets
Client-Side Widgets
Users can download widgets easily from Internet Web sites to perform many different functions. In FIG. 5, an illustration 500 of examples of widgets 502-506 in accordance with an aspect of an embodiment is shown. The illustration 500 shows a few examples of widgets that are freely available to do things like compare current exchange rates using the Currency Comparer 502, find chords using the Chord Finder 504, or just check the news from a particular source using the CNN Widget 506. Typically, after downloading the widgets, the widgets exist like any other application and can be shown on the desktop much in the way a regular-sized application is shown. Of course, if the user has tens or hundreds of widgets running, the desktop will quickly become cluttered and unmanageable. Thus, users attempt to file the widgets in some logical manner. However, this only slightly decreases the time it takes a user to hunt down an appropriate widget when they need it to perform a task.
Server-Side Widgets
These types of widgets contain functionality that is executed on a server without requiring that a user download any client-side application code. For example, a search engine may wish to provide a flight finding widget to facilitate finding cheap airfare where the functionality for finding flights resides on the server, and the client is only used to display the results via standard HTML (hypertext markup language) conventions. FIG. 6 depicts an illustration 600 of such an example of a browser-based widget 602. Having a broad range of server-side widgets allows users to have access to functionality they may only use once or twice with a minimum of effort. Of course, the problem remains that as the number of server-side widgets increases, finding the appropriate widget(s) at the appropriate time becomes more and more of a challenge.
Task Framework Overview
The Task Framework is described in depth in ADAPTIVE TASK FRAMEWORK (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407) and is briefly described here. The central construct is the notion of a “Task” where a task provides various metadata and slot information to describe an action. The “FlightFinder” task below illustrates some of the elements that might be seen in a task:
<Task Name=“FlightFinder”>
 <Keywords>cheap;tickets;flights;flight;vacations</Keywords>
 <Slots>
  <Slot name=“Arrival City” type= “CITY”>
   <PreIndicators>to, going into</PreIndicators>
   <PostIndicators>arrival city</PostIndicators>
  </Slot>
  <Slot name=“Departure City” type= “CITY”>
   <PreIndicators>from, originating in</PreIndicators>
   <PostIndicators>departure city</PostIndicators>
  </Slot>
  <Slot name=“Arrival Time” type= “TIME”>
   <PreIndicators>arriving at</PreIndicators>
   <PostIndicators>arrival time</PostIndicators>
  </Slot>
  <Slot name=“ Departure Time” type= “TIME”>
   <PreIndicators>leaving at</PreIndicators>
   <PostIndicators>departure time</PostIndicators>
  </Slot>
  <Slot name=“Adults” type= “INTEGER”>
   <PreIndicators> </PreIndicators>
   <PostIndicators> adult, adults</PostIndicators>
  </Slot>
  <Slot name=“Seniors” type= “INTEGER”>
   <PreIndicators> </PreIndicators>
   <PostIndicators>senior,seniors</PostIndicators>
  </Slot>
  <Slot name=“Children” type= “INTEGER”>
   <PreIndicators> </PreIndicators>
   <PostIndicators>children,child,kid,kids</PostIndicators>
  </Slot>
 </Slots>
</Task>

Where:
    • Keywords are terms that might be used to surface a Task.
    • Slots are parameter values that may or may not be filled by the user Query.
      • They are uniquely specified by their Name and Type.
    • PreIndicators are words that might disambiguate slots by occurring before a value.
      • “to Boston” would prefer the “Arrival City” slot over the “Departure City” slot even though Boston maps to CITY and can be a value for either slot.
    • PostIndicators are words that might disambiguate slots by occurring before a value.
      • “from Boston” would prefer the “Departure City” slot over the “Arrival City” slot even though Boston maps to CITY and can be a value for either slot.
        Given this schema, the following example queries can be handled:
    • “I want a flight from Boston with a 8:30 PM departure time with 2 adults and 1 child.”
    • “Buy a ticket from Seattle to New York leaving at 5:15 PM.”
Additionally, the Task Framework and adaptive semantic reasoning engine provide mechanisms to learn from user behavior such that if users start entering queries such as “departing Boston for Seattle” to mean “Departure City”=“Boston” and “Arrival City”=“Seattle” the system automatically learns the pattern “departing <Departure City> for <Arrival City>” without needing to explicitly add new Pre or Post indicators to the Task definition. A system implementing the Task Framework/adaptive semantic reasoning engine is responsible for taking an input query, finding a set of likely Tasks given the input query, filling out slot values given a Task and the input query, retrieving the most likely Tasks with the most likely slot values, and/or optionally receiving feedback data to learn from the user feedback.
Task Framework-Based Widget Searching/Executing
Widgets are incredibly useful at encapsulating a piece of functionality within a pseudo-application. However, the number of potential widgets is incredibly large. Thus, finding an appropriate widget at an appropriate time becomes a substantial problem with existing solutions. However, the Task Framework provides an approach for modeling widgets as tasks that facilitate both retrieval of the widget (e.g., finding the appropriate widget given a query such as “what is the exchange rate of USD to GBP?”) and slot-filling (e.g., Currency1=“USD” and Currency2=“GBP”). Moreover, instances of the systems and methods herein have the added benefit of scaling to large numbers of tasks easily.
Each widget is responsible for exposing metadata and methods used by the Task Framework. For example, the FlightFinder widget would expose the data shown for the Task=“FlightFinder” shown above. This allows the retrieval engine to retrieve the proper widget if any of the words in the <Keywords> tag (e.g., “cheap,” “tickets,” “flights,” “flight,” “vacations”) occur. It allows the widget to be called with any of the slot parameters (e.g., “Arrival City” . . . “Adults” . . . “Children”) specified as well. Thus, when the widget is created, the task metadata must be created with it through a well-defined task API. By adhering to a strict task API, a widget is capable of being found and having its slots filled using a centralized Task Reasoning entity (i.e., adaptive semantic reasoning engine). This ensures consistency of the ranking algorithms, and the ability to find the best task at the appropriate time. Optionally, the widget can pass user feedback to the system to improve both the retrieval and slot-filling models (e.g., a user who enters the query “I want 2 tickets departing Boston for Seattle” would end up setting Adults=“2,” Departure City=“Boston,” and Arrival City=“Seattle” and that feedback can be used to map “tickets”→FlightFinder and “departure”→“Departure City” and the like.
FIG. 7 illustrates an example data flow 700 between a task reasoning system 702 and a widget 704. FIG. 8 illustrates an example data flow 800 between a task reasoning system 802, a calling application 804, and a widget 806. FIG. 9 illustrates an example data flow 900 between a task reasoning system 902, a calling application 904, a browser 906, and a widget 908. One instance of a Task Framework/adaptive semantic reasoning engine-based widget searching system can function as follows:
    • 1. The calling application manages the widgets and the Task Reasoning System (TRS).
    • 2. Each widget is queried for the Task Interface and Metadata which seeds the TRS models.
    • 3. A query is entered into the calling application.
    • 4. The query is then passed to the TRS, and the most appropriate widget(s) is(are) found. Where applicable, slots are filled in.
    • 5. The results are then passed to the application. Where applicable, the user is presented with the results and makes a selection (some instances present only a single widget selection to the user, and, thus, is automatically invoked per step 6).
    • 6. The widget is selected and invoked with the slot information (if applicable).
In cases where additional information is required or confirmation is needed, the widget is responsible for that process.
    • 7. The user interacts with the widget directly.
    • 8. Upon completion of the task, optional feedback data can be passed from the widget to the application and the TRS.
      The server-side widget scenario is almost identical except that the front-end is contained in a Web browser.
In view of the exemplary systems shown and described above, methodologies that may be implemented in accordance with the embodiments will be better appreciated with reference to the flow charts of FIGS. 10-12. While, for purposes of simplicity of explanation, the methodologies are shown and described as a series of blocks, it is to be understood and appreciated that the embodiments are not limited by the order of the blocks, as some blocks may, in accordance with an embodiment, occur in different orders and/or concurrently with other blocks from that shown and described herein. Moreover, not all illustrated blocks may be required to implement the methodologies in accordance with the embodiments.
The embodiments may be described in the general context of computer-executable instructions, such as program modules, executed by one or more components. Generally, program modules include routines, programs, objects, data structures, etc., that perform particular tasks or implement particular abstract data types. Typically, the functionality of the program modules may be combined or distributed as desired in various instances of the embodiments.
In FIG. 10, a flow diagram of a method 1000 of facilitating widget searching in accordance with an aspect of an embodiment is shown. The method 1000 starts 1002 by obtaining task associated data from at least one widget 1004. The task associated data can include, but is not limited to, widget task capabilities and/or widget slot information for performing a task and the like and is based upon aspects of ADAPTIVE TASK FRAMEWORK mechanisms (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407). The task associated data is employed to facilitate in selecting an appropriate widget for a given user widget-associated query 1006. Semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076) are typically utilized to facilitate this process. The query is processed to determine an appropriate task and/or slot information that can be utilized to pre-fill widget slots. The task associated data is then utilized to determine “best-guess” slot filling for the selected widget 1008. The selected widget with appropriate slots filled is then called 1010, ending the flow 1012.
Looking at FIG. 11, another flow diagram of a method 1100 of facilitating widget searching in accordance with an aspect of an embodiment is depicted. The method 1100 starts 1102 by utilizing a calling application to obtain task associated data from at least one widget 1104. A calling application can include, but is not limited to, applications such as search engines and/or toolbars and the like. The task associated data can include, but is not limited to, widget task capabilities and/or widget slot information for performing a task and the like and is based upon aspects of ADAPTIVE TASK FRAMEWORK mechanisms (U.S. patent application Ser. Nos. 11/270,393 and 11/270,407). The task associated data is then passed from the calling application to an adaptive task reasoning entity 1106. The adaptive task reasoning entity utilizes, at least in part, semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076). The adaptive task reasoning entity can be, but is not limited to, a component and/or a system that performs task reasoning. The adaptive task reasoning entity is then employed to facilitate in selecting an appropriate widget for a given user widget-associated query and to determine “best-guess” slot filling for the selected widget 1108. The selected widget and “best-guess” slot filling from the adaptive task reasoning entity is then passed to the calling application 1110. The selected widget with filled slots is then invoked via the calling application 1112, ending the flow 1114.
Turning to FIG. 12, a flow diagram of a method 1200 of facilitating widget searching utilizing user feedback in accordance with an aspect of an embodiment is illustrated. The method 1200 starts 1202 by obtaining a widget-associated query from a user 1204. The query can be obtained directly and/or indirectly (e.g., via a Web browser, etc.) from the user. Adaptive task reasoning is then employed to facilitate in determining an appropriate widget selection for the query and widget “best guess” slot filling 1206. The adaptive task reasoning is based on, at least in part, semantic reasoning aspects from ADAPTIVE SEMANTIC REASONING ENGINE (see, U.S. patent application Ser. No. 11/290,076). The selected widget with filled slots is then invoked for utilization by the user 1208. User feedback regarding the selected widget and/or the slot filling is then obtained to improve adaptive task reasoning widget selection and/or slot filling 1210, ending the flow 1212. An adaptive semantic reasoning engine can be utilized to facilitate performance improvements on the widget selection process and/or the widget slot matching/filling process. The adaptive reasoning engine can employ statistical learning models (e.g., Hidden Markov Models (HMM) for semantic slot-filling, Naïve Bayesian models for Information Retrieval (IR), Max Entropy Minimum Divergence (MEMD) for ranking and/or query and context to asset mapping).
In order to provide additional context for implementing various aspects of the embodiments, FIG. 13 and the following discussion is intended to provide a brief, general description of a suitable computing environment 1300 in which the various aspects of the embodiments can be performed. While the embodiments have been described above in the general context of computer-executable instructions of a computer program that runs on a local computer and/or remote computer, those skilled in the art will recognize that the embodiments can also be performed in combination with other program modules. Generally, program modules include routines, programs, components, data structures, etc., that perform particular tasks and/or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the inventive methods can be practiced with other computer system configurations, including single-processor or multi-processor computer systems, minicomputers, mainframe computers, as well as personal computers, hand-held computing devices, microprocessor-based and/or programmable consumer electronics, and the like, each of which can operatively communicate with one or more associated devices. The illustrated aspects of the embodiments can also be practiced in distributed computing environments where certain tasks are performed by remote processing devices that are linked through a communications network. However, some, if not all, aspects of the embodiments can be practiced on stand-alone computers. In a distributed computing environment, program modules can be located in local and/or remote memory storage devices.
With reference to FIG. 13, an exemplary system environment 1300 for performing the various aspects of the embodiments include a conventional computer 1302, including a processing unit 1304, a system memory 1306, and a system bus 1308 that couples various system components, including the system memory, to the processing unit 1304. The processing unit 1304 can be any commercially available or proprietary processor. In addition, the processing unit can be implemented as multi-processor formed of more than one processor, such as can be connected in parallel.
The system bus 1308 can be any of several types of bus structure including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of conventional bus architectures such as PCI, VESA, Microchannel, ISA, and EISA, to name a few. The system memory 1306 includes read only memory (ROM) 1310 and random access memory (RAM) 1312. A basic input/output system (BIOS) 1314, containing the basic routines that help to transfer information between elements within the computer 1302, such as during start-up, is stored in ROM 1310.
The computer 1302 also can include, for example, a hard disk drive 1316, a magnetic disk drive 1318, e.g., to read from or write to a removable disk 1320, and an optical disk drive 1322, e.g., for reading from or writing to a CD-ROM disk 1324 or other optical media. The hard disk drive 1316, magnetic disk drive 1318, and optical disk drive 1322 are connected to the system bus 1308 by a hard disk drive interface 1326, a magnetic disk drive interface 1328, and an optical drive interface 1330, respectively. The drives 1316-1322 and their associated computer-readable media provide nonvolatile storage of data, data structures, computer-executable instructions, etc. for the computer 1302. Although the description of computer-readable media above refers to a hard disk, a removable magnetic disk and a CD, it should be appreciated by those skilled in the art that other types of media which are readable by a computer, such as magnetic cassettes, flash memory, digital video disks, Bernoulli cartridges, and the like, can also be used in the exemplary operating environment 1300, and further that any such media can contain computer-executable instructions for performing the methods of the embodiments.
A number of program modules can be stored in the drives 1316-1322 and RAM 1312, including an operating system 1332, one or more application programs 1334, other program modules 1336, and program data 1338. The operating system 1332 can be any suitable operating system or combination of operating systems. By way of example, the application programs 1334 and program modules 1336 can include a widget searching scheme in accordance with an aspect of an embodiment.
A user can enter commands and information into the computer 1302 through one or more user input devices, such as a keyboard 1340 and a pointing device (e.g., a mouse 1342). Other input devices (not shown) can include a microphone, a joystick, a game pad, a satellite dish, a wireless remote, a scanner, or the like. These and other input devices are often connected to the processing unit 1304 through a serial port interface 1344 that is coupled to the system bus 1308, but can be connected by other interfaces, such as a parallel port, a game port or a universal serial bus (USB). A monitor 1346 or other type of display device is also connected to the system bus 1308 via an interface, such as a video adapter 1348. In addition to the monitor 1346, the computer 1302 can include other peripheral output devices (not shown), such as speakers, printers, etc.
It is to be appreciated that the computer 1302 can operate in a networked environment using logical connections to one or more remote computers 1360. The remote computer 1360 can be a workstation, a server computer, a router, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 1302, although for purposes of brevity, only a memory storage device 1362 is illustrated in FIG. 13. The logical connections depicted in FIG. 13 can include a local area network (LAN) 1364 and a wide area network (WAN) 1366. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.
When used in a LAN networking environment, for example, the computer 1302 is connected to the local network 1364 through a network interface or adapter 1368. When used in a WAN networking environment, the computer 1302 typically includes a modem (e.g., telephone, DSL, cable, etc.) 1370, or is connected to a communications server on the LAN, or has other means for establishing communications over the WAN 1366, such as the Internet. The modem 1370, which can be internal or external relative to the computer 1302, is connected to the system bus 1308 via the serial port interface 1344. In a networked environment, program modules (including application programs 1334) and/or program data 1338 can be stored in the remote memory storage device 1362. It will be appreciated that the network connections shown are exemplary and other means (e.g., wired or wireless) of establishing a communications link between the computers 1302 and 1360 can be used when carrying out an aspect of an embodiment.
In accordance with the practices of persons skilled in the art of computer programming, the embodiments have been described with reference to acts and symbolic representations of operations that are performed by a computer, such as the computer 1302 or remote computer 1360, unless otherwise indicated. Such acts and operations are sometimes referred to as being computer-executed. It will be appreciated that the acts and symbolically represented operations include the manipulation by the processing unit 1304 of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory system (including the system memory 1306, hard drive 1316, floppy disks 1320, CD-ROM 1324, and remote memory 1362) to thereby reconfigure or otherwise alter the computer system's operation, as well as other processing of signals. The memory locations where such data bits are maintained are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits.
FIG. 14 is another block diagram of a sample computing environment 1400 with which embodiments can interact. The system 1400 further illustrates a system that includes one or more client(s) 1402. The client(s) 1402 can be hardware and/or software (e.g., threads, processes, computing devices). The system 1400 also includes one or more server(s) 1404. The server(s) 1404 can also be hardware and/or software (e.g., threads, processes, computing devices). One possible communication between a client 1402 and a server 1404 can be in the form of a data packet adapted to be transmitted between two or more computer processes. The system 1400 includes a communication framework 1408 that can be employed to facilitate communications between the client(s) 1402 and the server(s) 1404. The client(s) 1402 are connected to one or more client data store(s) 1410 that can be employed to store information local to the client(s) 1402. Similarly, the server(s) 1404 are connected to one or more server data store(s) 1406 that can be employed to store information local to the server(s) 1404.
It is to be appreciated that the systems and/or methods of the embodiments can be utilized in widget search facilitating computer components and non-computer related components alike. Further, those skilled in the art will recognize that the systems and/or methods of the embodiments are employable in a vast array of electronic related technologies, including, but not limited to, computers, servers and/or handheld electronic devices, and the like.
What has been described above includes examples of the embodiments. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the embodiments, but one of ordinary skill in the art may recognize that many further combinations and permutations of the embodiments are possible. Accordingly, the subject matter is intended to embrace all such alterations, modifications and variations that fall within the spirit and scope of the appended claims. Furthermore, to the extent that the term “includes” is used in either the detailed description or the claims, such term is intended to be inclusive in a manner similar to the term “comprising” as “comprising” is interpreted when employed as a transitional word in a claim.

Claims (11)

1. A computer readable storage medium having computer-executable components stored thereon that facilitates widget searching, comprising:
a calling application component that receives a natural language query and is associated with a plurality of widgets configured to expose parametric task data to the calling application component and including one or more widgets associated with the natural language query, wherein the calling application interfaces with the plurality of widgets to obtain parametric task data from each of the plurality of widgets, the parametric task data includes at least one of task capabilities, types of acceptable slots, or information to facilitate filling of widget slots based on the query; and
an adaptive task reasoning component that receives the natural language query from the calling application component and utilizes the obtained parametric task data to automatically select one or more appropriate widgets from among the plurality of widgets in response to the natural language query, wherein the adaptive task reasoning component further determines appropriate slot filling for the selected widgets from the obtained parametric task data, and provides the slot filling for each of the selected widgets to the calling application component;
wherein the calling application component invokes a widget using the slot filling for that widget to allow a user to utilize the functionality of the one or more selected widgets, the widget selected from among the one or more widgets selected by the adaptive task reasoning component in response to the natural language query, and wherein the adaptive task reasoning component employs user feedback related to at least one selected widget to facilitate in subsequent widget selections and slot filling in response to subsequent natural language queries.
2. The computer readable storage medium of claim 1, the calling application component receives the natural language query directly from a user or via a Web browser.
3. The computer readable storage medium of claim 1, the calling application component or the adaptive task reasoning component resides on a server.
4. The computer readable storage medium of claim 1, the natural language query comprising a modality independent query input.
5. A server-side widget search system that utilizes the computer readable storage medium of claim 1 to facilitate in providing at least one appropriate widget to a user via a Web browser.
6. The computer readable storage medium of claim 1, wherein, upon determination that the one or more widgets includes a single widget, the calling application component provides the selected widget to the user without providing another widget concurrently.
7. A computer-implemented method for facilitating widget searching, comprising:
employing a calling application to obtain task associated data exposed by each of a plurality of widgets, each widget residing on a client or server and configured to expose the task associated data to the calling application, the task associated data includes widget task capabilities, types of acceptable slots, or information to facilitate widget slot filling;
receiving a user query associated with one or more of the plurality of widgets, wherein the user query is a natural language query;
passing the task associated data from the calling application to a task reasoning process that is based, at least in part, on an adaptive semantic reasoning engine;
employing the adaptive task reasoning engine to apply adaptive task reasoning and the task associated data obtained from the plurality of widgets to facilitate in selecting one or more appropriate widgets responsive to the user query;
utilizing the task associated data to determine slot filling for the selected widgets;
employing selected widget feedback from a user to facilitate in determining the one or more appropriate widgets and slot filling in response to the user query; and
calling at least one of the selected widgets with appropriate slots filled.
8. The method of claim 7 further comprising:
receiving the user query associated with one or more of the plurality of widgets directly from a user and/or via a Web browser.
9. The method of claim 7 further comprising:
relaying the selected widgets and slot filling for the selected widgets to the calling application; and
invoking at least one of the selected widgets with filled slots for utilization by a user.
10. A widget search method that employs the method of claim 7 to facilitate client-side widget searching.
11. A computer readable storage medium that facilitates widget searching, comprising:
means for receiving a natural language query processible by a widget;
means for determining an appropriate widget and slot filling for the natural language query, employed by an adaptive task reasoning process;
means for invoking the determined widget for interaction with a user, the determined widget configured to expose metadata describing tasks performed by that widget;
means for obtaining user feedback, slot filling data, or metadata related to the system, or a combination thereof, from interaction with the determined widget;
means for determining appropriate slot filling for the selected widget based on the natural language query;
means for filling the appropriate slots of the selected widget based on the natural language query;
means for employing an adaptive semantic reasoning engine to facilitate improvement on the adaptive task reasoning based upon the obtained user feedback, upon the obtained slot filling data, upon the obtained metadata, or a combination thereof, wherein the adaptive semantic reasoning engine employs statistical learning models; and
means for employing the user feedback relating to the determined widget to facilitate in future widget selections and slot filling in response to natural language queries.
US11/367,292 2006-03-02 2006-03-02 Widget searching utilizing task framework Active 2027-05-31 US7996783B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/367,292 US7996783B2 (en) 2006-03-02 2006-03-02 Widget searching utilizing task framework

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/367,292 US7996783B2 (en) 2006-03-02 2006-03-02 Widget searching utilizing task framework

Publications (2)

Publication Number Publication Date
US20070209013A1 US20070209013A1 (en) 2007-09-06
US7996783B2 true US7996783B2 (en) 2011-08-09

Family

ID=38472767

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/367,292 Active 2027-05-31 US7996783B2 (en) 2006-03-02 2006-03-02 Widget searching utilizing task framework

Country Status (1)

Country Link
US (1) US7996783B2 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080034314A1 (en) * 2006-08-04 2008-02-07 Louch John O Management and generation of dashboards
US8954871B2 (en) 2007-07-18 2015-02-10 Apple Inc. User-centric widgets and dashboards
US9032318B2 (en) 2005-10-27 2015-05-12 Apple Inc. Widget security
US9104294B2 (en) 2005-10-27 2015-08-11 Apple Inc. Linked widgets
US9417888B2 (en) 2005-11-18 2016-08-16 Apple Inc. Management of user interface elements in a display environment
US9513930B2 (en) 2005-10-27 2016-12-06 Apple Inc. Workflow widgets
US11061904B2 (en) 2018-04-17 2021-07-13 International Business Machines Corporation Resource condition correction using intelligently configured dashboard widgets

Families Citing this family (58)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7681112B1 (en) 2003-05-30 2010-03-16 Adobe Systems Incorporated Embedded reuse meta information
US7490295B2 (en) * 2004-06-25 2009-02-10 Apple Inc. Layer for accessing user interface elements
US8239749B2 (en) 2004-06-25 2012-08-07 Apple Inc. Procedurally expressing graphic objects for web pages
US8453065B2 (en) 2004-06-25 2013-05-28 Apple Inc. Preview and installation of user interface elements in a display environment
US8302020B2 (en) 2004-06-25 2012-10-30 Apple Inc. Widget authoring and editing environment
US8566732B2 (en) 2004-06-25 2013-10-22 Apple Inc. Synchronization of widgets and dashboards
US7761800B2 (en) 2004-06-25 2010-07-20 Apple Inc. Unified interest layer for user interface
US8140975B2 (en) 2005-01-07 2012-03-20 Apple Inc. Slide show navigation
US8543931B2 (en) 2005-06-07 2013-09-24 Apple Inc. Preview including theme based installation of user interface elements in a display environment
US7954064B2 (en) 2005-10-27 2011-05-31 Apple Inc. Multiple dashboards
US8543824B2 (en) 2005-10-27 2013-09-24 Apple Inc. Safe distribution and use of content
US7822699B2 (en) * 2005-11-30 2010-10-26 Microsoft Corporation Adaptive semantic reasoning engine
US7831585B2 (en) * 2005-12-05 2010-11-09 Microsoft Corporation Employment of task framework for advertising
US20070130134A1 (en) * 2005-12-05 2007-06-07 Microsoft Corporation Natural-language enabling arbitrary web forms
US7933914B2 (en) * 2005-12-05 2011-04-26 Microsoft Corporation Automatic task creation and execution using browser helper objects
US20080010130A1 (en) * 2006-06-15 2008-01-10 Nokia Corporation Auctions for widget space
US8869066B2 (en) 2006-07-06 2014-10-21 Addthis, Llc Generic content collection systems
US8056092B2 (en) * 2006-09-29 2011-11-08 Clearspring Technologies, Inc. Method and apparatus for widget-container hosting and generation
US20080082627A1 (en) * 2006-09-29 2008-04-03 Allen Stewart O Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation
US9009728B2 (en) 2007-03-06 2015-04-14 Addthis, Inc. Method and apparatus for widget and widget-container distribution control based on content rules
US8266274B2 (en) 2007-03-06 2012-09-11 Clearspring Technologies, Inc. Method and apparatus for data processing
US8954469B2 (en) * 2007-03-14 2015-02-10 Vcvciii Llc Query templates and labeled search tip system, methods, and techniques
US20080271127A1 (en) * 2007-04-24 2008-10-30 Business Objects, S.A. Apparatus and method for creating stand-alone business intelligence widgets within an authentication framework
US20080300980A1 (en) * 2007-05-31 2008-12-04 Goodstorm, Inc. Method and system of synchronizing data processed through web widgets distributed across network nodes
US9167070B2 (en) * 2007-07-31 2015-10-20 Qualcomm Incorporated Widget discovery in computing devices
US8104044B1 (en) * 2007-07-31 2012-01-24 Amazon Technologies, Inc. System and method for client-side widget communication
US8667415B2 (en) 2007-08-06 2014-03-04 Apple Inc. Web widgets
US8156467B2 (en) 2007-08-27 2012-04-10 Adobe Systems Incorporated Reusing components in a running application
US9268856B2 (en) * 2007-09-28 2016-02-23 Yahoo! Inc. System and method for inclusion of interactive elements on a search results page
US8176466B2 (en) 2007-10-01 2012-05-08 Adobe Systems Incorporated System and method for generating an application fragment
US8209378B2 (en) 2007-10-04 2012-06-26 Clearspring Technologies, Inc. Methods and apparatus for widget sharing between content aggregation points
US8594996B2 (en) 2007-10-17 2013-11-26 Evri Inc. NLP-based entity recognition and disambiguation
AU2008312423B2 (en) * 2007-10-17 2013-12-19 Vcvc Iii Llc NLP-based content recommender
US20090144066A1 (en) * 2007-11-30 2009-06-04 Leviathan Entertainment, Inc. Method and System for Differential Billing
JP2009157901A (en) * 2007-12-27 2009-07-16 Sharp Corp Information provision device, information display device, information provision system, information provision method, program and computer-readable recording medium recording program
JP4739370B2 (en) * 2007-12-27 2011-08-03 シャープ株式会社 INFORMATION PROVIDING DEVICE, INFORMATION DISPLAY DEVICE, INFORMATION PROVIDING SYSTEM, CONTROL METHOD, CONTROL PROGRAM, AND RECORDING MEDIUM
US9619304B2 (en) 2008-02-05 2017-04-11 Adobe Systems Incorporated Automatic connections between application components
US20090288004A1 (en) * 2008-05-15 2009-11-19 Toni Peter Strandell System, method, apparatus and computer program product for providing a notification of widget availability
KR101539461B1 (en) * 2008-07-16 2015-07-30 삼성전자주식회사 Apparatus and method for providing an user interface service in a multimedia system
US8656293B1 (en) 2008-07-29 2014-02-18 Adobe Systems Incorporated Configuring mobile devices
US20100037157A1 (en) * 2008-08-05 2010-02-11 International Business Machines Corp. Proactive machine-aided mashup construction with implicit and explicit input from user community
US8938465B2 (en) * 2008-09-10 2015-01-20 Samsung Electronics Co., Ltd. Method and system for utilizing packaged content sources to identify and provide information based on contextual information
US20100114878A1 (en) * 2008-10-22 2010-05-06 Yumao Lu Selective term weighting for web search based on automatic semantic parsing
US8073857B2 (en) * 2009-02-17 2011-12-06 International Business Machines Corporation Semantics-based data transformation over a wire in mashups
US20130275890A1 (en) * 2009-10-23 2013-10-17 Mark Caron Mobile widget dashboard
US20110119637A1 (en) * 2009-11-13 2011-05-19 Nokia Corporation Method and apparatus for interacting with a content object
WO2011080360A1 (en) * 2009-12-30 2011-07-07 Telefonica, S.A. Method for establishing a relationship between semantic data and the running of a widget
US9710556B2 (en) 2010-03-01 2017-07-18 Vcvc Iii Llc Content recommendation based on collections of entities
US8645125B2 (en) 2010-03-30 2014-02-04 Evri, Inc. NLP-based systems and methods for providing quotations
US9405848B2 (en) 2010-09-15 2016-08-02 Vcvc Iii Llc Recommending mobile device activities
US8725739B2 (en) 2010-11-01 2014-05-13 Evri, Inc. Category-based content recommendation
US9015140B2 (en) * 2010-12-30 2015-04-21 Yahoo! Inc. System and method for providing contextual actions on a search results page
US9116995B2 (en) 2011-03-30 2015-08-25 Vcvc Iii Llc Cluster-based identification of news stories
US9069814B2 (en) * 2011-07-27 2015-06-30 Wolfram Alpha Llc Method and system for using natural language to generate widgets
US9933861B2 (en) * 2012-01-12 2018-04-03 Wolfram Research, Inc. Method and apparatus for generating a user interface for taking or viewing the results of predicted actions
US9665556B1 (en) 2012-07-23 2017-05-30 Amazon Technologies, Inc. Assigning slots to user interface elements
US9792095B2 (en) * 2014-11-25 2017-10-17 Symbol Technologies, Llc Apparatus and method for converting a procedure manual to an automated program
US10007918B1 (en) * 2014-12-26 2018-06-26 Sprint Communications Company L.P. Customer care automation system

Citations (126)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4736296A (en) 1983-12-26 1988-04-05 Hitachi, Ltd. Method and apparatus of intelligent guidance in natural language
US4965763A (en) 1987-03-03 1990-10-23 International Business Machines Corporation Computer method for automatic extraction of commonly specified information from business correspondence
US4974191A (en) 1987-07-31 1990-11-27 Syntellect Software Inc. Adaptive natural language computer interface system
US5208816A (en) 1989-08-18 1993-05-04 At&T Bell Laboratories Generalized viterbi decoding algorithms
US5477451A (en) 1991-07-25 1995-12-19 International Business Machines Corp. Method and system for natural language translation
US5577241A (en) 1994-12-07 1996-11-19 Excite, Inc. Information retrieval system and method with implementation extensible query architecture
US5625814A (en) 1992-05-27 1997-04-29 Apple Computer, Inc. Method and apparatus for processing natural language with a hierarchy of mapping routines
US5636036A (en) 1987-02-27 1997-06-03 Ashbey; James A. Interactive video system having frame recall dependent upon user input and current displayed image
US5696962A (en) 1993-06-24 1997-12-09 Xerox Corporation Method for computerized information retrieval using shallow linguistic analysis
US5748974A (en) 1994-12-13 1998-05-05 International Business Machines Corporation Multimodal natural language interface for cross-application tasks
US5752244A (en) * 1996-07-15 1998-05-12 Andersen Consulting Llp Computerized multimedia asset management system
US5754174A (en) * 1992-08-27 1998-05-19 Starfish Software, Inc. User interface with individually configurable panel interfaces for use in a computer system
US5754173A (en) * 1996-02-28 1998-05-19 Sun Microsystems, Inc. Method and system for creating user interface independent programs with a user interface provider
US5794259A (en) * 1996-07-25 1998-08-11 Lextron Systems, Inc Apparatus and methods to enhance web browsing on the internet
US5832459A (en) * 1994-08-19 1998-11-03 Andersen Consulting Llp Computerized source searching system and method for use in an order entry system
US5855015A (en) * 1995-03-20 1998-12-29 Interval Research Corporation System and method for retrieval of hyperlinked information resources
US5892900A (en) 1996-08-30 1999-04-06 Intertrust Technologies Corp. Systems and methods for secure transaction management and electronic rights protection
US5999948A (en) 1997-09-03 1999-12-07 3Com Corporation Dynamic configuration forms in network management software
US6055528A (en) 1997-07-25 2000-04-25 Claritech Corporation Method for cross-linguistic document retrieval
US6078914A (en) * 1996-12-09 2000-06-20 Open Text Corporation Natural language meta-search system and method
US6088700A (en) * 1999-08-06 2000-07-11 Larsen; Kenneth N. Automated forms completion for global information network applications
US6118939A (en) 1998-01-22 2000-09-12 International Business Machines Corporation Method and system for a replaceable application interface at the user task level
US6212494B1 (en) 1994-09-28 2001-04-03 Apple Computer, Inc. Method for extracting knowledge from online documentation and creating a glossary, index, help database or the like
WO2001029823A1 (en) 1999-10-19 2001-04-26 Sony Electronics Inc. Natural language interface control system
US6278996B1 (en) 1997-03-31 2001-08-21 Brightware, Inc. System and method for message process and response
US6314398B1 (en) 1999-03-01 2001-11-06 Matsushita Electric Industrial Co., Ltd. Apparatus and method using speech understanding for automatic channel selection in interactive television
US20020032680A1 (en) 1998-06-30 2002-03-14 Microsoft Corporation Flexible keyword searching
US20020042793A1 (en) 2000-08-23 2002-04-11 Jun-Hyeog Choi Method of order-ranking document clusters using entropy data and bayesian self-organizing feature maps
US20020045463A1 (en) 2000-10-13 2002-04-18 Zheng Chen Language input system for mobile devices
US20020049750A1 (en) 2000-04-10 2002-04-25 Srinivas Venkatram Concept mapping based knowledge acquisition system and methods
US20020059132A1 (en) 2000-08-18 2002-05-16 Quay Steven C. Online bidding for a contract to provide a good or service
US20020065959A1 (en) 2000-10-13 2002-05-30 Bo-Sung Kim Information search method and apparatus using Inverse Hidden Markov Model
US20020101448A1 (en) 2000-11-29 2002-08-01 Sanderson Richard A. Generating a declarative user interface
US20020124115A1 (en) 2000-11-13 2002-09-05 Mclean Alistair William Filter based authoring tool
US20020143949A1 (en) 2000-12-11 2002-10-03 Vij Rajarajan Method and system for task based management of multiple network resources
US20020152190A1 (en) 2001-02-07 2002-10-17 International Business Machines Corporation Customer self service subsystem for adaptive indexing of resource solutions and resource lookup
WO2003001413A1 (en) 2001-06-22 2003-01-03 Nosa Omoigui System and method for knowledge retrieval, management, delivery and presentation
US6513006B2 (en) 1999-08-26 2003-01-28 Matsushita Electronic Industrial Co., Ltd. Automatic control of household activity using speech recognition and natural language
US20030023598A1 (en) 2001-07-26 2003-01-30 International Business Machines Corporation Dynamic composite advertisements for distribution via computer networks
US20030078766A1 (en) 1999-09-17 2003-04-24 Douglas E. Appelt Information retrieval by natural language querying
US20030084035A1 (en) 2001-07-23 2003-05-01 Emerick Charles L. Integrated search and information discovery system
US20030120700A1 (en) 2001-09-11 2003-06-26 Sun Microsystems, Inc. Task grouping in a distributed processing framework system and methods for implementing the same
US20030135584A1 (en) 1999-06-10 2003-07-17 Bow Street Software, Inc. Method and apparatus creating network services
US6643620B1 (en) 1999-03-15 2003-11-04 Matsushita Electric Industrial Co., Ltd. Voice activated controller for recording and retrieving audio/video programs
US20030222912A1 (en) 2002-02-01 2003-12-04 John Fairweather System and method for managing dataflows
US6675159B1 (en) 2000-07-27 2004-01-06 Science Applic Int Corp Concept-based search and retrieval system
US6678694B1 (en) 2000-11-08 2004-01-13 Frank Meik Indexed, extensible, interactive document retrieval system
US6678677B2 (en) 2000-12-19 2004-01-13 Xerox Corporation Apparatus and method for information retrieval using self-appending semantic lattice
US6690390B1 (en) 2000-10-24 2004-02-10 National Instruments Corporation Interactive on-line help for completing a task
US20040030710A1 (en) 2001-05-21 2004-02-12 Thomas Shadle Rules-based task browser for engineering systems
US20040030556A1 (en) 1999-11-12 2004-02-12 Bennett Ian M. Speech based learning/training system using semantic decoding
US20040030697A1 (en) * 2002-07-31 2004-02-12 American Management Systems, Inc. System and method for online feedback
US20040034652A1 (en) 2000-07-26 2004-02-19 Thomas Hofmann System and method for personalized search, information filtering, and for generating recommendations utilizing statistical latent class models
WO2004017230A1 (en) 2002-08-16 2004-02-26 Teamware Group Oy System and method for a context-independent framework for management and execution of xml processing tasks
US6724403B1 (en) * 1999-10-29 2004-04-20 Surfcast, Inc. System and method for simultaneous display of multiple information sources
US20040111419A1 (en) 2002-12-05 2004-06-10 Cook Daniel B. Method and apparatus for adapting a search classifier based on user queries
US6751606B1 (en) 1998-12-23 2004-06-15 Microsoft Corporation System for enhancing a query interface
US20040117395A1 (en) 2002-12-11 2004-06-17 International Business Machines Corporation Method and knowledge structures for reasoning about concepts, relations, and rules
US20040122674A1 (en) 2002-12-19 2004-06-24 Srinivas Bangalore Context-sensitive interface widgets for multi-modal dialog systems
US20040130572A1 (en) 2003-01-07 2004-07-08 Aravind Bala Active content wizard: execution of tasks and structured content
US20040148154A1 (en) 2003-01-23 2004-07-29 Alejandro Acero System for using statistical classifiers for spoken language understanding
US20040181749A1 (en) 2003-01-29 2004-09-16 Microsoft Corporation Method and apparatus for populating electronic forms from scanned documents
US20040220893A1 (en) 2002-11-20 2004-11-04 Radar Networks, Inc. User interface for managing semantic objects
US6816857B1 (en) 1999-11-01 2004-11-09 Applied Semantics, Inc. Meaning-based advertising and document relevance determination
US20040236580A1 (en) 1999-11-12 2004-11-25 Bennett Ian M. Method for processing speech using dynamic grammars
US20040250255A1 (en) 2003-06-03 2004-12-09 Achim Kraiss Analytical application framework
US20040260689A1 (en) 2001-11-13 2004-12-23 Overture Services, Inc. System and method allowing advertisers to manage search listings in a pay for placement search system using grouping
US20040260534A1 (en) 2003-06-19 2004-12-23 Pak Wai H. Intelligent data search
US20040267725A1 (en) 2003-06-30 2004-12-30 Harik Georges R Serving advertisements using a search of advertiser Web information
US6850252B1 (en) 1999-10-05 2005-02-01 Steven M. Hoffberg Intelligent electronic appliance system and method
US20050028133A1 (en) 2003-08-02 2005-02-03 Viswanath Ananth System and method for rapid design, prototyping, and implementation of distributed scalable architecture for task control and automation
US20050027666A1 (en) 2003-07-15 2005-02-03 Vente, Inc Interactive online research system and method
US20050034098A1 (en) 2003-08-05 2005-02-10 Accenture Global Services Gmbh Methodology framework and delivery vehicle
US20050044058A1 (en) * 2003-08-21 2005-02-24 Matthews David A. System and method for providing rich minimized applications
US20050049874A1 (en) 2003-09-03 2005-03-03 International Business Machines Corporation Method and apparatus for dynamic modification of command weights in a natural language understanding system
US20050049852A1 (en) 2003-09-03 2005-03-03 Chao Gerald Cheshun Adaptive and scalable method for resolving natural language ambiguities
US20050065995A1 (en) 2003-09-23 2005-03-24 Microsoft Corporation Content and task-execution services provided through dialog-based interfaces
US20050075878A1 (en) 2003-10-01 2005-04-07 International Business Machines Corporation Method, system, and apparatus for natural language mixed-initiative dialogue processing
US20050075859A1 (en) 2003-10-06 2005-04-07 Microsoft Corporation Method and apparatus for identifying semantic structures from text
US20050080782A1 (en) 2003-10-10 2005-04-14 Microsoft Corporation Computer aided query to task mapping
US20050078805A1 (en) 2002-07-02 2005-04-14 Sbc Properties, L.P. System and method for the automated analysis of performance data
US20050080625A1 (en) 1999-11-12 2005-04-14 Bennett Ian M. Distributed real time speech recognition system
WO2005036365A2 (en) 2003-10-10 2005-04-21 Accenture Global Services Gmbh Tool for synchronization of business information
US20050114854A1 (en) 2003-11-24 2005-05-26 Microsoft Corporation System and method for dynamic cooperative distributed execution of computer tasks without a centralized controller
US6901399B1 (en) 1997-07-22 2005-05-31 Microsoft Corporation System for processing textual inputs using natural language processing techniques
US6904402B1 (en) 1999-11-05 2005-06-07 Microsoft Corporation System and iterative method for lexicon, segmentation and language model joint optimization
US20050132380A1 (en) 2003-12-11 2005-06-16 International Business Machines Corporation Method for hiding latency in a task-based library framework for a multiprocessor environment
US20050131672A1 (en) 2003-12-12 2005-06-16 International Business Machines Corporation Language-enhanced programming tools
US20050137939A1 (en) 2003-12-19 2005-06-23 Palo Alto Research Center Incorporated Server-based keyword advertisement management
US20050144065A1 (en) 2003-12-19 2005-06-30 Palo Alto Research Center Incorporated Keyword advertisement management with coordinated bidding among advertisers
US20050144064A1 (en) 2003-12-19 2005-06-30 Palo Alto Research Center Incorporated Keyword advertisement management
US20050187818A1 (en) 2004-02-20 2005-08-25 Zito David D. Computerized advertising offer exchange
US20050193055A1 (en) 2004-02-26 2005-09-01 Mark Angel Context sensitive dynamic user interface for customer service agent
US20050192992A1 (en) 2004-03-01 2005-09-01 Microsoft Corporation Systems and methods that determine intent of data and respond to the data based on the intent
US6947923B2 (en) 2000-12-08 2005-09-20 Electronics And Telecommunications Research Institute Information generation and retrieval method based on standardized format of sentence structure and semantic structure and system using the same
US20050216356A1 (en) * 2003-07-30 2005-09-29 Pearce William M Method for automatically filling in web forms
US20050228744A1 (en) 2004-04-09 2005-10-13 Cmarket, Inc. Method and apparatus for modifying the winning bid in an on-line auction to benefit a charitable organization
US20050246726A1 (en) 2004-04-28 2005-11-03 Fujitsu Limited Task computing
US20050257148A1 (en) 2004-05-12 2005-11-17 Microsoft Corporation Intelligent autofill
US20050283473A1 (en) * 2004-06-17 2005-12-22 Armand Rousso Apparatus, method and system of artificial intelligence for data searching applications
US20060005207A1 (en) * 2004-06-25 2006-01-05 Louch John O Widget authoring and editing environment
US20060059434A1 (en) 2004-09-16 2006-03-16 International Business Machines Corporation System and method to capture and manage input values for automatic form fill
US20060064302A1 (en) 2004-09-20 2006-03-23 International Business Machines Corporation Method and system for voice-enabled autofill
US20060064411A1 (en) 2004-09-22 2006-03-23 William Gross Search engine using user intent
US7020607B2 (en) 2000-07-13 2006-03-28 Fujitsu Limited Dialogue processing system and method
US7020658B1 (en) * 2000-06-02 2006-03-28 Charles E. Hill & Associates Data file management system and method for browsers
US20060107219A1 (en) 2004-05-26 2006-05-18 Motorola, Inc. Method to enhance user interface and target applications based on context awareness
US20060129463A1 (en) 2004-12-15 2006-06-15 Zicherman Amir S Method and system for automatic product searching, and use thereof
US20060156248A1 (en) * 2004-06-25 2006-07-13 Chaudhri Imran A Configuration bar for lauching layer for accessing user interface elements
US20060179404A1 (en) 2005-02-08 2006-08-10 Microsoft Corporation Method for a browser auto form fill
US20070027850A1 (en) 2005-08-01 2007-02-01 Reprise Media, Llc Methods and systems for developing and managing a computer-based marketing campaign
US20070038934A1 (en) * 2005-08-12 2007-02-15 Barry Fellman Service for generation of customizable display widgets
US20070038614A1 (en) 2005-08-10 2007-02-15 Guha Ramanathan V Generating and presenting advertisements based on context data for programmable search engines
US20070067217A1 (en) 2005-09-20 2007-03-22 Joshua Schachter System and method for selecting advertising
US20070101279A1 (en) * 2005-10-27 2007-05-03 Chaudhri Imran A Selection of user interface elements for unified display in a display environment
US20070100688A1 (en) 2005-10-28 2007-05-03 Book Joyce A Method and apparatus for dynamic ad creation
US20070101297A1 (en) * 2005-10-27 2007-05-03 Scott Forstall Multiple dashboards
US20070106496A1 (en) * 2005-11-09 2007-05-10 Microsoft Corporation Adaptive task framework
US20070106495A1 (en) 2005-11-09 2007-05-10 Microsoft Corporation Adaptive task framework
US20070124263A1 (en) 2005-11-30 2007-05-31 Microsoft Corporation Adaptive semantic reasoning engine
US20070130134A1 (en) 2005-12-05 2007-06-07 Microsoft Corporation Natural-language enabling arbitrary web forms
US20070130124A1 (en) 2005-12-05 2007-06-07 Microsoft Corporation Employment of task framework for advertising
US20070130186A1 (en) * 2005-12-05 2007-06-07 Microsoft Corporation Automatic task creation and execution using browser helper objects
US20070192179A1 (en) * 2006-02-15 2007-08-16 Van Luchene Andrew S Survey-Based Qualification of Keyword Searches
US7328199B2 (en) 2005-10-07 2008-02-05 Microsoft Corporation Componentized slot-filling architecture
US7523099B1 (en) 2004-12-30 2009-04-21 Google Inc. Category suggestions relating to a search

Patent Citations (131)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4736296A (en) 1983-12-26 1988-04-05 Hitachi, Ltd. Method and apparatus of intelligent guidance in natural language
US5636036A (en) 1987-02-27 1997-06-03 Ashbey; James A. Interactive video system having frame recall dependent upon user input and current displayed image
US4965763A (en) 1987-03-03 1990-10-23 International Business Machines Corporation Computer method for automatic extraction of commonly specified information from business correspondence
US4974191A (en) 1987-07-31 1990-11-27 Syntellect Software Inc. Adaptive natural language computer interface system
US5208816A (en) 1989-08-18 1993-05-04 At&T Bell Laboratories Generalized viterbi decoding algorithms
US5477451A (en) 1991-07-25 1995-12-19 International Business Machines Corp. Method and system for natural language translation
US5625814A (en) 1992-05-27 1997-04-29 Apple Computer, Inc. Method and apparatus for processing natural language with a hierarchy of mapping routines
US5754174A (en) * 1992-08-27 1998-05-19 Starfish Software, Inc. User interface with individually configurable panel interfaces for use in a computer system
US5696962A (en) 1993-06-24 1997-12-09 Xerox Corporation Method for computerized information retrieval using shallow linguistic analysis
US5832459A (en) * 1994-08-19 1998-11-03 Andersen Consulting Llp Computerized source searching system and method for use in an order entry system
US6212494B1 (en) 1994-09-28 2001-04-03 Apple Computer, Inc. Method for extracting knowledge from online documentation and creating a glossary, index, help database or the like
US5577241A (en) 1994-12-07 1996-11-19 Excite, Inc. Information retrieval system and method with implementation extensible query architecture
US5748974A (en) 1994-12-13 1998-05-05 International Business Machines Corporation Multimodal natural language interface for cross-application tasks
US5855015A (en) * 1995-03-20 1998-12-29 Interval Research Corporation System and method for retrieval of hyperlinked information resources
US5754173A (en) * 1996-02-28 1998-05-19 Sun Microsystems, Inc. Method and system for creating user interface independent programs with a user interface provider
US5752244A (en) * 1996-07-15 1998-05-12 Andersen Consulting Llp Computerized multimedia asset management system
US5794259A (en) * 1996-07-25 1998-08-11 Lextron Systems, Inc Apparatus and methods to enhance web browsing on the internet
US5892900A (en) 1996-08-30 1999-04-06 Intertrust Technologies Corp. Systems and methods for secure transaction management and electronic rights protection
US6078914A (en) * 1996-12-09 2000-06-20 Open Text Corporation Natural language meta-search system and method
US6278996B1 (en) 1997-03-31 2001-08-21 Brightware, Inc. System and method for message process and response
US6901399B1 (en) 1997-07-22 2005-05-31 Microsoft Corporation System for processing textual inputs using natural language processing techniques
US6055528A (en) 1997-07-25 2000-04-25 Claritech Corporation Method for cross-linguistic document retrieval
US5999948A (en) 1997-09-03 1999-12-07 3Com Corporation Dynamic configuration forms in network management software
US6118939A (en) 1998-01-22 2000-09-12 International Business Machines Corporation Method and system for a replaceable application interface at the user task level
US20020032680A1 (en) 1998-06-30 2002-03-14 Microsoft Corporation Flexible keyword searching
US6751606B1 (en) 1998-12-23 2004-06-15 Microsoft Corporation System for enhancing a query interface
US6314398B1 (en) 1999-03-01 2001-11-06 Matsushita Electric Industrial Co., Ltd. Apparatus and method using speech understanding for automatic channel selection in interactive television
US6643620B1 (en) 1999-03-15 2003-11-04 Matsushita Electric Industrial Co., Ltd. Voice activated controller for recording and retrieving audio/video programs
US20030135584A1 (en) 1999-06-10 2003-07-17 Bow Street Software, Inc. Method and apparatus creating network services
US6088700A (en) * 1999-08-06 2000-07-11 Larsen; Kenneth N. Automated forms completion for global information network applications
US6513006B2 (en) 1999-08-26 2003-01-28 Matsushita Electronic Industrial Co., Ltd. Automatic control of household activity using speech recognition and natural language
US6910003B1 (en) 1999-09-17 2005-06-21 Discern Communications, Inc. System, method and article of manufacture for concept based information searching
US20030078766A1 (en) 1999-09-17 2003-04-24 Douglas E. Appelt Information retrieval by natural language querying
US6850252B1 (en) 1999-10-05 2005-02-01 Steven M. Hoffberg Intelligent electronic appliance system and method
WO2001029823A1 (en) 1999-10-19 2001-04-26 Sony Electronics Inc. Natural language interface control system
US6724403B1 (en) * 1999-10-29 2004-04-20 Surfcast, Inc. System and method for simultaneous display of multiple information sources
US6816857B1 (en) 1999-11-01 2004-11-09 Applied Semantics, Inc. Meaning-based advertising and document relevance determination
US6904402B1 (en) 1999-11-05 2005-06-07 Microsoft Corporation System and iterative method for lexicon, segmentation and language model joint optimization
US20040030556A1 (en) 1999-11-12 2004-02-12 Bennett Ian M. Speech based learning/training system using semantic decoding
US20040236580A1 (en) 1999-11-12 2004-11-25 Bennett Ian M. Method for processing speech using dynamic grammars
US20050086059A1 (en) 1999-11-12 2005-04-21 Bennett Ian M. Partial speech processing device & method for use in distributed systems
US20050080625A1 (en) 1999-11-12 2005-04-14 Bennett Ian M. Distributed real time speech recognition system
US20020049750A1 (en) 2000-04-10 2002-04-25 Srinivas Venkatram Concept mapping based knowledge acquisition system and methods
US7020658B1 (en) * 2000-06-02 2006-03-28 Charles E. Hill & Associates Data file management system and method for browsers
US7020607B2 (en) 2000-07-13 2006-03-28 Fujitsu Limited Dialogue processing system and method
US20040034652A1 (en) 2000-07-26 2004-02-19 Thomas Hofmann System and method for personalized search, information filtering, and for generating recommendations utilizing statistical latent class models
US6675159B1 (en) 2000-07-27 2004-01-06 Science Applic Int Corp Concept-based search and retrieval system
US20020059132A1 (en) 2000-08-18 2002-05-16 Quay Steven C. Online bidding for a contract to provide a good or service
US20020042793A1 (en) 2000-08-23 2002-04-11 Jun-Hyeog Choi Method of order-ranking document clusters using entropy data and bayesian self-organizing feature maps
US20020065959A1 (en) 2000-10-13 2002-05-30 Bo-Sung Kim Information search method and apparatus using Inverse Hidden Markov Model
US20020045463A1 (en) 2000-10-13 2002-04-18 Zheng Chen Language input system for mobile devices
US6690390B1 (en) 2000-10-24 2004-02-10 National Instruments Corporation Interactive on-line help for completing a task
US6678694B1 (en) 2000-11-08 2004-01-13 Frank Meik Indexed, extensible, interactive document retrieval system
US20020124115A1 (en) 2000-11-13 2002-09-05 Mclean Alistair William Filter based authoring tool
US20020101448A1 (en) 2000-11-29 2002-08-01 Sanderson Richard A. Generating a declarative user interface
US6947923B2 (en) 2000-12-08 2005-09-20 Electronics And Telecommunications Research Institute Information generation and retrieval method based on standardized format of sentence structure and semantic structure and system using the same
US20020143949A1 (en) 2000-12-11 2002-10-03 Vij Rajarajan Method and system for task based management of multiple network resources
US6678677B2 (en) 2000-12-19 2004-01-13 Xerox Corporation Apparatus and method for information retrieval using self-appending semantic lattice
US20020152190A1 (en) 2001-02-07 2002-10-17 International Business Machines Corporation Customer self service subsystem for adaptive indexing of resource solutions and resource lookup
US20040030710A1 (en) 2001-05-21 2004-02-12 Thomas Shadle Rules-based task browser for engineering systems
WO2003001413A1 (en) 2001-06-22 2003-01-03 Nosa Omoigui System and method for knowledge retrieval, management, delivery and presentation
US20030084035A1 (en) 2001-07-23 2003-05-01 Emerick Charles L. Integrated search and information discovery system
US20030023598A1 (en) 2001-07-26 2003-01-30 International Business Machines Corporation Dynamic composite advertisements for distribution via computer networks
US20030120700A1 (en) 2001-09-11 2003-06-26 Sun Microsystems, Inc. Task grouping in a distributed processing framework system and methods for implementing the same
US20040260689A1 (en) 2001-11-13 2004-12-23 Overture Services, Inc. System and method allowing advertisers to manage search listings in a pay for placement search system using grouping
US20030222912A1 (en) 2002-02-01 2003-12-04 John Fairweather System and method for managing dataflows
US20050078805A1 (en) 2002-07-02 2005-04-14 Sbc Properties, L.P. System and method for the automated analysis of performance data
US20040030697A1 (en) * 2002-07-31 2004-02-12 American Management Systems, Inc. System and method for online feedback
WO2004017230A1 (en) 2002-08-16 2004-02-26 Teamware Group Oy System and method for a context-independent framework for management and execution of xml processing tasks
US20040220893A1 (en) 2002-11-20 2004-11-04 Radar Networks, Inc. User interface for managing semantic objects
US20040111419A1 (en) 2002-12-05 2004-06-10 Cook Daniel B. Method and apparatus for adapting a search classifier based on user queries
US20040117395A1 (en) 2002-12-11 2004-06-17 International Business Machines Corporation Method and knowledge structures for reasoning about concepts, relations, and rules
US20040122674A1 (en) 2002-12-19 2004-06-24 Srinivas Bangalore Context-sensitive interface widgets for multi-modal dialog systems
US20040130572A1 (en) 2003-01-07 2004-07-08 Aravind Bala Active content wizard: execution of tasks and structured content
US20040148154A1 (en) 2003-01-23 2004-07-29 Alejandro Acero System for using statistical classifiers for spoken language understanding
US20040181749A1 (en) 2003-01-29 2004-09-16 Microsoft Corporation Method and apparatus for populating electronic forms from scanned documents
US20040250255A1 (en) 2003-06-03 2004-12-09 Achim Kraiss Analytical application framework
US20040260534A1 (en) 2003-06-19 2004-12-23 Pak Wai H. Intelligent data search
US20040267725A1 (en) 2003-06-30 2004-12-30 Harik Georges R Serving advertisements using a search of advertiser Web information
US20050027666A1 (en) 2003-07-15 2005-02-03 Vente, Inc Interactive online research system and method
US20050216356A1 (en) * 2003-07-30 2005-09-29 Pearce William M Method for automatically filling in web forms
US20050028133A1 (en) 2003-08-02 2005-02-03 Viswanath Ananth System and method for rapid design, prototyping, and implementation of distributed scalable architecture for task control and automation
US20050034098A1 (en) 2003-08-05 2005-02-10 Accenture Global Services Gmbh Methodology framework and delivery vehicle
US20050044058A1 (en) * 2003-08-21 2005-02-24 Matthews David A. System and method for providing rich minimized applications
US20050049874A1 (en) 2003-09-03 2005-03-03 International Business Machines Corporation Method and apparatus for dynamic modification of command weights in a natural language understanding system
US20050049852A1 (en) 2003-09-03 2005-03-03 Chao Gerald Cheshun Adaptive and scalable method for resolving natural language ambiguities
US20050065995A1 (en) 2003-09-23 2005-03-24 Microsoft Corporation Content and task-execution services provided through dialog-based interfaces
US20050075878A1 (en) 2003-10-01 2005-04-07 International Business Machines Corporation Method, system, and apparatus for natural language mixed-initiative dialogue processing
US20050075859A1 (en) 2003-10-06 2005-04-07 Microsoft Corporation Method and apparatus for identifying semantic structures from text
WO2005036365A2 (en) 2003-10-10 2005-04-21 Accenture Global Services Gmbh Tool for synchronization of business information
US20050080782A1 (en) 2003-10-10 2005-04-14 Microsoft Corporation Computer aided query to task mapping
US20050114854A1 (en) 2003-11-24 2005-05-26 Microsoft Corporation System and method for dynamic cooperative distributed execution of computer tasks without a centralized controller
US20050132380A1 (en) 2003-12-11 2005-06-16 International Business Machines Corporation Method for hiding latency in a task-based library framework for a multiprocessor environment
US20050131672A1 (en) 2003-12-12 2005-06-16 International Business Machines Corporation Language-enhanced programming tools
US20050144064A1 (en) 2003-12-19 2005-06-30 Palo Alto Research Center Incorporated Keyword advertisement management
US20050144065A1 (en) 2003-12-19 2005-06-30 Palo Alto Research Center Incorporated Keyword advertisement management with coordinated bidding among advertisers
US20050137939A1 (en) 2003-12-19 2005-06-23 Palo Alto Research Center Incorporated Server-based keyword advertisement management
US20050187818A1 (en) 2004-02-20 2005-08-25 Zito David D. Computerized advertising offer exchange
US20050193055A1 (en) 2004-02-26 2005-09-01 Mark Angel Context sensitive dynamic user interface for customer service agent
EP1571578A1 (en) 2004-03-01 2005-09-07 Microsoft Corporation Systems and methods that determine intent of data and respond to the data based on the intent
US20050192992A1 (en) 2004-03-01 2005-09-01 Microsoft Corporation Systems and methods that determine intent of data and respond to the data based on the intent
EP1580666A2 (en) 2004-03-24 2005-09-28 Microsoft Corporation Method and apparatus for populating electronic forms from scanned documents
US20050228744A1 (en) 2004-04-09 2005-10-13 Cmarket, Inc. Method and apparatus for modifying the winning bid in an on-line auction to benefit a charitable organization
US20050246726A1 (en) 2004-04-28 2005-11-03 Fujitsu Limited Task computing
US20050257148A1 (en) 2004-05-12 2005-11-17 Microsoft Corporation Intelligent autofill
US20060107219A1 (en) 2004-05-26 2006-05-18 Motorola, Inc. Method to enhance user interface and target applications based on context awareness
US20050283473A1 (en) * 2004-06-17 2005-12-22 Armand Rousso Apparatus, method and system of artificial intelligence for data searching applications
US20060005207A1 (en) * 2004-06-25 2006-01-05 Louch John O Widget authoring and editing environment
US20060156248A1 (en) * 2004-06-25 2006-07-13 Chaudhri Imran A Configuration bar for lauching layer for accessing user interface elements
US20060206835A1 (en) * 2004-06-25 2006-09-14 Chaudhri Imran A User interface element with auxiliary function
US20060059434A1 (en) 2004-09-16 2006-03-16 International Business Machines Corporation System and method to capture and manage input values for automatic form fill
US20060064302A1 (en) 2004-09-20 2006-03-23 International Business Machines Corporation Method and system for voice-enabled autofill
US20060064411A1 (en) 2004-09-22 2006-03-23 William Gross Search engine using user intent
US20060129463A1 (en) 2004-12-15 2006-06-15 Zicherman Amir S Method and system for automatic product searching, and use thereof
US7523099B1 (en) 2004-12-30 2009-04-21 Google Inc. Category suggestions relating to a search
US20060179404A1 (en) 2005-02-08 2006-08-10 Microsoft Corporation Method for a browser auto form fill
US20070027850A1 (en) 2005-08-01 2007-02-01 Reprise Media, Llc Methods and systems for developing and managing a computer-based marketing campaign
US20070038614A1 (en) 2005-08-10 2007-02-15 Guha Ramanathan V Generating and presenting advertisements based on context data for programmable search engines
US20070038934A1 (en) * 2005-08-12 2007-02-15 Barry Fellman Service for generation of customizable display widgets
US20070067217A1 (en) 2005-09-20 2007-03-22 Joshua Schachter System and method for selecting advertising
US7328199B2 (en) 2005-10-07 2008-02-05 Microsoft Corporation Componentized slot-filling architecture
US20070101279A1 (en) * 2005-10-27 2007-05-03 Chaudhri Imran A Selection of user interface elements for unified display in a display environment
US20070101297A1 (en) * 2005-10-27 2007-05-03 Scott Forstall Multiple dashboards
US20070100688A1 (en) 2005-10-28 2007-05-03 Book Joyce A Method and apparatus for dynamic ad creation
US20070106496A1 (en) * 2005-11-09 2007-05-10 Microsoft Corporation Adaptive task framework
US20070106495A1 (en) 2005-11-09 2007-05-10 Microsoft Corporation Adaptive task framework
US20070124263A1 (en) 2005-11-30 2007-05-31 Microsoft Corporation Adaptive semantic reasoning engine
US20070130134A1 (en) 2005-12-05 2007-06-07 Microsoft Corporation Natural-language enabling arbitrary web forms
US20070130124A1 (en) 2005-12-05 2007-06-07 Microsoft Corporation Employment of task framework for advertising
US20070130186A1 (en) * 2005-12-05 2007-06-07 Microsoft Corporation Automatic task creation and execution using browser helper objects
US20070192179A1 (en) * 2006-02-15 2007-08-16 Van Luchene Andrew S Survey-Based Qualification of Keyword Searches

Non-Patent Citations (75)

* Cited by examiner, † Cited by third party
Title
"Componentized Architecture", AgileTek. https://www.agiletek.com/agileplus#CompArchitecture. Last accessed Jan. 5, 2006, 2 pages.
"DTS Programming :Creating the Custom Task Framework." https://msdn.microsoft.com/library/default.asp?url=/library/en-us/dtsprog/dtspcusttskc-3hwr.asp. Last accessed Jan. 5, 2006, 1 page.
"DTS: Programming: Creating the Custom Task Framework", 1 page, accessible at: https://msdn.microsoft.com/library/default.asp?url=/library/en-us/dtsprog/dtspcusttskc-3hwr.asp, last accessed Jan. 5, 2006.
"Google Flight search takes off", by Elinor Mills, published Oct. 28, 2005, pp. 1-3. *
"Our Intelligent Agents." https://www.korns.com/technology.htm. Last accessed Jan. 5, 2006, 4 pages.
"TAEMS: A Framework for Task Analysis, Environment Modeling, and Simulation," Multi-Agent Systems Lab. https://dis.cs.umass.edu/research/taems/. Last accessed Jan. 5, 2006, 3 pages.
"Technical Forum : Machine Intelligence and the Turing Test," IBM Sysytems Journal, 2002, pp. 524-539, vol. 41, No. 3.
"Technical Forum: Machine Intelligence and the Turing Test", IBM Systems Journal, 2002, pp. 524-539, vol. 41, No. 3.
AdWords Reference Guide, Google, 114 pages (Nov. 30, 2004).
AgileTek, "Componentized Architecture", 2 pages, accessible at: https://www.agiletek.com/agileplus#CompArchitecture, last accessed Jan. 5, 2006.
Chepegin, et al. "CHIME: Service-Oriented Framework for Adaptive Web-Based Systems," in Proceedings of Dutch National Conference InfWet, Eindhoven, The Netherlands, Nov. 20, 2003, pp. 29-36.
Clarifying Search; A User-Interface Framework for Text Searches Downloaded from https://www.dlib.org/dlib/january97/retrieval/01shneiderman.html, Oct. 1997.
Clarifying Search; A User-Interface Framework for Text Searches Downloaded from https://www.dlib.org/dlib/january97/retrieval/01shneiderman.html.
Conlan, et al. "Applying Adaptive Hypermedia Techniques to Semantic Web Service Composition," in Proceedings of AH 2003 : Workshop on Adaptive Hypermedia and Adaptive Web Based Systems, 2003, pp. 53-62.
Ernst, et al. "A Task Framework for the Web Interface W2H", Bioinformatics, 2003, pp. 278-282, vol. 19, No. 2, Oxford University Press.
Ernst, et al., "A Task Framework for the Web Interface W2H", Bioinformatics, 2003, pp. 278-282, vol. 19, No. 2, Oxford University Press.
Esposito, Dino. "Browser Helper Objects:The Browser the Way You Want It. Microsoft Corporation", Jan. 1999, 12 pages.
Esposito. "Browser Helper Objects: The Browser the Way You Want It." Microsoft Corporation, Jan. 1999, 12 pages.
Free Microsoft Office Information Bridge Framework Donwloaded from https://www.microsoft.com/industry/government/InformationBridge.mspx, Nov. 2005.
Free Microsoft Office Information Bridge Framework Donwloaded from htttp:https://www.microsoft.com/industry/government/InformationBridge.mspx.
Google Toolbar; Revision History; https://www.google.com/support/toolbar/bin/static.py?page=version-info.html ; Dec. 11, 2000.
H. Lieberman, et al., "Instructible Agents: Software That Just Keeps Getting Better", IBM Systems Journal, 1996, pp. 539-556, vol. 35, Nos. 3 and 4.
H. Liu, et al., "Goose: A Goal-Oriented Search Engine with Commonsense", Adaptive Hypermedia and Adaptive Web-Based Systems, Second International Conference, AH 2002, Malaga, Spain, May 29-31, 2002, Lecture Notes in Computer Science, pp. 253-263, No. 2347.
Hochberg, et al. "A Flexible Framework for Developing Mixed-Initiative Dialog Systems," in Association for Computational Linguistics, Proceedings of the Third SIGdial Workshop on Discourse and Dialogue, Philadelphia, Jul. 2002, pp. 60-63.
Hochberg, et al., "A Flexible Framework for Developing Mixed-Initiative Dialog Systems", Association for Computational Linguistics, Proceedings of the Third SIGdial Workshop on Discourse and Dialogue, Jul. 2002, pp. 60-63, Philadelphia.
International Search Report dated Mar. 29, 2007, mailed Mar. 30, 2007, for International Application No. US2006/044418, 3 pages.
International Search Report mailed Apr. 11, 2007 in Application No. PCT/US2006/043663.
Korns Associates "Our Intelligent Agents", 4 pages, accessible at: https://www.korms.com/technology.htm, last accessed Jan. 5, 2006.
Korns Associates "Our Intelligent Agents", 4 pages, accessible at: https://www.korns.com/technology.htm, last accessed Jan. 5, 2006.
Leon Peshkin, "Research Statement", 2 pages, accessible at: https://people.csail.mit.edu/pesha/my-res.pdf, last accessed Jan. 5, 2006.
Lieberman, et al. "Instructible Agents : Software that just Keeps Getting Better," IBM Systems Journal, 1996, pp. 539-556, vol. 35, Nos. 3&4.
Liu, et al. "GOOSE: A Goal-Oriented Search Engine with Commonsense," Adaptive Hypermedia and Adaptive Web Based Systems Second International Conference, AH 2002, Malaga, Spain, May 29-31, 2002, Lecture Notes in Computer Science, pp. 253-263, No. 2347.
Multi-Agent Systems Lab, "TAEMS: A Framework for Task Analysis, Environment Modeling, and Simulation", 3 pages, acessible at: https://dis.cs.umass.edu/research/taems/, last accessed Jan. 5, 2006.
O. Conlan, et al., "Applying Adaptive Hypermedia Techniques to Semantic Web Service Composition", In Proceedings of AH 2003: Workshop on Adaptive Hypermedia and Adaptive Web-based Systems, 2003, pp. 53-62.
OA Dated Jun. 16, 2008 for U.S. Appl. No. 11/270,393, 21 pages.
OA Dated Jun. 30, 2008 for U.S. Appl. No. 11/270,407, 33 pages.
OA Dated May 13, 2008 for U.S. Appl. No. 11/294,265, 27 pages.
PESHKIN. "Research Statement." https://people.csail.mit.edu/pesha/my-res.pdf. Last accessed Jan. 5, 2006, 2 pages.
U.S. Appl. No. 11/246,847, filed Oct. 7, 2005, Ramsey, et al.
U.S. Appl. No. 11/270,393, filed Nov. 9, 2005, Ramsey, et al.
U.S. Appl. No. 11/270,407, filed Nov. 9, 2005, Ramsey, et al.
U.S. Appl. No. 11/290,076, filed Nov. 30, 2005, Ramsey, et al.
U.S. Appl. No. 11/294,262, filed Dec. 5, 2005, Ramsey, et al.
U.S. Appl. No. 11/294,265, filed Dec. 5, 2005, Ramsey, et al.
U.S. Appl. No. 11/294,581, filed Dec. 5, 2005, Yao, et al.
U.S. Final Office Action cited in U.S. Appl. No. 11/246,847 mailed Apr. 11, 2007.
U.S. Final Office Action cited in U.S. Appl. No. 11/270,393 mailed Jun. 4, 2007.
U.S. Final Office Action cited in U.S. Appl. No. 11/270,407 mailed Jan. 2, 2009.
U.S. Final Office Action cited in U.S. Appl. No. 11/290,076 mailed Sep. 19, 2008.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,262 mailed Apr. 1, 2010.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,262 mailed Mar. 12, 2009.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,262 mailed May 13, 2008.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,265 on Dec. 16, 2009.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,581 mailed Dec. 30, 2009.
U.S. Final Office Action cited in U.S. Appl. No. 11/294,581 mailed Feb. 5, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/246,847 mailed Oct. 18, 2006.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/270,393 mailed Dec. 19, 2006.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/270,393 mailed Mar. 2, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/270,393 mailed Nov. 20, 2007.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/290,076 mailed Feb. 14, 2008.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/290,076 mailed Jun. 9, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,262 mailed Aug. 21, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,262 mailed Nov. 28, 2007.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,262 mailed Sep. 22, 2008.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,265 mailed Feb. 23, 2010.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,265 mailed Jun. 12, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,265 mailed Nov. 26, 2008.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,265 mailed Nov. 28, 2007.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,581 mailed Jun. 23, 2009.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,581 mailed May 13, 2008.
U.S. Non-Final Office Action cited in U.S. Appl. No. 11/294,581 mailed Nov. 28, 2007.
US Non-Final-Office-Action cited in U.S. Appl. No. 11/294,262 mailed Jul. 19, 2010.
Usability for component-based portals Downloaded from https://www-128.ibm.com/developerworks/web/library/us-portal/, Jun. 2007.
Usability for component-based portals Downloaded from https://www-128.ibm.com/developerworks/web/library/us-portal/.
V. Chepegin, et al., "CHIME: Service-Oriented Framework for Adaptive Web-Based Systems", in Paul De Bra (ed): Proceedings of Dutch national conference InfWet, Eindhoven, the Netherlands, Nov. 20, 2003, pp. 29-36.

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9032318B2 (en) 2005-10-27 2015-05-12 Apple Inc. Widget security
US9104294B2 (en) 2005-10-27 2015-08-11 Apple Inc. Linked widgets
US9513930B2 (en) 2005-10-27 2016-12-06 Apple Inc. Workflow widgets
US11150781B2 (en) 2005-10-27 2021-10-19 Apple Inc. Workflow widgets
US9417888B2 (en) 2005-11-18 2016-08-16 Apple Inc. Management of user interface elements in a display environment
US20080034314A1 (en) * 2006-08-04 2008-02-07 Louch John O Management and generation of dashboards
US8869027B2 (en) * 2006-08-04 2014-10-21 Apple Inc. Management and generation of dashboards
US8954871B2 (en) 2007-07-18 2015-02-10 Apple Inc. User-centric widgets and dashboards
US9483164B2 (en) 2007-07-18 2016-11-01 Apple Inc. User-centric widgets and dashboards
US11061904B2 (en) 2018-04-17 2021-07-13 International Business Machines Corporation Resource condition correction using intelligently configured dashboard widgets

Also Published As

Publication number Publication date
US20070209013A1 (en) 2007-09-06

Similar Documents

Publication Publication Date Title
US7996783B2 (en) Widget searching utilizing task framework
US10643035B2 (en) Tool for facilitating the development of new language understanding scenarios
US11948058B2 (en) Utilizing recurrent neural networks to recognize and extract open intent from text inputs
US8356046B2 (en) Context-based user interface, search, and navigation
US7822699B2 (en) Adaptive semantic reasoning engine
US20070203869A1 (en) Adaptive semantic platform architecture
US9448772B2 (en) Generating program fragments using keywords and context information
US20170337261A1 (en) Decision Making and Planning/Prediction System for Human Intention Resolution
US8725492B2 (en) Recognizing multiple semantic items from single utterance
US10825115B2 (en) Identifying correlated services during processing services
US20130166563A1 (en) Integration of Text Analysis and Search Functionality
US20160275196A1 (en) Semantic search apparatus and method using mobile terminal
US20110161347A1 (en) System and method for an n-best list interface
US20090293059A1 (en) Automatically connecting items of workflow in a computer program
WO2017173773A1 (en) Information search method and device
CN116127020A (en) Method for training generated large language model and searching method based on model
US20170372700A1 (en) Method of entering data in an electronic device
US20050010422A1 (en) Speech processing apparatus and method
CN110692042B (en) Platform selection to perform requested actions in an audio-based computing environment
US11604929B2 (en) Guided text generation for task-oriented dialogue
US20140280352A1 (en) Processing semi-structured data
US11620282B2 (en) Automated information retrieval system and semantic parsing
CN111126073B (en) Semantic retrieval method and device
Lee et al. Semantically enabled data mashups using ontology learning method for Web APIs
Pierce et al. Using Web 2.0 for scientific applications and scientific communities

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT CORPORATION, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:RAMSEY, WILLIAM D.;KATARIYA, SANJEEV;REEL/FRAME:017356/0217;SIGNING DATES FROM 20060228 TO 20060301

Owner name: MICROSOFT CORPORATION, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:RAMSEY, WILLIAM D.;KATARIYA, SANJEEV;SIGNING DATES FROM 20060228 TO 20060301;REEL/FRAME:017356/0217

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

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

Effective date: 20141014

FPAY Fee payment

Year of fee payment: 4

MAFP Maintenance fee payment

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

Year of fee payment: 8

MAFP Maintenance fee payment

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

Year of fee payment: 12