Users often employ a variety of search components to locate desired content for use on a computing device. Functional limitations of some search utilities may compel users to resort to different search components depending on the domain in which the desired content may be stored. For example, a user may employ a local search component of the computing device's operating system to locate content stored locally on the computing device (“local domain”). The user may then access a remote search component via a web browser to locate content stored external to the computing device (“web domain”). The remote search component may return search results for the web domain identifying content such as web pages, internet-based multimedia content, or various files stored on a remote server. Exemplary remote search engines are well known in the art, for instance, a commonly known commercial engine is the BING™ search engine provided by Microsoft Corporation of Redmond, Wash. Furthermore, search results within a domain (i.e. the local domain and/or the web domain) may be classified by a result group according to a type of content. For example, local domain search results may be classified into a document, multimedia, application, and/or setting result group.
Some search components may communicate a user's search query to both a local search component and a remote search component. These global search components may allow the user to simultaneously locate content in both a local and web domain that may be relevant to the user's search query. One such example is the SMART SEARCH™ search component in the WINDOWS 8.1™ operating system provided by Microsoft Corporation of Redmond, Wash. A global search component may receive search results from both the local search component and the remote search component. These search results may be ranked based on relevance to the user's search query within one or more result groups of each respective domain. The global search component may simultaneously present ranked result groups from both the local and web domain search results to the user through a single search engine results page (“SERP”). Thus, users of global search components may locate both locally and remotely stored content by submitting a single search query.
The ability to receive search results regarding content from a wider range of sources provided by global search components may simultaneously be a benefit and a hindrance. On the one hand, the user gains the benefit of receiving a much larger volume of relevant search results in response to a single search query. Yet, the user must now sift through a larger volume of potentially relevant search results drawn from a larger pool of sources to locate their desired content. Depending on the context of a search query, search results from some sources may match a user's query intent more than others. Thus, local domain search results may match the user's query intent more than remotely stored content, or vice versa. Also, within a domain one result group may match the user's query intent more than another.
For example, search results from the web domain may match the user's query intent more than those from the local domain for a search query of “actor John Doe news.” Alternatively, search results from the local domain may match the user's query intent more than those from the web domain for a search query of “*.doc”. Furthermore, search results from a document result group within the local domain may match the user's query intent more than those from a settings result group based on that search query. In some instances, both local and web domain search results may equally match the user's query intent, for example, for a search query of “singer Jane Doe music.” The user could equally intend to locate a copy of a Jane Doe song in the local domain as a webpage in the web domain detailing Jane Doe's upcoming album. However, a search result from a music result group within the local domain may match the user's query intent more than those from a documents result group.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
In various embodiments, systems, methods, and computer-readable storage media are provided for, among other things, adjusting one or more presentation characteristics of a Search Engine Result Page (“SERP”) to emphasize at least one result group to the user that matches a user's query intent more than another. The presentation characteristic adjustments are based, at least in part, on a result group score computed locally on a client device. The result group scores are computed using one or more Machine Learning Algorithms (“MLAs”) received from a remote search service via a network.
Embodiments of the invention are illustrated by way of example and not limited in the accompanying figures in which like reference numerals indicate similar elements and in which:
The subject matter of this patent is described with specificity herein to meet statutory requirements. However, the description itself is not intended to necessarily limit the scope of the claims. Rather, the claimed subject matter might be embodied in other ways to include different steps or combinations of steps similar to the ones described in this document, in conjunction with other present or future technologies. Although the terms “step,” “block,” or “component,” etc., might be used herein to connote different components of methods or systems employed, the terms should not be interpreted as implying any particular order among or between various steps herein disclosed unless and except when the order of individual steps is explicitly described.
Various aspects of the technology described herein are generally directed to systems, methods, and computer-readable storage media for, among other things, providing query-completion suggestions configured to be searched against information domains. Information domains are content sites generally provided in association with a search engine (local or remote) that provides content and organization specific to a particular topic. Embodiments hereof further are directed to providing MLAs specific to query-completion suggestions and to adjusting one or more presentation characteristics of a SERP to emphasize at least one result group to the user that matches a user's query intent more than another. The presentation characteristic adjustments are based, at least in part, on a result group score computed locally on a client device utilizing MLAs received from a remote search service via a network.
Accordingly, some embodiments of the invention are directed to one or more computer-readable media having computer-executable instructions thereon that when executed by a computing device perform a method of adjusting presentation characteristics of a search engine results page (SERP) based on a query intent of a user. The method includes transmitting a search prefix comprising at least one character associated with an unexecuted search query to a search service, receiving one or more query suggestions and a machine learning algorithm configured to each query suggestion in response to the search prefix, transmitting an executed search query selected by the user from the query suggestions based in part on the query intent to a local search component configured to locate content stored in a local domain, receiving a plurality of result groups comprising at least one search result identifying content in the local domain from the local search component, and computing a result group score for each of the plurality of result groups using the machine learning algorithm configured to the selected query suggestion, wherein each result group score defines a relevance of the result group to the query intent, and wherein each result group score is based in part on client-computed features.
Another embodiment of the invention is directed to a system comprising one or more computer-readable media having computer-executable instructions thereon that when executed by a computing device perform a method of adjusting presentation characteristics of a SERP based on a query intent of a user. The method includes receiving a search prefix from a client device comprising at least one character associated with an unexecuted search query and transmitting one or more query suggestions and one or more machine learning algorithms configured to each query suggestion in response to the search prefix. Each machine learning algorithm is configured to compute a result group score defining a relevance of the result group to the query intent upon execution thereof, the execution being triggered upon receipt of a user-selection of the respective query suggestion.
Having briefly described an overview of embodiments of the invention, an exemplary operating environment in which embodiments of the invention may be implemented is described below to provide a general context for various aspects of these embodiments. Referring to the figures in general and initially to
The embodiments of the invention may be described in the general context of computer code or machine-useable instructions, including computer-executable instructions such as program components being executed by a computer or other machine, such as a personal data assistant or other handheld device. Generally, program components including routines, programs, applications objects, components, data structures, and the like, refer to code that performs particular tasks or implements particular abstract data types. Embodiments of the invention may be practiced in a variety of system configurations, including handheld devices, tablet computers, consumer electronics, general-purpose computers, specialty computing devices, etc. Embodiments of the invention may also be practiced in distributed computing environments where tasks are performed by remote-processing devices that are linked through a communications network.
As utilized herein, the phrase “computing device” generally refers to a dedicated computing device with processing power and storage memory, which supports operating software that underlies the execution of software, applications, and computer programs thereon. As one skilled in the art will appreciate, computing device 100 may include hardware, firmware, software, or a combination of hardware and software. The hardware includes processors and memories configured to execute instructions stored in the memories. The logic associated with the instructions may be implemented, in whole or in part, directly in hardware logic. For example, and without limitation, illustrative types of hardware logic include field programmable gate array (FPGA), application specific integrated circuit (ASIC), system-on-a-chip (SOC), or complex programmable logic devices (CPLDs).
The hardware logic allows a device to adjust one or more presentation characteristics of a SERP display to emphasize at least one result group that matches a user's query intent more than another to the user. The device may receive ranked search results within a plurality of result groups in response to a search query from a local search component and/or a remote search component. The local search component may send result groups from a local domain and the remote search component may send at least one result group from a web domain. The device may be configured to locally compute one or more result group scores based on machine learned algorithms (“MLAs”) received from a search service via a network. The device may determine which result group and/or domain matches a user's query intent more than another based on the computed result group scores. The device may adjust one or more presentation characteristics of a SERP display to emphasize at least one result group that matches the user's query intent more than another, and present the SERP display to the user. Query intent, as used herein, refers to a relevance of a result group and/or domain to a user search query based in part on the relevance of search results within the result group.
With continued reference to
The computing device 100 typically includes a variety of computer-readable media. Computer-readable media can be any available media that is accessible by the computing device 100 and includes both volatile and nonvolatile media, removable and non-removable media. Computer-readable media may comprise computer storage media and communication media; computer storage media excluding signals per se.
Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, Random Access Memory (RAM), Read Only Memory (ROM), Electronically Erasable Programmable Read Only Memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other holographic memory, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to encode desired data and that can be accessed by the computing device 100. In an embodiment, the computer storage media can be selected from tangible computer storage media like flash memory. These memory technologies can store data momentarily, temporarily, or permanently. Computer storage does not include and excludes communication media.
On the other hand, communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media.
The memory 112 includes computer-storage media in the form of volatile and/or nonvolatile memory. The memory may be removable, nonremovable, or a combination thereof. Exemplary hardware devices include solid-state memory, hard drives, optical-disc drives, etc. Computing device 100 includes one or more processors that read data from various entities such as the memory 112 or the I/O components 120. The presentation component(s) 116 present data indications to a user or other device. Exemplary presentation components 116 include a display device, speaker, printing component, vibrating component, etc. The I/O ports 118 allow the computing device 100 to be logically coupled to other devices including I/O components 120, some of which may be built in. Illustrative I/O components include a microphone, joystick, game pad, satellite dish, scanner, printer, wireless device, a controller (such as a stylus, keyboard, and mouse) or a natural user interface (NUI), etc.
A NUI processes gestures (e.g., hand, face, body, etc.), voice, or other physiological inputs generated by a user. These inputs may be interpreted as queries, requests for selecting URLs, or requests for interacting with a URL included as a search result. The input of the NUI may be transmitted to the appropriate network elements for further processing. The NUI implements any combination of speech recognition, touch and stylus recognition, facial recognition, biometric recognition, gesture recognition both on screen and adjacent to the screen, air gestures, head and eye tracking, and touch recognition associated with displays on the computing device 100. The computing device 100 may be equipped with depth cameras, such as stereoscopic camera systems, infrared camera systems, RGB camera systems, and combinations of these, for gesture detection and recognition. Additionally, the computing device 100 may be equipped with accelerometers or gyroscopes that enable detection of motion. The output of the accelerometers or gyroscopes is provided to the display of the computing device 100 to render immersive augmented reality or virtual reality.
As previously mentioned, embodiments of the invention are generally directed to systems, methods, and computer-readable storage media for, among other things, adjusting one or more presentation characteristics of a SERP to emphasize at least one result group that matches a user's query intent more than another to the user. The presentation characteristic adjustments are based in part on a result group score computed locally on a client device. The result group scores are computed using one or more MLAs received remotely from a search service via a network.
Various aspects of the technology described herein are generally employed in computer systems, computer-implemented methods, and computer-readable storage media for, among other things, providing MLAs associated with query completion suggestions in response to a received search prefix for use by a client device to compute one or more result group scores. In one embodiment, a server executes a query formulation component that sends one or more query completion suggestions in response to a received search prefix. The query formulation component may also provide one or more MLAs for each query completion suggestion sent. The server may also execute a remote search component that receives a search query selected from the one or more query completion suggestions sent and in response provide one or more search results from a web domain. The server may also execute a query log component that may receive feedback information based on a user's interaction with search results from the web domain and a local domain associated with the user's computing device that may be used to train MLAs.
Referring now to
As illustrated, the computing system 200 includes a client device 210, a search service 220, a machine learning algorithm (“MLA”) trainer 230, and a network 240. The network 240 may communicatively connect the client device 210 and the search service 220. It should be understood that any number of client computing devices (e.g. client device 210) and search services (e.g. search service 220) may be employed in the computing system 200 within the scope of embodiments of the invention. Each may comprise a single device/interface or multiple devices/interfaces cooperating in a distributed environment. For instance, the search service 220 may comprise multiple devices and/or modules arranged in a distributed environment that collectively provide the functionality of the search service 220 described herein. Additionally, other components/modules not shown also may be included within the computing system 200.
In some embodiments, one or more of the illustrated components/modules may be implemented as stand-alone applications. In other embodiments, one or more of the illustrated components/modules may be implemented via the client device 210, as an Internet-based service, or as a module inside the search service 220. It will be understood by those of ordinary skill in the art that the components/modules illustrated in
The client device 210 may communicate with the search service 220 to facilitate a user's search for content. For example, a user may utilize the client device 210 to simultaneously search for content available both in a local memory (e.g. memory 112 of
The client device 210 may be a computing device (e.g. computing device 100 of
The query input component 212 may be configured to receive a search prefix from a user searching for content via an input device in communication with the client device 210. For example, the input device may include a mouse, joystick, key pad, microphone, I/O components 120 of
The global search component 214 may be configured to receive a search query via query the input component 212. In response to receiving the search query, the global search component 214 may forward the search query to the local search component 216 and/or the search service 220. The global search component 214 may be further configured to receive search results from the local search component 216 and/or the search service 220 in response to the forwarded search query. The search results may be presented to the user on a SERP display via a presentation component (not shown). In certain embodiments, the search results may include a content preview (not shown) that allows the user to quickly preview content associated with the search results. In an embodiment, the global search component 214 may be further configured to transmit feedback information to the search service 220 based on user interaction with the local and/or web domain search results. The feedback information may enable the search service 220 to improve future query completion suggestions, search responses, and/or MLAs. In this embodiment, feedback information transmitted to the search service 220 may not include information specific to the user.
Search results, as used herein, refer to content and/or links to content that are determined to satisfy (or at least substantially satisfy) a search query. Often, presented search results are approximations of satisfying results rather than exact result matches, such as when an insufficient number of satisfying search results is available. Those of skill in the art will understand that search results differ from query completion suggestions not only in content (although in some instances the content may be substantially similar), but also in their use upon user selection thereof.
In some embodiments, the user may instruct the global search component 214 to forward the search query to a specific domain or both domains via the search input display. In these embodiments, an input may be presented to the user via search input display enabling the user to limit a search to a specific domain (e.g. only the local or web domain) or both domains. For example, if the user limits the search to the web domain via the input, the global search component 214 may only forward the search query to the search service 220.
The local search component 216 may be configured to receive a search query from the global search component 214 and return search results to the global search component 214 identifying content in the local domain relevant to the search query. The local search component 216 may operate as a conventional search engine by indexing content from the local domain and returning ranked search results in response to search queries. In some embodiments, the local search component 216 may be further configured to record user clicks on search results to improve searching.
The score computation component 218 may be configured to receive one or more MLAs from the search service 220. MLAs may provide a plurality of factors for the score computation component 218 to use in calculating a score for each domain and/or result group. The domain and/or result group score may be used to determine how closely the domain or result group matches a user's query intent relative to another. These factors may include one or more weighting values to be applied to one or more client-computed features for each domain and/or result group. The factors may also include one or more threshold values that may apply to each domain and/or result group when determining their relative degree of user query intent match. Another factor may include a constant value that may be used to equalize weighted client-computed features. In an embodiment, the constant value may provide a direct score in which case weighting values may be ignored. Result groups, as used herein, refer to a categorization or grouping of results based on a commonality. For example, results within a local domain may be categorized into result groups such as applications, settings, data files, and the like. Data files may be further categorized into result groups such as documents, multimedia content (e.g. music, videos, etc.), compressed archive files, and the like.
Client-computed features may be a set of values for each result group and/or domain determined by the score computation component 218 based on characteristics of the results within each respective result group and/or how the results match the search query. A result group score for every result group may be computed by score computation component 218 based on a combination of client-computed features and MLAs. Client-computed features may be available to the score computation component 218 via computer readable-media (e.g. the computer readable-media discussed with regards to
For example, client-computed features may include a number of results within a result group, ranks for results within the result group computed by the local search component 216, and/or a type of match for results in the result group. The type of match for results may include elements such as result title and/or keyword matches with the search query. Also, the type of match for results may be partially based on the result group of the result. For example, a result within a music result group may have client-computed features such as artist, genre, and/or album title matches with the search query.
The client device 210 may use the result group scores to adjust various presentation characteristics of a SERP display presented in response to the search query as described herein. Generally, the client device 210 may be in communication with a presentation component (e.g. the presentation component discussed with regards to
The search service 220 may communicate with the client device 210 to facilitate a user's search for content and dynamic adjustment of a SERP display by the client device. The search service 220 may implement any combination of the following components to perform these functions: a query formulation component 222, a remote search component 224, and a query log component 226.
The query formulation component 222 may be configured to communicate with a query input component (e.g. query input component 212) to provide the user with one or more query completion suggestions. One or more MLAs associated with each query completion suggestion may be forwarded to a score computation component (e.g. score computation component 218) to facilitate a score calculation for both local and web domain result groups. If updated query completion suggestions are provided, the query formulation component 222 forwards one or more MLAs associated with any updated query completion suggestions. As more fully described below, the score calculated by the client device may be used to adjust one or more presentation characteristics of a SERP display to emphasize at least one result group over another.
The remote search component 224 may be configured to receive a search query from the global search component 214 and return ranked search results to the global search component 214 identifying content in the web domain relevant to the search query. The remote search component 224 may operate as a conventional search engine by crawling content from the web domain, indexing web domain content, and returning search results in response to search queries.
The query log component 226 may be configured to receive feedback information from a client device (e.g. client device 210). The feedback information received may comprise information describing user interaction with local and/or web domain search results. For example the feedback information may include elements such as file names or any other information specific to the user that may not be transmitted to the query log component 226. Application specific information may be transmitted to the query log component 226 comprising no information specific to the user for use in improving future query completion suggestions and/or search results. As such, the search service 220 may facilitate the client device 210 with a ranking of local domain result groups while receiving feedback information on user interactions with the search results. The search service 220 may do this without receiving any privacy-sensitive information regarding local domain content. Relegating any privacy-sensitive information to the client device may have functional implications as well (e.g. security issues, performance concerns, and offline access to a global search component). For example, a binding may occur so that a partial set of search results may be presented to the user by the client device 210 in a progressive manner. Therefore, in some embodiments, the local domain results may arrive before web domain results, and accordingly be displayed first. As such, the user may still view result groups without delay in situations where other result groups or web domain results have not yet been received and some partial result group score computation is possible
The query log component 226 may store user's feedback information and/or aggregate feedback information from a plurality of users. The search service 220 may utilize the user's and/or aggregate feedback information to improve future query completion suggestions and/or search results. For example, the search service 220 may use feedback information to provide improved query completion suggestions and/or search results tailored for the user. The search service 220 may also use feedback information for general improvements to query completion suggestions and/or search results for any future user. The query log component 226 may be further configured to forward the user's and/or aggregate feedback information to the MLA trainer 230.
The MLA trainer 230 may be configured to receive a user's and/or an aggregation of a plurality of users' feedback information from the query log component 226. The feedback information may be used by MLA trainer to train MLA factors offline (e.g. weighting, threshold, and constant values). As such an MLA may be updateable and configurable for each user search query received. The MLA trainer 230 may be further configured to implement a late-binding MLA evaluation in order to prevent the disclosure of private, secure, or any local domain specific information to the search service 220.
The network 240 may be configured to communicatively couple the client device 210 and the search service 220. The network 240 may include any number of networks such as, for example, a local area network (LAN), a wide area network (WAN), the Internet, a cellular network, a peer-to-peer (P2P) network, a mobile network, or a combination of networks. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. Accordingly, the network 214 is not further described herein. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. Accordingly, the network 214 is not further described herein.
Turning now to
In step 320, the search service may return, in response to the search prefix, one or more query completion suggestions and one or more MLAs associated with each query completion suggestion. An MLA may comprise a plurality of factors for the client device to use in calculating a score for each domain and/or result group. The score may determine how each domain and/or result group matches a user's query intent relative to others. In step 330, the client device may forward a search query representing the query completion suggestion selected by the user to execute the search for desired content. The search query may be forwarded to a local search component associated with the client device and/or a remote search component associated with the search service.
In step 340, the client device may receive one or more result groups that each comprises at least one search response from the local search component, in response, identifying local content relevant to the search query. In step 350, the client device may calculate result group scores for each result group in the local and/or web domain based on a combination of client-computed features and MLAs. Client-computed features may be a set of values for each result group and/or domain determined by the client device. Client-computed features may be based on characteristics of the results within each respective result group and/or how the results match the search query.
In step 360, the client device may receive one or more result groups that each comprises at least one search response from the remote search component identifying web content relevant to the search query. In step 370, the client device may present result groups via a SERP display after adjusting one or more presentation characteristics of the SERP display using the computed result group scores. For example, the client device may reorder and/or resize local/web domain result groups to emphasize at least one result group over another based on how closely match they the user's query intent. In step 380, the client device may forward the computed result group scores and/or other feedback information to the search service for logging. The method terminates in step 381.
In an embodiment, search display area 500 may further comprise query scope input 520 that enables the user to define a scope of the query. For example, query scope input 520 may be a drop down menu comprising options such as “Everywhere”, “Local Only”, and/or “Remote Only”. A global search component (e.g. global search component 214 of
For example, the user may be searching for content associated with “Movie A” and begins entering the search query “Movie A” in the search bar. After the user enters the first two characters of the search query, a search prefix 512 (“mo”) may be forwarded to the query formulation component. Autosuggest display area 530 may update accordingly to display one or more query completion suggestions (e.g. “mo” 531, “movie” 532, “Movie A” 533, and/or “model” 534.) As “Movie A” 533 matches the user's query intent in this example, the user may execute a search query by selecting query completion suggest “Movie A” 533 via an input device.
In the embodiment of
In yet another embodiment, result groups from all domains may be interleaved and thus reordered based on ranking from highest result group score to lowest regardless of the domain. For example, in this embodiment, document result group 624 may have a higher computed result group score than a first web result group (not shown), which in turn has a higher computed result group score than photo result group 626. In this example, the result groups could be reordered such that document result group 624 is placed to the far left of SERP display 800, followed by the first web result group, followed next by photo result group 626.
In the embodiment shown in
In an embodiment, a result group may be displayed by default as a medium size by displaying a default number of results from the result group in the column layout of the result group. For example, a column layout of a result group may be capable of displaying seven results of the result group. In this example, a result group may be displayed as a medium size by displaying four results in the column layout of the result group. A result group may be resized to a large size by displaying additional results from the result group in the column layout of the result group (e.g. seven results). A result group may be resized to a small size by displaying fewer results from the result group in the column layout of the result group (e.g. one result). Accordingly, in the embodiment of
In another embodiment, a result group may be displayed by default as a medium size by displaying icons for the results of the result group as medium sized icons (e.g. 32×32 pixels). A result group may be resized to a large size by displaying icons for the results of the result group as large sized icons (e.g. 64×64 pixels). A result group may be resized to a small size by displaying icons for the result of the result group as small sized icons (e.g. 16×16 pixels). In this embodiment, emphasis could be placed on result groups by displaying icons for results of the result group sized accordingly in a column layout without changing the number of results displayed. Additionally, emphasis could be placed on result groups by both sizing the icons for results accordingly and changing the number of results displayed. In another embodiment, result groups with a computed result group score below a minimum value could be deemphasized by not displaying the result group on the SERP display at all. In another embodiment, result groups could be emphasized by adding an overlay to icons representing results of the result group and/or resizing the overlays added to the icons.
In another embodiment, the result group(s) within the domain having the highest cumulative domain score could be resized (not shown) in lieu of apportioning a larger area of the SERP display to the domain. Alternatively, the result group(s) within the domain having the highest cumulative domain score could be resized (not shown) in addition to apportioning a larger area of the SERP display to the domain. In yet another embodiment, each respective result group could be resized based on ranking from highest result group score to lowest regardless of the domain. In this embodiment, resizing the result groups could occur with or without apportioning a larger area of the SERP display to their respective domains.
In the embodiment shown in
In an embodiment, all results within a results group may still be available to the user even when not displayed on a SERP display. In this embodiment, “more results” indicators 1123, 1125, and 1127 can be displayed to provide an indication to a user that one or more additional results can be displayed upon selection. More result indicators can be represented in any manner, such as a text link, an arrow-shaped link, etc. Such indicators can provide a user an avenue for interacting with results not initially displayed.
As shown above in the embodiments of
In some embodiments, machine learned algorithms provided by a remote server may be used by a client device to compute a variety of values regarding each result group and result. In these embodiments, at least one presentation characteristic may be adjusted based on a client device calculated value that is not a result group or cumulative domain score using the machine learned algorithms.
While the invention is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.
It will be understood by those of ordinary skill in the art that the order of steps shown in the figures and described above are not meant to limit the scope of the embodiments of the invention in any way and, in fact, the steps may occur in a variety of different sequences within embodiments hereof. Any and all such variations, and any combination thereof, are contemplated to be within the scope of embodiments of the invention.