US 7685112 B2
A method and system for autonomously downloading and indexing Hidden Web pages from Websites includes the steps of selecting a query term and issuing a query to a site-specific search interface containing Hidden Web pages. A results index is then acquired and the Hidden Web pages are downloaded from the results index. A plurality of potential query terms are then identified from the downloaded Hidden Web pages. The efficiency of each potential query term is then estimated and a next query term is selected from the plurality of potential query terms, wherein the next selected query term has the greatest efficiency. The next selected query term is then issued to the site-specific search interface using the next query term. The process is repeated until all or most of the Hidden Web pages are discovered.
1. A computer-implemented method of downloading Hidden Web pages comprising:
a) selecting a query term;
b) issuing a query to a site-specific search interface containing Hidden Web pages;
c) acquiring a results index;
d) downloading the Hidden Web pages from the results index;
e) identifying a plurality of potential query terms from the downloaded Hidden Web pages;
f) estimating the efficiency of each potential query term based on a ratio of the number of new pages returned for a particular query to the cost of issuing the particular query wherein the cost of issuing the particular query is equal to cq+crP(qi)+cdPnew(qi) where P(qi) represents the fraction of pages returned for a particular query (qi) and Pnew(qi) represents the fraction of new pages returned for a particular query (qi), and where cq represents the cost of submitting the particular query, cr represents the cost of retrieving a results index page, and cd represents the cost for downloading a matching document;
g) selecting a next query term from the plurality of potential query terms, wherein the next selected query term has the greatest efficiency; and
h) issuing a next query to the site-specific search interface using the next query term.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
10. The method of
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. A system for downloading Hidden Web pages comprising:
a web crawler for issuing a plurality of queries to a site-specific search interface containing Hidden Web pages and downloading the Hidden Web pages, the Hidden Web pages containing a plurality of potential query terms; and
wherein the web crawler is configured to:
select a query term;
issue a query to a site-specific search interface containing Hidden Web pages;
acquire a results index;
download the Hidden Web pages from the results index;
identify a plurality of potential query terms from the downloaded Hidden Web pages;
a computer configured to apply an algorithm to estimate the efficiency of each potential query term, wherein for each query, the most efficient query term is issued to the site-specific search interface by the web crawler; the algorithm comprising:
estimating the efficiency of each potential query term based on a ratio of the number of new pages returned for a particular query to the cost of issuing the particular query wherein the cost of issuing the particular query is equal to cq+crP(qi)+cdPnew(qi) where P(qi) represents the fraction of pages returned for a particular query (qi) and Pnew(qi) represents the fraction of new pages returned for a particular query (qi), and where cq represents the cost of submitting the particular query, cr represents the cost of retrieving a results index page, and cd represents the cost for downloading a matching document;
selecting a next query term from the plurality of potential query terms, wherein the next selected query term has the greatest efficiency; and
issuing a next query to the site-specific search interface using the next query term.
17. The system of
18. The system of
This Application is a U.S. National Stage filing under 35 U.S.C. §371 of International Application No. PCT/US2005/018849, filed 17 May 2005, which claims priority of U.S. Provisional Patent Application No. 60/580,543 filed on Jun. 17, 2004. The contents of the aforementioned application is hereby incorporated herein by reference in its entirety. Priority to the aforementioned application is hereby expressly claimed in accordance with 35 U.S.C. §§119, 120, 365 and 371 and any other applicable statutes.
This invention was made with Government support of Grant number 9986679 awarded by the National Science Foundation. The government has certain rights in this invention.
The field of the invention generally relates to methods and systems used to access, index, and acquire information stored on a Wide Area Network (WAN) such as the Internet. More specifically, the field of the invention generally relates to methods and systems used to autonomously locate and acquire so-called “hidden” or “deep” Web pages accessible via the Internet or similar WAN.
The Internet is becoming increasingly important as a repository of information. For example, such information may be stored on the World Wide Web (“Web”) in the form of Web pages. To search or access information located on the Web, a user typically uses a search engine such as, for example, GOOGLE, YAHOO, ASK JEEVES, MSN SEARCH or the like. Search engines generally operate by creating indices by spidering or crawling over Web pages. Typical crawlers today discover and index Web pages simply by following the hyperlinks from one page to another. Using this method, in order for the search engines to index a page, the page has to be static and, in addition, have other pages linking to it, so that it can be discovered through the crawling. Unfortunately, an ever-increasing amount of information is available to users only through site-specific search interfaces. In order to access these Web pages, a user must input one or more keywords or text strings into the site-specific search interface. Conventional search engines are unable to discover and index these pages because they are dynamically generated—there are no static links to these pages. These “hidden” pages are often referred to as the “Hidden Web” or the “Deep Web.”
The volume of information contained in the Hidden Web is increasing rapidly as many entities and organizations place their content online through easy-to-use Web interfaces. For example, the Securities and Exchange Commission and the United States Patent and Trademark Office each make available public documents via Web-based search interfaces. The content of these databases is, however, hidden from users that are searching using conventional search engines. Moreover, the content of many Hidden Websites is often highly relevant and useful to particular searches performed by users. For example, PubMed hosts numerous high-quality documents on medical research that have been selected from a carefully conducted peer-review process. The documents contained in the PubMed database are generally hidden from users unless they use the site-specific search interface.
There thus is a need for a method and system that is capable of automatically identifying and downloading Web pages from the Hidden Web so that conventional search engines (e.g., GOOGLE, YAHOO, ASK JEEVES, MSN SEARCH, etc.) can index and subsequently access the pages. There also is a need for a method and system for the generic information retrieval from Hidden Web pages. The method may be implemented using a software program such as a crawler that automatically downloads Web pages for search engines. Preferably, the crawler is able to download or otherwise make available Web pages such that current search engines are able to index the Web pages. Alternatively, Hidden Web pages may be downloaded or replicated locally on a user's computer. The Hidden Web pages are thus made available to users via conventional search engines.
The method and system of downloading and indexing Hidden Web pages will allow typical Internet users to easily access information from a single location (e.g., a single search engine) that, previously, was available only by searching through site-specific search interfaces. The method and system would improve the overall user experience by reducing wasted time and effort searching through a multitude of site-specific search interfaces for Hidden Web pages. Finally, current search engines introduce a significant bias into search results because of the manner in which Web pages are indexed. By making a larger fraction of the Web available for searching, the method and system is able to mitigate the bias introduced by the search engine to the search results.
The present invention is directed to a system and method for autonomously downloading and indexing Hidden Web pages from Websites having site-specific search interfaces. In a preferred embodiment, the method is implemented using a Web crawler or the like which autonomously traverses the Web to cull Hidden Web pages from one or more Websites known to have hidden content contained therein. The system and method preferably generates or otherwise prepares an index of the discovered Hidden Web pages such that conventional search engines are able to access the hidden content. For example, content that was previously hidden from a user searching the Internet with a search engine is no longer hidden. A search performed through a conventional search engine will now produce an index or list of “hits” that contain Hidden Web pages that was heretofore “invisible” to search engines.
The system and method described herein will allow a user searching the Web to more easily explore the vast quantity of information that is mostly “hidden” from view. Because most users search the Web use conventional search engines, “hidden” Web pages are not accessible because the pages are not indexed. Instead, a user must access the content via site-specific search interfaces which require additional input and searching. Many users, however, would like to use a single search interface such as that provided by a search engine to perform a single search rather than multiple searches across a number of site-specific search interface platforms. There thus is a need for a way to integrate Hidden Web content into existing search engine databases.
In addition, the system and method described herein is able to reduce the potential bias introduced by search engines. When a search is performed using a conventional search engine, a results list is generated and displayed to the user. However, the results list does not necessarily reflect what actually exists on the Web. Rather, the results list may be limited to those Web pages that are able to be indexed by the search engine. Moreover, the results list may include paid search listings or other information displayed more prominently that bias the results displayed to the user. The system and method described herein will make a larger fraction of the Web accessible through search engines, thereby mitigating bias that may be introduced by the search engine.
In one aspect of the invention, a method is provided for autonomously downloading and indexing Hidden Web pages from Websites having site-specific search interfaces. The method may be implemented using a crawler program or the like to cull Hidden Web content. The method includes the steps of selecting a query term and issuing a query to a site-specific search interface containing Hidden Web pages. The first query may be initiated using a seed term, for example, that may exist on the page containing the site-specific search interface. A results index is then acquired and the Hidden Web pages are downloaded from the results index. A plurality of potential query terms are then identified from the downloaded Hidden Web pages. The efficiency of each potential query term is then estimated and a next query term is selected from the plurality of potential query terms, wherein the next selected query term has the greatest efficiency. The next selected query term is then issued to the site-specific search interface. The method is an iterative process that repeats itself for a number or cycles, with each cycle resulting in a new query term chosen based on its projected efficiency. The method may also include the step of creating an index of each downloaded Hidden Web page.
The method and system described herein may be used on Websites having either a single-attribute search interface or a multi-attribute search interface. In the case of a multi-attribute search interface, potential keywords may be identified for each attribute of the search interface.
In one aspect of the invention, the process is repeated until all the Hidden Web documents are downloaded. In another aspect of the invention, the process is repeated until the number of new documents returned for one or more queries falls below a pre-set threshold.
In one aspect of the invention, the efficiency of each potential query term is expressed as a ratio of number of new documents returned for the potential query term to the cost associated with issuing the potential query. In another aspect of the invention, the efficiency of each potential query term is a function of the number of new documents returned for a particular query term.
In another aspect of the invention, the number of new pages returned (Pnew (qi)) for a particular query (qi) is equal to P(qi)−P(q1∪ . . . ∪ qi−1) P(qi|q1∪ . . . ∪qi−1) where P(qi) represents the fraction of pages returned for a particular query (qi).
In another aspect of the invention, the cost of issuing the particular query is equal to cq+crP(qi)+cdPnew(qi) where P(qi) represents the fraction of pages returned for a particular query (qi) and Pnew(qi) represents the fraction of new pages returned for a particular query (qi), and where cq represents the cost of submitting the particular query, cr represents the cost of retrieving a results index page, and cd represents the cost for downloading a matching document.
In another aspect of the invention, a system for downloading Hidden Web pages includes a Web crawler for issuing a plurality of queries to one or more site-specific search interfaces containing Hidden Web pages. The Web crawler downloads the Hidden Web pages in response to the queries. The terms used in the queries are obtained from the downloaded Web pages. The system includes a computer configured to apply an algorithm to estimate the efficiency of each potential query term, wherein for each query, the most efficient query term is issued to the site-specific search interface by the Web crawler.
In still another aspect of the invention, the system stores an index of each downloaded Hidden Web page. The system may include a search engine having associated therewith an index of Web pages, wherein at least some of the indexed Web pages are Hidden Web pages.
With reference to the algorithm in
On a theoretical level, the problem of query selection is similar to the set-covering problem in graph theory.
There are, however, two primary difficulties with this problem. First, in a real-world situation, the crawler 4 does not know which Web pages will be returned by any particular query so the subsets of S (in
In one aspect of the invention, the above-identified problems are overcome by using an approximation algorithm that is able to find a near-optimal solution at a reasonable resource (e.g., computational or other resource) cost. The algorithm is based on the fact that while one cannot determine a priori which Web pages will be returned by each query qi that is issued, the method is able to predict how many Web pages will be returned. Based on this information, the algorithm is able to select the quasi-optimum or “quasi-best” queries that cover the particular content of the Website of interest.
In one aspect of the invention, the algorithm is best understood in terms of cost and performance metrics. Given a particular query qi, P(qi) represents the fraction of Web page that will be returned by issuing a particular query qi to the site. For instance, if a Website has 10,000 Hidden Web pages in total and if 3,000 Web pages are returned for the query where qi=“medicine,” then P(qi)=0.3. The intersection of P(q1) and P(q2) (P(q1∩q2)) represents the fraction of pages that are returned from both q1 and q2. Similarly, the union of P(q1) and P(q2) (P(q1∪q2)) represents the fraction of pages that are returned from either q1 or q2.
With respect to the cost component of the algorithm, Cost(qi) is used to represent the cost of issuing the query qi. Depending on the particular scenario, the cost may be measured, for example, in time, network bandwidth, the number of interactions with the site, or a combination or sub-combination of these components. Generally, the algorithm used in accordance with the present invention is independent of the exact cost function.
In a typical search, the query cost consist of a number of factors including the cost for submitting the query to the site, the cost for retrieving the result index page, and the cost associated with downloading the actual Hidden Web pages. Assuming that a particular query incurs a fixed cost of cq, the cost for downloading the result index page (cr) is proportional to the number of matching documents to the query. Similarly, the cost (cd) for downloading matching documents is also fixed. The overall cost of a particular query qi may be represented by Equation 1 below:
In many cases, however, some of the Web pages returned from qi may have already been downloaded from previous queries. In this case, the crawler 4 may skip downloading these documents. Consequently, the cost of qi may be represented by Equation 2 below where Pnew(qi) represents the fraction of new (i.e., unique) documents returned from qi that have not been returned from prior queries:
As explained in more detail below, P(qi) and Pnew(qi) may be estimated to estimate the cost of qi. Generally, since the algorithm employed to download Hidden Web pages is independent of the exact cost function, a generic cost function may be assumed (Cost(qi)). However, when a concrete cost function is needed, cost function in Equation 2 may be employed. Given this, the goal of the crawler 4 may be identified as follows:
Find the set of queries q1, . . . , qn that maximizes:
Under the constraint:
Where t is the maximum download resource that the crawler 4 has available to it.
Given that the goal of the crawler 4 is to download the maximum number of unique Web pages (e.g., documents) from a textual database, the crawler 4 needs to efficiently select a “next” query to issue to the Website. For example, the crawler 4 may select random keywords from, for instance, an English dictionary and issue them to the site-specific search interface 2 (i.e., a random algorithm). Alternatively, a generic document corpus collected elsewhere (e.g., from the Web) may be obtained and a generic frequency distribution of each keyword may be obtained. Based on the generic distribution, the search may begin with the most frequent keyword. A second search could be performed with the second most frequent keyword and so on and so forth until the all download resources are exhausted (i.e., a generic-frequency algorithm). In still another alternative, the Web pages returned from the previous queries issued to the site-specific search interface 2 containing the Hidden Web pages are analyzed and an estimate is made of which keyword is most likely to return the most number of unique Web pages. Based on this estimate, the most promising keyword or term is issued to the site-specific search interface 2. The process is repeated, wherein after each new search, the most desired or optimum search term is determined and then issued to the search interface 2.
The present invention is directed to this last option, namely, the method relies on an adaptive algorithm that identifies the most promising query based on the keywords or terms identified in Hidden Web pages in prior queries. The random algorithm may be considered as the base comparison or control since this algorithm is expected to perform the worst of the three algorithms discussed above.
With respect to the adaptive algorithm, in order to identify the most promising “next” query, the number of estimated unique Hidden Web pages or documents that will be downloaded if a next query qi is issued to a site-specific search interface 2 needs to be estimated. More specifically, assuming that queries q1, . . . , qi−1 have been issued, P(q1∪ . . . ∪qi−1∪qi) needs to be estimated for every potential next query. In estimating this number, P(q1∪ . . . ∪qi−1∪qi) may be rewritten as:
In Equation 6 above, P(q1∪ . . . ∪qi−1) and P(qi|q1∪ . . . ∪qi−1) can be precisely measured by analyzing previously-downloaded pages. First, the union of all Web pages downloaded from q1, . . . , qi−1 is already known (i.e., P(q1∪ . . . ∪qi−1)) because the crawler 4 has already issued terms for q1, . . . , qi−1 and downloaded the resulting Web pages. In addition, the probability that qi appears in the Web pages from q1, . . . , qi−1 (i.e., P(qi|q1∪ . . . ∪qi−1)) can be measured by counting how many times that qi appears in the pages from q1, . . . , qi−1. For example, a query statistics table may be repeatedly updated to efficiently compute this probability. Consequently, one only needs to estimate P(qi) to evaluate P(q1∪ . . . ∪qi).
P(qi) may be estimated using any known techniques. For example, using an independence estimator, one can assume that the appearance of the term qi is independent of the terms q1, . . . , qi−1. Consequently, it can be assumed that P(qi)=P(qi∪q1∪ . . . ∪qi−1). Alternatively, the Zipf estimator technique is able to estimate how many times a particular term occurs in the entire corpus based on a smaller subset of documents from the larger corpus. This method exploits the fact that the frequency of terms inside text collections follows a power law distribution. Thus, if all terms are ranked based on their occurrence frequency (with the most frequent term having a rank of 1, second most frequent having a rank of 2), then the frequency f of a term inside the collection is given by Equation 7 below:
Where r is the rank of the term and α, β, and γ are constants that depend on the text collection. The general idea behind the Zipf estimator technique is to estimate the three parameters α, β, and γ based on the subset of documents (i.e., Web pages) that have been downloaded from previous queries. The estimated parameters are then used to predict the frequency f given the ranking r of a term within the subset. This frequency can thus be used to estimate P(qi). After estimating the values for P(qi) and P(qi|q1∪ . . . ∪qi−1) the value for P(q1∪ . . . ∪qi) can then be estimated.
As stated above, the goal of the algorithm implemented by the crawler 4 is to download the maximum number of unique Hidden Web pages from a database using its limited download resources. Thus, the crawler 4 should select query terms that maximize search efficiency of the collection of Hidden Web pages. In one preferred aspect of the invention, the crawler 4 determines subsequent query terms based on (1) the number of new documents that can be obtained from the query qi, and (2) the cost of issuing the query qi. For example, if two queries, qi and qj, incur the same cost, but qi returns more unique Web pages than qj, then qi is more desirable than qj. Conversely, if qi and qj return the same number of new Web pages, but qi incurs less cost than qj, then qi is more desirable. Consequently, the crawler 4 may use an efficiency metric based on the ratio in Equation 8 shown below to quantify the desirability of a particular search term qi.
In Equation 8, Pnew(qi) represents the amount of new Web pages (e.g., documents or files) returned for a particular query qi. In addition, Cost(qi) represents the cost of issuing the query qi. Generally, the efficiency of a particular query qi measures how many new or unique Web pages are retrieved per unit cost and can be used as an indicator or proxy of how well resources are spend when issuing a particular query qi. In a preferred aspect of the invention, the crawler 4 can estimate the efficiency of every candidate or potential search query term qi and select the one with the highest value.
As seen in
The efficiency of every potential query using the estimation method described above may be used. Specifically, the size of new or unique documents form the query qi, Pnew(qi) is set forth below in Equations 9 and 10.
As stated above, P(qi) may be estimated using, for example, the independence estimator technique or the Zipf estimator technique. In a similar manner, Cost(qi) may be estimated. For example, if Cost(qi) is represented by Equation 11 below, Cost(qi) may be estimated by estimating P(qi) and Pnew(qi):
As seen in Equation 10 above, in estimating the efficiencies of potential queries, there is a need to measure P(qi|q1∪ . . . ∪qi−1) for every potential query qi. This calculation, however, can be very time-consuming if the calculation is repeated from scratch for every query qi, in every iteration of the algorithm. In one preferred aspect of the invention, P(qi|q1∪ . . . ∪qi−1) may be computed efficiently by maintaining and updating a query statistics table 200. The query statistics table 200 permits P(qi|q1∪ . . . ∪qi−1) to be measured by counting how many times the term or keyword qi appears within Web pages or documents downloaded from qi, . . . , qi−1. The count tabulations are maintained in a query statistics table 200, for example, of the type disclosed in
With reference to
In certain Websites, when a query issued by the crawler 4 matches a large number of Web pages, only a small subset or portion is returned to crawler 4. For example, the Open Directory Project allows users to see only up to 10,000 results after a query has been issued. This truncation of the search results impacts the crawler 4 in several ways. First, because the crawler 4 can only retrieve up to a specific number of Web pages per query, the crawler 4 will need to issue more queries which may use up additional resources in order to download the Web pages. Second, the query selection method described herein assumes that for every potential query qi, the crawler 4 will find P(qi|q1∪ . . . ∪qi−1) or the fraction of Web pages in the whole database that contains qi with at least one of q1, . . . , qi−1. However, if the database returned only a portion of the results for any of the q1, . . . , qi−1 then the value of P(qi|q1∪ . . . ∪qi−1) is not accurate and may affect the determination of the next query term or keyword and, potentially, the performance of the crawler 4. Because the crawler 4 cannot retrieve more than the maximum number of results than the Website allows, the crawler 4 has no other choice but to submit additional queries.
There is, however, a way to estimate the correct value of P(qi|q1∪ . . . ∪qi−1) in the case where the Website returns only a portion of the search results.
In Equation 12, P(q1∪ . . . ∪qi) can be found by estimating P(qi) as describe above. In addition, P(qi+1∩(q1∪ . . . ∪qi−1)) and P(qi+1∩qi∩q1∪ . . . ∪qi−1)) may be determined by directly examining the Web pages that have been downloaded by the crawler 4 from queries q1, . . . , qi−1. The term P(qi+1∩qi) is unknown and needs to be estimated. Assuming that qi′ is a random sample of qi, then:
From Equation 13, P(qi+1∩qi) may be calculated and this value may be replaced into Equation 12 to yield P(qi+1|q1∪ . . . ∪qi).
Experiments were performed to evaluate the performance of three different algorithms implemented on the Web crawler 4. The algorithms or policies employed included a random algorithm, a generic-frequency algorithm, and an adaptive algorithm. In the random algorithm a corpus of documents consisting of 5.5 million Web pages were downloaded form 154 Websites of various topics. Search terms or keywords where then selected at random. In order to further investigate how the quality of the potential query term list affects the algorithm, two sets were constructed. A first set included the 16,000 most frequently used terms or words (referred to as random-16k). A second set included the 1,000,000 most frequently used terms or words (referred to as random-1M). The first set has frequent words or terms that appear in a large number of documents and therefore can be considered “high-quality” terms. The second set contains a much larger collection of terms or words, some of which are irrelevant or meaningless (e.g., “xxzyz”).
In the generic-frequency algorithm, the frequency distribution of terms or keywords was computed from the same Web corpus used in the random algorithm. Terms or keywords were selected based on their decreasing frequency with which they appear in the document set with the most frequent term being selected first followed by the second-most frequent term, and so on and so forth. The algorithm did not exclude stop words from the keyword list (e.g., the, is, of, etc.).
The adaptive algorithm, which is the subject of the present invention, learned new keywords or terms in accordance with the selection process described herein. In particular, the crawler 4 identified and selected keywords or terms based on the efficiency metric based on the ratio in Equation 8. To make the experiment and analysis simple, a unit cost was chosen for every query. The goal was to return the maximum number of downloaded Web pages by issuing the fewest number of queries. During this experiment, the independence estimator method was used to estimate P(qi) from the downloaded Web pages.
The three algorithms were then used to crawl and download Hidden Web content from thee Websites having site-specific search interfaces. The Websites used in the experiments included the PubMed Medical Library (http://www.pubmed.org), Amazon.com (http://www.amazon.com), and the Open Directory Project (http://dmoz.org). With respect to the PubMed Website, its collection includes approximately 14 million abstracts of articles in the medical and biomedical fields. The abstracts were considered to be hidden “documents” contained within the site and were the source for each iteration of the adaptive algorithm described herein. The goal was to discover as many unique abstracts as possible by repeatedly querying the site-specific search interface 2 of PubMed. The PubMed Website is considered to be a topic-specific Website because the abstracts contained therein are within the fields of medicine and biology.
In the case of the Amazon.com Website, the crawler 4 is interested in downloading all the Hidden Web pages that contain information on books. The querying by the crawler 4 of the Amazon.com Website is performed through the Software Developer's Kit that Amazon provides for interfacing to its Website, and which returns results in XML form. In this experiment, the generic “keyword” field was used for searching, and as input. For the adaptive algorithm, terms or keywords were extracted from the product descriptions and the text accompanying customer reviews when present in the XML reply. Because Amazon.com does not provide any information on how many books it has in its catalogue, a random sampling was used on the 10-digit ISBN number of the books to estimate the size of the total collection. Out of 10,000 random ISBN numbers queried, 46 were found in the Amazon.com catalogue. Consequently, the size of its book collection was estimated to be 46/10,000*1010=4.6 million books. In addition, the Amazon.com Website imposes an upper limit on the number of results returned by each query, which was set to 32,000.
With respect to the third Hidden Website, the dmoz Open Directory Project, the site maintains hyperlinks to 3.8 million sites together with a brief summary of each listed site. The hyperlinks are searchable through a site-specific keyword search interface 2. Each indexed link together with its brief summary was considered as the “document” of the dmoz Website, and the short summaries were provided to the adaptive algorithm to drive the selection of new keywords for querying. On the dmoz Website, two different Hidden Web crawls were performed. The first was performed on the Website's generic collection of 3.8 million indexed sites, regardless of the category in which they fall into. The second crawl was performed specifically on only a subset of the overall database, namely, the Arts section of the dmoz Website (http://dmoz.org/Arts) which includes approximately 429,000 indexed sites that are relevant to arts, thereby making this crawl topic-specific as in PubMed. In addition, dmoz enforces an upper limit on the number of returned results, which is 10,000 links with their corresponding summaries.
Between the generic-frequency and the adaptive algorithms, the latter algorithm outperforms the former when the site is topic-specific. For example, for the PubMed site (
As seen in
For the generic collections of Amazon.com and the dmoz sites, shown in
As in the case of topic-specific Hidden Websites, the random-based policies exhibit poor performance compared to the other two algorithms when crawling generic sites. For the Amazon.com Website, the random-16K search succeeds in downloading almost 36.7% after issuing 775 queries. For the generic collection of dmoz, the fraction of the collection of links downloaded is 13.5% after the 770th query. Finally, as expected, the random-1M search is even worse than the random-16K search, downloading only 14.5% of Hidden Web pages from Amazon.com and 0.3% from the generic dmoz.
As seen in the experimental results, the adaptive algorithm performs remarkably well in all cases. The crawler 4 using the adaptive algorithm is able to discover and download most of the documents stored in Hidden Websites by issuing the least number of queries. When the collection refers to a specific topic, crawler 4 is able to identify the keywords most relevant to the topic of the site and consequently ask or query with terms that are most likely to return a large number of results. Finally, the random policy performs poorly with respect to its efficiency.
The impact of the selection of the initial choice of the keyword in the adaptive algorithm was also examined for its affect, if any, on the effectiveness on subsequent iterations. The choice of the initial keyword is not done by the selection of the adaptive algorithm itself and has to be manually set, since the contents of the query statistics table 200 has not been populated yet. For this reason, three adaptive Hidden Web crawlers 4 were employed to target the PubMed Website with different seed-words. These seed-words included the word “data,” which returned 1,344,999 documents, the word “information” that returned 308,474 documents, and the word “return” that retrieved 29,707 pages out of total of about 14 million.
These keywords or terms represent varying degrees of term popularity in PubMed, with the first word (i.e., data) being of high popularity, the second word (i.e., information) of medium popularity, and the third word (i.e., return) of low popularity.
The results confirm the observation that the choice of the initial query has minimal effect on the final performance of the adaptive algorithm. The adaptive algorithm approximates the optimal set of queries to use for a particular Website. Once the algorithm has issued a significant number of queries, it has an accurate estimation of the content of the Website, regardless of the initial query. Since this estimation is similar for all runs of the algorithm, the crawlers 4 will use roughly the same queries.
While the Amazon.com and dmoz sites have limits of 32,000 and 10,000 results, respectively, in their result sizes, these limits may be larger than those imposed by other Hidden Websites. In order to investigate how a “tighter” limit in the result size affects the performance of our algorithms, two additional crawls were performed to the generic-dmoz site. Specifically, the generic-frequency and adaptive algorithms were run but retrieved only up to the top 1,000 results for every query. In
In the experimental results described above, the performance evaluation results assumed a simplified cost-model where every query involved a constant cost. Additional experiments were performed to test the performance of the adaptive and generic-frequency algorithms using Equation 2 to drive the query selection process. As discussed above, this query cost model includes the cost for submitting the query to the site, retrieving the result index page, and also the cost associated with downloading the actual Web pages. For these costs, we examined the size of every result in the index page and the sizes of the documents, where cq=100, cr=100, and cd=10000 for the parameters of Equation 2. The test was run on the PubMed Website. The values set forth above that were selected imply that the cost for issuing one query and retrieving one result from the result index page are roughly the same, while the cost for downloading an actual page is 100 times larger. It is believed that these values are reasonable for the PubMed Website.
The web crawler 4 described herein may be used with single attribute databases as well as multi-attribute databases. For example, to generate queries for a multi-attribute database, the crawler 4 may exploit the fact that the site often returns Web pages that contain values for each of the query attributes. For example, when an online bookstore supports queries on title, author and ISBN, the Web pages returned from a query typically contain the title, author and ISBN of corresponding books. Thus, from the returned Web pages the values for each field (e.g., title=“Harry Potter”; author=“J. K. Rowling”; etc.) may be extracted. The frequency of each attribute value may be estimated and the most promising query term or keyword may be chosen for a subsequent query. A primary challenge is to automatically segment the returned pages so that the crawler 4 can identify the sections of the Web pages that present the values corresponding to each attribute. Since many Websites follow limited formatting styles in presenting multiple attributes, the crawler 4 may learn page-segmentation rules automatically from a small set of training examples. For example, most book titles are preceded by the label “Title.” The crawler 4 may use this to identify the text following the word “title” as representative of the books' respective titles.
There are certain practical issues that should be addressed to build a fully automatic Hidden Web crawler 4. For example, the crawler 4 needs to interface correctly with different site-specific search interface 2. In one aspect, the crawler 4 may be pre-programmed or updated periodically with unique rules (e.g., protocol or formatting rules) for each particular Website or groups of Websites having Hidden Web page content. In another aspect, the crawler 4 may be extended with a software component for automatically learning the page-segmentation rules of the interface of a Hidden Web site, from a small set of training example-pages obtained from a Web site. Alternatively, the method proposed in J. Cope et al., Automated discovery of search interfaces on the web, Proceedings of the 14th Australasian Conference on Database Technologies, 2003 may be employed. The content of this publication is incorporated by reference as if set forth fully herein. In addition, some Hidden Websites return their results in batches of, for example, 20 pages so the user has to click on a “next” button or similar link in order to see additional results. In this case, a fully automatic Web crawler 4 should know that the first result index page contains only a partial result and automatically “clicks” the next button or link. Finally, some Hidden Websites may contain an infinite number of Hidden Web pages which do not contribute much significant content (e.g., a calendar with links for every day). Consequently, the Hidden Web crawler 4 should be able to detect that the site does not have much more new or unique content and stop downloading pages from the site. For this purpose, the crawler 4 may include page similarity detection algorithms.
The invention described herein may be implemented in a system for downloading Hidden Web pages. The system includes a Web crawler 4 that issues a plurality of queries to a site-specific search interface 2 containing Hidden Web pages. The Hidden Web pages are downloaded and potential query terms are obtained from that actual content of the downloaded pages. One or more computers 6 or processors are configured to apply an adaptive algorithm to estimate the efficiency of each potential query term. For each subsequent query, the most efficient query term is issued to the site-specific search interface by the Web crawler 4. The system may store an index of each downloaded Hidden Web page such that the pages may be later accessed by a search engine.
As stated above, the crawler 4 utilizes an adaptive algorithm to identify and select an optimal query term for a next search based on the content of the Web pages previously downloaded from the Hidden Website. Experimental evaluation on actual Websites containing Hidden Web content shows that this algorithm has a great potential to rapidly download a significant portion of this hidden content. For example, in certain cases the adaptive algorithm can download more than 90% of a Hidden Website after issuing approximately 100 queries. Given these results, a crawler 4 of the type disclosed herein provides a mechanism to improve the search-engine coverage of the Web as well as the user experience of a Web-based search.
The crawler 4 and search method described herein is applicable to searching multi-lingual Hidden Websites without any additional modification. For example, the crawler 4 may be used to search Hidden Web pages having non-English content. The web crawler 4 is able to do this because the adaptive algorithm “learns” its vocabulary from the Web pages it downloads and is therefore able to discover frequent words that are not necessarily contained in the English dictionary. This is in contrast with the generic-frequency algorithm which is restricted by the language used in the corpus analyzed for the frequency distribution of keywords or terms.
While embodiments of the present invention have been shown and described, various modifications may be made without departing from the scope of the present invention. The invention, therefore, should not be limited, except to the following claims, and their equivalents.