1. Field of the Invention
This invention relates generally to systems and methods for retrieving electronic documents using an image or portion of the electronic document. More particularly, the present invention is related to systems and methods for retrieving electronic documents by converting the electronic documents to synthetic text, converting an input image to synthetic text, and comparing the synthetic text for a match.
2. Description of the Related Art
The retrieval of electronic documents in the presence of noise or only given a very small part of the document is a very difficult problem. The larger the collection of documents, the more difficult the problem is. For example, retrieving an electronic text document given a blurry or illegible image of a portion of a printed page taken with a camera cell phone is difficult when the corpus of is large. This problem 100 is illustrated by
One attempt by the prior art to solve this problem is to extract features of the image and use an index to retrieve documents containing a majority of the features. For example, inverted files are used to index individual image features. However, the features do not provide enough context information for consistent and accurate matches. Moreover, because of the poor quality of the input image it is often difficult to identify the features in the input image. Even when features can be identified in the input image, the noise degrades the information such that it is often not sufficient to find a matching electronic document. In other words, the features are incorrectly recognized leading matches to the wrong documents.
Another approach is to apply Optical Character Recognition (OCR) on the input image and the use the output of the OCR process to search the text strings of in the document. However, this suffers from the same problems noted above, namely that the image quality is so poor that OCR cannot be effectively performed. Even when it is performed, the error rate in the recognition is so high as to make the search ineffective because the matching documents are so unrelated to the original image.
The present invention overcomes the deficiencies of the prior art with a system for retrieving electronic documents by converting them to synthetic text. The present invention is particularly advantageous because it is able to match images that include a high level of noise even from a small portion of the original document to an electronic version of the document from which it was created. In other words, the present invention provides a system that extracts images features that can be reliably recognized on blurry images and yet sufficiently discriminate to differentiate between documents. The present invention also provides a computationally efficient indexing mechanism that searches for matching documents that is unaffected by features that have noise and relies on feature location in the sample image and the document.
The system of the present invention converts electronic documents to plain text documents in a synthetic language to be able to leverage existing text document retrieval algorithms that are very fast and scalable, thus enabling search of arbitrary electronic documents at text search speeds. The present invention advantageously provides full true mapping of the electronic document to plain text where the plain text is in a synthetic language and where the synthetic text representation of the document alone is sufficient to perform retrieval. More specifically, the synthetic text does not represent the natural language content of the original document if any, in contrast to OCR. The present invention relies on the two-dimensional information in documents and encodes two-dimensional structures into a one-dimensional synthetic language such that two-dimensional documents can be searched at text search speed. In one embodiment, the system comprises: an indexing module, a retrieval module, an encoder, a quantization module, a retrieval engine and a control module coupled by a bus. A number of electronic documents are first indexed by the indexing module and stored as a synthetic text library. The retrieval module then converts an input image to synthetic text and searches for matches to the synthetic text in the synthetic text library. The matches can be in turn used to retrieve the corresponding electronic documents. It should be noted that a plurality of matches and corresponding electronic documents may be retrieved ranked by order according the similarity of the synthetic text.
In one or more embodiments, the present invention includes a method for indexing documents by converting them to synthetic text, and a method for retrieving documents by converting an image to synthetic text and comparing the synthetic text to documents that have been converted to synthetic text for a match.
The features and advantages described herein are not all-inclusive, and many additional features and advantages will be apparent to one of ordinary skill in the art in view of the figures and description. Moreover, it should be noted that the language used in the specification has been principally selected for readability and instructional purposes, and not to limit the scope of the inventive subject matter.
The invention is illustrated by way of example, and not by way of limitation in the figures of the accompanying drawings in which like reference numerals are used to refer to similar elements.
A system and methods for converting electronic documents to synthetic text, and using the synthetic text for retrieving electronic documents are described below. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the invention. It will be apparent, however, to one skilled in the art that the invention can be practiced without these specific details. In other instances, structures and devices are shown in block diagram form in order to avoid obscuring the invention.
Reference in the specification to “one embodiment,” “an embodiment” or “the embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
Some portions of the detailed descriptions that follow are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing” or “computing” or “calculating” or “determining” or “displaying” or the like, refer to the action and processes of a computer system, a personal digital assistant (PDA), a cellular telephone or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
The present invention also relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions, each coupled to a computer system bus.
Finally, the algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems may be used with programs in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will appear from the description below. In addition, the present invention is not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the invention as described herein.
System
Referring now also to
The control unit 250 comprises an arithmetic logic unit, a microprocessor, a general purpose computer or some other information appliance equipped to provide electronic display signals to display device 210. In one embodiment, the control unit 250 comprises a general purpose computer having a graphical user interface, which may be generated by, for example, a program written in Java running on top of an operating system like WINDOWS® or UNIX®.
Still referring to
Processor 202 processes data signals and may comprise various computing architectures including a complex instruction set computer (CISC) architecture, a reduced instruction set computer (RISC) architecture, or an architecture implementing a one or more of instruction sets. Although only a single processor is shown in
Main memory 204 stores instructions and/or data that may be executed by processor 202. The instructions and/or data may comprise code for performing any and/or all of the techniques described herein. Main memory 204 may be a dynamic random access memory (DRAM) device, a static random access memory (SRAM) device, or some other memory device known in the art. The memory 204 is described in more detail below with reference to
Data storage device 206 stores data and instructions for processor 202 and comprises one or more devices including a hard disk drive, a floppy disk drive, a CD-ROM device, a DVD-ROM device, a DVD-RAM device, a DVD-RW device, a flash memory device, or some other mass storage device known in the art. In one embodiment, the data storage device 206 includes data for presentation on the display device 210. In another embodiment, the data storage device 206 is a disk array separate from the system 150 but communicatively coupled for high speed access.
System bus 208 represents a shared bus for communicating information and data throughout control unit 250. System bus 208 may represent one or more buses including an industry standard architecture (ISA) bus, a peripheral component interconnect (PCI) bus, a universal serial bus (USB), or some other bus known in the art to provide similar functionality. Additional components coupled to control unit 250 through system bus 208 include the display device 210, the keyboard 212, the cursor control 214, the communication device 216 and the I/O device(s) 218.
The display device 210 represents any device equipped to display electronic images and data as described herein. In one embodiment, the display device 210 is a liquid crystal display (LCD) and light emitting diodes (LEDs) similar to those on many conventional display system for computers to provide a display area and status feedback, operation settings and other information to the user. In other embodiments, the display device 210 may be cathode ray tube type display.
Keyboard 212 represents an alphanumeric input device coupled to control unit 250 to communicate information and command selections to processor 202. The keyboard 212 can be a QWERTY keyboard, a key pad, or representations of such created on a touch screen.
Cursor control 214 represents a user input device equipped to communicate positional data as well as command selections to processor 202. Cursor control 214 may include a trackball, a stylus, a pen, a touch screen, cursor direction keys or other mechanisms to cause movement of a cursor. In one embodiment, cursor control 214 is a digitizer in which a touch-sensitive, transparent panel covers the screen of display device 210.
The system 150 may optionally include the communication devices 216 and one or more input/output (I/O) devices 218 such as described below.
The communication device 216 may be a network controller that links control unit 250 to a network (not shown) via signal line 220 that may include multiple processing systems. The network of processing systems may comprise a local area network (LAN), a wide area network (WAN) (e.g., the Internet), and/or any other interconnected data path across which multiple devices may communicate. The control unit 250 also has other conventional connections to other systems such as a network for distribution of files (media objects) using standard network protocols such as TCP/IP, http, https, and SMTP as will be understood to those skilled in the art. The communication device 216 in other embodiments includes a Bluetooth® transceivers, wireless transceivers, or infrared transceivers for communication along a channel 220.
One or more I/O devices 218 are coupled to the bus 208. These I/O devices 218 are part of system 150 in one embodiment. The I/O device 218 may also include audio input/output device equipped to receive audio input via a microphone and transmit audio output via speakers. Optionally, I/O audio device 218 may contain one or more analog-to-digital or digital-to-analog converters, and/or one or more digital signal processors to facilitate audio processing. In one embodiment, I/O device 418 is a general purpose audio add-in/expansion card designed for use within a general purpose computer system. In yet another embodiment, the input/output device is a camera for the capture of still and video images and sound.
It should be apparent to one skilled in the art that the system 150 may include more or less components than those shown in
The operating system 302 is one of a conventional type such as WINDOWS®, SOLARIS®, BREW®, SYMBIAN®, MAC-OS or a LINUX® based operating system.
The memory 204 may also include one or more application programs 304 including, without limitation, drawing applications, word processing applications, electronic mail applications, financial applications and web browser applications.
The indexing module 306 includes software and routines for indexing an original electronic document or an image in accordance with the present invention. The indexing module 306 begins with an electronic version of a document. This can be the original document, an image of the original document, or alternatively it can be a portion of an image of the original document with a high level of noise. Basically, the indexing module 306 generates synthetic text for an electronic document it receives. The indexing module 306 also associates documents, pages and locations within a page for the synthetic text generated. This allows the synthetic text to be used is as an index back to the original electronic document. In one embodiment, the indexing module 306 receives an electronic document, identifies bounding boxes for text and other content within the electronic document, and converts the bounding boxes to synthetic text. In one embodiment, a synthetic word is created for every bounding box in the image. Various implementations for the indexing module 306 are described in more detail below with reference to
The retrieval module 308 includes software and routines for retrieving one or more documents corresponding to an input image. The retrieval module 308 works in conjunction with the indexing module 306 to convert an input image into synthetic text. The retrieval module 308 uses the synthetic text string generated by processing the input image with the indexing module 306 to search the indexed document storage 310. The retrieval module 308 is communicatively coupled to cooperate with the retrieval engine 318 and provides the searching functionality. Additionally, the retrieval module 308 retrieves one or more original electronic documents corresponding to portions of matching synthetic text from the synthetics text library 160. In one embodiment, the retrieval module 308 presents an ordered list of the documents most likely to match the input image. The functionality of the retrieval module 308 is described in more detail below with reference to
The indexed document storage 310 is storage of a conventional type. It may be a combination of both volatile and non volatile storage. The indexed document storage 310 stores original electronic images or documents, corresponding synthetic text and an index between the synthetic text and the original electronic images or documents. For example, in one embodiment the indexed document storage includes: an electronic document in a computer readable form such as an XML file, synthetic text corresponding to the XML file and an index between the XML file and synthetic text. In another embodiment for example, the indexed document storage may include an original application file (E.g., an MS-Word file), an image file representing how the application file would be printed or displayed, synthetic text and one or more indexes between a synthetic text and the application file.
The snake encoder 312 and SIFT encoder 314 are two exemplary encoders that can be used by the present invention to generate the synthetic text. These encoders 312, 314 can be used individually or collectively. Those skilled in the art will recognize that a variety of other types of encoders may be used to generate the synthetic text from the input images. In another embodiment, a spiral encoder is used. A spiral encoder is similar to the snake encoder described below in that it is based on bounding boxes and produces one synthetic word for each bounding box. It uses the same principle of creating a path starting at each word, and then encoding this path. The path is a spiral around the word, connecting the centers of words, and what is encoded are the angles of the segments, and/or the relative lengths of the 2 words joined by the segments, and/or the aspect ratio of bounding boxes, or other similar parameters that will be understood by those skilled in the art. In yet another embodiment, the encoder is a graph encoder. Graph encoders are a family of encoders based on bounding boxes that produces a graph for each bounding box. Although some bounding boxes may not be used in different variations, or a graph is made for each pair of words, or group of three words, or the graph could be non-continuous, or not be a path—e.g. Star shaped and encodes some parameters of this graph as features. Snake encoders and spiral encoders are two embodiments of graph encoders.
The snake encoder 312 includes software and routines for encoding an image into synthetic text. In particular, the snake encoder 312 is adapted for encoding documents including western character-based languages. In particular, snake coding converts a page of written Western scripts into a sequence of feature vectors. So a sequence of few of these vectors extracted from an image of a patch of text in which bounding boxes of words can be extracted can be used to uniquely identify the original location within a document database. Referring now also to
In one embodiment, every page of every document that is wanted in the index undergoes encoding according to the process described above. This means that every bounding box on a page produces a synthetic word. For printed documents, the bounding boxes can be obtained from the printer driver, which is typically more efficient than two dimensional image processing. This is the synthetic text resulting from encoding each page is indexed and stored in the indexed document storage 310.
The SIFT encoder 314 includes software routines for encoding an image into synthetic text. In particular, the SIFT encoder 314 is adapted for encoding documents including eastern ideographic languages. The SIFT encoder 314 performs a function similar to that of the snake encoder 312. The SIFT encoder 314 generates feature vectors based on Scale Invariant Feature Transformation (SIFT) features in a document. In particular, SIFT features align along the lines of text when applied to documents contain Asian scripts of the giving making them suitable for the present invention. Referring now also to
Those skilled in the art will recognize that various other encodings may be used in place of the snake encoder 312 or the SIFT encoder 314. Snake coding has the fundamental property of being able to encode a two-dimensional layout into a one-dimensional text string. The key principle is to encode vertical layout information as a sequence of letters within a word, and horizontal information as a concatenation of words. This is similar to storing a 2D matrix as a vector by storing one column after another. Other encodings are possible with the same property. Also encodings that can encode patches containing images or a mixture of images and text are possible. Snake coding uses a local approach to quantize feature vectors (i.e. the angles in the path) into words. Namely is angle is quantized separately. In alternate embodiments, a mechanism of encoding groups of features or words based on classifier may be used. In this approach a classifier is trained to classify a given path into one of a few thousand categories. Then a word encoding the category would actually be used to store the path. The classifier would be built using unsupervised clustering given many observed paths as training examples. In a more sophisticated instance many paths corresponding to the same layout, obtained through artificial imaging of a patch, are presented to the classifier with the constraint that they should be assigned to the same cluster, with the goal of achieving a classifier more robust to image noise. Similarly the classes for which instances are confused in the validation phase could be given “similar” words, so that when performing text search the two classes would be considered close under some form of edit distance (this already happens naturally in the current implementation of snake coding.)
The quantization module 316 includes software routines for cooperating with the snake encoder 312 or the SIFT encoder 314 to adjust and optimize the encoding. In one embodiment, the quantization of the angles (converting angles to characters) is done by quantizing linearly the tangent of the angle (y=x) to avoid trigonometric computations. For example, one quantization is shown below in Table 1.
The actual size of the bins can be adjusted. Coarser bins will produce fewer errors when quantizing bounding boxes are obtained from a noisy image, but also less unique patterns. Such a coarser quantization is shown in Table 2 below.
In the Snake encoder, noise affects differently even and odd characters as they encode different geometric properties. Thus in one embodiment a different quantization of odd and even characters is provided. In one embodiment, a sensitivity analysis is performed to produce the quantization as different bins may experience different noise levels due to the geometry of the problem. In yet another embodiment, the present invention can employ quantization at multiple levels. For example, the library of synthetic text may be created such that includes two levels of quantization for each document. The first level quantization is of course, over inclusive level quantization. The second level quantization is that a finer level with the increased accuracy. The retrieval module 308 could then operate by first using the first level quantization to identify a subset of documents in the corpus of documents stored in the indexed document storage 310. Then the second level quantization could be used to retrieve yet a smaller subset of documents from the identified first subset to increase the accuracy and speed at which documents could be recognized.
The retrieval engine 318 is software and routines for comparing a string of synthetic text to a library of synthetic text. One of the particular advantages of the present invention is that it is able to leverage and scale upon existing search engine technology. Thus the retrieval engine 318 may be any more variety of commercial search engines presently available such as from Google, Yahoo, Overture, etc. Any search engine capable of searching for a text string and returning results with a page rank order may be used. The retrieval engine 318 receives a string of synthetic text generated by the indexing module 306 and searches for matching patterns in the synthetic library 160 stored in the indexed document storage 310. The retrieval engine 318, in one embodiment, interacts and is under the control of the retrieval module 308 to perform the image matching of the present invention.
The control module 320 is software routines for controlling the processes of the present invention. In particular, the control module 320 interacts with the other components of the memory unit 204 in accordance with the methods that are described below with reference to
Methods
Referring now to
Referring now to
Referring now to
Referring now to
Those skilled in the art will recognize that the present invention can be enhanced by employing different search strategies. The description above has assumed the use of a conventional search engine and input of the synthetic text generated from processing the input image patch. However, when an image is taken, a paragraph is produced in a new lexicon. This paragraph constitutes the query by which the original document is retrieved. However when presented to the text search engine, it may be advantageous to add words to the query incrementally using previous results to refine the query. For example, alternate spellings (e.g. due to likely quantization errors when a value is in the proximity of a quantization boundary) can be created and input to the search engine. Such alternate search strategies can be optimized by considering 1) the need for prefix search, as the lines visible in a patch may not reach far down enough in the page to produce the complete word; 2) the redundancy in the encoding. For example typically when using a snake encoder, the top two lines in the patch contain most of the information and thus it may be sufficient to submit them as query; and 3) the possibility that noise may alter some letters of the encoding in a predictable way, for example because the value was close to the quantization boundary.
A specific modification to the above embodiment is to employ spelling variations in. For example, likely spelling variations for every term in a spiral coding query can be used to increase accuracy. This approach considers the distance of the floating point features encoded in each term to the quantization boundary that determines the letter that the given feature will be encoded as. Features that are closer to the quantization boundaries are more likely to be changed by noisy imaging. Using this new approach fewer alternative spellings are generated, thus decreasing the number and score of false positives. This improvement can be used to increasing the speed of recognition (because fewer spelling variations are tested), and/or to increase scalability maintaining the number of spelling variations per term approximately constant (query time and recognition rate will also stay approximately constant.) This can be achieved increasing the number of bits per encoded feature, which will increase the misspelling rate, but also the uniqueness of each term.
The foregoing description of the embodiments of the present invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the present invention to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. For example, the systems and methods of the present invention may be used for other applications such as but not limited to comparing music, comparing fingerprint signatures, or comparing images of faces. In all these other applications, the original input is converted to text compared to a library of synthetic text. Specifically, a very small clip of music may be converted to synthetic text where notes are converted to characters inappropriately grouped into words and then compared to a library of music that has been converted to synthetic text to determine a match. Similarly, fingerprint matching can be ordered and thus the method can be applied using a procedure analogous to that described above for Asian characters. It is intended that the scope of the present invention be limited not by this detailed description, but rather by the claims of this application. As will be understood by those familiar with the art, the present invention may be embodied in other specific forms without departing from the spirit or essential characteristics thereof. Likewise, the particular naming and division of the modules, routines, features, attributes, methodologies and other aspects are not mandatory or significant, and the mechanisms that implement the present invention or its features may have different names, divisions and/or formats. Accordingly, the disclosure of the present invention is intended to be illustrative, but not limiting, of the scope of the present invention, which is set forth in the following claims.
Number | Name | Date | Kind |
---|---|---|---|
1915993 | Handel | Jun 1933 | A |
4759075 | Lipkie et al. | Jul 1988 | A |
5027421 | Kanno | Jun 1991 | A |
5035302 | Thangavelu | Jul 1991 | A |
5077805 | Tan | Dec 1991 | A |
5109439 | Froessl | Apr 1992 | A |
5263100 | Kim et al. | Nov 1993 | A |
5392447 | Schlack et al. | Feb 1995 | A |
5416892 | Loken-Kim | May 1995 | A |
5432864 | Lu et al. | Jul 1995 | A |
5465353 | Hull et al. | Nov 1995 | A |
5493689 | Waclawsky et al. | Feb 1996 | A |
5546502 | Hart et al. | Aug 1996 | A |
5553217 | Hart et al. | Sep 1996 | A |
5555556 | Ozaki | Sep 1996 | A |
5579471 | Barber et al. | Nov 1996 | A |
5706097 | Schelling et al. | Jan 1998 | A |
5752055 | Redpath et al. | May 1998 | A |
5761344 | Al-Hussein | Jun 1998 | A |
5764277 | Loui et al. | Jun 1998 | A |
5806005 | Hull et al. | Sep 1998 | A |
5832474 | Lopresti et al. | Nov 1998 | A |
5832530 | Paknad et al. | Nov 1998 | A |
5842194 | Arbuckle | Nov 1998 | A |
5873077 | Kanoh et al. | Feb 1999 | A |
5892843 | Zhou et al. | Apr 1999 | A |
5899999 | De Bonet | May 1999 | A |
5905502 | Deering | May 1999 | A |
5918012 | Astiz et al. | Jun 1999 | A |
5956468 | Ancin | Sep 1999 | A |
5968175 | Morishita et al. | Oct 1999 | A |
5999915 | Nahan et al. | Dec 1999 | A |
6035055 | Wang et al. | Mar 2000 | A |
6104834 | Hull | Aug 2000 | A |
6121969 | Jain et al. | Sep 2000 | A |
6138129 | Combs | Oct 2000 | A |
6192157 | Prebble | Feb 2001 | B1 |
6208771 | Jared et al. | Mar 2001 | B1 |
6223171 | Chaudhuri et al. | Apr 2001 | B1 |
6253201 | Abdel-Mottaleb et al. | Jun 2001 | B1 |
6301386 | Zhu et al. | Oct 2001 | B1 |
6332039 | Bando et al. | Dec 2001 | B1 |
6345274 | Zhu et al. | Feb 2002 | B1 |
6353822 | Lieberman | Mar 2002 | B1 |
6363381 | Lee et al. | Mar 2002 | B1 |
6393142 | Swain et al. | May 2002 | B1 |
6397213 | Cullen et al. | May 2002 | B1 |
6405172 | Baker et al. | Jun 2002 | B1 |
6408257 | Harrington et al. | Jun 2002 | B1 |
6411953 | Ganapathy et al. | Jun 2002 | B1 |
6448979 | Schena et al. | Sep 2002 | B1 |
6457026 | Graham et al. | Sep 2002 | B1 |
6460036 | Herz | Oct 2002 | B1 |
6470264 | Bide | Oct 2002 | B2 |
6504571 | Narayanaswami et al. | Jan 2003 | B1 |
6537324 | Tabata et al. | Mar 2003 | B1 |
6567799 | Sweet et al. | May 2003 | B2 |
6574375 | Cullen et al. | Jun 2003 | B1 |
6574644 | Hsu et al. | Jun 2003 | B2 |
6584223 | Shiiyama | Jun 2003 | B1 |
6611862 | Reisman | Aug 2003 | B2 |
6732915 | Nelson et al. | May 2004 | B1 |
6751343 | Ferrell et al. | Jun 2004 | B1 |
6753883 | Schena et al. | Jun 2004 | B2 |
6766363 | Rothschild | Jul 2004 | B1 |
6791605 | Reele et al. | Sep 2004 | B1 |
6799201 | Lee et al. | Sep 2004 | B1 |
6804332 | Miner et al. | Oct 2004 | B1 |
6804659 | Graham et al. | Oct 2004 | B1 |
6813381 | Ohnishi et al. | Nov 2004 | B2 |
6824057 | Rathus et al. | Nov 2004 | B2 |
6827267 | Rathus et al. | Dec 2004 | B2 |
6830187 | Rathus et al. | Dec 2004 | B2 |
6834804 | Rathus et al. | Dec 2004 | B2 |
6842755 | Maslov | Jan 2005 | B2 |
6843411 | Rathus et al. | Jan 2005 | B2 |
6859909 | Lerner et al. | Feb 2005 | B1 |
6865302 | Chang | Mar 2005 | B2 |
6866196 | Rathus et al. | Mar 2005 | B1 |
6922699 | Schuetze et al. | Jul 2005 | B2 |
6929182 | Rathus et al. | Aug 2005 | B2 |
6940491 | Incertis Carro | Sep 2005 | B2 |
6963358 | Cohen et al. | Nov 2005 | B2 |
6964374 | Djuknic et al. | Nov 2005 | B1 |
6980962 | Arganbright et al. | Dec 2005 | B1 |
6981224 | Gardner et al. | Dec 2005 | B1 |
6993573 | Hunter | Jan 2006 | B2 |
7013309 | Chakraborty et al. | Mar 2006 | B2 |
7031965 | Moriya et al. | Apr 2006 | B1 |
7051086 | Rhoads et al. | May 2006 | B2 |
7089487 | Tsai | Aug 2006 | B2 |
7092953 | Haynes | Aug 2006 | B1 |
7134095 | Smith et al. | Nov 2006 | B1 |
7150399 | Barrus et al. | Dec 2006 | B2 |
7167574 | Kim | Jan 2007 | B2 |
7174031 | Rhoads et al. | Feb 2007 | B2 |
7185274 | Rubin et al. | Feb 2007 | B1 |
7206820 | Rhoads et al. | Apr 2007 | B1 |
7232057 | Rathus et al. | Jun 2007 | B2 |
7236632 | Erol et al. | Jun 2007 | B2 |
7240279 | Chartier et al. | Jul 2007 | B1 |
7249123 | Elder et al. | Jul 2007 | B2 |
7251689 | Wesley | Jul 2007 | B2 |
7263205 | Lev | Aug 2007 | B2 |
7305435 | Hamynen | Dec 2007 | B2 |
7310769 | Dash | Dec 2007 | B1 |
7310779 | Carro | Dec 2007 | B2 |
7337175 | Comps et al. | Feb 2008 | B2 |
7359094 | Sayuda | Apr 2008 | B1 |
7363580 | Tabata et al. | Apr 2008 | B2 |
7366979 | Spielberg et al. | Apr 2008 | B2 |
7386789 | Chao et al. | Jun 2008 | B2 |
7392287 | Ratcliff, III | Jun 2008 | B2 |
7406214 | Rhoads et al. | Jul 2008 | B2 |
7421153 | Ronca et al. | Sep 2008 | B1 |
7421155 | King et al. | Sep 2008 | B2 |
7437023 | King et al. | Oct 2008 | B2 |
7450760 | Molnar et al. | Nov 2008 | B2 |
7458014 | Rubin et al. | Nov 2008 | B1 |
7489415 | Furuta et al. | Feb 2009 | B2 |
7509386 | Miyashita | Mar 2009 | B2 |
7546524 | Bryar et al. | Jun 2009 | B1 |
7567262 | Clemens et al. | Jul 2009 | B1 |
7593605 | King et al. | Sep 2009 | B2 |
7593961 | Eguchi et al. | Sep 2009 | B2 |
7613686 | Rui | Nov 2009 | B2 |
7644078 | Sastry et al. | Jan 2010 | B2 |
7653238 | Stentiford | Jan 2010 | B2 |
7668405 | Gallagher | Feb 2010 | B2 |
7680850 | Oda | Mar 2010 | B2 |
7707039 | King et al. | Apr 2010 | B2 |
7746376 | Mendoza et al. | Jun 2010 | B2 |
7761436 | Norton et al. | Jul 2010 | B2 |
7765231 | Rathus et al. | Jul 2010 | B2 |
7812986 | Graham et al. | Oct 2010 | B2 |
7872669 | Darrell et al. | Jan 2011 | B2 |
7882113 | Yaeger | Feb 2011 | B2 |
7930292 | Nakajima | Apr 2011 | B2 |
7946491 | Burian et al. | May 2011 | B2 |
20010011276 | Durst Jr. et al. | Aug 2001 | A1 |
20010013546 | Ross | Aug 2001 | A1 |
20010024514 | Matsunaga | Sep 2001 | A1 |
20010042030 | Ito et al. | Nov 2001 | A1 |
20010042085 | Peairs et al. | Nov 2001 | A1 |
20010043741 | Mahoney et al. | Nov 2001 | A1 |
20010049700 | Ichikura | Dec 2001 | A1 |
20020038430 | Edwards et al. | Mar 2002 | A1 |
20020052872 | Yada | May 2002 | A1 |
20020054059 | Schneiderman | May 2002 | A1 |
20020063709 | Gilbert et al. | May 2002 | A1 |
20020073236 | Helgeson et al. | Jun 2002 | A1 |
20020102966 | Lev et al. | Aug 2002 | A1 |
20020118379 | Chakraborty et al. | Aug 2002 | A1 |
20020146176 | Meyers | Oct 2002 | A1 |
20020154148 | Inoue et al. | Oct 2002 | A1 |
20020157028 | Koue et al. | Oct 2002 | A1 |
20020159640 | Vaithilingam et al. | Oct 2002 | A1 |
20020191003 | Hobgood et al. | Dec 2002 | A1 |
20020191848 | Boose et al. | Dec 2002 | A1 |
20020194264 | Uchiyama et al. | Dec 2002 | A1 |
20030025714 | Ebersole et al. | Feb 2003 | A1 |
20030030835 | Yoshida et al. | Feb 2003 | A1 |
20030098877 | Boegelund | May 2003 | A1 |
20030110130 | Pelletier | Jun 2003 | A1 |
20030110216 | Althin et al. | Jun 2003 | A1 |
20030112930 | Bosik et al. | Jun 2003 | A1 |
20030121006 | Tabata et al. | Jun 2003 | A1 |
20030122922 | Saffer et al. | Jul 2003 | A1 |
20030126147 | Essafi et al. | Jul 2003 | A1 |
20030128375 | Ruhl et al. | Jul 2003 | A1 |
20030151674 | Lin | Aug 2003 | A1 |
20030152293 | Bresler et al. | Aug 2003 | A1 |
20030187886 | Hull et al. | Oct 2003 | A1 |
20030190094 | Yokota | Oct 2003 | A1 |
20030193530 | Blackman et al. | Oct 2003 | A1 |
20030212585 | Kyoya et al. | Nov 2003 | A1 |
20030229857 | Sayuda et al. | Dec 2003 | A1 |
20040017482 | Weitman | Jan 2004 | A1 |
20040027604 | Jeran et al. | Feb 2004 | A1 |
20040036679 | Emerson | Feb 2004 | A1 |
20040042667 | Lee et al. | Mar 2004 | A1 |
20040102898 | Yokota et al. | May 2004 | A1 |
20040122811 | Page | Jun 2004 | A1 |
20040133582 | Howard et al. | Jul 2004 | A1 |
20040139391 | Stumbo et al. | Jul 2004 | A1 |
20040143644 | Berton et al. | Jul 2004 | A1 |
20040198396 | Fransioli | Oct 2004 | A1 |
20040199531 | Kim et al. | Oct 2004 | A1 |
20040201706 | Shimizu et al. | Oct 2004 | A1 |
20040205347 | Erol et al. | Oct 2004 | A1 |
20040215689 | Dooley et al. | Oct 2004 | A1 |
20040221244 | Baldino | Nov 2004 | A1 |
20040233235 | Rubin et al. | Nov 2004 | A1 |
20040238621 | Beenau et al. | Dec 2004 | A1 |
20040243514 | Wankmueller | Dec 2004 | A1 |
20040260625 | Usami et al. | Dec 2004 | A1 |
20040260680 | Best et al. | Dec 2004 | A1 |
20050012960 | Eden et al. | Jan 2005 | A1 |
20050080693 | Foss et al. | Apr 2005 | A1 |
20050086188 | Hillis et al. | Apr 2005 | A1 |
20050086224 | Franciosa et al. | Apr 2005 | A1 |
20050089246 | Luo | Apr 2005 | A1 |
20050100219 | Berkner et al. | May 2005 | A1 |
20050114325 | Liu et al. | May 2005 | A1 |
20050125390 | Hurst-Hiller et al. | Jun 2005 | A1 |
20050129293 | Acharya et al. | Jun 2005 | A1 |
20050135483 | Nair | Jun 2005 | A1 |
20050160115 | Starkweather | Jul 2005 | A1 |
20050160258 | O'Shea et al. | Jul 2005 | A1 |
20050165747 | Bargeron et al. | Jul 2005 | A1 |
20050165784 | Gomez et al. | Jul 2005 | A1 |
20050169520 | Chen et al. | Aug 2005 | A1 |
20050182773 | Feinsmith et al. | Aug 2005 | A1 |
20050185060 | Neven | Aug 2005 | A1 |
20050185225 | Brawn et al. | Aug 2005 | A1 |
20050190273 | Toyama et al. | Sep 2005 | A1 |
20050190972 | Thomas et al. | Sep 2005 | A1 |
20050198095 | Du et al. | Sep 2005 | A1 |
20050216257 | Tanabe et al. | Sep 2005 | A1 |
20050234851 | King et al. | Oct 2005 | A1 |
20050240381 | Seiler et al. | Oct 2005 | A1 |
20050261990 | Gocht et al. | Nov 2005 | A1 |
20050273812 | Sakai | Dec 2005 | A1 |
20050288859 | Golding et al. | Dec 2005 | A1 |
20050288911 | Porikli | Dec 2005 | A1 |
20050289182 | Pandian et al. | Dec 2005 | A1 |
20050289447 | Hadley et al. | Dec 2005 | A1 |
20060002607 | Boncyk et al. | Jan 2006 | A1 |
20060012677 | Neven et al. | Jan 2006 | A1 |
20060020630 | Stager et al. | Jan 2006 | A1 |
20060023945 | King et al. | Feb 2006 | A1 |
20060026140 | King et al. | Feb 2006 | A1 |
20060041605 | King et al. | Feb 2006 | A1 |
20060043188 | Kricorissian | Mar 2006 | A1 |
20060048059 | Etkin | Mar 2006 | A1 |
20060053097 | King et al. | Mar 2006 | A1 |
20060056696 | Jun et al. | Mar 2006 | A1 |
20060056697 | Jun et al. | Mar 2006 | A1 |
20060061806 | King et al. | Mar 2006 | A1 |
20060070120 | Aoki et al. | Mar 2006 | A1 |
20060074828 | Heumann et al. | Apr 2006 | A1 |
20060082438 | Bazakos et al. | Apr 2006 | A1 |
20060085477 | Phillips et al. | Apr 2006 | A1 |
20060085735 | Shimizu | Apr 2006 | A1 |
20060104515 | King et al. | May 2006 | A1 |
20060112092 | Ziou et al. | May 2006 | A1 |
20060116555 | Pavlidis et al. | Jun 2006 | A1 |
20060119880 | Dandekar et al. | Jun 2006 | A1 |
20060122884 | Graham et al. | Jun 2006 | A1 |
20060122983 | King et al. | Jun 2006 | A1 |
20060123347 | Hewitt et al. | Jun 2006 | A1 |
20060140475 | Chin et al. | Jun 2006 | A1 |
20060140614 | Kim et al. | Jun 2006 | A1 |
20060143176 | Mojsilovic et al. | Jun 2006 | A1 |
20060150079 | Albornoz et al. | Jul 2006 | A1 |
20060190812 | Ellenby et al. | Aug 2006 | A1 |
20060200480 | Harris et al. | Sep 2006 | A1 |
20060206335 | Thelen et al. | Sep 2006 | A1 |
20060218225 | Hee Voon et al. | Sep 2006 | A1 |
20060227992 | Rathus et al. | Oct 2006 | A1 |
20060240862 | Neven et al. | Oct 2006 | A1 |
20060251292 | Gokturk et al. | Nov 2006 | A1 |
20060251339 | Gokturk et al. | Nov 2006 | A1 |
20060253439 | Ren et al. | Nov 2006 | A1 |
20060253491 | Gokturk et al. | Nov 2006 | A1 |
20060262352 | Hull et al. | Nov 2006 | A1 |
20060262962 | Hull et al. | Nov 2006 | A1 |
20060262976 | Hart et al. | Nov 2006 | A1 |
20060285172 | Hull et al. | Dec 2006 | A1 |
20060285755 | Hager et al. | Dec 2006 | A1 |
20060285772 | Hull et al. | Dec 2006 | A1 |
20060286951 | Nagamoto et al. | Dec 2006 | A1 |
20060294049 | Sechrest et al. | Dec 2006 | A1 |
20070003166 | Berkner | Jan 2007 | A1 |
20070019261 | Chu | Jan 2007 | A1 |
20070036469 | Kim et al. | Feb 2007 | A1 |
20070041668 | Todaka | Feb 2007 | A1 |
20070047819 | Hull et al. | Mar 2007 | A1 |
20070053513 | Hoffberg | Mar 2007 | A1 |
20070076922 | Living et al. | Apr 2007 | A1 |
20070115373 | Gallagher et al. | May 2007 | A1 |
20070150466 | Brave et al. | Jun 2007 | A1 |
20070165904 | Nudd et al. | Jul 2007 | A1 |
20070174269 | Jing et al. | Jul 2007 | A1 |
20070175998 | Lev | Aug 2007 | A1 |
20070233613 | Barrus et al. | Oct 2007 | A1 |
20070271247 | Best et al. | Nov 2007 | A1 |
20070276845 | Geilich | Nov 2007 | A1 |
20080010605 | Frank | Jan 2008 | A1 |
20080071767 | Grieselhuber et al. | Mar 2008 | A1 |
20080078836 | Tomita | Apr 2008 | A1 |
20080267504 | Schloter et al. | Oct 2008 | A1 |
20080275881 | Conn et al. | Nov 2008 | A1 |
20080288476 | Kim et al. | Nov 2008 | A1 |
20080296362 | Lubow | Dec 2008 | A1 |
20080310717 | Saathoff et al. | Dec 2008 | A1 |
20090067726 | Erol et al. | Mar 2009 | A1 |
20090152357 | Lei et al. | Jun 2009 | A1 |
20090235187 | Kim et al. | Sep 2009 | A1 |
20100013615 | Hebert et al. | Jan 2010 | A1 |
20100174783 | Zarom | Jul 2010 | A1 |
20110121069 | Lindahl et al. | May 2011 | A1 |
Number | Date | Country |
---|---|---|
1245935 | Mar 2000 | CN |
0706283 | Apr 1996 | EP |
1229496 | Aug 2002 | EP |
1555626 | Jul 2005 | EP |
1662064 | May 2006 | EP |
1783681 | May 2007 | EP |
10-228468 | Aug 1998 | JP |
2000-165645 | Jun 2000 | JP |
200268179 | Sep 2000 | JP |
2001211359 | Aug 2001 | JP |
2001230916 | Aug 2001 | JP |
2002513480 | May 2002 | JP |
2005286395 | Oct 2005 | JP |
2006053568 | Feb 2006 | JP |
2006059351 | Mar 2006 | JP |
2006215756 | Aug 2006 | JP |
WO 9905658 | Feb 1999 | WO |
WO 2004072897 | Aug 2004 | WO |
WO 2005043270 | May 2005 | WO |
WO 2007073347 | Jun 2007 | WO |
2008129373 | Oct 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20090018990 A1 | Jan 2009 | US |