US20130031087A1 - Systems and methods for contextual personalized searching - Google Patents

Systems and methods for contextual personalized searching Download PDF

Info

Publication number
US20130031087A1
US20130031087A1 US13/554,779 US201213554779A US2013031087A1 US 20130031087 A1 US20130031087 A1 US 20130031087A1 US 201213554779 A US201213554779 A US 201213554779A US 2013031087 A1 US2013031087 A1 US 2013031087A1
Authority
US
United States
Prior art keywords
user
search
content
entity
selected entity
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US13/554,779
Inventor
Gerald Kropitz
Carlos Bhola
Ludovic Cabre
Brian Rogers
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.)
Kikin Inc
Original Assignee
Kikin Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Kikin Inc filed Critical Kikin Inc
Priority to US13/554,779 priority Critical patent/US20130031087A1/en
Assigned to Kikin Inc. reassignment Kikin Inc. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BHOLA, Carlos, CABRE, Ludovic, KROPITZ, Gerald, ROGERS, BRIAN
Assigned to 2B HOLDINGS LLC reassignment 2B HOLDINGS LLC SECURITY AGREEMENT Assignors: 2B HOLDINGS LLC
Assigned to 2B HOLDINGS LLC reassignment 2B HOLDINGS LLC SECURITY AGREEMENT Assignors: Kikin Inc.
Publication of US20130031087A1 publication Critical patent/US20130031087A1/en
Assigned to BAIDU HOLDINGS LIMITED reassignment BAIDU HOLDINGS LIMITED SECURITY AGREEMENT Assignors: KIKIN INC
Abandoned legal-status Critical Current

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/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]
    • G06F16/9562Bookmark management
    • 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/951Indexing; Web crawling techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/30Information retrieval; Database structures therefor; File system structures therefor of unstructured textual data
    • G06F16/33Querying
    • G06F16/3331Query processing
    • G06F16/3332Query translation
    • 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/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]

Definitions

  • Embodiments of the present invention relate generally to the field of searching the Internet and other content sources (including, but not limited to, advertising streams) and computerized searching.
  • the systems and methods described herein allow traditional web, monetization, and other content to be consumed in a radically different manner based on characteristics of the consumer and his/her query and intent.
  • the World Wide Web has become a daily resource for many people. However, the large and relatively unstructured nature of the Web makes it difficult to find sites that are useful or relevant. Similarly, there are now many applications available to users and each application often has many features, all of which can leave a user bewildered and in need of guidance. Also as users search the web and use applications they expect to receive relevant advertisements and/or offers.
  • FIG. 1A is a schematic diagram of a system in accordance with an embodiment of the present invention.
  • FIG. 1B is a exploded diagram of the apparatus of FIG. 1 , in accordance with an embodiment of the present invention.
  • FIG. 2 is a schematic diagram of a system transferring information, in accordance with an embodiment of the present invention.
  • FIG. 3A is an exemplary view of a screen shot showing a webpage before contextual mode has been activated, according to an embodiment of the present invention
  • FIGS. 3B and 3C are exemplary views of screen shots showing a webpage after contextual mode has been activated and various search terms are highlighted, according to some embodiments of the present invention.
  • FIG. 3D is an exemplary view of a screen shot showing an overlay window and a webpage after a contextual search has been conducted, according to an embodiment of the present invention
  • FIG. 4 is a flow diagram of a process according to an embodiment of the present invention.
  • FIGS. 5A-5D are more detailed flow diagrams of a process according to an embodiment of the present invention.
  • FIG. 6 is a textual representation of a data structure containing information regarding a sample user profile, according to an embodiment of the present invention.
  • FIG. 7A is an exemplary view of a screen shot showing a webpage in which a user has highlighted a search entity
  • FIG. 7B is a sample rich-query string based on the search entity and webpage of FIG. 7A , according to an embodiment of the present invention.
  • the present invention relates to a method for providing highly relevant answers in response to a user's request. This is accomplished by utilizing and applying contextual information pertaining to a user's request.
  • a client device receives input indicating a desire to receive contextual information regarding a selected entity included in content on the device; transmits to a server contextual information pertaining to the selected entity; the server constructs a query corresponding to the selected entity and translates the query into a set of simple queries; submits the simple queries to a relevant subset of a plurality of search, content and monetization sources; receives a plurality of results returned from the relevant subset of search, content and monetization sources in response to the simple queries; prioritizes the received results based on elements of the selected entity, the user, context about the selected entity, time and date, original location of the user, and aspects of the application on which the entity was selected; and presents a prioritized list of the results to the user on the client device.
  • the present invention relates to a system for providing highly relevant answers in response to a user's request. This is accomplished by utilizing and applying contextual information pertaining to a user's request.
  • the present invention includes to a means for receiving input at a client device indicating a desire to receive contextual information regarding a selected entity included in content on the device, means for transmitting, to a server contextual information pertaining to the selected entity, means for constructing a query on the server corresponding to the selected entity and translating the query into a set of simple queries, means for submitting the simple queries to a relevant subset of a plurality of search, content and monetization sources, means for receiving, a plurality of search results returned from the relevant subset of search, content and monetization sources in response to the simple queries, means for prioritizing the received results based on elements of the selected entity, the user, context about the selected entity and user, time and date, original location of the user, and aspects of the application on which the entity was selected, and means for presenting a prioritize
  • Various embodiments of the present invention provide a process or system for providing highly relevant answers in response to a user's request.
  • a user views a webpage, a document, or other content.
  • the contextual search service accepts input from the user regarding one or more search terms, phrases, images, or other information indicating a topic or topics of interest (hereinafter referred to as a “search entity”).
  • search entity a topic or topics of interest
  • the service selects additional input related to the search entity to determine the context of the search entity, in order to conduct a search that is more likely to be relevant than a search that does not involve the context.
  • the service uses the search entity and context that may be related to the search entity to search for and obtain search results. According to various embodiments, these results are presented to the user on the client device.
  • FIG. 1A illustrates a networked environment 101 according to some embodiments, in which a contextual search service is provided.
  • the networked environment 101 includes one or more client machines 102 A- 102 N (generally referred to herein as “client machine(s) 102 ” or “client(s) 102 ”) in communication with one or more servers 106 A- 106 N (generally referred to herein as “server machine(s) 106 ” or “server(s) 106 ”) over a network 104 .
  • the client machine(s) 102 can, in some embodiments, be referred to as a single client machine 102 or a single group of client machines 102
  • server(s) 106 may be referred to as a single server 106 or a single group of servers 106 .
  • three client machines 102 and three server machines 106 are depicted in FIG. 1A , any number of clients 102 can be in communication with any number of servers 106 .
  • a single client machine 102 communicates with more than one server 106
  • a single server 106 communicates with more than one client machine 102 .
  • a single client machine 102 communicates with a single server 106 .
  • a single network 104 is shown connecting client machines 102 to server machines 106 , it should be understood that according to some embodiments, multiple, separate networks connect a subset of client machines 102 to a subset of server machines 106 .
  • the computing environment 101 includes an appliance (not shown in FIG. 1A ) installed between the server(s) 106 and client machine(s) 102 .
  • This appliance can mange client/server connections, and in some cases can load balance connections made by client machines 102 to server machines 106 .
  • Suitable appliances are manufactured by any one of the following companies (but are not limited to these companies): the Citrix Systems Inc. Application Networking Group; Silver Peak Systems, Inc, both of Santa Clara, Calif.; Riverbed Technology, Inc. of San Francisco, Calif.; F5 Networks, Inc. of Seattle, Wash.; or Juniper Networks, Inc. of Sunnyvale, Calif.
  • Client(s) 102 and server(s) 106 may be provided as a computing device 100 , a specific embodiment of which is illustrated in FIG. 1B .
  • a system bus 150 that communicates with the following components: a central processing unit 121 (“processor”); a main memory 122 providing non-transient storage; storage memory 128 providing non-transient storage; an input/output (I/O) controller 123 ; display devices 124 A- 124 N; an installation device 116 ; and a network interface 118 .
  • the storage memory 128 includes: an operating system, software routines, and a client agent 120 .
  • the I/O controller 123 is further connected one or more input devices.
  • Volatile computer memory, non-volatile computer memory, and combinations of volatile and non-volatile computer memory are to be included within the scope of non-transient storage.
  • the I/O controller 123 is connected to a camera 125 , a keyboard 126 , a pointing device 127 such as (but not limited to) a mouse, and a microphone 129 .
  • Various embodiments of the computing machine 100 include a central processing unit 121 characterized by any one of the following component configurations: logic circuits that respond to and process instructions fetched from the main memory unit 122 ; a microprocessor unit, such as (but not limited to): those manufactured by Intel Corporation; those manufactured by Motorola Corporation; those manufactured by Transmeta Corporation of Santa Clara, Calif.; the RS/6000 processor such as those manufactured by International Business Machines; a processor such as those manufactured by Advanced Micro Devices; or any other combination of logic circuits.
  • a central processing unit 121 characterized by any one of the following component configurations: logic circuits that respond to and process instructions fetched from the main memory unit 122 ; a microprocessor unit, such as (but not limited to): those manufactured by Intel Corporation; those manufactured by Motorola Corporation; those manufactured by Transmeta Corporation of Santa Clara, Calif.; the RS/6000 processor such as those manufactured by International Business Machines; a processor such as those manufactured by Advanced Micro Devices; or any other combination of logic circuits.
  • central processing unit 122 include any one or combination of the following: a microprocessor, a microcontroller, a central processing unit with a single processing core, a central processing unit with two processing cores, or a central processing unit with more than one processing core.
  • FIG. 1B illustrates a computing device 100 that includes a single central processing unit 121
  • the computing device 100 include one or more processing units 121 .
  • the computing device 100 can store and execute firmware or other executable instructions that, when executed, direct the one or more processing units 121 to simultaneously execute instructions or to simultaneously execute instructions on a single piece of data.
  • the computing device 100 store and execute firmware or other executable instructions that, when executed, direct the one or more processing units to each execute a section of a group of instructions. For example, each processing unit 121 may be instructed to execute a portion of a program or a particular module within a program.
  • the processing unit 121 includes one or more processing cores.
  • the processing unit 121 has two cores, four cores, eight cores, or any number of cores.
  • the processing unit 121 comprises one or more parallel processing cores.
  • the processing cores of the processing unit 121 in some embodiments, access available memory as a global address space, or in other embodiments, memory within the computing device 100 is segmented and assigned to a particular core within the processing unit 121 .
  • the one or more processing cores or processors in the computing device 100 can each access local memory.
  • memory within the computing device 100 is shared amongst one or more processors or processing cores, while other memory can be accessed by particular processors or subsets of processors.
  • the multiple processing units are included in a single integrated circuit (IC). These multiple processors, in some embodiments, are linked together by an internal high speed bus, which may be referred to as an element interconnect bus.
  • the processors in some embodiments, can execute a single instruction simultaneously on multiple pieces of data (SIMD), or in other embodiments can execute multiple instructions simultaneously on multiple pieces of data (MIMD). In some embodiments, the computing device 100 includes any number of SIMD and MIMD processors.
  • the computing device 100 includes a graphics processor or a graphics processing unit (not shown).
  • the graphics processing unit includes any combination of software and hardware, and can further input graphics data and graphics instructions, render a graphic from the inputted data and instructions, and output the rendered graphic.
  • the graphics processing unit is included within the processing unit 121 .
  • the computing device 100 includes one or more processing units 121 , such that at least one processing unit 121 is dedicated to processing and rendering graphics.
  • Some embodiments of the computing device 100 provide support for any one of the following installation devices 116 (but is not limited to these devices): a CD-ROM drive, a CD-R/RW drive, a DVD-ROM drive, tape drives of various formats, USB device, a bootable medium, a bootable CD, a bootable CD for GNU/Linux distribution such as KNOPPIX®, a hard-drive or any other device suitable for installing applications or software.
  • Applications include a client agent 120 , or any portion of a client agent 120 .
  • the computing device 100 further includes a storage device 128 that is either one or more hard disk drives, or one or more redundant arrays of independent disks; where the storage device is configured to store an operating system, software, programs applications, or at least a portion of the client agent 120 .
  • a further embodiment of the computing device 100 includes an installation device 116 that is used as the storage device 128 .
  • Embodiments of the computing device 100 include any one of the following I/O devices 130 A- 130 N (but is not limited to these examples): a camera 125 , keyboard 126 ; a pointing device 127 ; a microphone 129 ; mice; trackpads; an optical pen; trackballs; microphones; drawing tablets; video displays; speakers; inkjet printers; laser printers; and dye-sublimation printers; touch screen; or any other input/output device able to perform the methods and systems described herein.
  • an I/O controller 123 connects to multiple I/O devices 103 A- 130 N to control the one or more I/O devices.
  • the I/O devices 130 A- 130 N are configured to provide storage or an installation medium 116 . According to other embodiments, the I/O devices 130 A- 130 N are configured to provide a universal serial bus (USB) interface for receiving USB storage devices such as (but not limited to) the USB Flash Drive line of devices manufactured by Twintech Industry, Inc.
  • USB universal serial bus
  • an I/O device 130 that is a bridge between the system bus 150 and an external communication bus, such as (but not limited to): a USB bus; an Apple Desktop Bus; an RS-232 serial connection; a SCSI bus; a FireWire bus; a FireWire 800 bus; an Ethernet bus; an AppleTalk bus; a Gigabit Ethernet bus; an Asynchronous Transfer Mode bus; a HIPPI bus; a Super HIPPI bus; a SerialPlus bus; a SCI/LAMP bus; a FibreChannel bus; or a Serial Attached small computer system interface bus.
  • an external communication bus such as (but not limited to): a USB bus; an Apple Desktop Bus; an RS-232 serial connection; a SCSI bus; a FireWire bus; a FireWire 800 bus; an Ethernet bus; an AppleTalk bus; a Gigabit Ethernet bus; an Asynchronous Transfer Mode bus; a HIPPI bus; a Super HIPPI bus; a SerialPlus bus; a SCI/LAMP
  • the computing machine 100 can execute any operating system, while in other embodiments the computing machine 100 can execute any of the following operating systems: versions of the MICROSOFT WINDOWS operating systems such as WINDOWS 3.x; WINDOWS 95; WINDOWS 98; WINDOWS 2000; WINDOWS NT 3.51; WINDOWS NT 4.0; WINDOWS CE; WINDOWS XP; WINDOWS VISTA; and WINDOWS 7; the different releases of the Unix and Linux operating systems; any version of the MAC OS or iOS manufactured by Apple Computer; OS/2, manufactured by International Business Machines; any embedded operating system; any real-time operating system; any open source operating system; any proprietary operating system; any operating systems for mobile computing devices; or any other operating system.
  • versions of the MICROSOFT WINDOWS operating systems such as WINDOWS 3.x; WINDOWS 95; WINDOWS 98; WINDOWS 2000; WINDOWS NT 3.51; WINDOWS NT 4.0; WIN
  • the computing machine 100 can execute multiple operating systems.
  • the computing machine 100 can execute PARALLELS or another virtualization platform that can execute or manage a virtual machine executing a first operating system, while the computing machine 100 executes a second operating system different from the first operating system.
  • the computing machine 100 is embodied in any one of the following computing devices (but is not limited to these devices): a computing workstation; a desktop computer; a laptop or notebook computer; a server; a handheld computer; a mobile telephone; a portable telecommunication device; a media playing device; a gaming system; a mobile computing device; a netbook; a device of the IPOD family of devices manufactured by Apple Computer; any one of the PLAYSTATION family of devices manufactured by the Sony Corporation; any one of the Nintendo family of devices manufactured by Nintendo Co; any one of the XBOX family of devices manufactured by the Microsoft Corporation; or any other type and/or form of computing, telecommunications or media device that is capable of communication and that has sufficient processor power and memory capacity to perform the methods and systems described herein.
  • the computing machine 100 is a mobile device such as (but not limited to) any one of the following mobile devices: a JAVA-enabled cellular telephone or personal digital assistant (PDA), such as the i55sr, i58sr, i85s, i88s, i90c, i95cl, or the im1100, all of which are manufactured by Motorola Corp; the 6035 or the 7135, manufactured by Kyocera; the i300 or i330, manufactured by Samsung Electronics Co., Ltd; the TREO 180, 270, 600, 650, 680, 700p, 700w, or 750 smart phone manufactured by Palm, Inc; any computing device that has different processors, operating systems, and input devices consistent with the device; or any other mobile computing device capable of performing the methods and systems described herein.
  • PDA personal digital assistant
  • the computing device 100 is any one of the following mobile computing devices (but is not limited to these devices): any one series of Blackberry, or other handheld device manufactured by Research In Motion Limited; the iPhone manufactured by Apple Computer; Palm Pre; a Pocket PC; a Pocket PC Phone; or any other handheld mobile device.
  • the computing device 100 is a smart phone or tablet computer, such as (but not limited to) the iPhone or iPad manufactured by Apple, Inc. of Cupertino, Calif.; the BlackBerry devices manufactured by Research in Motion, Ltd. of Waterloo, Ontario, Canada; Windows Mobile devices manufactured by Microsoft Corp., of Redmond, Wash.; the Xoom manufactured by Motorola, Inc. of Libertyville, Ill.; devices capable of running the Android platform provided by Google, Inc. of Mountain View, Calif.; or any other type and form of portable computing device.
  • the computing device 100 is a virtual machine.
  • the virtual machine is any virtual machine, such as (but not limited to) those managed by a hypervisor developed by XenSolutions, Citrix Systems, IBM, VMware, or any other hypervisor.
  • the virtual machine is managed by a hypervisor executing on a server 106 or a hypervisor executing on a client 102 .
  • the computing device 100 can execute, operate or otherwise provide an application that is any one of the following: software; an application or program; executable instructions; a virtual machine; a hypervisor; a web browser; a web-based client; a client-server application; an ActiveX control; a Java applet; software related to voice over internet protocol (VoIP) communications like a soft IP telephone; an application for streaming video and/or audio or receiving and playing streamed video and/or audio; an application for facilitating real-time-data communications; a HTTP client; a FTP client; or any other set of executable instructions.
  • Still other embodiments include a client device 102 that displays application output generated by an application remotely executing on a server 106 or other remotely located machine. In these embodiments, the client device 102 can display the application output in an application window, a browser, or other output window.
  • the computing device 100 further includes a network interface 118 to interface to a Local Area Network (LAN), Wide Area Network (WAN), the Internet, or any type of network, through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (e.g., 802.11, T1, T3, 56 kb, X.25, SNA, DECNET), broadband connections (e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET), wireless connections, or some combination of any or all of the above.
  • LAN Local Area Network
  • WAN Wide Area Network
  • the Internet or any type of network
  • broadband connections e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET
  • Connections can also be established using a variety of communication protocols (e.g., TCP/IP, IPX, SPX, NetBIOS, Ethernet, ARCNET, SONET, SDH, Fiber Distributed Data Interface (FDDI), RS232, RS485, IEEE 802.11, IEEE 802.11a, IEEE 802.11b, IEEE 802.11g, CDMA, GSM, WiMax and direct asynchronous connections).
  • the network 104 comprises one or more sub-networks, and is installed between any combination of the clients 102 , servers 106 , computing machines and appliances included within the computing environment 101 .
  • the network topology of the network 104 differs within different embodiments, possible network topologies include: a bus network topology; a star network topology; a ring network topology; a repeater-based network topology; or a tiered-star network topology.
  • Additional embodiments include a network 104 of mobile telephone networks that use a protocol to communicate among mobile devices, where the protocol is any one of the following: AMPS; TDMA; CDMA; GSM; GPRS UMTS; or any other protocol able to transmit data among mobile devices.
  • the computing environment 101 includes more than one server 106 A- 106 N such that the servers 106 A- 106 N are logically grouped together into a server farm 106 .
  • the server farm 106 includes servers 106 that are geographically dispersed and logically grouped together in a server farm 106 , servers 106 that are located proximate to each other and logically grouped together in a server farm 106 , or several virtual servers executing on physical servers.
  • Geographically dispersed servers 106 A- 106 N within a server farm 106 can, in some embodiments, communicate using a WAN, MAN, or LAN, where different geographic regions can be characterized as: different continents; different regions of a continent; different countries; different states; different cities; different campuses; different rooms; or any, combination of the preceding geographical locations.
  • the server farm 106 is administered as a single entity, while in other embodiments, the server farm 106 includes multiple server farms 106 .
  • information 204 regarding a contextual search is transferred between the server(s) 106 and the component(s) 202 .
  • the component(s) 202 is computer software.
  • the component(s) 202 is computer hardware or circuitry.
  • the component(s) 202 is part of, or executes on, the client(s) 102 .
  • the component(s) 202 is part of, or executes on, the server(s) 106 .
  • information 204 is transferred to the server(s) 106 from the component(s) 202 .
  • information 204 is transferred to the component(s) from the server(s) 106 .
  • information 204 is transferred back and forth between the server(s) 106 and the component(s) 202 .
  • FIGS. 3A-D illustrate the user experience of the contextual search service according to a non-limiting, exemplary embodiment.
  • the user has navigated to a webpage in a web browser using a touch-screen tablet device.
  • contextual mode has been activated, and some search entities have been identified on the display by highlighting certain words on the underlying webpage.
  • the service has automatically highlighted certain words to notify the user that more information is available about those terms (although all the items, words, and objects on the webpage are selectable and searchable).
  • the words “New” and “York” are highlighted, to the right of the overlay window. Although those two words are on separate lines, the service determined that they were related by comparing those words with the context, and then highlighting them both on the display.
  • a search was conducted, which returned the results displayed in the overlay window.
  • the system does not require activation of contextual mode to allow a user to perform a search.
  • the user navigates to a web page, as shown in FIG. 3A and any word or series of words displayed by the web page is available for selection by the user.
  • the user indicates a desire to search for additional information about a term, such as by a activating a specific mouse button or by executing a “long press” on a touch screen, and the term is highlighted in a manner similar to that shown in FIG. 3D .
  • FIGS. 4 and 5 A- 5 D show non-limiting processes for a contextual search service, according to various embodiments of the invention.
  • the contextual searching mode is activated by a component(s) 202 before contextual searches can be performed.
  • contextual searching mode is activated by the contextual search service accepting input, using a processor of a computing device, from the user to enable it. Examples include (but are not limited to), user input in the form of mouse input, touch-screen input, keyboard input, spoken command, or the like.
  • contextual searching mode is activated with a touch-screen device by receiving input corresponding with a sliding movement from the bottom of the screen.
  • contextual searching mode is activated by receiving input from a keyboard corresponding with a user pressing Alt (or a specific meta key).
  • the service indicates, using a display, audio device, or the like, that the contextual searching mode has been activated.
  • contextual mode is “always on,” that is, it does not need to be activated in order for contextual searches to be performed.
  • the user selects a term to be searched by providing specific, predefined input such as the activation of a specific mouse button (e.g., right-clicking), the activation of a specific mouse button in combination with a specific key of a keyboard (e.g., control-click), or by providing a specific touch gesture, such as a double-finger press, triple-finger press or long press.
  • the user's finger must contact the screen for more than 500 milliseconds to register a long press.
  • the length of time the user's finger's must contact the screen in order to register a long press is greater than 100 milliseconds, 300 milliseconds, 750 milliseconds, or 1000 milliseconds.
  • contextual searching mode is made persistent (that is, to stay on until it is turned off) when activated, or in some embodiments, is made optionally persistent by accepting input indicating that a user pressed a hotkey or otherwise indicated that the option was selected.
  • contextual searching mode can be made non-persistent (when it would otherwise be persistent) by accepting input indicating that a user pressed a hotkey or otherwise indicated that that option was selected.
  • entering contextual mode involves suspending the otherwise typical user interface behavior of the webpage browser, email client, or document viewer.
  • contextual mode is “always on”
  • the activation of contextual searching suspends the normal behavior of the page.
  • the ability of those software applications to accept input as normal may be suspended until the service is no longer in contextual mode. In that case, only the service will respond to user input directed at those applications unless the user input is directed at disabling the service or contextual mode.
  • user interaction events with the underlying page are intercepted and redirected or, in some case, discarded.
  • the following JavaScript event may be used to perform the interception of user interaction events: event.stopPropagation( ).
  • a computer monitor may display the webpage shown in FIG. 7A in a browser window, where the word “JOBS” is hyperlinked. While not in contextual mode, clicking on “JOBS” would cause the browser to load the webpage specified by the hyperlink. While in contextual mode, clicking on “JOBS” would not cause the browser to load that webpage. Instead, “JOBS” would be highlighted by the service, indicating that “JOBS” is a search entity.
  • the contextual search service identifies at least one search entity.
  • the search entity (or entities) is identified by the contextual search service accepting input, using a processor of a computing device, from the user to indicate search term(s). Examples include (but are not limited to), user input in the form of mouse input, touch-screen input, keyboard input, or the like.
  • the service accepts input from a mouse corresponding with a user clicking on something.
  • the service accepts input from a touch-screen device corresponding with a user touching, pointing, holding, releasing, making a dragging movement, or the like.
  • the contextual search service determines the search entity (or entities) at least in part through a disambiguation process, using a processor of a computing device.
  • the disambiguation process itself also involves determining the local context in order to automatically select additional search terms or to determine the boundaries of the search entity (or entities).
  • the context is used to determine how often various combinations of potential terms are each searched. The frequency is then used, at least in part, to determine which additional search terms, if any, to select, beyond the one(s) indicated by the user.
  • this disambiguation instead is performed by the server(s) 106 during step S 440 .
  • disambiguation takes place both during steps S 410 and S 440 .
  • a touch-screen computer user highlights the word “Depp” while viewing a webpage about the movie, The Pirates of the Caribbean .
  • the contextual search service takes as input the terms surrounding Depp, which were, “The actors included Johnny Depp, Keira Knightley, and Orlando Bloom.” The service then determines that, for instance, “Johnny Depp” is a term that is searched for more often than “Depp, Keira”. The service also determines that “Johnny Depp” is a more desirable search term than “Depp”. Therefore, the service selects “Johnny Depp” as the search entity.
  • the contextual search service determines the local context by finding other term(s), collections of term(s), or the like, in proximity to those indicated by the user.
  • such terms include (but are not limited to): postal addresses, email addresses, URLs (which may or may not correspond with a hypertext link), currency, phone numbers, geographic locations, or the like.
  • regular expressions may be used to determine the existence of these types of terms.
  • Exemplary regular expressions include: address—[ ⁇ regex: /[ ⁇ t ⁇ r ⁇ n]*(.+[, ⁇ u00A0] ⁇ 1, ⁇ [A-Z] ⁇ 2 ⁇ [ ⁇ u00A0]?[ ⁇ d] ⁇ 5 ⁇ )($
  • search terms may be chosen based on whether the terms begin with a capital letter, are in all capital letters, or are in mixed case. According to some embodiments, such terms may be chosen from the beginning or end of a nearby sentence, where some embodiments take care to ignore periods that do not denote the end of a sentence (such as those used for abbreviations such as “U.S.” or “Inc.”). Some embodiments choose such terms based on the existence or non-existence of a nearby word “bridges” such as (but not limited to) the “of” in “the United States of America”, apostrophes used to indicate possession (“Gerry's”), ampersands (“His & Hers”), and the like. In many embodiments this behavior is provided via a rule base containing commonly-used rules.
  • Some embodiments ignore terms that are common (for example, ignoring a date such as “February”). Some embodiments choose terms based on whether the surrounding HTML tag or other encoding denotes it with a special tag (for example, bold, italic, links, heading tags ( ⁇ h1>, ⁇ h2>, ⁇ h3>), or the like). Some embodiments choose terms based on whether the parent node in a HTML or similar document is marked as a Microformat or special semantic tag. Some embodiments choose terms based on a Microformat where the Microformat consists of multiple parts (like an address), scan surrounding areas for the other related tags to highlight them at the same time. Some embodiments choose terms based on detected sentences, dictionary terms, nouns, or the like. Various embodiments choose terms based on any combination of the examples described above, or other similar examples.
  • every type of analysis described above is performed in order to identify search terms extant on a displayed page.
  • various subsets of the identified techniques may be applied.
  • the client machine is resource constrained, such as a tablet or mobile phone
  • a restricted area is analyzed to conserve resources.
  • the following JavaScript may be used to determine if the device is a mobile device: navigator.userAgent.indexOf(‘mobile’).
  • the rules and techniques may be applied independently of structural boundaries in the displayed page; for example, processing is not affected by text wrapping from one line to the next.
  • the contextual search service notifies, using a processor, the user of the search entity (or entities) identified in step S 410 .
  • the notification is visual, such as through a display of a computer device.
  • the search entity (or entities) is highlighted within a document on a display.
  • a copy of the selected area is magnified in order to help the user identify the selected entity.
  • the document is overlaid with a darker layer to improve contrast of the selected entity.
  • the text style of selected text is analyzed and the replicated with the color changed to black for best contrast; in an HTML document the font-style, font-family, font-weight, and text-transformation styles will be analyzed and replicated.
  • these styles can be determined using the following JavaScript function: node.style.fontFamily.
  • a pop-up window, text box, or the like is displayed to the user above the darker layer (if provided), which may include a list of any search entities.
  • the selected search entity (or entities) is the same as what was indicated by the user, so no additional notification is made.
  • the service requests input from the user regarding which search entity to select.
  • the service accepts inputs from the user indicating the user's selection.
  • the input indicates that the user pressed a key, touched a touch screen, pointed with a mouse, made a voice command, or otherwise indicated the user's selection.
  • the selected search entity is an image, video, audio, map, or other non-textual entity.
  • a highlight is applied to the selected entity and it is brought to the foreground, for example, displayed on top of the darker layer, if present.
  • the service has already selected the search entity, whether or not textual, and requests input from the user to confirm that the user wishes to conduct a search using that search entity.
  • a query is a string constructed and posted to a server using a processor.
  • the rich query string is a URL encoded so that it can be included in the body of a HTTP POST request.
  • the rich query includes both the search entity and context information (hereinafter referred to as a “rich query”).
  • the rich query includes context information which increases the likelihood of a relevant search.
  • the context information includes any combination of the title of the page on which the entity is found (accessible using the JavaScript command, document.title), the URL of the page on which the entity is found (accessible using the JavaScript command document.location or, in some embodiments, read from native code using provided APIs), META tags, information regarding word frequencies, and/or the like, of the webpage where the search entity was found. Word frequencies may be calculated on the client and included in the HTTP POST request to the server.
  • the context information includes any combination of the text that is located just before the search entity, the text that is located just after the search entity, the corresponding URL if hypertext tags surround the search entity, information (such as attributes) inside a parent tag surrounding the search entity, information regarding semantic tags surrounding the search entity, information regarding the application currently being executed (such as a web browser), information related to previous searches, information related to web pages visited, information related to hypertext links selected, information related to the user's profile, and/or the like.
  • Information about the application currently being executed may be exposed by an API provided by the operating system of the client.
  • the system is able to access the title of the window, or window name, in which the selected entity appears as well as the name of the executable application responsible for displaying the selected entity.
  • Certain applications may allow access to further information.
  • an email program may also allow access to the title of the title of the email, that is, the “re” line and a word processing program may allow access to the title of the displayed document or to other characteristics of the document, such as word count.
  • Contextual information may be obtained by traversing the DOM tree to ascertain the node previous to the node containing the selected entity and extracting the content of the previous node and also to ascertain the node following the node containing the selected entity and extracting the content of the next node.
  • the text “Nicolas Sarkozy” will also be extracted and included the HTTP POST request.
  • a similar technique may be used to ascertain text after the selected entity, i.e., in the sentence above the term “French Republic” may also be extracted and included in the HTTP POST request.
  • this technique is used until 25 characters before the selected entity are obtained, 25 characters after the selected entity are obtained, or both, in other embodiments it is used to obtain 50 characters before the selected entity are obtained, 50 characters after the selected entity are obtained, or both, in still other embodiments it is used to obtain 100 characters before the selected entity are obtained, 100 characters after the selected entity are obtained, or both and in still further embodiments it is used to obtain 250 characters before the selected entity are obtained, 250 characters after the selected entity are obtained, or both.
  • Exemplary code for extracting the content from the previous node is as follows:
  • exemplary code for obtaining the content of the next node is as follows:
  • the selected entity is part of a hyperlink, or link.
  • a hyperlink or link.
  • the user may actually be selecting the following HTML code:
  • the selection of a entity will suspend normal processing by the page. Thus, rather than traversing the link identified by the text “23 rd President,” that selection will be intercepted and discarded.
  • the system will then recognize, using the “A” HTML tag that the selected entity is a link and will then also extract from the HTML code helpful attributes from the link, such as the HREF, ALT and TITLE attributes, in the example above. These extracted attributes are included with the selected entity in the HTTP POST request.
  • the system may further use the JavaScript command “element.getattribute( )” in order to acquire the attributes of a tag.
  • the system may acquire text associated with headers from the page on which the selected entity appears using the JavaScript command “document.querySelectorAll(‘h1,h2,h3,h4,h5,h6,h7.h8’). The acquired text is then included in the IMP POST request sent to the server.
  • the system may also search the DOM of the web page to identify META tags. The text associated with META tags may also be useful.
  • Each of the META tags in a document will be returned by the following command: document.getElementsByTagName(‘meta’) and each returned tag may be analyzed using the following exemplary code:
  • FIG. 7A shows a sample webpage and FIG. 7B shows a corresponding rich-query string.
  • the user has highlighted “132 Crosby Street, 4 th Floor New York, N.Y. 10012”, which is used as the search entity.
  • the rich-query string includes the name of the server (“query-server-beta”), the data type (“JSON”), a requested layout type (“default”), a return type (“javascript”), a language or culture specifier (“en-US”), and the URL of the search entity's webpage (“http://kikin.com/contact”).
  • the rich-query string includes information found on the search entity's webpage, including an address (“132 Crosby Street, 4th Floor, New York, N.Y. 10012”), text in close proximity to the address (“kikin Headquarters”), a phone number (“646-395-1280”), prominent text (“Contact Us”), and keywords specified in the META tags (“kikin, facebook, twitter, social networking, price comparison, browser plugin”).
  • information about the HTML hierarchy of the page on which the selected entity is found may be used to determine content.
  • the HTML code for displaying the address to the user may be:
  • selecting “New York” will cause the system to traverse the DOM model for the page and detect that the selected entity is part of an ADDRESS tag and a DIV tag.
  • the extracted hierarchal information is included in the HTTP POST request sent to the server.
  • the system may identify entities using microformats, when available.
  • Microformats are attributes of HTML elements that store extra information, not visible to the user, about a tag. For example:
  • the system will detect the presence of the property “itemprop” and parse the DOM tree to tag the selection as an address. If a microformat is identified, it is saved and included in the HTTP POST request to the server.
  • information related the user's profile may also be used when formulating a rich query for transmission to the server.
  • Such information includes, but is not limited to, any combination of the user's history of documents visited, favorite websites or bookmarks, categories of favorite websites or bookmarks, shares, prior searches, recent prior searches, the search that referred the user to the current webpage, saves, interests, social networks, frequently accessed applications/documents/websites, a Bloom filter data structure that represents all domains that the user visited during a specific period of time, a Bloom filter data structure that represents all domains from which the user saved a webpage, a Bloom filter data structure that represents all domains on which the user shared a webpage, or the like.
  • FIG. 6 shows a textual representation of a data structure containing information regarding a sample user profile.
  • Prior searches performed by the user are stored and may be used as part of the user profile. Additionally, as the user visits web pages, the URLs of those web pages are recorded and sent to the server. For example, is a user searches www.***.com for “new camera” and then visits multiple web pages about cameras, that search and the pages visited by the user will be sent to the server and used to refine a contextual query to direct it more towards camera-related results.
  • the bookmarks saved by a user during web browsing are accessed and sent to the server to be used to refine a contextual search. For example, if a user has bookmarked ***.com, bbc.com/news, and cnn.com, the server may use this fact to provide more news-related sites in response to a request.
  • this rich query is sent, using a processor, from the component(s) 202 to the server(s) 106 .
  • more than one rich query may be constructed and sent.
  • the rich queries may be identical, and in other embodiments, at least some of the rich queries may be at least partially different from another rich query.
  • the processor sends the rich query (or queries) to the server(s) 106 using a networking device.
  • the rich query is not sent to a server and is instead processed by the component(s) 202 in step S 440 .
  • no rich query is constructed, and instead the contextual information that would have otherwise been used for a rich query is processed directly by the component(s) 202 in step S 440 .
  • the contextual search service uses a processor, obtains the context from the rich query (or queries) it receives from the component(s) 202 .
  • the service preprocesses the attributes stored in the rich query (or queries) to identify context that is potentially useful to improve search results.
  • the service categorizes the search entity (or entities) based on the context information stored in the search query (or queries).
  • the service disambiguates the meaning of any ambiguous terms with the help of the context information.
  • the service may also leverage the results obtained by other users of the service to further refine the results given to any particular user.
  • the selected entity is an image
  • the image is submitted to a facial recognition service to identify the pictured person or product.
  • the result from that conversion, which is text is then used by the service as the selected entity to search.
  • a digital fingerprint of the audio is submitted to an audio recognition service.
  • the audio fingerprint is generated by executing a hash on the PCM data comprising the file. The result from that conversion, which is text, is then used by the service as the selected entity to search.
  • the server identifies a most probable sequence of words based on the selected text and the surrounding text. In one embodiment, the server accomplishes this by generating a list of n-word-grams. In some embodiments, the number words used to create the word grams are 10 words, in other embodiments 8 words are used, in still other embodiments 6 words are used, in still further embodiments 4 words are used and in still other embodiments 2 words are used.
  • each of the generated word-grams may be used as input to a search engine, such as ***.com, yahoo.com and the like.
  • the results returned from these searches can be reviewed to determine if any of the results contain links to a knowledge management site, such as wikipedia.com.
  • Word-grams that returned search results having links to a knowledge management site are then ordered from most popular to least popular. The longest word-gram returning the most popular search is selected as the intended search term.
  • the selected search term may then be reviewed to determine if the word or word sequence has multiple meanings. In one embodiment, this is accomplished by consulting a directory of ambiguous phrases, such as that maintained by wikipedia.com. In this embodiment, if the phrase is ambiguous, compare the text of the page where the user originally selected the text, with the text on each page that is linked from the disambiguation page. Select the page with the most significant overlap and adjust the highlight text based on this. In a specific example, for the following text: haps://www.applebank.com/aboutaspx when the user highlights “Apple,” a request is made to a disambiguation page, e.g., http://en.wikipedia.org/wiki/Apple_(disambiguation).
  • the contextual search service uses a processor, identifies relevant content source(s) for query submission.
  • Content sources include, but are not limited to, the Internet, specific commerce, travel, or other service-related sources, knowledge sources such as Wikipedia and Wolfram Alpha, proprietary sources such as corporate databases, and the like.
  • the contextual information determined in step S 440 is used to determine which content source(s) is (or are) relevant. For example, according to some non-limiting exemplary embodiments, rich queries which appear to relate to travel destinations (according to the search entity and its context) will be matched by the service to the Internet and travel-related sources.
  • the content source(s) is (or are) determined based at least in part on the type of media that the rich query seems to be related to, for example, videos, photos, etc. According to some embodiments, the content source(s) is (or are) determined based at least in part on the ontological category that the rich query seems to be related to, for example, commerce, travel, etc. According to some embodiments, preferences indicated by the user and received by the service determine, in part, the type of content source(s).
  • step S 450 may be performed by searching groupings of content sources, referred to herein as “vertical categories.”
  • the disambiguated word or word sequence is used to return general search results which are then, in turn, compared to a vertical category mapping directory to identify potentially relevant content sources.
  • the vertical categories may be selected or prioritized based on, for example, context-specific skew or user preferences.
  • a specific example of this process are the steps taken to select content sources for a general search term, “Hawaii.”
  • a general search for “Hawaii” may return, for example, the following results:
  • a URL prefix to category index contains the categorization for “Map->Map”, “Images->Images”, “Wikipedia->References”, and “Lonely Planet->Travel”. Based on these results, the serve selects the following vertical categorization: Map, Images, References, and Travel.
  • Map, Images, References, and Travel In one embodiment. for each domain, the verticals most frequently accessed by the user are tracked. That is, for example, if people on lonelyplanet.com happen to view more Images then Maps, then images will be prioritized over maps for all users in future searches associated with lonelyplanet.com. However if a specific user watches videos with greater frequency than the general population, the video category will be introduced (or boosted) only for that user.
  • the contextual search service uses a processor, converts the rich query (or queries) to a standard query (or queries).
  • Standard queries are queries that are acceptable as input to the content source(s) identified in step S 450 .
  • a standard query includes one or more search entities.
  • a standard query additionally includes context information related to the search entity.
  • the service disambiguated the meaning of any ambiguous terms with the help of the contextual information, additional terms may be included in the standard query, as determined by the disambiguation process.
  • Boolean logic is applied to standard query construction. In a non-limiting embodiment, for example, Boolean logic is used in constructing a standard query for an Internet Search source which accepts Boolean search queries.
  • unnecessary words in the search entity are not included in the standard query. For example, if the search entity is long, the search entity may be shortened for the standard query, to increase the diversity of results. This is because search strings that are too specific may return results from too narrow a list of sources.
  • each vertical source has an associated input and output mapping, which translates a rich query received from a client into a specific instructions for the content source.
  • the placeholders ⁇ QUERY ⁇ and ⁇ LANGUAGE ⁇ would be populated based on the rich query. YouTube results may be mapped in the following manner:
  • Content and monetization sources include, but are not limited to, on-device and in-cloud personal content; social media content; vertical category content; internet and enterprise search content; local or location-based content; advertisements, and products and services offers, discounts or coupons.
  • the contextual search service uses a processor, obtains results from the content source(s).
  • the results are obtained by submitting the standard query (or queries) that were constructed in step S 460 to the content source(s) identified in step S 450 , and the service then accepts results from one or more of the content source(s).
  • the results are processed.
  • the results are sorted to remove duplicates (for example, sending results to multiple content sources may return results from one content source that duplicate one or more of the results from another content source).
  • the results are sorted in order of contextual relevance.
  • the results or processed results are sent to the component(s) 202 by a processor, using a networking device.
  • FIG. 7C shows a textual representation of a data structure containing sample results returned by a server that had been provided the rich query string of FIG. 7B .
  • the search entity was “132 Crosby Street, 4th Floor New York, N.Y. 10012”.
  • Information regarding the user's profile included a country code, IP address, country, region, city, DMA code, region, area code, postal code, continent code, latitude and longitude.
  • the results included map information regarding address provided in the search entity (latitude, longitude, and postal address).
  • the results further included a website related to the location of the address provided in the search entity (the local government website).
  • the contextual search service uses a processor, filters the results.
  • the results are filtered according to settings received from the user or stored in a user profile.
  • the results are filtered according to the physical limitations of the device of the components ( 202 ), for example, the device screen size, latency, and/or caching.
  • the results of all content source searched may be merged based on the order of the vertical categories and the merged results may be sent to the client.
  • the results are sent to client together with client-side query descriptors.
  • the search results are sent to the client in a JSON-encoded structure.
  • the contextual search service using a processor, presents the results.
  • presenting the results involves rendering the results on a display.
  • the service accepts input from the user to update the search entity so that a new search may be conducted.
  • the results are displayed in a pop-up window, dialogue box, unopened or opened tab, overlay, new partial screen, new full screen, or the like.
  • the results are displayed in text form; and/or rich media form, including audio, images, videos, maps, and/or the like; and/or applications for displaying rich media form including audio, images, videos, maps, and/or the like.
  • the client may itself execute parallel queries of content sources and merge those results into the results received from the server. For these embodiments, the client follows the same query logic as that described able in connection with the server.

Abstract

A method for providing highly relevant answers in response to a user's request uses contextual information pertaining to a user's request. A semantic entity is selected from content on the device and contextual information pertaining to the selected entity is transmitted to a server. The server constructs a query corresponding to the selected entity and translates the query into a set of simple queries; submits the simple queries to a relevant subset of a plurality of search, content and monetization sources; receives a plurality of results returned from the relevant subset of search, content and monetization sources in response to the simple queries; prioritizes the received results based on elements of the selected entity, the user, context about the selected entity, time and date, original location of the user, and aspects of the application on which the entity was selected; and presents a prioritized list of the results to the user on the client device.

Description

    RELATED APPLICATION FIELD OF THE INVENTION
  • This present application claims the benefit of and priority to U.S. Provisional Patent Application No. 61/512,826, entitled “SYSTEMS AND METHODS FOR CONTEXTUAL PERSONALIZED SEARCHING,” filed on Jul. 28, 2011, which is incorporated by reference in its entirety.
  • FIELD OF THE INVENTION
  • Embodiments of the present invention relate generally to the field of searching the Internet and other content sources (including, but not limited to, advertising streams) and computerized searching. In particular, the systems and methods described herein allow traditional web, monetization, and other content to be consumed in a radically different manner based on characteristics of the consumer and his/her query and intent.
  • BACKGROUND OF THE INVENTION
  • The World Wide Web has become a daily resource for many people. However, the large and relatively unstructured nature of the Web makes it difficult to find sites that are useful or relevant. Similarly, there are now many applications available to users and each application often has many features, all of which can leave a user bewildered and in need of guidance. Also as users search the web and use applications they expect to receive relevant advertisements and/or offers.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The foregoing and other objects, aspects, features, and advantages of the disclosure will become more apparent and better understood by referring to the following description taken in conjunction with the accompanying drawings, in which:
  • FIG. 1A is a schematic diagram of a system in accordance with an embodiment of the present invention;
  • FIG. 1B is a exploded diagram of the apparatus of FIG. 1, in accordance with an embodiment of the present invention;
  • FIG. 2 is a schematic diagram of a system transferring information, in accordance with an embodiment of the present invention;
  • FIG. 3A is an exemplary view of a screen shot showing a webpage before contextual mode has been activated, according to an embodiment of the present invention;
  • FIGS. 3B and 3C are exemplary views of screen shots showing a webpage after contextual mode has been activated and various search terms are highlighted, according to some embodiments of the present invention;
  • FIG. 3D is an exemplary view of a screen shot showing an overlay window and a webpage after a contextual search has been conducted, according to an embodiment of the present invention;
  • FIG. 4 is a flow diagram of a process according to an embodiment of the present invention;
  • FIGS. 5A-5D are more detailed flow diagrams of a process according to an embodiment of the present invention.
  • FIG. 6 is a textual representation of a data structure containing information regarding a sample user profile, according to an embodiment of the present invention;
  • FIG. 7A is an exemplary view of a screen shot showing a webpage in which a user has highlighted a search entity;
  • FIG. 7B is a sample rich-query string based on the search entity and webpage of FIG. 7A, according to an embodiment of the present invention; and
  • FIG. 7C is a textual representation of a data structure containing a sample text search result as returned by a server that had been provided the rich-query string of FIG. 7B, according to an embodiment of the present invention.
  • SUMMARY OF THE INVENTION
  • In one aspect, the present invention relates to a method for providing highly relevant answers in response to a user's request. This is accomplished by utilizing and applying contextual information pertaining to a user's request. A client device receives input indicating a desire to receive contextual information regarding a selected entity included in content on the device; transmits to a server contextual information pertaining to the selected entity; the server constructs a query corresponding to the selected entity and translates the query into a set of simple queries; submits the simple queries to a relevant subset of a plurality of search, content and monetization sources; receives a plurality of results returned from the relevant subset of search, content and monetization sources in response to the simple queries; prioritizes the received results based on elements of the selected entity, the user, context about the selected entity, time and date, original location of the user, and aspects of the application on which the entity was selected; and presents a prioritized list of the results to the user on the client device.
  • In another aspect, the present invention relates to a system for providing highly relevant answers in response to a user's request. This is accomplished by utilizing and applying contextual information pertaining to a user's request. In one particular embodiment, the present invention includes to a means for receiving input at a client device indicating a desire to receive contextual information regarding a selected entity included in content on the device, means for transmitting, to a server contextual information pertaining to the selected entity, means for constructing a query on the server corresponding to the selected entity and translating the query into a set of simple queries, means for submitting the simple queries to a relevant subset of a plurality of search, content and monetization sources, means for receiving, a plurality of search results returned from the relevant subset of search, content and monetization sources in response to the simple queries, means for prioritizing the received results based on elements of the selected entity, the user, context about the selected entity and user, time and date, original location of the user, and aspects of the application on which the entity was selected, and means for presenting a prioritized list of the results to the user on the client device.
  • DETAILED DESCRIPTION OF THE INVENTION
  • Various embodiments of the present invention provide a process or system for providing highly relevant answers in response to a user's request. A user views a webpage, a document, or other content. According to some embodiments, the contextual search service accepts input from the user regarding one or more search terms, phrases, images, or other information indicating a topic or topics of interest (hereinafter referred to as a “search entity”). According to some embodiments, anything and everything in a document is searchable. According to various embodiments, the service selects additional input related to the search entity to determine the context of the search entity, in order to conduct a search that is more likely to be relevant than a search that does not involve the context. According to various further embodiments, the service uses the search entity and context that may be related to the search entity to search for and obtain search results. According to various embodiments, these results are presented to the user on the client device.
  • FIG. 1A illustrates a networked environment 101 according to some embodiments, in which a contextual search service is provided. As shown in FIG. 1A, the networked environment 101 includes one or more client machines 102A-102N (generally referred to herein as “client machine(s) 102” or “client(s) 102”) in communication with one or more servers 106A-106N (generally referred to herein as “server machine(s) 106” or “server(s) 106”) over a network 104. The client machine(s) 102 can, in some embodiments, be referred to as a single client machine 102 or a single group of client machines 102, while server(s) 106 may be referred to as a single server 106 or a single group of servers 106. Although three client machines 102 and three server machines 106 are depicted in FIG. 1A, any number of clients 102 can be in communication with any number of servers 106. In some embodiments, a single client machine 102 communicates with more than one server 106, while in another embodiment a single server 106 communicates with more than one client machine 102. In yet another embodiment, a single client machine 102 communicates with a single server 106. Further, although a single network 104 is shown connecting client machines 102 to server machines 106, it should be understood that according to some embodiments, multiple, separate networks connect a subset of client machines 102 to a subset of server machines 106.
  • In some embodiments, the computing environment 101 includes an appliance (not shown in FIG. 1A) installed between the server(s) 106 and client machine(s) 102. This appliance can mange client/server connections, and in some cases can load balance connections made by client machines 102 to server machines 106. Suitable appliances are manufactured by any one of the following companies (but are not limited to these companies): the Citrix Systems Inc. Application Networking Group; Silver Peak Systems, Inc, both of Santa Clara, Calif.; Riverbed Technology, Inc. of San Francisco, Calif.; F5 Networks, Inc. of Seattle, Wash.; or Juniper Networks, Inc. of Sunnyvale, Calif.
  • Client(s) 102 and server(s) 106 may be provided as a computing device 100, a specific embodiment of which is illustrated in FIG. 1B. Included within the computing device 100 is a system bus 150 that communicates with the following components: a central processing unit 121 (“processor”); a main memory 122 providing non-transient storage; storage memory 128 providing non-transient storage; an input/output (I/O) controller 123; display devices 124A-124N; an installation device 116; and a network interface 118. In some embodiments, the storage memory 128 includes: an operating system, software routines, and a client agent 120. The I/O controller 123, in some embodiments, is further connected one or more input devices. Volatile computer memory, non-volatile computer memory, and combinations of volatile and non-volatile computer memory are to be included within the scope of non-transient storage. As shown in FIG. 1B, the I/O controller 123 is connected to a camera 125, a keyboard 126, a pointing device 127 such as (but not limited to) a mouse, and a microphone 129.
  • Various embodiments of the computing machine 100 include a central processing unit 121 characterized by any one of the following component configurations: logic circuits that respond to and process instructions fetched from the main memory unit 122; a microprocessor unit, such as (but not limited to): those manufactured by Intel Corporation; those manufactured by Motorola Corporation; those manufactured by Transmeta Corporation of Santa Clara, Calif.; the RS/6000 processor such as those manufactured by International Business Machines; a processor such as those manufactured by Advanced Micro Devices; or any other combination of logic circuits. Still other embodiments of the central processing unit 122 include any one or combination of the following: a microprocessor, a microcontroller, a central processing unit with a single processing core, a central processing unit with two processing cores, or a central processing unit with more than one processing core.
  • While FIG. 1B illustrates a computing device 100 that includes a single central processing unit 121, in some embodiments the computing device 100 include one or more processing units 121. In these embodiments, the computing device 100 can store and execute firmware or other executable instructions that, when executed, direct the one or more processing units 121 to simultaneously execute instructions or to simultaneously execute instructions on a single piece of data. In other embodiments, the computing device 100 store and execute firmware or other executable instructions that, when executed, direct the one or more processing units to each execute a section of a group of instructions. For example, each processing unit 121 may be instructed to execute a portion of a program or a particular module within a program.
  • In some embodiments, the processing unit 121 includes one or more processing cores. For example, according to some embodiments the processing unit 121 has two cores, four cores, eight cores, or any number of cores. In some embodiments, the processing unit 121 comprises one or more parallel processing cores. The processing cores of the processing unit 121, in some embodiments, access available memory as a global address space, or in other embodiments, memory within the computing device 100 is segmented and assigned to a particular core within the processing unit 121. In some embodiments, the one or more processing cores or processors in the computing device 100 can each access local memory. In still other embodiments, memory within the computing device 100 is shared amongst one or more processors or processing cores, while other memory can be accessed by particular processors or subsets of processors. In embodiments where the computing device 100 includes more than one processing unit, the multiple processing units are included in a single integrated circuit (IC). These multiple processors, in some embodiments, are linked together by an internal high speed bus, which may be referred to as an element interconnect bus.
  • In embodiments where the computing device 100 includes one or more processing units 121, or a processing unit 121 including one or more processing cores, the processors, in some embodiments, can execute a single instruction simultaneously on multiple pieces of data (SIMD), or in other embodiments can execute multiple instructions simultaneously on multiple pieces of data (MIMD). In some embodiments, the computing device 100 includes any number of SIMD and MIMD processors.
  • The computing device 100, in some embodiments, includes a graphics processor or a graphics processing unit (not shown). In various embodiments, the graphics processing unit includes any combination of software and hardware, and can further input graphics data and graphics instructions, render a graphic from the inputted data and instructions, and output the rendered graphic. In some embodiments, the graphics processing unit is included within the processing unit 121. In other embodiments, the computing device 100 includes one or more processing units 121, such that at least one processing unit 121 is dedicated to processing and rendering graphics.
  • Some embodiments of the computing device 100 provide support for any one of the following installation devices 116 (but is not limited to these devices): a CD-ROM drive, a CD-R/RW drive, a DVD-ROM drive, tape drives of various formats, USB device, a bootable medium, a bootable CD, a bootable CD for GNU/Linux distribution such as KNOPPIX®, a hard-drive or any other device suitable for installing applications or software. Applications, in some embodiments, include a client agent 120, or any portion of a client agent 120. According to some embodiments, the computing device 100 further includes a storage device 128 that is either one or more hard disk drives, or one or more redundant arrays of independent disks; where the storage device is configured to store an operating system, software, programs applications, or at least a portion of the client agent 120. A further embodiment of the computing device 100 includes an installation device 116 that is used as the storage device 128.
  • Embodiments of the computing device 100 include any one of the following I/O devices 130A-130N (but is not limited to these examples): a camera 125, keyboard 126; a pointing device 127; a microphone 129; mice; trackpads; an optical pen; trackballs; microphones; drawing tablets; video displays; speakers; inkjet printers; laser printers; and dye-sublimation printers; touch screen; or any other input/output device able to perform the methods and systems described herein. According to some embodiments, an I/O controller 123 connects to multiple I/O devices 103A-130N to control the one or more I/O devices. According to some embodiments, the I/O devices 130A-130N are configured to provide storage or an installation medium 116. According to other embodiments, the I/O devices 130A-130N are configured to provide a universal serial bus (USB) interface for receiving USB storage devices such as (but not limited to) the USB Flash Drive line of devices manufactured by Twintech Industry, Inc. Still other embodiments include an I/O device 130 that is a bridge between the system bus 150 and an external communication bus, such as (but not limited to): a USB bus; an Apple Desktop Bus; an RS-232 serial connection; a SCSI bus; a FireWire bus; a FireWire 800 bus; an Ethernet bus; an AppleTalk bus; a Gigabit Ethernet bus; an Asynchronous Transfer Mode bus; a HIPPI bus; a Super HIPPI bus; a SerialPlus bus; a SCI/LAMP bus; a FibreChannel bus; or a Serial Attached small computer system interface bus.
  • In some embodiments, the computing machine 100 can execute any operating system, while in other embodiments the computing machine 100 can execute any of the following operating systems: versions of the MICROSOFT WINDOWS operating systems such as WINDOWS 3.x; WINDOWS 95; WINDOWS 98; WINDOWS 2000; WINDOWS NT 3.51; WINDOWS NT 4.0; WINDOWS CE; WINDOWS XP; WINDOWS VISTA; and WINDOWS 7; the different releases of the Unix and Linux operating systems; any version of the MAC OS or iOS manufactured by Apple Computer; OS/2, manufactured by International Business Machines; any embedded operating system; any real-time operating system; any open source operating system; any proprietary operating system; any operating systems for mobile computing devices; or any other operating system. In still another embodiment, the computing machine 100 can execute multiple operating systems. For example, the computing machine 100 can execute PARALLELS or another virtualization platform that can execute or manage a virtual machine executing a first operating system, while the computing machine 100 executes a second operating system different from the first operating system.
  • In various embodiments, the computing machine 100 is embodied in any one of the following computing devices (but is not limited to these devices): a computing workstation; a desktop computer; a laptop or notebook computer; a server; a handheld computer; a mobile telephone; a portable telecommunication device; a media playing device; a gaming system; a mobile computing device; a netbook; a device of the IPOD family of devices manufactured by Apple Computer; any one of the PLAYSTATION family of devices manufactured by the Sony Corporation; any one of the Nintendo family of devices manufactured by Nintendo Co; any one of the XBOX family of devices manufactured by the Microsoft Corporation; or any other type and/or form of computing, telecommunications or media device that is capable of communication and that has sufficient processor power and memory capacity to perform the methods and systems described herein.
  • In other embodiments, the computing machine 100 is a mobile device such as (but not limited to) any one of the following mobile devices: a JAVA-enabled cellular telephone or personal digital assistant (PDA), such as the i55sr, i58sr, i85s, i88s, i90c, i95cl, or the im1100, all of which are manufactured by Motorola Corp; the 6035 or the 7135, manufactured by Kyocera; the i300 or i330, manufactured by Samsung Electronics Co., Ltd; the TREO 180, 270, 600, 650, 680, 700p, 700w, or 750 smart phone manufactured by Palm, Inc; any computing device that has different processors, operating systems, and input devices consistent with the device; or any other mobile computing device capable of performing the methods and systems described herein. In still other embodiments, the computing device 100 is any one of the following mobile computing devices (but is not limited to these devices): any one series of Blackberry, or other handheld device manufactured by Research In Motion Limited; the iPhone manufactured by Apple Computer; Palm Pre; a Pocket PC; a Pocket PC Phone; or any other handheld mobile device. In yet still other embodiments, the computing device 100 is a smart phone or tablet computer, such as (but not limited to) the iPhone or iPad manufactured by Apple, Inc. of Cupertino, Calif.; the BlackBerry devices manufactured by Research in Motion, Ltd. of Waterloo, Ontario, Canada; Windows Mobile devices manufactured by Microsoft Corp., of Redmond, Wash.; the Xoom manufactured by Motorola, Inc. of Libertyville, Ill.; devices capable of running the Android platform provided by Google, Inc. of Mountain View, Calif.; or any other type and form of portable computing device.
  • In still other embodiments, the computing device 100 is a virtual machine. In some embodiments, the virtual machine is any virtual machine, such as (but not limited to) those managed by a hypervisor developed by XenSolutions, Citrix Systems, IBM, VMware, or any other hypervisor. In still other embodiments, the virtual machine is managed by a hypervisor executing on a server 106 or a hypervisor executing on a client 102.
  • In still other embodiments, the computing device 100 can execute, operate or otherwise provide an application that is any one of the following: software; an application or program; executable instructions; a virtual machine; a hypervisor; a web browser; a web-based client; a client-server application; an ActiveX control; a Java applet; software related to voice over internet protocol (VoIP) communications like a soft IP telephone; an application for streaming video and/or audio or receiving and playing streamed video and/or audio; an application for facilitating real-time-data communications; a HTTP client; a FTP client; or any other set of executable instructions. Still other embodiments include a client device 102 that displays application output generated by an application remotely executing on a server 106 or other remotely located machine. In these embodiments, the client device 102 can display the application output in an application window, a browser, or other output window.
  • According to various embodiments, the computing device 100 further includes a network interface 118 to interface to a Local Area Network (LAN), Wide Area Network (WAN), the Internet, or any type of network, through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (e.g., 802.11, T1, T3, 56 kb, X.25, SNA, DECNET), broadband connections (e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET), wireless connections, or some combination of any or all of the above. Connections can also be established using a variety of communication protocols (e.g., TCP/IP, IPX, SPX, NetBIOS, Ethernet, ARCNET, SONET, SDH, Fiber Distributed Data Interface (FDDI), RS232, RS485, IEEE 802.11, IEEE 802.11a, IEEE 802.11b, IEEE 802.11g, CDMA, GSM, WiMax and direct asynchronous connections). In some embodiments, the network 104 comprises one or more sub-networks, and is installed between any combination of the clients 102, servers 106, computing machines and appliances included within the computing environment 101. In some embodiments, the network 104 is: a local-area network (LAN); a metropolitan area network (MAN); a wide area network (WAN); a primary network 104 comprised of multiple sub-networks 104 located between the client machines 102 and the servers 106; a primary public network 104 with a private sub-network 104; a primary private network 104 with a public sub-network 104; or a primary private network 104 with a private sub-network 104. According to some embodiments, the network topology of the network 104 differs within different embodiments, possible network topologies include: a bus network topology; a star network topology; a ring network topology; a repeater-based network topology; or a tiered-star network topology. Additional embodiments include a network 104 of mobile telephone networks that use a protocol to communicate among mobile devices, where the protocol is any one of the following: AMPS; TDMA; CDMA; GSM; GPRS UMTS; or any other protocol able to transmit data among mobile devices.
  • In various embodiments, the computing environment 101 includes more than one server 106A-106N such that the servers 106A-106N are logically grouped together into a server farm 106. In some embodiments, the server farm 106 includes servers 106 that are geographically dispersed and logically grouped together in a server farm 106, servers 106 that are located proximate to each other and logically grouped together in a server farm 106, or several virtual servers executing on physical servers. Geographically dispersed servers 106A-106N within a server farm 106 can, in some embodiments, communicate using a WAN, MAN, or LAN, where different geographic regions can be characterized as: different continents; different regions of a continent; different countries; different states; different cities; different campuses; different rooms; or any, combination of the preceding geographical locations. In some embodiments, the server farm 106 is administered as a single entity, while in other embodiments, the server farm 106 includes multiple server farms 106.
  • Referring now to FIG. 2, according to various embodiments of the invention, information 204 regarding a contextual search is transferred between the server(s) 106 and the component(s) 202. According to various embodiments, the component(s) 202 is computer software. According to other embodiments, the component(s) 202 is computer hardware or circuitry. According to various embodiments, the component(s) 202 is part of, or executes on, the client(s) 102. According to some embodiments, the component(s) 202 is part of, or executes on, the server(s) 106. According to various embodiments, information 204 is transferred to the server(s) 106 from the component(s) 202. According to various embodiments, information 204 is transferred to the component(s) from the server(s) 106. According to various embodiments, information 204 is transferred back and forth between the server(s) 106 and the component(s) 202.
  • FIGS. 3A-D illustrate the user experience of the contextual search service according to a non-limiting, exemplary embodiment. In FIG. 3A, the user has navigated to a webpage in a web browser using a touch-screen tablet device. In FIG. 3B, contextual mode has been activated, and some search entities have been identified on the display by highlighting certain words on the underlying webpage. In FIG. 3C, the service has automatically highlighted certain words to notify the user that more information is available about those terms (although all the items, words, and objects on the webpage are selectable and searchable). In FIG. 3D, the words “New” and “York” are highlighted, to the right of the overlay window. Although those two words are on separate lines, the service determined that they were related by comparing those words with the context, and then highlighting them both on the display. A search was conducted, which returned the results displayed in the overlay window.
  • In another embodiment, the system does not require activation of contextual mode to allow a user to perform a search. In these embodiment, the user navigates to a web page, as shown in FIG. 3A and any word or series of words displayed by the web page is available for selection by the user. The user indicates a desire to search for additional information about a term, such as by a activating a specific mouse button or by executing a “long press” on a touch screen, and the term is highlighted in a manner similar to that shown in FIG. 3D.
  • FIGS. 4 and 5A-5D show non-limiting processes for a contextual search service, according to various embodiments of the invention. Referring to FIG. 4, in step S400, according to some embodiments, the contextual searching mode is activated by a component(s) 202 before contextual searches can be performed. According to some embodiments, contextual searching mode is activated by the contextual search service accepting input, using a processor of a computing device, from the user to enable it. Examples include (but are not limited to), user input in the form of mouse input, touch-screen input, keyboard input, spoken command, or the like. For instance, in a non-limiting, exemplary embodiment, contextual searching mode is activated with a touch-screen device by receiving input corresponding with a sliding movement from the bottom of the screen. For another example, in a non-limiting, exemplary embodiment, contextual searching mode is activated by receiving input from a keyboard corresponding with a user pressing Alt (or a specific meta key). Once activated, according to some embodiments, the service indicates, using a display, audio device, or the like, that the contextual searching mode has been activated.
  • In still other embodiments, contextual mode is “always on,” that is, it does not need to be activated in order for contextual searches to be performed. In these embodiments, the user selects a term to be searched by providing specific, predefined input such as the activation of a specific mouse button (e.g., right-clicking), the activation of a specific mouse button in combination with a specific key of a keyboard (e.g., control-click), or by providing a specific touch gesture, such as a double-finger press, triple-finger press or long press. In some embodiments, the user's finger must contact the screen for more than 500 milliseconds to register a long press. In other embodiments the length of time the user's finger's must contact the screen in order to register a long press is greater than 100 milliseconds, 300 milliseconds, 750 milliseconds, or 1000 milliseconds.
  • According to some embodiments, contextual searching mode is made persistent (that is, to stay on until it is turned off) when activated, or in some embodiments, is made optionally persistent by accepting input indicating that a user pressed a hotkey or otherwise indicated that the option was selected. According to further embodiments, contextual searching mode can be made non-persistent (when it would otherwise be persistent) by accepting input indicating that a user pressed a hotkey or otherwise indicated that that option was selected.
  • For embodiments in which contextual mode is not “always on,” entering contextual mode involves suspending the otherwise typical user interface behavior of the webpage browser, email client, or document viewer. For embodiments in which contextual mode is “always on,” the activation of contextual searching suspends the normal behavior of the page. According to some embodiments, the ability of those software applications to accept input as normal may be suspended until the service is no longer in contextual mode. In that case, only the service will respond to user input directed at those applications unless the user input is directed at disabling the service or contextual mode. In these embodiments, user interaction events with the underlying page are intercepted and redirected or, in some case, discarded. For example, the following JavaScript event may be used to perform the interception of user interaction events: event.stopPropagation( ).
  • In a non-limiting, exemplary embodiment, a computer monitor may display the webpage shown in FIG. 7A in a browser window, where the word “JOBS” is hyperlinked. While not in contextual mode, clicking on “JOBS” would cause the browser to load the webpage specified by the hyperlink. While in contextual mode, clicking on “JOBS” would not cause the browser to load that webpage. Instead, “JOBS” would be highlighted by the service, indicating that “JOBS” is a search entity.
  • Returning to FIG. 4, in step S410, according to various embodiments, the contextual search service identifies at least one search entity. According to some embodiments, the search entity (or entities) is identified by the contextual search service accepting input, using a processor of a computing device, from the user to indicate search term(s). Examples include (but are not limited to), user input in the form of mouse input, touch-screen input, keyboard input, or the like. According to some embodiments, the service accepts input from a mouse corresponding with a user clicking on something. According to some embodiments, the service accepts input from a touch-screen device corresponding with a user touching, pointing, holding, releasing, making a dragging movement, or the like.
  • According to some embodiments, the contextual search service determines the search entity (or entities) at least in part through a disambiguation process, using a processor of a computing device. The disambiguation process itself also involves determining the local context in order to automatically select additional search terms or to determine the boundaries of the search entity (or entities). In some embodiments, the context is used to determine how often various combinations of potential terms are each searched. The frequency is then used, at least in part, to determine which additional search terms, if any, to select, beyond the one(s) indicated by the user. According to some embodiments, this disambiguation instead is performed by the server(s) 106 during step S440. According to some embodiments, disambiguation takes place both during steps S410 and S440.
  • For example, according to a non-limiting, exemplary embodiment, a touch-screen computer user highlights the word “Depp” while viewing a webpage about the movie, The Pirates of the Caribbean. The contextual search service takes as input the terms surrounding Depp, which were, “The actors included Johnny Depp, Keira Knightley, and Orlando Bloom.” The service then determines that, for instance, “Johnny Depp” is a term that is searched for more often than “Depp, Keira”. The service also determines that “Johnny Depp” is a more desirable search term than “Depp”. Therefore, the service selects “Johnny Depp” as the search entity.
  • According to some embodiments, the contextual search service determines the local context by finding other term(s), collections of term(s), or the like, in proximity to those indicated by the user. According to some embodiments, such terms include (but are not limited to): postal addresses, email addresses, URLs (which may or may not correspond with a hypertext link), currency, phone numbers, geographic locations, or the like. In these embodiments, regular expressions may be used to determine the existence of these types of terms. Exemplary regular expressions include: address—[{regex: /[\t\r\n]*(.+[, \u00A0]{1,}[A-Z]{2}[\u00A0]?[\d]{5})($|[\−\r\n]+)/}, {regex: /(\d+\w*[̂\r\n,]+(?:Street|St|Avenue|Ave)(, \d+\w+Floor)?)/}]; currency—{code: ‘USD’, symbol: ‘$’, name: ‘dollars?’},{code: ‘EUR’, symbol: ‘
    Figure US20130031087A1-20130131-P00001
    ’, name: ‘euros?’},{code: ‘GBP’, symbol: ‘£’, name: ‘pounds?’}; Twitter handle—/̂@[A-Za-z0-9_]+$/; and phone—[{regex: /([\d]{2} [\d]{2} [\d]{2} [\d]{2} [\d]{2})/},{regex: /([\d]{4} [\d]{4})/}, regex: /((\+[\d]+)?\(?[\d]{3} \)?[−][\d]{3}[−][\d]{4})/}].
  • According to some embodiments, search terms may be chosen based on whether the terms begin with a capital letter, are in all capital letters, or are in mixed case. According to some embodiments, such terms may be chosen from the beginning or end of a nearby sentence, where some embodiments take care to ignore periods that do not denote the end of a sentence (such as those used for abbreviations such as “U.S.” or “Inc.”). Some embodiments choose such terms based on the existence or non-existence of a nearby word “bridges” such as (but not limited to) the “of” in “the United States of America”, apostrophes used to indicate possession (“Gerry's”), ampersands (“His & Hers”), and the like. In many embodiments this behavior is provided via a rule base containing commonly-used rules.
  • Some embodiments ignore terms that are common (for example, ignoring a date such as “February”). Some embodiments choose terms based on whether the surrounding HTML tag or other encoding denotes it with a special tag (for example, bold, italic, links, heading tags (<h1>, <h2>, <h3>), or the like). Some embodiments choose terms based on whether the parent node in a HTML or similar document is marked as a Microformat or special semantic tag. Some embodiments choose terms based on a Microformat where the Microformat consists of multiple parts (like an address), scan surrounding areas for the other related tags to highlight them at the same time. Some embodiments choose terms based on detected sentences, dictionary terms, nouns, or the like. Various embodiments choose terms based on any combination of the examples described above, or other similar examples.
  • In still further embodiments, every type of analysis described above is performed in order to identify search terms extant on a displayed page. In still other embodiments, various subsets of the identified techniques may be applied. For embodiments in which the client machine is resource constrained, such as a tablet or mobile phone, a restricted area is analyzed to conserve resources. For example, the following JavaScript may be used to determine if the device is a mobile device: navigator.userAgent.indexOf(‘mobile’). The rules and techniques may be applied independently of structural boundaries in the displayed page; for example, processing is not affected by text wrapping from one line to the next.
  • In step S420, according to various embodiments, the contextual search service notifies, using a processor, the user of the search entity (or entities) identified in step S410. According to some embodiments, the notification is visual, such as through a display of a computer device. In some embodiments, the search entity (or entities) is highlighted within a document on a display. In other embodiments, a copy of the selected area is magnified in order to help the user identify the selected entity. In still further embodiments, the document is overlaid with a darker layer to improve contrast of the selected entity. In other embodiments, the text style of selected text is analyzed and the replicated with the color changed to black for best contrast; in an HTML document the font-style, font-family, font-weight, and text-transformation styles will be analyzed and replicated. Alternatively, these styles can be determined using the following JavaScript function: node.style.fontFamily.
  • In some embodiments, a pop-up window, text box, or the like is displayed to the user above the darker layer (if provided), which may include a list of any search entities. According to some embodiments, the selected search entity (or entities) is the same as what was indicated by the user, so no additional notification is made. According to some embodiments, the service requests input from the user regarding which search entity to select. In some further embodiments, the service accepts inputs from the user indicating the user's selection. In some embodiments, the input indicates that the user pressed a key, touched a touch screen, pointed with a mouse, made a voice command, or otherwise indicated the user's selection.
  • In some other embodiments the selected search entity is an image, video, audio, map, or other non-textual entity. In these embodiments, a highlight is applied to the selected entity and it is brought to the foreground, for example, displayed on top of the darker layer, if present.
  • According to some embodiments, the service has already selected the search entity, whether or not textual, and requests input from the user to confirm that the user wishes to conduct a search using that search entity.
  • In step S430, according to various embodiments, after a search entity is selected, that is, after the touch/click is registered and released, a query is a string constructed and posted to a server using a processor. According to various embodiments, the rich query string is a URL encoded so that it can be included in the body of a HTTP POST request. The rich query includes both the search entity and context information (hereinafter referred to as a “rich query”). According to some embodiments, the rich query includes context information which increases the likelihood of a relevant search. According to some non-limiting, exemplary embodiments, the context information includes any combination of the title of the page on which the entity is found (accessible using the JavaScript command, document.title), the URL of the page on which the entity is found (accessible using the JavaScript command document.location or, in some embodiments, read from native code using provided APIs), META tags, information regarding word frequencies, and/or the like, of the webpage where the search entity was found. Word frequencies may be calculated on the client and included in the HTTP POST request to the server. According to some embodiments, the context information includes any combination of the text that is located just before the search entity, the text that is located just after the search entity, the corresponding URL if hypertext tags surround the search entity, information (such as attributes) inside a parent tag surrounding the search entity, information regarding semantic tags surrounding the search entity, information regarding the application currently being executed (such as a web browser), information related to previous searches, information related to web pages visited, information related to hypertext links selected, information related to the user's profile, and/or the like.
  • Information about the application currently being executed may be exposed by an API provided by the operating system of the client. In some particular embodiments, the system is able to access the title of the window, or window name, in which the selected entity appears as well as the name of the executable application responsible for displaying the selected entity. Certain applications may allow access to further information. For example, an email program may also allow access to the title of the title of the email, that is, the “re” line and a word processing program may allow access to the title of the displayed document or to other characteristics of the document, such as word count.
  • Contextual information may be obtained by traversing the DOM tree to ascertain the node previous to the node containing the selected entity and extracting the content of the previous node and also to ascertain the node following the node containing the selected entity and extracting the content of the next node. Thus, in the following sentence: “Nicolas Sarkozy is the 23rd President of the French Republic,” in which 23rd President has been selected, the text “Nicolas Sarkozy” will also be extracted and included the HTTP POST request. A similar technique may be used to ascertain text after the selected entity, i.e., in the sentence above the term “French Republic” may also be extracted and included in the HTTP POST request. In some embodiments, this technique is used until 25 characters before the selected entity are obtained, 25 characters after the selected entity are obtained, or both, in other embodiments it is used to obtain 50 characters before the selected entity are obtained, 50 characters after the selected entity are obtained, or both, in still other embodiments it is used to obtain 100 characters before the selected entity are obtained, 100 characters after the selected entity are obtained, or both and in still further embodiments it is used to obtain 250 characters before the selected entity are obtained, 250 characters after the selected entity are obtained, or both. Exemplary code for extracting the content from the previous node is as follows:
  •   getPreviousTextNode: function(node) {
     var childs = node.parentNode.childNodes,
     idx = −1;
     for (var i=0; i<childs.length; i++) {
     if (childs[i] === node) {
       idx = i;
       break;
      }
     }
     if (idx > 0) {
      var pnode = childs[idx−1];
      while (pnode.childNodes.length > 0) {
       pnode =
    pnode.childNodes[pnode.childNodes.length−1];
      }
      return pnode;
     } else {
      return this.getPreviousTextNode(node.parentNode);
     }
    }
  • Similarly, exemplary code for obtaining the content of the next node is as follows:
  •  getNextTextNode: function(node) {
    if (!node | | !node.parentNode) return null;
    var childs = node.parentNode.childNodes,
    idx = −1;
    for (var i=0; i<childs.length; i++) {
     if (childs[i] === node) {
      idx = i;
      break;
     }
    }
    if (idx < childs.length−1) {
     var pnode = childs[idx+1];
     while (pnode.childNodes.length > 0) {
      pnode = pnode.childNodes[0];
     }
     return pnode;
    } else {
     return this.getNextTextNode(node.parentNode);
     }
    }
  • In some embodiments the selected entity is part of a hyperlink, or link. For example, using the example above, when selecting “23rd President” the user may actually be selecting the following HTML code:
  •    <div>
     Nicolas Sarkozy is the
     <a href=‘http://www.presidents.fr’ title=’Presidents of
    France’>
      23rd President of the French Republic
     </a>
    </div>
  • As described above, the selection of a entity will suspend normal processing by the page. Thus, rather than traversing the link identified by the text “23rd President,” that selection will be intercepted and discarded. The system will then recognize, using the “A” HTML tag that the selected entity is a link and will then also extract from the HTML code helpful attributes from the link, such as the HREF, ALT and TITLE attributes, in the example above. These extracted attributes are included with the selected entity in the HTTP POST request. The system may further use the JavaScript command “element.getattribute( )” in order to acquire the attributes of a tag.
  • In still other embodiments, the system may acquire text associated with headers from the page on which the selected entity appears using the JavaScript command “document.querySelectorAll(‘h1,h2,h3,h4,h5,h6,h7.h8’). The acquired text is then included in the IMP POST request sent to the server. The system may also search the DOM of the web page to identify META tags. The text associated with META tags may also be useful. Each of the META tags in a document will be returned by the following command: document.getElementsByTagName(‘meta’) and each returned tag may be analyzed using the following exemplary code:
  •   for (i = 0; i < metas.length; i++) {
     if(metas[i].name == ‘keywords’) {
      richQuery[‘keywords’] = metas[i].content;
     }
    }
  • According to a non-limiting, exemplary embodiment, FIG. 7A shows a sample webpage and FIG. 7B shows a corresponding rich-query string. The user has highlighted “132 Crosby Street, 4th Floor New York, N.Y. 10012”, which is used as the search entity. The rich-query string includes the name of the server (“query-server-beta”), the data type (“JSON”), a requested layout type (“default”), a return type (“javascript”), a language or culture specifier (“en-US”), and the URL of the search entity's webpage (“http://kikin.com/contact”). Additionally, the rich-query string includes information found on the search entity's webpage, including an address (“132 Crosby Street, 4th Floor, New York, N.Y. 10012”), text in close proximity to the address (“kikin Headquarters”), a phone number (“646-395-1280”), prominent text (“Contact Us”), and keywords specified in the META tags (“kikin, facebook, twitter, social networking, price comparison, browser plugin”).
  • In another embodiment, information about the HTML hierarchy of the page on which the selected entity is found may be used to determine content. In the example above, the HTML code for displaying the address to the user may be:
  •    <div id=‘ address’>
     Our address:
     <address>
      132 crosby street, New York, NY 10012
     </address>
    </div>
  • In these embodiments selecting “New York” will cause the system to traverse the DOM model for the page and detect that the selected entity is part of an ADDRESS tag and a DIV tag. The extracted hierarchal information is included in the HTTP POST request sent to the server.
  • In still other embodiments, the system may identify entities using microformats, when available. Microformats are attributes of HTML elements that store extra information, not visible to the user, about a tag. For example:
  •   <p itemprop=“address” itemscope=””
    itemtype=“http://data-vocabulary.org/Address”>
     <span itemprop=“stress-address”>2 Lincoln Place</span>,
      <span itemprop=“locality”>
       Brooklyn
      </span>
      <span itemprop=“region”>
       NY
      </span>
     </span>
    </p>
  • In the example above if the user selects “Brooklyn,” the system will detect the presence of the property “itemprop” and parse the DOM tree to tag the selection as an address. If a microformat is identified, it is saved and included in the HTTP POST request to the server.
  • According to various embodiments, information related the user's profile may also be used when formulating a rich query for transmission to the server. Such information includes, but is not limited to, any combination of the user's history of documents visited, favorite websites or bookmarks, categories of favorite websites or bookmarks, shares, prior searches, recent prior searches, the search that referred the user to the current webpage, saves, interests, social networks, frequently accessed applications/documents/websites, a Bloom filter data structure that represents all domains that the user visited during a specific period of time, a Bloom filter data structure that represents all domains from which the user saved a webpage, a Bloom filter data structure that represents all domains on which the user shared a webpage, or the like. According to a non-limiting, exemplary embodiment, FIG. 6 shows a textual representation of a data structure containing information regarding a sample user profile.
  • Prior searches performed by the user are stored and may be used as part of the user profile. Additionally, as the user visits web pages, the URLs of those web pages are recorded and sent to the server. For example, is a user searches www.***.com for “new camera” and then visits multiple web pages about cameras, that search and the pages visited by the user will be sent to the server and used to refine a contextual query to direct it more towards camera-related results.
  • Similarly, the bookmarks saved by a user during web browsing are accessed and sent to the server to be used to refine a contextual search. For example, if a user has bookmarked ***.com, bbc.com/news, and cnn.com, the server may use this fact to provide more news-related sites in response to a request.
  • According to various embodiments, after the rich query is constructed, this rich query is sent, using a processor, from the component(s) 202 to the server(s) 106. According to some embodiments, more than one rich query may be constructed and sent. According to further embodiments, the rich queries may be identical, and in other embodiments, at least some of the rich queries may be at least partially different from another rich query. According to various embodiments, the processor sends the rich query (or queries) to the server(s) 106 using a networking device. According to some embodiments, the rich query is not sent to a server and is instead processed by the component(s) 202 in step S440. According to further embodiments, no rich query is constructed, and instead the contextual information that would have otherwise been used for a rich query is processed directly by the component(s) 202 in step S440.
  • In step S440, according to various embodiments, the contextual search service, using a processor, obtains the context from the rich query (or queries) it receives from the component(s) 202. According to some embodiments, the service preprocesses the attributes stored in the rich query (or queries) to identify context that is potentially useful to improve search results. According to some embodiments, the service categorizes the search entity (or entities) based on the context information stored in the search query (or queries). According to some embodiments, the service disambiguates the meaning of any ambiguous terms with the help of the context information. The service may also leverage the results obtained by other users of the service to further refine the results given to any particular user.
  • For embodiments in which the selected entity is an image, the image is submitted to a facial recognition service to identify the pictured person or product. The result from that conversion, which is text, is then used by the service as the selected entity to search. For embodiments in which the selected entity is audio, a digital fingerprint of the audio is submitted to an audio recognition service. In some embodiments, the audio fingerprint is generated by executing a hash on the PCM data comprising the file. The result from that conversion, which is text, is then used by the service as the selected entity to search.
  • For embodiments in which the selected entity is textual, the server identifies a most probable sequence of words based on the selected text and the surrounding text. In one embodiment, the server accomplishes this by generating a list of n-word-grams. In some embodiments, the number words used to create the word grams are 10 words, in other embodiments 8 words are used, in still other embodiments 6 words are used, in still further embodiments 4 words are used and in still other embodiments 2 words are used.
  • As an example of this, for the sentence:
  • Tunisia, the country where the Arab Spring uprisings began this year, has joined the International Criminal court, becoming the first North African country to do so
  • in which “international Criminal” was the selected text would result, in an embodiment in which 6 words are used, in the following set of word-grams:
  • this year has joined the international year has joined the international criminal has joined the international criminal court joined the international criminal court becoming the international criminal court becoming the international criminal court becoming the first criminal court becoming the first north year has joined the international has joined the international criminal joined the international criminal court the international criminal court becoming international criminal court becoming the criminal court becoming the first has joined the international joined the international criminal the international criminal court international criminal court becoming criminal court becoming the joined the international the international criminal international criminal court criminal court becoming the international international criminal criminal court international criminal
  • In some embodiments, each of the generated word-grams may used as input to a search engine, such as ***.com, yahoo.com and the like. The results returned from these searches can be reviewed to determine if any of the results contain links to a knowledge management site, such as wikipedia.com. Word-grams that returned search results having links to a knowledge management site are then ordered from most popular to least popular. The longest word-gram returning the most popular search is selected as the intended search term.
  • The selected search term may then be reviewed to determine if the word or word sequence has multiple meanings. In one embodiment, this is accomplished by consulting a directory of ambiguous phrases, such as that maintained by wikipedia.com. In this embodiment, if the phrase is ambiguous, compare the text of the page where the user originally selected the text, with the text on each page that is linked from the disambiguation page. Select the page with the most significant overlap and adjust the highlight text based on this. In a specific example, for the following text: haps://www.applebank.com/aboutaspx when the user highlights “Apple,” a request is made to a disambiguation page, e.g., http://en.wikipedia.org/wiki/Apple_(disambiguation). The text on the about page is compared with each page linked from above disambiguation page. Because words used on http://en.wikipedia.org/wiki/Apple_Bank overlap more than with the other pages, e.g., 1863 (the year the bank was incorporated), 125th (the street the first branch was located on), mortgage, financial, or New York, Apple Bank is selected as the disambiguated search term to use going forward.
  • In step S450, according to various embodiments, the contextual search service, using a processor, identifies relevant content source(s) for query submission. Content sources include, but are not limited to, the Internet, specific commerce, travel, or other service-related sources, knowledge sources such as Wikipedia and Wolfram Alpha, proprietary sources such as corporate databases, and the like. According to various embodiments, the contextual information determined in step S440 is used to determine which content source(s) is (or are) relevant. For example, according to some non-limiting exemplary embodiments, rich queries which appear to relate to travel destinations (according to the search entity and its context) will be matched by the service to the Internet and travel-related sources. According to some embodiments, the content source(s) is (or are) determined based at least in part on the type of media that the rich query seems to be related to, for example, videos, photos, etc. According to some embodiments, the content source(s) is (or are) determined based at least in part on the ontological category that the rich query seems to be related to, for example, commerce, travel, etc. According to some embodiments, preferences indicated by the user and received by the service determine, in part, the type of content source(s).
  • In more detail, step S450 may be performed by searching groupings of content sources, referred to herein as “vertical categories.” In general, the disambiguated word or word sequence is used to return general search results which are then, in turn, compared to a vertical category mapping directory to identify potentially relevant content sources. In some embodiments, the vertical categories may be selected or prioritized based on, for example, context-specific skew or user preferences.
  • A specific example of this process are the steps taken to select content sources for a general search term, “Hawaii.” A general search for “Hawaii may return, for example, the following results:
  • 1. www.gohawaii.com
    2. www.gohawaii.com/big-island
  • 3. Map of Hawaii
  • 4. hawaii.gov/
    5. www.capitol.hawaii.gov/session2011/
  • 6. Images for Hawaii
  • 7. en.wikipedia.org/wiki/Hawaii
    8. www.co.hawaii.hi.us/9.
    9. www.lonelyplanet.com/usa/hawaii
  • A URL prefix to category index contains the categorization for “Map->Map”, “Images->Images”, “Wikipedia->References”, and “Lonely Planet->Travel”. Based on these results, the serve selects the following vertical categorization: Map, Images, References, and Travel. In one embodiment. for each domain, the verticals most frequently accessed by the user are tracked. That is, for example, if people on lonelyplanet.com happen to view more Images then Maps, then images will be prioritized over maps for all users in future searches associated with lonelyplanet.com. However if a specific user watches videos with greater frequency than the general population, the video category will be introduced (or boosted) only for that user.
  • In step S460, according to various embodiments, the contextual search service, using a processor, converts the rich query (or queries) to a standard query (or queries). Standard queries are queries that are acceptable as input to the content source(s) identified in step S450. According to various embodiments, a standard query includes one or more search entities. According to various embodiments, a standard query additionally includes context information related to the search entity. According to some embodiments, if during step S440, the service disambiguated the meaning of any ambiguous terms with the help of the contextual information, additional terms may be included in the standard query, as determined by the disambiguation process. According to some embodiments, Boolean logic is applied to standard query construction. In a non-limiting embodiment, for example, Boolean logic is used in constructing a standard query for an Internet Search source which accepts Boolean search queries.
  • According to some embodiments, unnecessary words in the search entity are not included in the standard query. For example, if the search entity is long, the search entity may be shortened for the standard query, to increase the diversity of results. This is because search strings that are too specific may return results from too narrow a list of sources.
  • In greater detail, for each vertical source identified, a query string is created that can be understood by the context source. In some embodiments, each vertical source has an associated input and output mapping, which translates a rich query received from a client into a specific instructions for the content source. For example, to search YouTube the following query instruction may be generated: http://gdata.youtube.com/feeds/api/videos?q={QUERY}&orderby=relevance&safeSearch=moderate&max-results=20&format=5&v=2&client=ytapi-kikin-Youtubevideowidg-s7 nshfa6-0&lr={LANGUAGE}
  • The placeholders {QUERY} and {LANGUAGE} would be populated based on the rich query. YouTube results may be mapped in the following manner:
  • feed/entries/title->title
  • feed/entries/links/href->link
  • feed/entries/mediaGroup/thumbnails->thumbnail
  • in order to return result that can be used by the service. In some embodiments, all content sources are accessed in parallel and the results of each source are post-filtered and re-ordered. Content and monetization sources include, but are not limited to, on-device and in-cloud personal content; social media content; vertical category content; internet and enterprise search content; local or location-based content; advertisements, and products and services offers, discounts or coupons.
  • In step S470, according to various embodiments, the contextual search service, using a processor, obtains results from the content source(s). According to various embodiments, the results are obtained by submitting the standard query (or queries) that were constructed in step S460 to the content source(s) identified in step S450, and the service then accepts results from one or more of the content source(s). According to various embodiments, the results are processed. According to some embodiments, the results are sorted to remove duplicates (for example, sending results to multiple content sources may return results from one content source that duplicate one or more of the results from another content source). According to some embodiments, the results are sorted in order of contextual relevance. According to various embodiments, the results or processed results are sent to the component(s) 202 by a processor, using a networking device.
  • According to a non-limiting, exemplary embodiment, FIG. 7C shows a textual representation of a data structure containing sample results returned by a server that had been provided the rich query string of FIG. 7B. The search entity was “132 Crosby Street, 4th Floor New York, N.Y. 10012”. Information regarding the user's profile included a country code, IP address, country, region, city, DMA code, region, area code, postal code, continent code, latitude and longitude. The results included map information regarding address provided in the search entity (latitude, longitude, and postal address). The results further included a website related to the location of the address provided in the search entity (the local government website).
  • Returning to FIG. 4, in step S480, according to various embodiments, the contextual search service, using a processor, filters the results. According to some embodiments, the results are filtered according to settings received from the user or stored in a user profile. According to some embodiments, the results are filtered according to the physical limitations of the device of the components (202), for example, the device screen size, latency, and/or caching.
  • In greater detail, the results of all content source searched may be merged based on the order of the vertical categories and the merged results may be sent to the client. In some embodiments, the results are sent to client together with client-side query descriptors. In some specific embodiments, the search results are sent to the client in a JSON-encoded structure.
  • In step S490, according to various embodiments, the contextual search service, using a processor, presents the results. According to various embodiments, presenting the results involves rendering the results on a display. According to some embodiments, the service accepts input from the user to update the search entity so that a new search may be conducted. According to some embodiments, the results are displayed in a pop-up window, dialogue box, unopened or opened tab, overlay, new partial screen, new full screen, or the like. According to some embodiments, the results are displayed in text form; and/or rich media form, including audio, images, videos, maps, and/or the like; and/or applications for displaying rich media form including audio, images, videos, maps, and/or the like.
  • In some embodiments, the client may itself execute parallel queries of content sources and merge those results into the results received from the server. For these embodiments, the client follows the same query logic as that described able in connection with the server.
  • Having described certain embodiments of an apparatus for interacting with software, it will now become apparent to one of skill in the art that other embodiments incorporating the concepts of the disclosure may be used.

Claims (24)

1. A method for providing contextual information regarding semantic entities included in content, the method comprising:
receiving input at a client device indicating a desire to receive contextual information regarding a selected entity included in content on the device;
transmitting, to a server, metadata contextual information pertaining to the selected entity;
constructing a query corresponding to the selected entity and translating the query into a set of simple queries;
submitting the simple queries to a relevant subset of a plurality of search, content and monetization sources;
receiving, a plurality of search results returned from the relevant subset of search, content and monetization sources in response to the simple queries;
prioritizing the received results based on elements of the selected entity, the user, context about the selected entity and user, time and date, original location of the user, and aspects of the application on which the entity was selected; and
presenting a prioritized list of the results received from the server.
2. The method of claim 1, further comprising highlighting the selected entity.
3. The method of claim 1, wherein the received user input is received in the form of touch-screen input.
4. The method of claim 1 wherein the received user input is received in the form of mouse input.
5. The method of claim 1, further comprising suspending the default user interface behavior of the application or device presenting the content.
6. The method of claim 5, further comprising suspending the default user interface behavior of the application or device presenting the content in response to user input comprising a dragging movement.
7. The method of claim 1, further comprising gathering metadata information pertaining to the selected entity from the content.
8. The method of claim 1, further comprising
gathering user profile information; and
transmitting, to a server, metadata information pertaining to the selected entity and the gathered user profile information.
9. The method of claim 1, further comprising disambiguating the selected entity.
10. The method of claim 1, further comprising submitting the simple queries to a local or location-based information source.
11. The method of claim 1, further comprising including in the received plurality of search results one or more results from information stored locally at the client device.
12. The method of claim 1, furthering comprising filtering the result received from the submitted simple queries by removing duplicate results.
13. A system for providing contextual information regarding semantic entities included in content, the method comprising:
means for receiving input at a client device indicating a desire to receive contextual information regarding a selected entity included in content on the device;
means for transmitting, to a server metadata information pertaining to the selected entity;
means for constructing a query corresponding to the selected entity and translating the query into a set of simple queries;
means for submitting the simple queries to a relevant subset of a plurality of search, content and monetization sources;
means for receiving, a plurality of search results returned from the relevant subset of search, content and monetization sources in response to the simple queries;
means for prioritizing the received results based on elements of the selected entity, the user, context about the selected entity and user, time and date, original location of the user, and aspects of the application on which the entity was selected; and
means for presenting a prioritized list of the results received from the server.
14. The system of claim 13, further comprising means for highlighting the selected entity.
15. The system of claim 13, wherein the means for receiving user input comprises a touch-screen.
16. The system of claim 13 wherein the means for receiving user input comprises a mouse.
17. The system of claim 13, further comprising means for suspending the default user interface behavior of the application or device presenting the content.
18. The system of claim 7, further comprising means for suspending the default user interface behavior of the application or device that is responsive to user input comprising a dragging movement.
19. The system of claim 13 further comprising means for gathering metadata information pertaining to the selected entity from the content.
20. The system of claim 13 further comprising means for gathering user profile information.
21. The system of claim 11, further comprising means for disambiguating the selected entity.
22. The system of claim 11, further comprising means for submitting the simple queries to a local or location-based information source.
23. The system of claim 11, wherein the means for receiving the plurality of search results includes one or more results from information stored locally at the client device.
24. The system of claim 11, furthering comprising means for filtering the result received from the submitted simple queries.
US13/554,779 2011-07-28 2012-07-20 Systems and methods for contextual personalized searching Abandoned US20130031087A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/554,779 US20130031087A1 (en) 2011-07-28 2012-07-20 Systems and methods for contextual personalized searching

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201161512826P 2011-07-28 2011-07-28
US13/554,779 US20130031087A1 (en) 2011-07-28 2012-07-20 Systems and methods for contextual personalized searching

Publications (1)

Publication Number Publication Date
US20130031087A1 true US20130031087A1 (en) 2013-01-31

Family

ID=47598114

Family Applications (5)

Application Number Title Priority Date Filing Date
US13/229,311 Abandoned US20130031076A1 (en) 2011-07-28 2011-09-09 Systems and methods for contextual searching of semantic entities
US13/229,245 Expired - Fee Related US8898583B2 (en) 2011-07-28 2011-09-09 Systems and methods for providing information regarding semantic entities included in a page of content
US13/229,302 Abandoned US20130031110A1 (en) 2011-07-28 2011-09-09 Systems and methods for rich query construction
US13/554,779 Abandoned US20130031087A1 (en) 2011-07-28 2012-07-20 Systems and methods for contextual personalized searching
US14/043,613 Abandoned US20140032522A1 (en) 2011-07-28 2013-10-01 Systems and methods for contextual searching of semantic entities

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US13/229,311 Abandoned US20130031076A1 (en) 2011-07-28 2011-09-09 Systems and methods for contextual searching of semantic entities
US13/229,245 Expired - Fee Related US8898583B2 (en) 2011-07-28 2011-09-09 Systems and methods for providing information regarding semantic entities included in a page of content
US13/229,302 Abandoned US20130031110A1 (en) 2011-07-28 2011-09-09 Systems and methods for rich query construction

Family Applications After (1)

Application Number Title Priority Date Filing Date
US14/043,613 Abandoned US20140032522A1 (en) 2011-07-28 2013-10-01 Systems and methods for contextual searching of semantic entities

Country Status (4)

Country Link
US (5) US20130031076A1 (en)
EP (2) EP2737413A1 (en)
CN (2) CN104025085A (en)
WO (2) WO2013015852A1 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070299466A1 (en) * 2004-11-24 2007-12-27 Ravish Sachar Percutaneous Transluminal Angioplasty Device With Integral Embolic Filter
US20100106182A1 (en) * 2008-10-22 2010-04-29 Patel Udayan G Angioplasty device with embolic filter
US20150052128A1 (en) * 2013-08-15 2015-02-19 Google Inc. Query response using media consumption history
US20180116811A1 (en) * 2016-10-27 2018-05-03 Ldr Medical Expansible Intersomatic Cage
US10292805B2 (en) 2015-01-23 2019-05-21 Contego Medical, Llc Interventional device having an integrated embolic filter and associated methods
US10366368B2 (en) * 2016-09-22 2019-07-30 Microsoft Technology Licensing, Llc Search prioritization among users in communication platforms

Families Citing this family (37)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9443518B1 (en) 2011-08-31 2016-09-13 Google Inc. Text transcript generation from a communication session
US9128896B2 (en) 2011-12-20 2015-09-08 Bitly, Inc. Systems and methods for identifying phrases in digital content that are trending
US9582592B2 (en) 2011-12-20 2017-02-28 Bitly, Inc. Systems and methods for generating a recommended list of URLs by aggregating a plurality of enumerated lists of URLs, the recommended list of URLs identifying URLs accessed by users that also accessed a submitted URL
US9111211B2 (en) 2011-12-20 2015-08-18 Bitly, Inc. Systems and methods for relevance scoring of a digital resource
US9619811B2 (en) 2011-12-20 2017-04-11 Bitly, Inc. Systems and methods for influence of a user on content shared via 7 encoded uniform resource locator (URL) link
US9135344B2 (en) * 2011-12-20 2015-09-15 Bitly, Inc. System and method providing search results based on user interaction with content
US9135211B2 (en) 2011-12-20 2015-09-15 Bitly, Inc. Systems and methods for trending and relevance of phrases for a user
US9098345B2 (en) * 2012-02-01 2015-08-04 Softlayer Technologies, Inc. System and method for portable and flexible deployment of servers
KR20130106519A (en) * 2012-03-20 2013-09-30 삼성전자주식회사 Method and apparatus for managing history of web-browser
US9251133B2 (en) 2012-12-12 2016-02-02 International Business Machines Corporation Approximate named-entity extraction
US20140181096A1 (en) * 2012-12-21 2014-06-26 Microsoft Corporation Entity name disambiguation
US20150006325A1 (en) * 2013-06-27 2015-01-01 Lucy Ma Zhao Product search using user selections in images systems and methods
US10235455B2 (en) * 2013-07-31 2019-03-19 Innography, Inc. Semantic search system interface and method
US10055103B1 (en) 2013-10-21 2018-08-21 Google Llc Text entry based on persisting actions
US10175850B2 (en) * 2013-11-23 2019-01-08 Sharp Laboratories Of America Search inquiry method using contextual annotation
KR102146261B1 (en) 2014-02-14 2020-08-20 삼성전자 주식회사 Electronic Device And Method For Extracting And Using Semantic Entity In Conversation Message Of The Same
US20150278860A1 (en) * 2014-03-25 2015-10-01 Google Inc. Dynamically determining a search radius to select online content
US9613145B2 (en) * 2014-06-18 2017-04-04 Google Inc. Generating contextual search presentations
US11120210B2 (en) 2014-07-18 2021-09-14 Microsoft Technology Licensing, Llc Entity recognition for enhanced document productivity
US9710558B2 (en) * 2014-07-22 2017-07-18 Bank Of America Corporation Method and apparatus for navigational searching of a website
CN105677684A (en) * 2014-11-21 2016-06-15 华东师范大学 Method for making semantic annotations on content generated by users based on external data sources
US9472009B2 (en) 2015-01-13 2016-10-18 International Business Machines Corporation Display of context based animated content in electronic map
CN105868166B (en) * 2015-01-22 2020-01-17 阿里巴巴集团控股有限公司 Regular expression generation method and system
CN107206227B (en) * 2015-02-03 2021-06-01 日机装株式会社 Clamping device
US10009297B2 (en) 2015-03-12 2018-06-26 International Business Machines Corporation Entity metadata attached to multi-media surface forms
US11442977B2 (en) 2015-03-24 2022-09-13 International Business Machines Corporation Augmenting search queries based on personalized association patterns
US10324926B2 (en) 2015-05-15 2019-06-18 Microsoft Technology Licensing, Llc System and method for extracting and sharing application-related user data
US11468101B2 (en) * 2015-05-29 2022-10-11 Kuni Ahi LLC Context-rich key framework implementations for global concept management
US10425492B2 (en) 2015-07-07 2019-09-24 Bitly, Inc. Systems and methods for web to mobile app correlation
WO2017075521A1 (en) * 2015-10-30 2017-05-04 ECMOtek, LLC Devices for endovascular access through extracorporeal life support circuits
US10650007B2 (en) * 2016-04-25 2020-05-12 Microsoft Technology Licensing, Llc Ranking contextual metadata to generate relevant data insights
EP3655966A4 (en) * 2017-07-17 2021-04-14 Happify, Inc. Assessing adherence fidelity to behavioral interventions
CN108986797B (en) * 2018-08-06 2021-07-06 中国科学技术大学 Voice theme recognition method and system
USD937304S1 (en) * 2020-07-27 2021-11-30 Bytedance Inc. Display screen or portion thereof with an animated graphical user interface
USD937303S1 (en) * 2020-07-27 2021-11-30 Bytedance Inc. Display screen or portion thereof with a graphical user interface
CN113190740A (en) * 2021-04-30 2021-07-30 百度在线网络技术(北京)有限公司 Search processing method, search processing device, electronic device, storage medium, and program product
CN113609309B (en) * 2021-08-16 2024-02-06 脸萌有限公司 Knowledge graph construction method and device, storage medium and electronic equipment

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100094878A1 (en) * 2005-09-14 2010-04-15 Adam Soroca Contextual Targeting of Content Using a Monetization Platform

Family Cites Families (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050091576A1 (en) * 2003-10-24 2005-04-28 Microsoft Corporation Programming interface for a computer platform
US20020194166A1 (en) 2001-05-01 2002-12-19 Fowler Abraham Michael Mechanism to sift through search results using keywords from the results
US7703040B2 (en) 2005-06-29 2010-04-20 Microsoft Corporation Local search engine user interface
US7676455B2 (en) 2006-02-03 2010-03-09 Bloomberg Finance L.P. Identifying and/or extracting data in connection with creating or updating a record in a database
US8725729B2 (en) 2006-04-03 2014-05-13 Steven G. Lisa System, methods and applications for embedded internet searching and result display
US7636779B2 (en) * 2006-04-28 2009-12-22 Yahoo! Inc. Contextual mobile local search based on social network vitality information
US20080065685A1 (en) * 2006-08-04 2008-03-13 Metacarta, Inc. Systems and methods for presenting results of geographic text searches
US8564544B2 (en) * 2006-09-06 2013-10-22 Apple Inc. Touch screen device, method, and graphical user interface for customizing display of content category icons
US8316000B2 (en) * 2006-12-07 2012-11-20 At&T Intellectual Property Ii, L.P. Method and apparatus for using tag topology
US8594996B2 (en) 2007-10-17 2013-11-26 Evri Inc. NLP-based entity recognition and disambiguation
US8380731B2 (en) 2007-12-13 2013-02-19 The Boeing Company Methods and apparatus using sets of semantically similar words for text classification
US7933896B2 (en) 2008-02-22 2011-04-26 Tigerlogic Corporation Systems and methods of searching a document for relevant chunks in response to a search request
US20090216639A1 (en) * 2008-02-25 2009-08-27 Mark Joseph Kapczynski Advertising selection and display based on electronic profile information
CN101320382B (en) * 2008-05-07 2011-12-07 索意互动(北京)信息技术有限公司 Method and system for rearranging search result based on context
US8145521B2 (en) 2008-07-15 2012-03-27 Google Inc. Geographic and keyword context in embedded applications
US8275759B2 (en) 2009-02-24 2012-09-25 Microsoft Corporation Contextual query suggestion in result pages
FR2947358B1 (en) * 2009-06-26 2013-02-15 Alcatel Lucent A CONSULTING ASSISTANT USING THE SEMANTIC ANALYSIS OF COMMUNITY EXCHANGES
US8489390B2 (en) 2009-09-30 2013-07-16 Cisco Technology, Inc. System and method for generating vocabulary from network data
CN101706794B (en) * 2009-11-24 2012-08-22 上海显智信息科技有限公司 Information browsing and retrieval method based on semantic entity-relationship model and visualized recommendation
US8983989B2 (en) * 2010-02-05 2015-03-17 Microsoft Technology Licensing, Llc Contextual queries
US8346795B2 (en) * 2010-03-10 2013-01-01 Xerox Corporation System and method for guiding entity-based searching
US20110231395A1 (en) * 2010-03-19 2011-09-22 Microsoft Corporation Presenting answers
CN101853292A (en) * 2010-05-18 2010-10-06 深圳市北科瑞讯信息技术有限公司 Method and system for constructing business social network
US8316030B2 (en) * 2010-11-05 2012-11-20 Nextgen Datacom, Inc. Method and system for document classification or search using discrete words

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100094878A1 (en) * 2005-09-14 2010-04-15 Adam Soroca Contextual Targeting of Content Using a Monetization Platform

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9707071B2 (en) 2004-11-24 2017-07-18 Contego Medical Llc Percutaneous transluminal angioplasty device with integral embolic filter
US10702367B2 (en) 2004-11-24 2020-07-07 Contego Medical, Llc Percutaneous transluminal angioplasty device with integral embolic filter
US20070299466A1 (en) * 2004-11-24 2007-12-27 Ravish Sachar Percutaneous Transluminal Angioplasty Device With Integral Embolic Filter
US20100106182A1 (en) * 2008-10-22 2010-04-29 Patel Udayan G Angioplasty device with embolic filter
US9510930B2 (en) 2008-10-22 2016-12-06 Contego Medical, Llc Angioplasty device with embolic filter
US9477709B2 (en) * 2013-08-15 2016-10-25 Google Inc. Query response using media consumption history
US20150052128A1 (en) * 2013-08-15 2015-02-19 Google Inc. Query response using media consumption history
US10860639B2 (en) 2013-08-15 2020-12-08 Google Llc Query response using media consumption history
US11960526B2 (en) 2013-08-15 2024-04-16 Google Llc Query response using media consumption history
US10292805B2 (en) 2015-01-23 2019-05-21 Contego Medical, Llc Interventional device having an integrated embolic filter and associated methods
US11166802B2 (en) 2015-01-23 2021-11-09 Contego Medical, Inc. Interventional device having an integrated embolic filter and associated methods
US11844679B2 (en) 2015-01-23 2023-12-19 Contego Medical, Llc Interventional device having an integrated embolic filter and associated methods
US10366368B2 (en) * 2016-09-22 2019-07-30 Microsoft Technology Licensing, Llc Search prioritization among users in communication platforms
US20180116811A1 (en) * 2016-10-27 2018-05-03 Ldr Medical Expansible Intersomatic Cage

Also Published As

Publication number Publication date
EP2737413A1 (en) 2014-06-04
US20130031500A1 (en) 2013-01-31
CN104025085A (en) 2014-09-03
US8898583B2 (en) 2014-11-25
US20130031076A1 (en) 2013-01-31
US20130031110A1 (en) 2013-01-31
EP2737417A1 (en) 2014-06-04
WO2013015852A9 (en) 2014-05-01
WO2013015852A1 (en) 2013-01-31
CN103842993A (en) 2014-06-04
WO2013016219A1 (en) 2013-01-31
US20140032522A1 (en) 2014-01-30

Similar Documents

Publication Publication Date Title
US8898583B2 (en) Systems and methods for providing information regarding semantic entities included in a page of content
US10592515B2 (en) Surfacing applications based on browsing activity
US9323808B1 (en) Predictive query suggestion caching
EP3529714B1 (en) Animated snippets for search results
US20130006914A1 (en) Exposing search history by category
US9342233B1 (en) Dynamic dictionary based on context
US9201935B2 (en) Transition from first search results environment to second search results environment
US20140289236A1 (en) Refining search results for a compound search query
WO2013070534A1 (en) Function extension for browsers or documents
Borodin et al. Context browsing with mobiles-when less is more
RU2633180C2 (en) System and method for managing browser application, persistent computer-readable medium and electronic device
US20140372255A1 (en) Embeddable media content search widget
CN109952571A (en) Image search result based on context
RU2698405C2 (en) Method of search in database
JP6147629B2 (en) Page site server, program, and method for immediately displaying a point of interest for page content
KR101537555B1 (en) A direct search system for message on the instant messenger
US20130179832A1 (en) Method and apparatus for displaying suggestions to a user of a software application
US9501497B1 (en) Location query processing
US9135313B2 (en) Providing a search display environment on an online resource
US11120096B2 (en) Method and system for generating an object card

Legal Events

Date Code Title Description
AS Assignment

Owner name: KIKIN INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BHOLA, CARLOS;CABRE, LUDOVIC;KROPITZ, GERALD;AND OTHERS;REEL/FRAME:028874/0091

Effective date: 20120531

AS Assignment

Owner name: 2B HOLDINGS LLC, NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:2B HOLDINGS LLC;REEL/FRAME:029569/0755

Effective date: 20100101

AS Assignment

Owner name: 2B HOLDINGS LLC, NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:KIKIN INC.;REEL/FRAME:029580/0204

Effective date: 20100101

AS Assignment

Owner name: BAIDU HOLDINGS LIMITED, VIRGIN ISLANDS, BRITISH

Free format text: SECURITY AGREEMENT;ASSIGNOR:KIKIN INC;REEL/FRAME:031160/0455

Effective date: 20130514

STCB Information on status: application discontinuation

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