This application related to co-pending application Ser. No. 11/874,579 filed on the same day herewith, and titled “Ranking and Providing Search Results” which is owned by the same assignee of this application.
The use of search engines to locate relevant documents within a database, enterprise intranet, or the Internet has become commonplace. At a very high level, most search engines function by performing three distinct steps: identifying all documents which match the search criteria (the “candidate documents”); ranking the candidate documents based on a predicted relevance; and presenting the results to the user beginning with the most relevant.
The quality of the relevance ranking function is very important to the user's satisfaction with the search engine because the user is not expected to, and in many cases cannot realistically, review the entire set of matching documents. In most cases, the user will only review a relatively small number of those documents and so must be presented the most relevant candidates within that small subset for the search to be successful.
For purposes of comparing the performance of different ranking functions, it is convenient to approximate the overall user satisfaction by a single metric or set of metrics. Typically, the metric is computed over a representative set of queries that are selected by random sampling from the search domain. The metric can be as simple as the average count of relevant documents in the top N (1,5 or 10) results, often referred to as Precision @1, 5, or 10, or a slightly more complicated measure such as Normalized Discounted Cumulative Gain (NDCG).
The quality of the ranking function is dependent primarily on two characteristics: the set of features on which the ranking is based, and the specific algorithm applied to the features. The ranking features are attributes of the candidate documents that contribute to identifying relevance of the document. The ranking algorithm determines how these features are combined together into a single number that can be used to rank order the documents. Typical search engines use an algorithm which relies upon a linear combination of the ranking features. Neural networks have also been applied in the area of Internet searching.
The preferred set of ranking features varies depending on the search domain. Much of the emphasis for search engine development is on Internet searches. However, enterprise s searching of an intranet or document library is also in high demand but requires a different, tailored set of features for optimal results. This is driven primarily by different characteristics of the domain and the documents themselves.
This Summary is provided to introduce in a simplified form a selection of concepts that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Various aspects of the subject matter disclosed herein are related to utilizing a neural network to determine relevancy scores derived from a set of ranking features which have been found to perform well in an enterprise environment.
Other aspects relate to applying a set of transformations to the ranking features prior to input to the neural network. Some of these transformations use constant values which can be configured to tailor the invention to specific environments. If desired, this configuration can be incorporated into the process of training the neural network itself.
The approach describe below has demonstrated improved user satisfaction metrics of approximately 10% for Precision @ 10 and approximately a 4.5 point increase in NDCG, and may be implemented as a computer process, a computing system, or as an article of manufacture such as a computer program product. The computer program product may be a computer storage medium readable by a computer system and encoding a computer program of instructions for executing a computer process. The computer program product may also be a propagated signal on a carrier readable by a computing system and encoding a computer program of instructions for executing a computer process.
A more complete appreciation of the above summary can be obtained by reference to the accompanying drawings, which are briefly summarized below, to the following detailed description of present embodiments, and to the appended claims.
This detailed description is made with reference to the accompanying drawings, which form a part hereof, and which show, by way of illustration, specific exemplary embodiments. These embodiments are described in sufficient detail to enable those skilled in the art to practice what is taught below, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical, and other changes may be made without departing from the spirit or scope of the subject matter. The following detailed description is, therefore, not to be taken in a limiting sense, and its scope is defined only by the appended claims.
Overview
At a very high level of abstraction, a search engine which is used by a user to locate documents follows a process consisting of three steps: searching for candidate documents; ranking the candidate documents; and displaying the ranked documents to the user.
Searching typically involves obtaining a set of keywords from the user to direct the search and then identifying all documents within the search domain which match those keywords. In attempting to match the keywords, the search engine may compare the keywords to a variety of document attributes (i.e., title, body, etc), document metadata, or metadata about the candidate document maintained in another document (i.e., anchor text on hyperlinks to the candidate). The resulting set of candidate documents contains all documents from the search domain which may be relevant. Clearly, some are more likely to be relevant than others.
Ranking the candidate documents attempts to predict the relevance of the documents to the user. This is done by applying a ranking function to one or more characteristics, or ranking features, of the candidate documents to obtain a score for each document. The candidate documents are then ordered by their score in decreasing order of predicted relevance.
Following ranking, the ordered candidate documents are then presented to the user starting with the most relevant. Typically, the list is presented in relatively small groups, such as 10 or 20 at a time. Because of a natural tendency for the user to only review a small number of these groups, it is important that the user find what they consider to be the most relevant documents within this small subset of the candidate documents. User satisfaction with the search engine is thus critically dependent upon the predicted relevance calculated by the ranking function matching the user's perceived relevance so that the user finds what they want as easily as possible. It is the step of ranking the candidate documents which is the focus of the description below and will be discussed now in more detail.
Implementation of the Ranking Function in a Neural Network
The use of neural networks is known in the art. As such, their general principles will not be discussed in detail herein. Only a brief overview will be provided to establish a context for the present subject matter.
It is feasible to implement neural networks either in hardware or software and these embodiments would generally be considered equivalent. As is typical, hardware generally provides increased speed while software provides greater flexibility. The embodiments described herein will be presented as software implementations with the understanding that they encompass an equivalent hardware, or mixed hardware/software solution.
The subject matter may be described in the general context of computer-executable instructions, such as program modules, executed in an appropriate operating environment by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
In its most basic configuration, operating environment 100 typically includes at least one processing unit 102 and memory 104. Depending on the exact configuration and type of computing device, memory 104 may be volatile (such as RAM), non-volatile (such as ROM, flash memory, etc.), or some combination of the two. This most basic configuration is illustrated in
Operating environment 100 typically includes at least some form of computer readable media. Computer readable media can be any available media that can be accessed by processing unit 102 or other devices comprising the operating environment. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information. Communication media typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The operating environment 100 may be a single computer operating in a networked environment using logical connections to one or more remote computers. The remote computer may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above. The logical connections may include any method supported by available communications media. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.
Referring to
At the top layer, 200, the raw data values for the ranking features are made available. These may be any of a variety of data types including numeric values, Boolean flags, character codes, labels etc., and result from steps 300 and 302 in
One exemplary transformation is that for Click Distance (CD). CD is a query-independent ranking feature that measures the number of “clicks” required to reach a given page, or document, from a reference location. It takes advantage of the hierarchical structure of an intranet which usually follows a tree structure, with a root node (often the homepage) and subsequent branches extending to other nodes from that root. Viewing the tree as a graph, the CD is the shortest path between the root, as reference location, and the given page.
In its raw form, CD increases linearly in value the further the candidate document is from the root. Typically, the greater the CD, the less relevant the document is likely to be. Therefore, the formula
is used, where x is the raw value for CD, and k is the saturation constant. This gives a value that decreases with distance rather than increasing. It has the further advantage that the value for k can be modified separately or as part of the neural network training to adjust the rate of decrease providing an additional degree of control over sensitivity to this feature.
Another exemplary transformation is that for URL Depth (UD). Simplistically, UD counts the number of slashes (“/”) in the Uniform Resource Locator (URL) of a network resident document. More accurately, it is how many levels deep into the storage structure (i.e., file system) the document is stored relative to a defined root level. Like CD, UD increases with depth while presumed relevance is decreasing. The same formula
is used to transform UD, but with x representing the raw value for UD and k being a distinct saturation value which is also trainable.
A further exemplary transformation is that applied to enumerated data types. One example of such a data type is file type and another is language. For any given search domain, there are a finite set of file types present and/or supported by the search engine. For example an enterprise intranet may contain word processing documents, spreadsheets, HTML web pages, and other documents. Each of these file types may have a different impact on the relevance of the associated document. An exemplary transformation will convert the single file type value into a set of binary flags, one for each supported file type. Each of these flags is then made available to the neural network individually so that each may be given a separate weight and processed separately. Language (in which the document is written) can be handled in a similar manner, with a single discrete binary flag used to indicate whether or not the document is written in the user's primary language.
After any required transformations are applied, the data is preferably normalized in layer 204, step 306. This technique assures that all input data has the same average value and distribution. In an exemplary embodiment, the data is normalized so that it has an expected value of 0 and a standard deviation of 1. The normalized data is then provided to the neural network input nodes, 206. These nodes do not modify the data in any manner, but serve to distribute the data to each of the hidden nodes, layer 208, as illustrated.
The next step is to process the ranking features in the neural network, beginning with the calculation of the hidden node scores, step 308. In an exemplary embodiment, each of the hidden nodes, hj, calculates a linear combination of the input values using the formula
where hj is the output of hidden node j; xi is the input value from input node i; wij is the weight to be applied to input value xi by hidden node j; and tj is the threshold value for hidden node j, and tan h( ) is the hyperbolic tangent function. Alternatively, other sigmoid functions can be used in place of tan h( ).
The overall relevance ranking score is calculated, step 310, by the single node S in the scoring layer, 210, of the neural network. An exemplary embodiment uses the formula
Where hj is the output of hidden node j as calculated above and w2j is the weight to be applied to hidden node output j.
An advantage of the above approach is that the final score provides a non-linear combination of the inputs (ranking features). This overcomes a disadvantage of the linear combinations which assume independence of the input variables. A clear counter example is CD and UD (defined above). These will not typically be totally independent because it is probable that as UD increases (the document is located deeper in the tree) CD will also increase as more clicks are needed to navigate the tree. Dependencies such as these can be captured using a neural network implementation of the relevance ranking function.
With the scoring process complete, the candidate documents will be rank ordered according to their relevancy score, step 312, and displayed to the user, step 314. Note that step 312 is not essential to the scoring of the documents but performs actual ranking ordering of the documents based on the scoring results. Similarly, step 314 is not part of the ranking process but is a typical application of the results in the context of a search engine.
Relevance Ranking in an Enterprise Environment
One embodiment focuses on searching for documents within an enterprise environment. That is, items located on a company intranet, internal database or similar. In this environment the documents, and the search domain itself, have characteristics which differ sufficiently from the Internet that different relevancy ranking features are needed to achieve optimal results.
One such characteristic is that the documents are far more likely to be maintained by a custodian or at least according to a standard process than is the case of the public access Internet. Because of this, documents are more likely to have associated metadata and that metadata is more likely to be accurate. This characteristic increases the utility of metadata in determining the predicted relevance of documents.
Another distinguishing characteristic is that enterprise document collections tend to be more hierarchically organized than the Internet. This is likely due to these collections being focused on the business of the enterprise in question and tending to be narrower, and deeper, than a broad, general interest collection. It is also more likely that the collection is indexed and cross referenced via hyperlinks since it is being actively maintained.
Because of the more hierarchical nature of enterprise search domains, features such as CD and UD, as defined above, become more viable predictors of relevancy. Where a collection is being actively maintained, the most relevant and authoritative documents will be the most accessible. This implies a short CD and shallow UD. The further a document is from the authoritative references, the less relevant it is likely to be. This argument is even stronger where CD is improved by using a Biased Click Distance. Briefly, Biased Click Distance provides for the CD of documents which have been identified as authoritative to be manually specified as arbitrarily low, thus improving their relevancy score, and the scores for other documents are then calculated based on their distance from these documents, rather than only from the root node.
Another ranking feature which is useful in the enterprise environment is file type. While the Internet will almost certainly contain a wider variety of file types as a raw measure, it is far more uniform as a relative measure. Because of its nature, the Internet can be expected to be dominated by web-related document types (HTML, ASP, etc.). This uniformity limits the value of file type as a relevancy predictor. On the other hand, an enterprise domain is more likely to contain a relatively high percentage of content documents and they are more likely to be retained in their native format. That is, word processing documents will remain as such, rather than being converted to HTML; a CAD file will be available in its original form, rather than being converted to a JPG image; etc. Because of this, file type will serve as an accurate predictor of document relevancy for certain types of information.
Metadata may also be a useful ranking feature in the enterprise environment. As discussed above, metadata is more likely to be complete and accurate in an enterprise. Keywords stored with the document are more likely to be drawn from the vocabulary of the enterprise business. Titles will likely be more meaningful, since they will also be related to the business of the enterprise. The language in which a document is written will be a member of a much smaller set than on the Internet. There may also be custom metadata, such as project name, department name, etc. which are usable to predict relevancy.
Another exemplary approach is to generate a ranking feature which is based on multiple document characteristics and generates a single value which is then used as an input to the neural network. One such ranking feature is known in the art as BM25. A more beneficial version of the BM25 formula is BM25F. This formula accounts for each occurrence of a term in the search query as it appears in each of several predetermined fields associated with the document being scored. Each field has its own weight and associated values (such as length) which are used to generate a field specific score for that occurrence. All field scores are combined for each term and these term scores are combined across all terms in the query to provide an overall score for each document. That overall score is then used as a relevance ranking feature by the neural network.
In one embodiment, a variation of BM25F, known as BM25G, is used. It generates the same results as BM25F but is adapted for use with neural networks. Specifically parameter b is transformed differently so that it is more convenient to take derivatives. This simplifies the task of training the neural network. The formula for BM25G is
where Q is the query string; t is an individual query term (word); D is the document being scored; p is an individual property of the document; N is the total number of documents in the search domain; nt is the number of documents containing term t; DLp is the length of the property p; AVDLp is the average length of the property p; TFt,p is the term t frequency in the property p; wp is the weight for the property p; bp is the length normalization for the property p; and k1 is the curvature.
In the BM25G formula, p, the individual property, refers to fields associated with the document in which the individual search terms may be found. In an exemplary embodiment, the specific fields used include body, title, author, anchor text, URL display name, and extracted title. It should be noted that some of the fields (i.e., body) are part of the document itself, while others may be metadata directly associated with the document and still others (i.e., anchor text specified for a hyperlink to the document) may be metadata which is indirectly associated with the document, but stored with a different document.
One embodiment of a search engine utilizing a neural network for relevance ranking uses one or more of the above ranking features to score documents by predicted relevance. Additional features could also be used. If desired, the set of features could be tailored to the specific environment in which the search engine is used.
Training
A neural network must be trained prior to operational use. One embodiment utilizes LambdaRank training which offers the advantage that new features can be added relatively easily to the ranking function without significantly affecting the training accuracy or training speed. As discussed above, one embodiment will also modify one or more of the values used in the transform functions as a part of the training process adding an additional degree of adaptability.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims. It will be understood by those skilled in the art that many changes in construction and widely differing embodiments and applications will suggest themselves without departing from the scope of the disclosed subject matter.
Number | Name | Date | Kind |
---|---|---|---|
5222236 | Potash et al. | Jun 1993 | A |
5257577 | Clark | Nov 1993 | A |
5594660 | Sung et al. | Jan 1997 | A |
5606609 | Houser et al. | Feb 1997 | A |
5848404 | Hafner et al. | Dec 1998 | A |
5893092 | Driscoll | Apr 1999 | A |
5920859 | Li | Jul 1999 | A |
5933851 | Kojima et al. | Aug 1999 | A |
5960383 | Fleischer | Sep 1999 | A |
5983216 | Kirsch et al. | Nov 1999 | A |
5987457 | Ballard | Nov 1999 | A |
6006225 | Bowman et al. | Dec 1999 | A |
6012053 | Pant et al. | Jan 2000 | A |
6032196 | Monier | Feb 2000 | A |
6041323 | Kubota | Mar 2000 | A |
6070158 | Kirsch et al. | May 2000 | A |
6070191 | Narendran et al. | May 2000 | A |
6098064 | Pirolli et al. | Aug 2000 | A |
6125361 | Chakrabarti et al. | Sep 2000 | A |
6128701 | Malcolm et al. | Oct 2000 | A |
6145003 | Sanu et al. | Nov 2000 | A |
6151624 | Teare et al. | Nov 2000 | A |
6167369 | Schulze | Dec 2000 | A |
6182085 | Eichstaedt et al. | Jan 2001 | B1 |
6182113 | Narayanaswami | Jan 2001 | B1 |
6185558 | Bowman et al. | Feb 2001 | B1 |
6202058 | Rose et al. | Mar 2001 | B1 |
6208988 | Schultz | Mar 2001 | B1 |
6216123 | Robertson et al. | Apr 2001 | B1 |
6222559 | Asano et al. | Apr 2001 | B1 |
6240407 | Chang et al. | May 2001 | B1 |
6240408 | Kaufman | May 2001 | B1 |
6247013 | Morimoto | Jun 2001 | B1 |
6263364 | Najork et al. | Jul 2001 | B1 |
6285367 | Abrams et al. | Sep 2001 | B1 |
6285999 | Page | Sep 2001 | B1 |
6304864 | Liddy et al. | Oct 2001 | B1 |
6317741 | Burrows | Nov 2001 | B1 |
6327590 | Chidlovski et al. | Dec 2001 | B1 |
6349308 | Whang et al. | Feb 2002 | B1 |
6351467 | Dillon | Feb 2002 | B1 |
6351755 | Najork et al. | Feb 2002 | B1 |
6360215 | Judd et al. | Mar 2002 | B1 |
6385602 | Tso et al. | May 2002 | B1 |
6389436 | Chakrabarti et al. | May 2002 | B1 |
6418433 | Chakrabarti et al. | Jul 2002 | B1 |
6418452 | Kraft et al. | Jul 2002 | B1 |
6418453 | Kraft et al. | Jul 2002 | B1 |
6442606 | Subbaroyan et al. | Aug 2002 | B1 |
6473752 | Fleming, III | Oct 2002 | B1 |
6484204 | Rabinovich | Nov 2002 | B1 |
6516312 | Kraft et al. | Feb 2003 | B1 |
6539376 | Sundaresan et al. | Mar 2003 | B1 |
6546388 | Edlund et al. | Apr 2003 | B1 |
6547829 | Meyerzon et al. | Apr 2003 | B1 |
6549896 | Candan et al. | Apr 2003 | B1 |
6549897 | Katariya et al. | Apr 2003 | B1 |
6553364 | Wu | Apr 2003 | B1 |
6594682 | Peterson et al. | Jul 2003 | B2 |
6598047 | Russell et al. | Jul 2003 | B1 |
6598051 | Wiener et al. | Jul 2003 | B1 |
6601075 | Huang et al. | Jul 2003 | B1 |
6622140 | Kantrowitz | Sep 2003 | B1 |
6628304 | Mitchell et al. | Sep 2003 | B2 |
6633867 | Kraft et al. | Oct 2003 | B1 |
6633868 | Min et al. | Oct 2003 | B1 |
6636853 | Stephens | Oct 2003 | B1 |
6638314 | Meyerzon et al. | Oct 2003 | B1 |
6671683 | Kanno | Dec 2003 | B2 |
6701318 | Fox et al. | Mar 2004 | B2 |
6718324 | Edlund et al. | Apr 2004 | B2 |
6718365 | Dutta | Apr 2004 | B1 |
6738764 | Mao et al. | May 2004 | B2 |
6763362 | McKeeth | Jul 2004 | B2 |
6766316 | Caudill et al. | Jul 2004 | B2 |
6766422 | Beyda | Jul 2004 | B2 |
6775659 | Clifton-Bligh | Aug 2004 | B2 |
6775664 | Lang et al. | Aug 2004 | B2 |
6778997 | Sundaresan et al. | Aug 2004 | B2 |
6829606 | Ripley | Dec 2004 | B2 |
6859800 | Roche et al. | Feb 2005 | B1 |
6862710 | Marchisio | Mar 2005 | B1 |
6868411 | Shanahan | Mar 2005 | B2 |
6871202 | Broder | Mar 2005 | B2 |
6883135 | Obata et al. | Apr 2005 | B1 |
6886010 | Kostoff | Apr 2005 | B2 |
6886129 | Raghavan et al. | Apr 2005 | B1 |
6910029 | Sundaresan | Jun 2005 | B1 |
6931397 | Sundaresan | Aug 2005 | B1 |
6934714 | Meinig | Aug 2005 | B2 |
6944609 | Witbrock | Sep 2005 | B2 |
6947930 | Anick et al. | Sep 2005 | B2 |
6959326 | Day et al. | Oct 2005 | B1 |
6973490 | Robertson et al. | Dec 2005 | B1 |
6990628 | Palmer et al. | Jan 2006 | B1 |
7016540 | Gong et al. | Mar 2006 | B1 |
7028029 | Kamvar et al. | Apr 2006 | B2 |
7039234 | Geidl et al. | May 2006 | B2 |
7051023 | Kapur et al. | May 2006 | B2 |
7072888 | Perkins | Jul 2006 | B1 |
7076483 | Preda et al. | Jul 2006 | B2 |
7080073 | Jiang et al. | Jul 2006 | B1 |
7107218 | Preston | Sep 2006 | B1 |
7152059 | Monteverde | Dec 2006 | B2 |
7181438 | Szabo | Feb 2007 | B1 |
7228301 | Meyerzon et al. | Jun 2007 | B2 |
7231399 | Bem et al. | Jun 2007 | B1 |
7243102 | Naam et al. | Jul 2007 | B1 |
7246128 | Jordahl | Jul 2007 | B2 |
7257574 | Parikh | Aug 2007 | B2 |
7257577 | Fagin et al. | Aug 2007 | B2 |
7260573 | Jeh et al. | Aug 2007 | B1 |
7281002 | Farrell | Oct 2007 | B2 |
7308643 | Zhu et al. | Dec 2007 | B1 |
7328401 | Obata et al. | Feb 2008 | B2 |
7346604 | Bharat et al. | Mar 2008 | B1 |
7346839 | Acharya et al. | Mar 2008 | B2 |
7356530 | Kim et al. | Apr 2008 | B2 |
7386527 | Harris et al. | Jun 2008 | B2 |
7428530 | Ramarathnam et al. | Sep 2008 | B2 |
7496561 | Caudill et al. | Feb 2009 | B2 |
7519529 | Horvitz | Apr 2009 | B1 |
7599917 | Meyerzon et al. | Oct 2009 | B2 |
7685084 | Sisk et al. | Mar 2010 | B2 |
7689531 | Diao et al. | Mar 2010 | B1 |
7716225 | Dean et al. | May 2010 | B1 |
20010042076 | Fukuda | Nov 2001 | A1 |
20020055940 | Elkan | May 2002 | A1 |
20020062323 | Takatori et al. | May 2002 | A1 |
20020078045 | Dutta | Jun 2002 | A1 |
20020099694 | Diamond et al. | Jul 2002 | A1 |
20020103798 | Abrol et al. | Aug 2002 | A1 |
20020107861 | Clendinning et al. | Aug 2002 | A1 |
20020107886 | Gentner et al. | Aug 2002 | A1 |
20020129014 | Kim et al. | Sep 2002 | A1 |
20020169595 | Agichtein et al. | Nov 2002 | A1 |
20020169770 | Kim et al. | Nov 2002 | A1 |
20030037074 | Dwork et al. | Feb 2003 | A1 |
20030053084 | Geidl et al. | Mar 2003 | A1 |
20030055810 | Cragun et al. | Mar 2003 | A1 |
20030061201 | Grefenstette et al. | Mar 2003 | A1 |
20030065706 | Smyth et al. | Apr 2003 | A1 |
20030074368 | Schuetze et al. | Apr 2003 | A1 |
20030088545 | Subramaniam et al. | May 2003 | A1 |
20030208482 | Kim et al. | Nov 2003 | A1 |
20030217007 | Fukushima et al. | Nov 2003 | A1 |
20030217047 | Marchisio | Nov 2003 | A1 |
20030217052 | Rubenczyk et al. | Nov 2003 | A1 |
20040003028 | Emmett et al. | Jan 2004 | A1 |
20040006559 | Gange et al. | Jan 2004 | A1 |
20040049766 | Bloch et al. | Mar 2004 | A1 |
20040093328 | Damle | May 2004 | A1 |
20040111408 | Caudill et al. | Jun 2004 | A1 |
20040117351 | Challapalli et al. | Jun 2004 | A1 |
20040148278 | Milo et al. | Jul 2004 | A1 |
20040181515 | Ullmann et al. | Sep 2004 | A1 |
20040186827 | Anick et al. | Sep 2004 | A1 |
20040194099 | Lamping et al. | Sep 2004 | A1 |
20040199497 | Timmons | Oct 2004 | A1 |
20040205497 | Alexander et al. | Oct 2004 | A1 |
20040215606 | Cossock | Oct 2004 | A1 |
20040215664 | Hennings et al. | Oct 2004 | A1 |
20040254932 | Gupta et al. | Dec 2004 | A1 |
20050033742 | Kamvar et al. | Feb 2005 | A1 |
20050044071 | Cho et al. | Feb 2005 | A1 |
20050055340 | Dresden | Mar 2005 | A1 |
20050055347 | Cho et al. | Mar 2005 | A9 |
20050060186 | Blowers et al. | Mar 2005 | A1 |
20050060304 | Parikh | Mar 2005 | A1 |
20050060311 | Tong et al. | Mar 2005 | A1 |
20050071328 | Lawrence | Mar 2005 | A1 |
20050071741 | Acharya et al. | Mar 2005 | A1 |
20050086192 | Kodama | Apr 2005 | A1 |
20050086206 | Balasubramanian et al. | Apr 2005 | A1 |
20050086583 | Obata et al. | Apr 2005 | A1 |
20050089215 | Staelin et al. | Apr 2005 | A1 |
20050144162 | Liang | Jun 2005 | A1 |
20050154746 | Liu et al. | Jul 2005 | A1 |
20050165781 | Kraft et al. | Jul 2005 | A1 |
20050187965 | Abajian | Aug 2005 | A1 |
20050192936 | Meek et al. | Sep 2005 | A1 |
20050192955 | Farrell | Sep 2005 | A1 |
20050210006 | Robertson et al. | Sep 2005 | A1 |
20050216533 | Berkhin | Sep 2005 | A1 |
20050240580 | Zamir et al. | Oct 2005 | A1 |
20050251499 | Huang | Nov 2005 | A1 |
20050262050 | Fagin et al. | Nov 2005 | A1 |
20050283473 | Rousso et al. | Dec 2005 | A1 |
20060036598 | Wu | Feb 2006 | A1 |
20060047649 | Liang | Mar 2006 | A1 |
20060069982 | Petriuc | Mar 2006 | A1 |
20060074871 | Meyerzon et al. | Apr 2006 | A1 |
20060074903 | Meyerzon et al. | Apr 2006 | A1 |
20060136411 | Meyerzon et al. | Jun 2006 | A1 |
20060161534 | Carson et al. | Jul 2006 | A1 |
20060173560 | Widrow | Aug 2006 | A1 |
20060195440 | Burges et al. | Aug 2006 | A1 |
20060200460 | Meyerzon et al. | Sep 2006 | A1 |
20060206460 | Gadkari | Sep 2006 | A1 |
20060206476 | Kapur et al. | Sep 2006 | A1 |
20060282306 | Thissen-Roe | Dec 2006 | A1 |
20060282455 | Lee et al. | Dec 2006 | A1 |
20060287993 | Yao et al. | Dec 2006 | A1 |
20060294100 | Meyerzon et al. | Dec 2006 | A1 |
20070038616 | Guha | Feb 2007 | A1 |
20070038622 | Meyerzon et al. | Feb 2007 | A1 |
20070073748 | Barney | Mar 2007 | A1 |
20070106659 | Lu et al. | May 2007 | A1 |
20070150473 | Li et al. | Jun 2007 | A1 |
20070198459 | Boone et al. | Aug 2007 | A1 |
20070276829 | Wang et al. | Nov 2007 | A1 |
20080140641 | Wang | Jun 2008 | A1 |
20080195596 | Sisk et al. | Aug 2008 | A1 |
Number | Date | Country |
---|---|---|
10029644 | Jan 2002 | DE |
0950961 | Oct 1999 | EP |
0950961 | Oct 1999 | EP |
1050830 | Apr 2000 | EP |
1120717 | Aug 2001 | EP |
00309121 | Jul 2002 | EP |
1282060 | Feb 2003 | EP |
00309121.2-1522 | Jul 2003 | EP |
00309121.2-1527 | Jun 2004 | EP |
1557770 | Jul 2005 | EP |
05105048 | Jan 2006 | EP |
05105110 | Aug 2006 | EP |
PCTUS2006031965 | Jan 2007 | EP |
00309121.2-1527 | Feb 2007 | EP |
10091638 | Apr 1998 | JP |
11328191 | Nov 1999 | JP |
2002-091843 | Mar 2002 | JP |
2003-248696 | Sep 2003 | JP |
10-2002-0015838 | Mar 2002 | KR |
10-2003-0081209 | Oct 2003 | KR |
10-2006-0116042 | Nov 2006 | KR |
Number | Date | Country | |
---|---|---|---|
20090106223 A1 | Apr 2009 | US |