Embodiments relate to the field of search results, and more specifically to search results generated at least in part in response to one or more search queries.
With the vast quantities of information available on the internet, it may be desirable to provide one or more methods, apparatuses, or the like at least in part to find relevant or useful information for one or more users. For example, a user may want to use a search engine to locate information relating to one or more topics. In this example, a user may use a web browser to access a search engine and submit a user query to the search engine. In an embodiment, the search engine may process the query and provide a user with search results. Accordingly, it may be desirable to improve one or more aspects of a search engines performance.
Subject matter is particularly pointed out and distinctly claimed in the concluding portion of the specification. Claimed subject matter, however, both as to organization and method of operation, together with objects, features, and advantages thereof, may best be understood by reference of the following detailed description when read with the accompanying drawings in which:
In the following detailed description, numerous specific details are set forth to provide a thorough understanding of claimed subject matter. However, it will be understood by those skilled in the art that claimed subject matter may be practiced without these specific details. In other instances, methods, procedures, components or circuits that would be known by one of ordinary skill have not been described in detail so as not to obscure claimed subject matter.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of claimed subject matter. Thus, the appearances of the phrase “in one embodiment” or “an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined in one or more embodiments.
Some portions of the detailed description which follow are presented in terms of algorithms or symbolic representations of operations on binary digital signals stored within a memory of a specific apparatus or special purpose computing device or platform. In the context of this particular specification, the term specific apparatus or the like includes a general purpose computer once it is programmed to perform particular functions pursuant to instructions from program software. Algorithmic descriptions or symbolic representations are examples of techniques used by those of ordinary skill in the signal processing or related arts to convey the substance of their work to others skilled in the art. An algorithm is here, and generally, is considered to be a self-consistent sequence of operations or similar signal processing leading to a desired result. In this context, operations or processing involve physical manipulation of physical quantities. Typically, although not necessarily, such quantities may take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared or otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to such signals as bits, data, values, elements, symbols, characters, terms, numbers, numerals or the like. It should be understood, however, that all of these or similar terms are to be associated with appropriate physical quantities and are merely convenient labels. Unless specifically stated otherwise, as apparent from the following discussion, it is appreciated that throughout this specification discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining” or the like refer to actions or processes of a specific apparatus, such as a special purpose computer or a similar special purpose electronic computing device. In the context of this specification, therefore, a special purpose computer or a similar special purpose electronic computing device is capable of manipulating or transforming signals, typically represented as physical electronic or magnetic quantities within memories, registers, or other information storage devices, transmission devices, or display devices of the special purpose computer or similar special purpose electronic computing device.
A search engine computing platform may be useful for providing a user with one or more search results at least in response to a user submitting a query to the search engine, such as by employing a web browser in communication with a search engine computing platform via a network. In addition, under some circumstances it may be desirable for a search engine to store signal values corresponding to one or more user search queries, such as storing those signals in a memory cache, for example. In this example, a search engine platform may return cached results to a user submitting a corresponding user query rather than re-executing a user query that has already been stored in the memory cache. For example, if a user submits a search query a search engine platform may determine if corresponding search results have been saved in the memory cache. If search results corresponding to the submitted user query have been stored in the memory cache then the search engine platform may transmit signals corresponding to the cached results to a user. If, however, search results corresponding to the submitted user query have not been stored in the memory cache then the search engine platform may execute the user query and transmit signals corresponding to any generated search results to a user via a network.
In the foregoing example, it may be advantageous to update cached search results from time to time. For example, search result rankings may change over time and it may be advantageous to update cached search results to reflect changes in search result rankings from time to time. In an embodiment, requests to update cached search results may often be treated in a substantially similar manner to user submitted search queries. For example, such offline search query processing may be subject to similar limitations, such as, time, processor resources, or memory resources, as might on-line search query processing corresponding to one or more user search queries. In this embodiment, cached search results from offline search query processing may accordingly be substantially the same as search results from online search query processing generated in response to a user search query. As used herein, an “offline search query processing” request may refer to any search query processing request not initiated at least partially in response to an online search query process request. For example, an offline search query processing request may be generated by one or more computing platform at least in part to update one or more cached search results. As used herein, an “online search query processing” request may refer to a search query processing request initiated at least in part in response to a user initiated search query. For example, an online search query processing request may be initiated in response to a user submitting a search query to a search engine platform in one of the manners described above.
In at least one embodiment, a search engine platform may be implemented to handle requests to update cached search results in a different manner than user search queries. In this example, an offline search query processing request to update cached search results may be subjected to different time, processor resources, or memory resources than online search query processing of user search queries. In an example, one or more machine-learning models may provide more relevant results, but may take more time to generate and return search results to a user. In an embodiment, such machine-learning models may be employed for offline search query processing and cached for later use in connection with online search query processing without increasing latency of online query processing. For another example, offline search query processing requests to update cached search results may be allowed to execute on a search engine platform for a longer period of time that online search query processing requests at least in part to generate more refined search results. In this example, cached search results may be more relevant than search results generated in response to a user search query. In one embodiment, offline search query processing requests to update cached search results may be placed in a separate queue than online search query processing requests corresponding to user search queries and processed differently as discussed above. In another embodiment, offline search query processing requests to update cached search results may be transmitted to a separate search engine platform for execution as discussed above. It should, however, be noted that these are merely illustrative examples relating to updating cached search results and that claimed subject matter is not limited in this regard.
For another example, search engines may use one or more approximations to speed-up computation of a particular document's relevance to a particular search query. In this example, a search engine may employ one or more of the following techniques; consider only documents which contain all the words in a particular search query and disregarding documents that do not contain all the words of that particular search query; or use a relatively simple (fast) ranking function to eliminate many documents quickly and then use a relatively more accurate (and slow) ranking function to compute a relevance of the most promising documents. Since these approximations speed up the retrieval process at the cost of degrading the quality of results, a search engine may improve search results for offline user queries by not using the above approximations. For example, instead of only considering documents that match all terms of a particular search query a search engine may consider and rank any documents at least partially matching the query, such as any documents matching a threshold number of search terms. For further example, a search engine may process offline search queries using a relatively slow but more accurate ranking function for any documents that may match a particular search query. It should, however, be noted that these are merely illustrative examples relating to search query processing and claimed subject matter is not limited in this regard.
If, however, the online search query does not have corresponding cached search results then search engine platform may process the corresponding signals further for execution of the online search query. For example, search engine platform 106 may execute the online search query itself and transmit the search results to computing platform 102 via network 104. In another embodiment, search engine platform may search among additional search engine platforms, such as search engine platforms 108, 110, 112, 114, or 116. For example, search engine platform 106 may determine which if any of the other search engine platforms are available for executing the user search query. In this example, search engine platform 106 may transmit the online search query to an available search engine platform for execution. In addition, search engine platform 106 may receive one or more search results from one of the search engine platforms and transmit those search results to computing platform 102 via network 104. In yet another embodiment, search engine platform 106 may transmit the online search query to one or more of the other search engine platforms. In this example, the other search engine platforms may be assigned to search particular respective portions of available internet content. The other search engine platforms may transmit their respective search results to search engine platform 106. In this example, search engine platform 106 may assemble or rank one or more search results transmitted from the other search engine platforms and transmit the assembled search results to computing platform 102 via network 104. It should, however, be noted that these are merely illustrative examples relating to user queries or search engine results and that claimed subject matter is not limited in this regard.
In an embodiment it may be desirable for search engine platform 106 to update one or more of the cached search results. For example, it may be desirable to update cached search results from time to time to adjust for changes in available content or to reflect new content available that may correspond to a user search query. In this embodiment, search engine platform 106 may process an offline search query request to update cached search results. For example, search engine platform 106 may execute an offline search query corresponding to the cached results at least in part to generate updated search results and store the updated search results in the memory cache for subsequent use. In addition, as described above search engine platform 106 may employ additional search engine platforms, such as search engine platforms 108, 110, 112,114, or 116 such as in any of the manners described above, to generate updated search results corresponding to the cached search results and store the updated search results in the memory cache. It should, however, be noted that these are merely illustrative examples relating to updating cached search results and claimed subject matter is not limited in these regards.
In an embodiment, search engine platform 106 may, under some circumstances, handle offline search query processing requests in a manner different than online search query processing requests corresponding to a user search query. For example, online search query processing requests may be subject to limitations relating to amount of time for generating search results, processing resources for generating search results, memory resources for generating search results, or the like. In this example, offline search query processing requests to update cached search results may be subject to different limitations, such as more time, processing resources, memory resources, of the like for generating search results. In an embodiment, offline search query processing requests to update cached search results may employ the same or similar ranking processes as those used of user search requests. However, such a ranking process may be allowed to execute for a longer timer period with requests to update cached search results allowing for, under appropriate circumstances, improved search results stored in cache. In another embodiment, more complex algorithms may be used to process offline search query processing requests to update cached search results at least in part to generate more refined search results. It should, however, be noted that these are merely examples relating to updating cached search results and generating user search results and that claimed subject matter is not limited in this regard.
In an embodiment, search engine platform 106 may employ any of a number of processes at least in part to differentiate between offline search query processing requests to update cached search results and online search query processing requests corresponding to user search queries. In one example, search engine platform 106 may employ a first queue 118 for requests to update cached search results and a second queue 120 for user search queries. In this example, online search query processing requests corresponding to user search queries may be executed at a higher priority due to desirable time constraints on such queries. On the other hand, offline search query processing requests to update cached search results may be executed when processing resources are available for more in depth processing of such requests. In this embodiment, search engine platform 106 may parse one or more received queries at least in part to determine if such queries are online search query processing requests or offline search query processing requests. Once a query type is determined, search engine platform 106 may assign a received query to an appropriate one of queue 118 or queue 120. In yet another embodiment, search engine platform 106 may alternatively employ different additional search engine platforms for executing online search query processing requests corresponding to user search queries than for executing offline search query processing requests to update cached search results. For example, search engine platform 106 may assign offline search query processing requests to search engine platforms 108 and 110 for execution while assigning online search query processing requests to search engine platforms 112, 114, and 116 for execution. In this example, updated search results may be transmitted to search engine platform 106 and stored in a memory cache. Also in this example, user search results may be transmitted to search engine platform 106 for subsequent transmission to computing platform 102 via network 104. It should, however, be noted that these are merely illustrative examples relating to processing requests to update cached search results and generate user search results and that claimed subject matter is not limited in this regard.
It should be noted that, although aspects of the above system or process may have been described in a particular order, any specific order is merely an example of a process and claimed subject matter is of course not limited to the order described. It should also be noted that the methods and processes described herein, may be capable of being performed by one or more computing platforms. In addition, the methods or processes described herein may be capable of being stored on a storage medium as one or more machine readable instructions, that if executed may enable a computing platform to perform one or more actions. “Storage medium” as referred to herein relates to media capable of maintaining expressions, which may be operated on, or executed by, by one or more machines. For example, a storage medium may comprise one or more storage devices for storing machine-readable instructions or information. Such storage devices may comprise any one of several media types including, for example, magnetic, optical or semiconductor storage media. However, these are merely examples of a storage medium and claimed subject matter is not limited in these respects.
In the preceding description, various aspects of claimed subject matter have been described. For purposes of explanation, specific numbers, systems or configurations were set forth to provide a thorough understanding of claimed subject matter. However, it should be apparent to one skilled in the art having the benefit of this disclosure that claimed subject matter may be practiced without the specific details. In other instances, features that would be understood by one of ordinary skill were omitted or simplified so as not to obscure claimed subject matter. While certain features have been illustrated or described herein, many modifications, substitutions, changes or equivalents will now occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications or changes as fall within the true spirit of claimed subject matter.