Methods and systems for improved searching are described. In one of the described methods, a user enters a search query, and in response, a search engine receives a substantially complete initial search result set having a plurality of ranked article identifiers. The search engine automatically selects at least one of the article identifiers and provides a final result set in which the selected article identifier is ranked higher than in the initial search result set.
|
1. A computer-implemented method, comprising:
obtaining, in a server device, a plurality of first search results responsive to a first search query, the plurality of first search results being ranked in an order;
obtaining one or more second search results responsive to a second search query, the second search query being related to the first search query;
identifying a particular search result of the second search results;
determining that the particular search result is related to the first search query and that the particular search result is highly ranked for the second search query;
determining that the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query;
in response to determining that the particular search result is highly ranked for the second search query and the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query, modifying the first search results by providing the particular search result within the threshold number of highest-ranked first search results of the first search results responsive to the first search query; and
providing the modified plurality of first search results in response to the first search query.
23. A computer program product, encoded on one or more non-transitory computer storage media, comprising instructions that when executed by data processing apparatus cause the data processing apparatus to perform operations comprising:
obtaining a plurality of first search results responsive to a first search query, the plurality of first search results being ranked in an order;
obtaining one or more second search results responsive to a second search query, the second search query being related to the first search query;
identifying a particular search result of the second search results;
determining that the particular search result is related to the first search query and that the particular search result is highly ranked for the second search query;
determining that the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query;
in response to determining that the particular search result is highly ranked for the second search query and the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query, modifying the first search results by providing the particular first search result within the threshold number of highest-ranked first search results of the first search results responsive to the first search query; and
providing the modified plurality of first search results in response to the first search query.
12. A system comprising:
one or more data processing apparatus; and
a computer-readable storage device having stored thereon instructions that, when executed by the one or more data processing apparatus, cause the one or more data processing apparatus to perform operations comprising:
obtaining a plurality of first search results responsive to a first search query, the plurality of first search results being ranked in an order;
obtaining one or more second search results responsive to a second search query, the second search query being related to the first search query;
identifying a particular search result of the second search results;
determining that the particular search result is related to the first search query and that the particular search result is highly ranked for the second search query;
determining that the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query;
in response to determining that the particular search result is highly ranked for the second search query and the particular search result is not within a threshold number of highest-ranked first search results of the first search results responsive to the first search query, modifying the first search results by providing the particular first search result within the threshold number of highest-ranked first search results of the first search results responsive to the first search query; and
providing the modified plurality of first search results in response to the first search query.
2. The method of
determining the second search query is related to the first search query based on a temporal relationship between the first search query and the second search query.
3. The method of
4. The method of
determining the second search query is related to the first search query based on one or more shared terms between the first search query and the second search query.
5. The method of
generating the second search query by reformulating the first search query.
6. The method of
7. The method of
8. The method of
9. The method of
10. The method of
11. The method of
determining, based on information received after providing the modified plurality of first search results, whether the particular search result has a higher relevance to the first search query than the relevance indicated by the original position.
13. The system of
determining the second search query is related to the first search query based on a temporal relationship between the first search query and the second search query.
15. The system of
determining the second search query is related to the first search query based on one or more shared terms between the first search query and the second search query.
16. The system of
generating the second search query by reformulating the first search query.
17. The system of
18. The system of
19. The system of
20. The system of
21. The system of
22. The system of
determining, based on information received after providing the modified plurality of first search results, whether the particular search result has a higher relevance to the first search query than the relevance indicated by the original position.
|
This application is a continuation under 35 U.S.C. §120 of U.S. patent application Ser. No. 10/726,345, filed Dec. 3, 2003 and entitled “Systems and Methods for Improved Searching”, which is hereby incorporated by reference in its entirety.
The present invention relates generally to methods and systems for searching. The present invention relates particularly to methods and systems for improved searching.
A conventional search engine, such as the Google™ search engine, returns a result set in response to a search query submitted by a user. The search engine performs the search based on a conventional search method. For example, one known method, described in an article entitled “The Anatomy of a Large-Scale Hypertextual Search Engine,” by Sergey Brin and Lawrence Page, assigns a degree of importance to a document, such as a web page, based on the link structure of the web page. The search engine ranks or sorts the individual articles or documents in the result set based on a variety of measures. For example, the search engine may rank the results based on a popularity score. The search engine generally places the most popular results at the beginning of the result set.
Unfortunately, many links that the user is not likely to see may be of interest to the user. For example, a user may enter a very broad search term that results in a large number of documents returned by the search engine. The user may examine, for example, the first ten, twenty, or thirty documents, but may be unlikely to examine results occurring after some point in the result set. For this reason, the user is unlikely to ever see a result that appears after a certain point in a result set even though the result may be the most or one of the most useful or relevant for the particular user submitting the search query.
The desired web site may not appear highly ranked in the results due to a variety of factors, such as a poor ranking function or poor or unclear queries entered by the user. For example, the user may enter a query that is unclear, that does not use “good” search terms, or that the search engine has difficulty interpreting and finding results for. Spelling errors are one example of why a search engine may not return the desired result highly ranked in the result set.
Often, when a user does not see results they want, they are able to reformulate the query such as by using a different term to find the web site for which they are searching and do so in a subsequent query. The user may replace a term in the search query with a “good” search term or may, for example, correct the spelling of a term in a subsequent search query. Conventional search engines are unable to relate multiple queries in a way that addresses the problem set out above in an effective manner.
Thus, a need exists for systems and methods for improved searching.
Embodiments of the present invention provide systems and methods for improved searching. In one embodiment of the present invention, a user enters a search query, and in response, a search engine locates and ranks relevant documents. The search engine then relocates an article that is in a first position in the result set based on the initial ranking to a second position in the result set. The first position is a position not likely to be seen by the user, and the second position is a position that is likely to be seen by a user. The search engine may identify the article in various ways. For example, in one embodiment, the search engine randomly selects the article for relocation.
In another embodiment of the present invention, the search engine receives a first result set in response to a first search query and a second, candidate result set in response to a second search query. The search engine identifies an article in the candidate result set and inserts the article into the first result set. The queries may be related in various ways. For example, the second query may be a reformulated version of the first query.
Further details and advantages of embodiments of the present invention are set forth below.
These and other features, aspects, and advantages of the present invention are better understood when the following Detailed Description is read with reference to the accompanying drawings, wherein:
Embodiments of the present invention comprise methods and systems for improved searching. Referring now to the drawings in which like numerals indicate like elements throughout the several figures,
The client devices 102a-n shown each includes a computer-readable medium, such as a random access memory (RAM) 108 coupled to a processor 110. The processor 110 executes computer-executable program instructions stored in memory 108 as program code. Such processors may include a microprocessor, an ASIC, and state machines. Such processors include, or may be in communication with, media, for example computer-readable media, which stores instructions that, when executed by the processor, cause the processor to perform the steps described herein. Embodiments of computer-readable media include, but are not limited to, an electronic, optical, magnetic, or other storage or transmission device capable of providing a processor, such as the processor 110 of client 102a, with computer-readable instructions. Other examples of suitable media include, but are not limited to, a floppy disk, CD-ROM, DVD, magnetic disk, memory chip, ROM, RAM, an ASIC, a configured processor, all optical media, all magnetic tape or other magnetic media, or any other medium from which a computer processor can read instructions. Also, various other forms of computer-readable media may transmit or carry instructions to a computer, including a router, switch, private or public network, or other transmission device or channel, both wired and wireless. The instructions may comprise code from any computer-programming language, including, for example, C, C++, C#, Visual Basic, Java, Python, Perl, and JavaScript.
Client devices 102a-n may also include a number of external or internal devices such as a mouse, a CD-ROM, DVD, a keyboard, a display, or other input or output devices. Examples of client devices 102a-n are personal computers, digital assistants, personal digital assistants, cellular phones, mobile phones, smart phones, pagers, digital tablets, laptop computers, Internet appliances, and other processor-based devices. In general, a client device 102a may be any type of processor-based platform that is connected to a network 106 and that interacts with one or more application programs. Client devices 102a-n may operate on any operating system capable of supporting a browser or browser-enabled application, such as Microsoft® Windows® or Linux. The client devices 102a-n shown include, for example, personal computers executing a browser application program such as Internet Explorer™ from Microsoft Corporation, Netscape Navigator™ from Netscape Communications Corporation, and Safari™ from Apple Computer, Inc.
Through the client devices 102a-n, users 112a-n can communicate over the network 106 with each other and with other systems and devices coupled to the network 106. As shown in
The server device 104 shown includes a server executing a search engine application program, such as the Google™ search engine. Similar to the client devices 102a-n, the server device 104 shown includes a processor 116 coupled to a computer-readable memory 118. Server device 104, depicted as a single computer system, may be implemented as a network or cluster of computer processors. Examples of a server device 104 are servers, mainframe computers, networked computers, a processor-based device, and similar types of systems and devices. Client processor 110 and the server processor 116 can be any of a number of computer processors, such as processors from Intel Corporation of Santa Clara, Calif. and Motorola Corporation of Schaumburg, Ill.
Memory 118 contains the search engine application program, also known as a search engine 120. The search engine 120 locates relevant information in response to a search query 114 from a user 112a-n. The search engine 120 then provides the result set 134 to the client 102a via the network 106. The result set 134 comprises one or more article identifiers. An article identifier may be, for example, a uniform resource locator (URL), a file name, a link, an icon, a path for a local file, or anything else that identifies an article. In the embodiment shown, an article identifier comprises a URL associated with an article.
In the embodiment shown, the server device 104, or related device, has previously performed a crawl of the network 106 to locate articles, such as web pages, stored at other devices or systems connected to the network 106, and indexed the articles in memory 118 or on another data storage device. Articles include, for example, web pages of various formats, such as HTML, XML, XHTML, Portable Document Format (PDF) files, and word processor, database, and application program document files, audio, video, or any other documents or information of any type whatsoever made available on a network (such as the Internet), a personal computer, or other computing or storage means. The embodiments described herein are described generally in relation to HTML files or documents, but embodiments may operate on any type of article, including any type of image.
The search engine 120 includes a document locator 122, and a ranking processor 124. In the embodiment shown, each comprises computer code residing in the memory 118. The document locator 122 identifies a set of documents that are responsive to the search query 114 from a user 112a by, for example, accessing an index of documents, indexed in accordance with potential search queries or search terms.
In one embodiment of the present invention, the search engine 120 may also search a database (not shown) containing articles that have been previously identified as being relevant to a particular query. In yet another embodiment, the search engine 120 searches a file system of a local or remote machine to locate articles relevant to the first search query and of potential interest to the user 112a.
In the embodiment shown, the ranking processor 124 ranks or scores the search result 134 including the located set of web pages or documents based upon relevance to the search query 114 or another criteria, such as a popularity score. Note that other functions and characteristics of the document locator 122 and ranking processor 124 are further described below.
Server device 104 also provides access to other storage elements, such as a popularity database 128. The server device 104 can access other similar types of data storage devices. The popularity database 128 stores measures of the popularity of a document. The popularity database 128 may contain either or both query-dependent and query-independent popularity measures. For example, the popularity database 128 may store the number of times a particular document has been shown to users—a query-independent measure. Alternatively or additionally, the popularity database 128 may store the number of times that the article has been shown to a user in response to a particular keyword—a query-dependent measure. The ranking processor 124 utilizes this information in performing rankings of pages in the result set 134. When the search engine 120 generates a result set 134, the search engine 120 causes a record to be added or modified in the popularity database 128 to indicate that a particular result was shown to a user 112a in a result set 134.
Other measures of popularity may be stored in the popularity database 128, including, for example, click-through data. Click-through data is generally an indicator of quality in a search result. Quality signals or click-through data can include, but is not limited to, whether a particular URL or document is clicked by a particular user; how often a URL, document, or web page is clicked by one or more users; how often a particular user clicks on specific documents or web pages; and the ratio of how often a URL, document, or web page is clicked by one or more users to the number of times the URL, document or web page is shown to one or more users (known also as the click-through ratio). A popularity database 128 or similar data storage devices can store other types of quality signals similar to click-through data, such as user inputs or observational type data.
Other data related to documents located in a search result 134 that can be stored in a popularity database 128 or other data storage device can include, but is not limited to, how often a particular URL, document, or web page is shown in response to a search query 114; how many times a particular search query 114 is asked by users 112; the age or time a particular document has been posted on a network 106, and the identity of a source of a particular document on a network 106.
It should be noted that embodiments of the present invention may comprise systems having different architecture than that which is shown in
Various methods may be implemented in the environment shown in
Each document occupies a position in the search result 120. For example, the most highly-ranked document in the result set 134 occupies position one. The search engine 120 then relocates an article in a first position in the result set 134 based on the initial ranking to a second position in the result set 134. The first position is a position not likely to be seen by the user 112a. The second position is a position that is likely to be seen by a user. In one embodiment, the search engine 120 relocates the article only after receiving a substantially complete result set. In one such embodiment, a substantially complete result set may comprise a plurality of article identifiers (e.g., two or more) that represents a set or sub-set of a result set that may be operated upon to provide a final result set in which at least one of the article identifiers is ranked differently in the final result set than in the substantially complete result set. In one example of such an embodiment, a substantially complete result set comprises articles that are likely to be seen and articles that are unlikely to be seen by the user if provided as a final result set.
Search engines typically provide result sets of multiple article indicators. These result sets may be provided in, for example, one web page or multiple web pages. Typically, results after a particular number of article identifiers (e.g., 10, 20, or 30) are unlikely to be seen or viewed by the recipient of the search results. For example, a recipient may likely only page and/or scroll through the first 20 results (e.g., relevant article indicators) of a result set before trying another search, clicking through and becoming engaged with a web site associated with one of the viewed results, or carrying out some other activity. In such an example, if two thousand results are returned in a result set, twenty of such results may be likely to be viewed by the recipient and one thousand nine hundred and eighty may be unlikely to be viewed by the recipient. The number of results that a recipient is likely or unlikely to see depends on the context, and will vary depending on context. Ten, twenty, and thirty results are used above merely as examples. Factors influencing such variation include, for example, the number of results shown on a page, the type of device on which the recipient views the results (e.g., personal computer or hand-held device), the font size, the relevancy of the results, and many other factors.
In another embodiment, the search engine 120 receives an initial web (i.e., Internet or intranet) search result set having a plurality of ranked article identifiers. The search engine automatically selects at least one of the plurality of ranked article identifiers, for example, by randomly selecting an article identifier not likely to be seen by the user 112a. The search engine then provides the final search result 134 to the client, wherein the at least one of the plurality of article identifiers is ranked higher than in the initial web search result set. The search engine may also cause the final search result set to be displayed.
The terms first and second are used here merely to differentiate one item from another item. The terms first and second are not used to indicate first or second in time, or first or second in a list, or other order, unless explicitly noted. For example, the “second” may come in time or in list before the “first,” unless it is otherwise explicitly indicated.
The result set 134 may comprise tiers of various sizes, additional tiers, or may not comprise any tiers. The use of tiers is merely a convenient means of dividing the result set 134, separating results that are likely to be seen by a user 112a from those not likely to be seen by a user 112a.
In one embodiment, the first position in which the document is located is in a lower tier and the second position is in a higher tier. In one such embodiment, the higher tier comprises the first twenty articles in the result set 134 and the lower tier comprises the next fifty documents. In such an embodiment, a random number generator with a lower bound of twenty-one and an upper bound of seventy provides the location of the document to be relocated.
In an embodiment of the present invention, the search engine may identify the article in various ways. For example, in one embodiment, the search engine 134 randomly selects the article for relocation.
In another embodiment, the search engine 120 receives a first result set in response to a first search query, the result set ranked based on a ranking measure. The search engine 120 also receives a second, candidate result set in response to a second search query, the candidate result set is also sorted based on the ranking measure. The search engine 120 identifies an article in the candidate result set and inserts the article into the first result set. The first and second query may be substantially identical. For example, the search engine 120 may execute a first query for “infinity” and a second query for “infiniti.”
For each search query 114 received from the user 112a, the search engine 120 receives a candidate result set comprising documents, which may be inserted into the result set 134 that is sent to the client 102a. The candidate result set may be obtained in numerous ways, including, for example, by examining some results that are shown in the result set of the first search query in a position that is not likely to be seen by the user 112a, from highly ranked results on query refinements, or from a database of hand-picked results. The candidate result set may be generated before the search query 114 is submitted and stored in a database. When the search query 114 is executed by the search engine 120, the search engine 120 searches the data store (not shown) for one or more relevant candidate result sets from which to select documents for placement in the result set 134 sent to the client 102a.
Pre-generating the candidate result set provides several advantages. For instance, if the candidate result set is pre-generated, the user 112a does not have to wait for the candidate result set to be generated. In addition, having a pre-generated candidate provides a control for what is inserted into the result set 134. For example, the result set 134 for a particular query may change. By using a pre-generated candidate result set, the URL's that are relocated can be controlled.
Also, using a pre-generated candidate result set expands the scope of the manner in which the candidates are identified and inserted, allows the search engine 120 to generate the list in a more efficient manner than would otherwise be possible, and provides the opportunity to normalize the process of insertion to insure that specific results inserted into the result set 134 for the various users submitting a particular query are shown a comparable number of times.
The search engine 120 can identify the second query in various ways. In one embodiment, the search engine 120 identifies the second search query as one related to the first search query temporally. For example, the search engine 120 may determine that users often enter the search query “infiniti” immediately or almost immediately after entering the search query “infinity.” Such information is available in conventional log files generated by search engines. In one embodiment, the search engine 120 will determine that queries are related only if they are issued in close proximity numerous times. For example, in one embodiment, the search engine 120 determines that a search for “infinity” and “infiniti” are related after they are found in close temporal proximity five or more times. In another similar embodiment, the search engine 120 identifies particular articles that have been navigated to after submitting the first search query and inserts the URL for those articles in the result set 134. The user 112a may never have clicked on the article in a result set 134. However, the article to which the user 112a navigated and the search query may be related in some manner, e.g., temporally. For example, if users often navigate to www.infiniti.com after entering a search query that includes the term “infiniti” or “infinity,” the search engine 120 inserts the URL www.infiniti.com in the result set for the search queries “infiniti” and “infinity.”
In one such embodiment, the search engine 120 identifies the article as one appearing in a first tier of the candidate result set. The first tier comprises the set of documents that are likely to be viewed by the user 112a, e.g., the first twenty documents. In other words, the search engine 120 finds a second search query that is likely to be relevant to the first query and then locates documents that are highly ranked in the result set from the second query. In this way, the search engine 120 is able to identify potentially relevant documents that may not be highly ranked, and thus viewed, in the result set generated by the search engine 120 in response to receiving the first search query.
In another embodiment, the search engine 120 associates the first search query with a user identifier by, for example, searching the client 102a for a cookie or by retrieving the IP address of the client 102a. The search engine 120 then searches a data store (not shown) for a previously submitted query associated with the same user. The search engine 120 then executes the previously submitted query as the second query, retrieves a document from the result set of the second query and inserts the document into the result set from the first query. Various other measures may be used to determine that two queries by the same user 112a are related. For example, in one embodiment, two queries by the same user must include at least one shared or overlapping term before the search engine 120 identifies them as related. In another embodiment, two queries by different users are determined to be related because the queries include at least one shared term.
In yet another embodiment, the search engine 120 generates the second search query by reformulating the first search query. Reformulation may take various forms. In one embodiment, the search engine 120 replaces a first term in the search query with a second term. The second term may be, for example, a synonym of the first term. In another embodiment, the search engine 120 reformulates the query by removing a term. In yet another embodiment, the search engine 120 reformulates the query by adding an additional term.
In another embodiment, particular URL's are manually associated with a search query. The search engine 120 retrieves these “hand-picked” URL's to create the candidate result set. When the user 112a submits the search query, the search engine inserts the hand-picked URL into the result set 134. In yet another embodiment, the search engine 120 ranks the results in the first result set or, alternatively, in a second result set using an alternative ranking scheme to create the candidate result set. The search engine 120 then identifies articles in the candidate result set to insert into the result set 134.
Once the result set 134 has been created, the search engine 120 identifies a document in a candidate result set that may be of interest to the user 112a but that is not likely to be shown to the user 208. The search engine 120 may identify such a document in a number of ways as set forth herein. In one embodiment, the candidate result set comprises a section of the result set returned in response to the search query. In another embodiment, the search engine 120 retrieves the candidate result set from a data store (not shown). Data indicating actual popularity of the page can later be used to rank the relocated document in a conventional manner. Each user 112a is provided with a different random URL or set of URL's. In one embodiment, some URL's are identified as being potentially more relevant to the user or the user's query. In one such embodiment, although the URL's are chosen at random, the choice is biased towards the more potentially-relevant URL's. One goal of an embodiment of the present invention is to determine whether or not URL's that are not typically shown to a user 112a in response to a particular query are more relevant to the query than is evident using conventional ranking criteria.
The search engine 120 inserts the document in the result set 134 to a position that the user is likely to see 210. For example, the search engine 120 may relocate the document in the one-hundredth position in a result set 134 to the fifth position in the result set 134. The search engine 120 then provides the modified search result 134 to the client 102a by transmitting it over the network (106) 212.
The search engine 120 compares the result set of the related query to the original query by first identifying a highly ranked document in the result set from the related query 306. The search engine 120 may search a database for previously retrieved results from the related query or may execute the related query to retrieve the results. Although searching previously retrieved results may offer advantages, such as quicker response time, executing the related query during the process of identifying relevant documents to relocate may be preferred in that it can help to ensure that the results are as timely as possible. The query results in a list of documents satisfying the query and ranked in order of relevance. The search engine 120 then determines whether or not the document is highly ranked in the first query 308. If the document is not highly ranked in the first query, the search engine 120 relocates the document to a position in which the user 112a is likely to view it 310. The search engine 120 then provides the modified result set 134 to the client (102a) 312. The process then ends 314. If at step 308, the search engine 120 determines that the document is highly ranked in the query results for the first search query, there is no reason to relocate the document, and the process ends 314. Steps 306 through 312 may be repeated for each of the documents in the result set for the related query or for a subset comprising more than one document. In addition, steps 304 through 312 may be repeated for each query that is related to the search query 114 submitted by the user 112a.
For example, a user 112a may enter the search query 114 “infinity” in an attempt to find a site related to the Infiniti™ brand of automobiles. In response, the search engine 120 returns a result set 134. The user 112a examines the result set 134 and determines that the web site that the user 112a was trying to find is not in the first several pages of the result set 134. Further, the user 112a determines that the query 114 that the user 112a should have submitted was “infiniti.” The user 112a corrects the query 114 and submits the query 114 to the search engine 120. The search engine 120 returns the result set 134 for “infiniti.” The web site for Inifiniti™ automobiles appears first, and the user 112a navigates directly to the www.infiniti.com web site.
Subsequently, when a second user 112a enters the query “infinity,” the search engine 120 uses information from the first previously submitted queries to infer that “www.infiniti.com” may be relevant to the query “infinity.” Accordingly, the search engine 120 relocates the result “www.infiniti.com” to a location that the user 112a is likely to see. If users 112a that are presented with “www.infiniti.com” in response to the query “infinity” often navigate to “www.infiniti.com,” i.e., the document is a popular result to the query 114. As a result, in subsequent queries, the document may be highly ranked by a conventional ranking process. In other words, based on the popularity data gained by relocating the document, the search engine 120 will now determine that “www.infiniti.com” is a popular and highly relevant result for the query “infinity.”
In an embodiment of the present invention, the search engine 120 relocates documents to provide the user 112a with the opportunity to view documents that otherwise would likely not be viewed. If the user 112a clicks on the document, the search engine 120 logs the click in the popularity database 128 as in a conventional process. In subsequent queries, the document will be ranked higher due to the popularity data stored in the popularity database 128. Accordingly, it may be unnecessary to rerank the document in response to subsequent queries.
In another embodiment, the search engine selects one or more documents at random that appear within a predetermined range in the result set 134 and relocates those documents. For example, in one such embodiment, the search engine 120 selects one or more documents occurring in pages five through ten of the result set 134. These documents are ranked highly enough relative to most pages in the result set 134 to be potentially of interest to the user 112a but are unlikely to be seen by the user 112a. In another embodiment, the search engine 120 selects one or more documents between results fifty and one hundred. The pages or results within which documents are located may be varied in different embodiments to determine the optimal range within which to select documents.
The search engine may reformulate the query in numerous ways. In one embodiment, the search engine 120 reformulates the query by using variations of common words in the query. For example, if the query submitted is “cheap hotel,” the search engine may reformulate the query by varying the term “cheap.” In such an embodiment, one reformulation of the query may be “cheapest hotel.” Other reformulations may be used. For example, the search engine 120 may use synonyms for words in the query to reformulate it. Other methods of reformulation may be used.
Referring still to
In an embodiment of the present invention, the modified result set 134 should appear consistent to the user 112a during subsequent sessions in which the same query 114 is executed. This consistency is maintained over a relatively short period of time. During the relatively short period of time, the user 112a has an expectation that the result set 134 for a specific query 114 will remain consistent. However, the user 112a generally does not expect a result set 134 to remain consistent over an extended period, e.g., a week, due to the highly volatile nature of content on the Internet. The search engine 120 may accomplish consistency by storing a user identifier in a data store, such as a cookie, and using the user identifier to retrieve the search query, the URL of the result, and the position to which the result was relocated for a prescribed period of time. Other methods of maintaining consistency may also be used. In one embodiment, if an inserted document has been shown a set number of times, e.g., twenty, and does not appear to be a popular result to the query, the document is no longer inserted, i.e., the document is discarded as a potentially relevant result to the query.
The foregoing description of the preferred embodiments of the invention has been presented only for the purpose of illustration and description and is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Numerous modifications and adaptations thereof will be apparent to those skilled in the art without departing from the spirit and scope of the present invention.
Patent | Priority | Assignee | Title |
10339119, | Aug 17 2016 | International Business Machines Corporation | Calibration of a first search query based on a second search query |
10360268, | Aug 17 2016 | International Business Machines Corporation | Result set optimization for a search query |
12095773, | Jan 06 2023 | STRIPE, INC | Network of networks |
Patent | Priority | Assignee | Title |
5920854, | Aug 14 1996 | GOOGLE LLC | Real-time document collection search engine with phrase indexing |
5963932, | Apr 29 1997 | ORACLE INTERNATIONAL CORPORATION OIC | Method and apparatus for transforming queries |
6006222, | Apr 25 1997 | IAC SEARCH & MEDIA, INC | Method for organizing information |
6006225, | Jun 15 1998 | Amazon Technologies, Inc | Refining search queries by the suggestion of correlated terms from prior searches |
6014665, | Aug 01 1997 | IAC SEARCH & MEDIA, INC | Method for organizing information |
6078916, | Aug 01 1997 | IAC SEARCH & MEDIA, INC | Method for organizing information |
6169986, | Jun 15 1998 | Amazon Technologies, Inc | System and method for refining search queries |
6182068, | Aug 01 1997 | IAC SEARCH & MEDIA, INC | Personalized search methods |
6185558, | Mar 03 1998 | A9 COM, INC | Identifying the items most relevant to a current query based on items selected in connection with similar queries |
6185559, | May 09 1997 | Hitachi America, Ltd. | Method and apparatus for dynamically counting large itemsets |
6275820, | Jul 16 1998 | NTT DATA SERVICES CORPORATION | System and method for integrating search results from heterogeneous information resources |
6285999, | Jan 10 1997 | GOOGLE LLC | Method for node ranking in a linked database |
6321228, | Aug 31 1999 | POWERCAST MEDIA, INC | Internet search system for retrieving selected results from a previous search |
6353849, | Dec 20 1996 | Intel Corporation | System and server for providing customized web information based on attributes of the requestor |
6366934, | Oct 08 1998 | International Business Machines Corporation | Method and apparatus for querying structured documents using a database extender |
6424980, | Jun 10 1998 | Nippon Telegraph and Telephone Corporation | Integrated retrieval scheme for retrieving semi-structured documents |
6526440, | Jan 30 2001 | GOOGLE LLC | Ranking search results by reranking the results based on local inter-connectivity |
6529903, | Jul 06 2000 | GOOGLE LLC | Methods and apparatus for using a modified index to provide search results in response to an ambiguous search query |
6539377, | Aug 01 1997 | IAC SEARCH & MEDIA, INC | Personalized search methods |
6564213, | Apr 18 2000 | A9 COM, INC | Search query autocompletion |
6567103, | Aug 02 2000 | VALTRUS INNOVATIONS LIMITED | Graphical search results system and method |
6615209, | Feb 22 2000 | GOOGLE LLC | Detecting query-specific duplicate documents |
6658423, | Jan 24 2001 | GOOGLE LLC | Detecting duplicate and near-duplicate files |
6678681, | Mar 10 1999 | GOOGLE LLC | Information extraction from a database |
6684204, | Jun 19 2000 | GOOGLE LLC | Method for conducting a search on a network which includes documents having a plurality of tags |
6725259, | Jan 30 2001 | GOOGLE LLC | Ranking search results by reranking the results based on local inter-connectivity |
6728704, | Aug 27 2001 | VALTRUS INNOVATIONS LIMITED | Method and apparatus for merging result lists from multiple search engines |
6732086, | Sep 07 1999 | International Business Machines Corporation | Method for listing search results when performing a search in a network |
6732087, | Oct 01 1999 | TRIALSMITH, INC | Information storage, retrieval and delivery system and method operable with a computer network |
6738764, | May 08 2001 | VALTRUS INNOVATIONS LIMITED | Apparatus and method for adaptively ranking search results |
6745178, | Apr 28 2000 | GLOBALFOUNDRIES Inc | Internet based method for facilitating networking among persons with similar interests and for facilitating collaborative searching for information |
6754873, | Sep 20 1999 | GOOGLE LLC | Techniques for finding related hyperlinked documents using link-based analysis |
6826559, | Mar 31 1999 | Apple Inc | Hybrid category mapping for on-line query tool |
6832218, | Sep 22 2000 | International Business Machines Corporation | System and method for associating search results |
6847972, | Oct 06 1998 | GROUPM UK DIGITAL LIMITED | Apparatus for classifying or disambiguating data |
6853993, | Jul 15 1998 | A9 COM, INC | System and methods for predicting correct spellings of terms in multiple-term search queries |
6873982, | Jul 16 1999 | International Business Machines Corporation | Ordering of database search results based on user feedback |
6877002, | Nov 21 2000 | Microsoft Technology Licensing, LLC | Fuzzy database retrieval |
6990453, | Jul 31 2000 | Apple Inc | System and methods for recognizing sound and music signals in high noise and distortion |
7051014, | Jun 18 2003 | Microsoft Technology Licensing, LLC | Utilizing information redundancy to improve text searches |
7058624, | Jun 20 2001 | REGIONAL RESOURCES LIMITED | System and method for optimizing search results |
7152057, | Jun 18 2003 | Microsoft Technology Licensing, LLC | Utilizing information redundancy to improve text searches |
7152061, | Dec 08 2003 | IAC SEARCH & MEDIA, INC | Methods and systems for providing a response to a query |
7165080, | Oct 27 2000 | Canon Kabushiki Kaisha | Method and apparatus for facilitating refinement of a search |
7206780, | Jun 27 2003 | GOOGLE LLC | Relevance value for each category of a particular search result in the ranked list is estimated based on its rank and actual relevance values |
7277928, | Dec 22 2000 | Canon Kabushiki Kaisha | Method for facilitating access to multimedia content |
7574426, | Mar 31 2005 | Amazon Technologies, Inc | Efficiently identifying the items most relevant to a current query based on items selected in connection with similar queries |
7689615, | Feb 25 2005 | Microsoft Technology Licensing, LLC | Ranking results using multiple nested ranking |
7756857, | Jun 17 2002 | Canon Kabushiki Kaisha | Indexing and querying of structured documents |
20020042791, | |||
20020049752, | |||
20020069190, | |||
20020078020, | |||
20020123988, | |||
20020129014, | |||
20020133481, | |||
20020169754, | |||
20020194166, | |||
20030028890, | |||
20030033298, | |||
20030037074, | |||
20030078914, | |||
20030120654, | |||
20030149686, | |||
20030229640, | |||
20040024739, | |||
20040059708, | |||
20040059731, | |||
20040064447, | |||
20040068486, | |||
20040103087, | |||
20040119740, | |||
20040122811, | |||
20040153472, | |||
20040186828, | |||
20040215607, | |||
20050027670, | |||
20050027687, | |||
20050027691, | |||
20050033803, | |||
20050044070, | |||
20050050014, | |||
20050060311, | |||
20050071465, | |||
20060218114, | |||
20060224554, | |||
20060230022, | |||
20060294071, | |||
20060294086, | |||
20070011154, | |||
20070088692, | |||
20080313017, | |||
20100114933, | |||
20120095837, | |||
WO77689, | |||
WO167297, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 08 2007 | PEARSON, MARK | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 033198 | /0124 | |
Mar 08 2007 | TONG, SIMON | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 033198 | /0124 | |
Aug 22 2013 | Google Inc. | (assignment on the face of the patent) | / | |||
Sep 29 2017 | Google Inc | GOOGLE LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 044277 | /0001 |
Date | Maintenance Fee Events |
Jun 18 2018 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jun 16 2022 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Dec 16 2017 | 4 years fee payment window open |
Jun 16 2018 | 6 months grace period start (w surcharge) |
Dec 16 2018 | patent expiry (for year 4) |
Dec 16 2020 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 16 2021 | 8 years fee payment window open |
Jun 16 2022 | 6 months grace period start (w surcharge) |
Dec 16 2022 | patent expiry (for year 8) |
Dec 16 2024 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 16 2025 | 12 years fee payment window open |
Jun 16 2026 | 6 months grace period start (w surcharge) |
Dec 16 2026 | patent expiry (for year 12) |
Dec 16 2028 | 2 years to revive unintentionally abandoned end. (for year 12) |