This invention relates to machine vision systems, and particularly to methods for searching for a pattern in an image.
The problem of how to find a particular pattern in an image is a well-known problem with many known solutions, such as feature-based search methods. Typically, the pattern is assumed to have undergone one or more of a few basic transformations, such as being scaled, or being rotated. However, these known solutions often fail if the pattern has been deformed by being warped, pulled, bent, wrinkled, damaged, or otherwise fundamentally changed from the original un-deformed shape that the search process is adapted to find.
Nevertheless, even after transformation of the whole pattern, if the deformed pattern is divided into smaller sub-patterns, those sub-patterns are themselves fairly close in form to the corresponding parts of the original un-deformed pattern. For example, if the pattern is bent into a “V” or boomerang shape, then the two legs of the boomerang both represent good, easily-findable portions of the pattern. It's only the deformed pattern that is hard to find as an entirety. Therefore, searching for a deformed pattern in an image may be facilitated by dividing the deformed pattern into smaller sub-patterns. For many typical types of deformation encountered, most of those sub-patterns are probably findable by known feature-based search methods (because the sub-patterns are not themselves substantially distorted).
However, it is then necessary for a subsequent algorithm to combine the sub-pattern search results into a full match of the distorted whole pattern. Unfortunately, searching for a large number of sub-patterns in an image takes much longer than searching for a single whole pattern. Furthermore, sub-patterns are inherently simpler than the whole pattern, so they're more likely to be confused when they are used in searching the target image, potentially yielding many spurious matches in various locations of the target image.
It is sometimes useful to characterize the deformation of the deformed whole pattern after it has been found. However, even though a deformed whole pattern has been found, a characterization of the deformation may still not be known. The deformation of the whole pattern can be characterized after each of the sub-patterns have been located. In some cases, the deformation may be easily characterized, such as the deformation due to 3D perspective, or the deformation due to the whole pattern being wrapped around a cylinder, such as when a label is wrapped around a can. In other cases, the deformation may be more atypical, representing random wrinkles, folds, bends, dents, and so forth, and is consequently not characterized by a known or standard transformation. In either case, an automated method of characterizing deformation after finding a deformed pattern would be useful in some applications, e.g., inspecting printing on soda cans, inspecting labels on oddly shaped containers such as bags of sugar, or inspecting lot and date codes on medicine bottles. With a deformation transform that maps between the deformed pattern (e.g. the logo on a full bag of sugar or the date code on a curved bottle) and the original undeformed pattern (e.g., the logo as it would appear on a flat piece of paper), tasks using inspection tools suitable for undeformed patterns can be performed, such as inspection of logo print quality. This would be impossible without a characterization, and un-doing based on the characterization, of the deformation of the bag or bottle, because wrinkles or curvature would easily be misclassified as a print defects using inspection tools suitable for undeformed patterns, even though the print quality might otherwise be acceptable.
One general aspect of the invention is a method for finding a deformed pattern in an image. The method includes providing a plurality of features that represent the deformed pattern in the image, and then dividing the plurality of features into a plurality of sub-pluralities, each sub-plurality representing a sub-pattern in the image, a plurality of the sub-patterns representing the deformed pattern. Next a distance is determined between each pair of sub-patterns of the plurality of sub-pluralities. Then, a first sub-pattern is selected to locate in the image, locating the first sub-pattern in the image so as to provide a first sub-pattern location. Next, the first sub-pattern location is used to select a second sub-pattern to locate in the image, which is then located in the image so as to provide a second sub-pattern location. The first sub-pattern location and the second sub-pattern location are then used to determine a location of the deformed pattern.
In a preferred embodiment, providing a plurality of features that represent the deformed pattern in the image includes detecting features in the image. In a further preferred embodiment, detecting features in the image includes detecting features in the image using a Sobel edge detector.
In another preferred embodiment, determining a distance between each pair of sub-patterns of the plurality of sub-patterns includes storing each distance for later use. In another embodiment, determining a distance between each pair of sub-patterns of the plurality of sub-patterns includes determining the minimum distance between the pair of sub-patterns. In yet another embodiment, determining a distance between each pair of sub-patterns of the plurality of sub-patterns includes determining the distance between a first feature of a first sub-pattern and a second feature of a second sub-pattern. In still another embodiment, determining a distance between each pair of sub-patterns of the plurality of sub-patterns includes determining the distance between a first center of a first sub-pattern and a second center of a second sub-pattern.
In a preferred embodiment, locating the first sub-pattern in the image so as to provide a first sub-pattern location includes using a feature-based search method for locating the first sub-pattern in the image. In another embodiment, locating the second sub-pattern in the image so as to provide a second sub-pattern location includes computing a search area using the location of the first sub-pattern. In an alternate embodiment, locating the second sub-pattern in the image so as to provide a second sub-pattern location includes computing an expected angle and an expected scale of the second sub-pattern.
In a preferred embodiment, the expected scale is the expected X-dimension scale and the expected Y-dimension scale. In a further preferred embodiment, an expected aspect ratio of the second sub-pattern is also computed. In another embodiment, the expected angle and the expected scale of the second sub-pattern is used so as to provide an angular search range and a scale search range. In a further preferred embodiment, the scale search range is an X-dimension scale search range, and a Y-dimension scale search range. In another further embodiment, a distance between the first sub-pattern and the second sub-pattern, and a deformation rate, is used.
In a preferred embodiment of the method of the invention, locating the second sub-pattern in the image so as to provide a second sub-pattern location includes computing a search area using the location of the first sub-pattern, and then computing an expected angle of the second sub-pattern and an expected scale of the second sub-pattern using the angle and scale of the first sub-pattern. Next, the expected angle of the second sub-pattern, the expected scale of the second sub-pattern, a distance between the first sub-pattern and the second sub-pattern, and a deformation rate are all used so as to provide an expanded search area, an angular search range, and a scale search range. Then, the second sub-pattern is located within the expanded search area, the angular search range, and the scale search range so as to provide a second sub-pattern location.
In a further preferred embodiment, using the expected angle of the second sub-pattern, the expected scale of the second sub-pattern, a distance between the first sub-pattern and the second sub-pattern, and a deformation rate so as to provide an expanded search area, an angular search range, and a scale search range includes increasing the size of the expanded search area, the angular search range, and the scale search range upon an increase in the distance between the first sub-pattern and the second sub-pattern.
In an alternate further preferred embodiment, using the expected angle of the second sub-pattern, the expected scale of the second sub-pattern, a distance between the first sub-pattern and the second sub-pattern, and a deformation rate so as to provide an expanded search area, an angular search range, and a scale search range includes increasing, in proportion to the deformation rate, the size of the expanded search area, the angular search range, and the scale search range. In yet another embodiment, using the expected angle of the second sub-pattern, the expected scale of the second sub-pattern, a distance between the first sub-pattern and the second sub-pattern, and a deformation rate so as to provide an expanded search area, an angular search range, and a scale search range includes increasing, in proportion to the deformation rate, the size of the expanded search area, the angular search range, and the scale search range upon an increase in the distance between the first sub-pattern and the second sub-pattern.
In further embodiments, computing an expected angle of the second sub-pattern and an expected scale of the second sub-pattern using the angle and scale of the first sub-pattern includes computing an expected X-dimension scale and an expected Y-dimension scale using the X-dimension scale of the first sub-pattern and the Y-dimension scale of the first sub-pattern, respectively. In another embodiment, computing an expected angle of the second sub-pattern and an expected scale of the second sub-pattern using the angle and scale of the first sub-pattern includes computing an angular uncertainty and a scale uncertainty of the second sub-pattern using an angular uncertainty and a scale uncertainty of the first sub-pattern, respectively. In a further embodiment, computing an angular uncertainty and a scale uncertainty of the second sub-pattern using an angular uncertainty and a scale uncertainty of the first sub-pattern, respectively includes computing an X-dimension scale uncertainty and a Y-dimension scale uncertainty of the second sub-pattern using an X-dimension scale uncertainty of the first sub-pattern, and a Y-dimension scale uncertainty of the first sub-pattern, respectively.
Another general aspect of the invention is a method for characterizing a deformed pattern in an image. The method includes providing a plurality of features that represent the deformed pattern in the image; dividing the plurality of features into a plurality of sub-pluralities, each sub-plurality representing a sub-pattern in the image, a plurality of the sub-patterns representing the deformed pattern; determining a distance between each pair of sub-patterns of the plurality of sub-pluralities; locating a first sub-pattern in the image so as to provide a first sub-pattern location; locating a second sub-pattern in the image so as to provide a second sub-pattern location; and then using the first sub-pattern location and the second sub-pattern location for determining a deformation mapping that characterizes the deformed pattern in the image.
Another general aspect of the invention is another method for characterizing a deformed pattern in an image, wherein the method includes dividing the deformed pattern into at least a first sub-pattern and a second sub-pattern; locating the first sub-pattern in the image so as to provide a first sub-pattern pose; locating the second sub-pattern in the image so as to provide a second sub-pattern pose; and then using the first sub-pattern pose and the second sub-pattern pose for determining a deformation mapping that characterizes the deformed pattern in the image.
In a preferred embodiment, using the first sub-pattern pose and the second sub-pattern pose for determining a deformation mapping that characterizes the deformed pattern in the image includes deriving a plurality of source points from the first sub-pattern and a plurality of source points from the second sub-pattern; generating a plurality of destination points from the source points and the sub-pattern poses; and then using a transform to fit the plurality of source points and plurality of destination points so as to create the global deformation map. In preferred embodiments, the transform is a perspective transform, or is an affine transform, or is a spline transform, or is a thin-plate spline transform, or is a cylinder transform.
In further embodiments, the transform is fit using a least-squares-fit method, or a Total Variation method, or a Robust M-estimators method, or a Minimum Lp-Norm Estimation, or a Least Median of Squares method. In other embodiments, the first sub-pattern and the second sub-pattern each include a plurality of feature points. In yet other embodiments, the first sub-pattern and the second sub-pattern each include a region. In a preferred embodiment, each region is converted into feature points. In further preferred embodiments, each region is converted into feature points by representing each sub-pattern as a region having a boundary and interior area, and then selecting a plurality of boundary points along the boundary. In a yet further preferred embodiment, the boundary points include corners. In an alternate embodiment, the boundary points include a point midway between two vertices of the boundary.
In another preferred embodiment, deriving a plurality of source points from the first sub-pattern and a plurality of source points from the second sub-pattern includes representing each sub-pattern as a region having a boundary and an interior area, and then selecting at least one interior point. In another preferred embodiment, deriving a plurality of source points from the first sub-pattern and a plurality of source points from the second sub-pattern includes representing each sub-pattern as a region having a boundary and an interior area, and then selecting a plurality of boundary points along the boundary. In a further embodiment, the boundary points include corners. In another embodiment, the boundary points include a point midway between two vertices of the boundary.
In another preferred embodiment, dividing the deformed pattern into at least a first sub-pattern and a second sub-pattern includes dividing the deformed pattern in the image into a plurality of contiguous rectilinear regions so as to form a grid that extends over at least most of the deformed pattern, thereby providing at least a first sub-pattern and a second sub-pattern; and then deriving a plurality of source points from at least the first sub-pattern and the second sub-pattern.
In yet another preferred embodiment, deriving a plurality of source points from the first sub-pattern and a plurality of source points from the second sub-pattern includes representing each sub-pattern as a plurality of feature points, and then sub-sampling the plurality of feature points so as to reduce the number of feature points in each sub-pattern.
The method of the invention effectively restricts sub-pattern search ranges, which both improves search speed and reduces the number of spurious matches. The method of the invention also quickly decides which sub-patterns, out of several potential candidates, is most likely to correctly match a deformed sub-pattern.
The deformation characterization method of the invention uses results from feature-based search tools (typically the “pose” of each sub-pattern of a deformed whole pattern, the pose including position, angle, x-dimension scale, and y-dimension scale information, for example) to create a mapping that models the deformation of the pattern in the image. A transform, selectable by a user, is fit to the results from the feature-based search tools to create a global deformation mapping. This transformation is fit only to feature points derived from matches resulting from successful sub-pattern search, without including data from areas of the pattern that were blank, not matched, or otherwise didn't contain information about the pattern's distorted location.
The invention will be more fully understood by reference to the detailed description, in conjunction with the following figures, wherein:
Referring to
In a preferred embodiment, to obtain more spatially coherent sub-patterns, the main pattern is converted into feature points 210 by any method known in the art, such as by using a Sobel edge detector, where each feature point represents a point of pattern information, such as a point along a brightness boundary (i.e., an edge) within the image. These feature points are then clustered into sub-groups 220 using any known partitioning algorithm, such as simply dividing the points into groups by applying a regular grid to partition the area, or other clustering algorithm, such as the well-known “nearest-neighbor” or “k-means” clustering methods. Each clustered group then represents a sub-pattern. In another preferred embodiment, the feature points are clustered into sub-groups using the methods taught in co-pending U.S. patent application entitled “METHOD FOR PARTITIONING A PATTERN INTO OPTIMIZED SUB-PATTERNS”, filed Jul. 22, 2003. In another preferred embodiment, these feature points 115 are provided directly as inputs, in lieu of the image 100.
These feature points 115 need not be restricted to two-dimensional (2D) points. One skilled in the art can readily see that a pattern can be represented in any number of dimensions, for example 3D, with no change to this method. However, 2D points and 2D images are used as example images herein for ease of representation.
Next, in step 120, distances are computed between each pair of sub-patterns 110. These distances are stored in a look-up table for later use, in a data storage entity hereinafter referred to as the “distance table”. In one embodiment, shown in
In an alternate embodiment shown in
In step 130 a sub-pattern is selected for initial search. Referring to
Per step 150 of
If the chosen anchor pattern 410 is not found within the target image 400 at step 150, or if it is found but the remaining search steps 160,170, 172-178 are unsuccessful in matching the rest of the pattern, a different anchor pattern is selected using the same methods described above, except the next-highest scoring sub-pattern is chosen instead of the failed sub-pattern. If no anchor pattern is ever found within the target image 400, even after a plurality of attempts 165, the method is deemed to have failed to locate the main pattern in the image, and consequently it cannot characterize the deformation of the pattern 180. In this case, either the deformation was too extreme to allow the pattern 410 to be found with the method of the invention, or the user-supplied deformation-rate estimate was too low, or the pattern 410 was not in fact present in the image 400 at all.
Referring to
Referring to
At step 170, the highest-scoring sub-pattern is searched for in the target image 400, again using any search method known in the art that finds patterns in the presence of some sort of distortion, including but not limited to distortion of position, angle, x-dimension scale, y-dimension scale, etc.
With reference to
In step 176, the initial search ranges for those various degrees of freedom (e.g., search area, angle, scale) are then modified based on a number of factors. In one preferred embodiment, the initial search ranges are expanded further based on the user-provided “deformation rate estimate”, where higher rates increase the ranges more. For example, an estimate of high deformation, arbitrarily chosen as 0.8 for this example, could result in an expansion of a nominal angular search range from 40 to 60 degrees to 20 to 80 degrees, while an estimate of low deformation, such as 0.2, could result in an expansion of the angular search range to only 35 to 65 degrees. In a further preferred embodiment, the deformation rate estimate is multiplied by the distance between the current sub-pattern and the nearest previously located sub-pattern (called the “local anchor”) 510560. This results in larger search area ranges 570 for sub-patterns 580 that are further away from any known, “locally-anchored” regions 560 in the target image 400, and smaller search area ranges 520 for sub-patterns 530 that are closer to a known local anchor 510. In the embodiment, described above, where sub-patterns are chosen for searching based on the distances to more than one previously located sub-pattern, those distances can be combined here. If the nearby sub-patterns do not agree on the likely pose of the new sub-pattern, that is evidence that deformation to the pattern has occurred (as otherwise all sub-patterns would be found right where they're predicted to be anyway), so therefore the deformation estimate should be increased, to encompass the expected ranges from all nearby sub-patterns. In the embodiment of step 175, the position, as well as the angle, x-dimension scale, y-dimension scale, and other degrees of freedom of the local anchor 560 are used to determine the nominal, or expected, pose of the sub-pattern 550—the sub-pattern search is based on the assumption that the most likely place for the new sub-pattern is where it would be found if it had exactly the same sort of distortion (angle, scale, etc.) as its local anchor 560.
Another embodiment varies the D.O.F. search ranges based on the score obtained by the search for the local anchor, as the score is considered to be a measure of certainty, and when the local anchor's pose is uncertain, the search ranges for nearby sub-patterns can be advantageously enlarged 570, as shown in
Referring to
An actual score can most easily be computed by looking at how far away each D.O.F. value is from the expected value, relative to the possible range, and expressing that as a ratio. For example, if the expected angle was 20 degrees, and the search range was 10 to 30 degrees, then if the match angle was at 16 degrees, then the score would be 1.0−(20−16)/(20−10)=1.0−0.4=0.6. If the match angle was at 12 degrees, the score would be 1.0−(20−12)/(20−10)=1.0−0.8=0.2. Subtracting the ratio from 1.0 causes high scores to indicate better matches than low scores, which is what is preferred. A preferred embodiment combines both of these scoring methods into a single score 650, either by multiplying them together, or by adding them, or by any reasonable scheme for combining multiple score values into a single score.
Referring to
After the various parts of the target pattern 400 have been individually located in the image, an aggregate score for the match is computed based on the sub-pattern quality scores (already computed as described above 650), where non-located sub-patterns score as zero. In one embodiment, the scores of the sub-patterns are simply averaged. In a preferred embodiment, these sub-scores are combined as a weighted average, being weighted according to the area enclosed by the features of each sub-pattern, or by the size of the bounding-box. In another preferred embodiment, they are weighted by the number of features in each sub-pattern.
This aggregate score is returned, or a failure message is returned if the pattern could not be matched. The individual poses of the sub-pattern matches can also be returned, and also the individual sub-scores corresponding to the individual poses.
In a preferred embodiment, the individual poses of the sub-pattern, and the exact found positions of individual features in each sub-pattern are used to define a deformation map 180, and that deformation map can be returned as output, either instead of or in addition to other match information. In a refinement to that embodiment, the feature information used to help define the deformation map is a sub-set of the feature points provided by prior steps of the method for finding a deformed pattern. For example, the set of feature points can be sub-sampled, resulting in a less accurate result (as fewer features are considered), but then the deformation map can often be computed much faster from fewer features In another refinement, these points are a representative sampling of the region that each sub-pattern occupies, such as the corners or edges of the bounding box of the region, or a set of points along whatever contour may define the region. In a preferred refinement to this embodiment, individual feature points that were not matched as part of the core search for a deformed pattern are omitted from the list of feature points used to create the deformation map 180. The location or pose of the pattern in the image is returned 182 by the method of the invention, though the exact concept of “location” or “pose” for a deformed pattern permits a variety of definitions, the particular definition being chosen in accordance with the requirements of a particular application, or the convenience of a user or developer. In one embodiment, the location of the pattern is deemed to be the location of a particular designated “location point” in the pattern, the location point being designated by a user. In this embodiment, the returned location is the “location point” mapped through the above-described deformation map, which is a close approximation to the location of that point in the deformed pattern. In another embodiment, the pose of the pattern is deemed to be the location of a user-specified sub-pattern. In this case, the location includes the full pose of the sub-pattern (which was determined by the method of the invention), not just the position information. In another embodiment, the pose is computed by fitting an affine transform to all found feature points using any standard method for fitting such a transform, such as a least-squares fit, or other fitting methods disclosed herein. This yields only a rough approximation of the location of the pattern, as all deformation has been stripped away. However, for patterns that have only minor deformation, this may be the simplest solution. In a preferred embodiment, the deformation map itself is returned, as this map contains the most detailed information available on the pattern's position in the image. In this embodiment, the user can define “location” any way they choose by using the information provided by the deformation map. For example, they could map the four corners of the pattern rectangle through the deformation map to yield a “location quadrilateral” for the deformed pattern.
Method for Characterizing Deformation of a Pattern
Referring to
The above-described search method of the invention employs sub-patterns that each include a plurality of feature points which can be input directly as “undeformed pattern” points 700. The above-described search method of the invention also provides a found pose for each matched sub-pattern 910. Mapping each matched sub-pattern's set of feature points through the found pose gives a set of “deformed pattern” feature points 915 to be used as input to the method disclosed herein for characterizing the deformation of a pattern.
Alternatively, a set of source regions 730 can be used as initial inputs 900. The set of source regions 730 together represent an un-deformed pattern 740, and a corresponding set of regions 750 represent a deformed pattern 760. An example of a set of source regions is a grid of rectangles that cover the full area of an un-deformed pattern, and a corresponding set of destination regions is a collection of contiguous affine rectangles (e.g., rectangles that have undergone rotation, skew, scaling, and/or translation) that represent the approximate deformations of the rectangles of the grid.
Referring again to
A global deformation map 1040 as shown in
A preferred embodiment for accurately modeling more detailed deformation is the thin-plate-spline, a mathematical construct described in “Principal Warps: Thin-Plate Splines and the Decomposition of Deformations” by Fred L. Bookstein (IEEE Transactions on Pattern Analysis and Machine Intelligence, June 1989). Depending on the domain, any number of possible models can be fit to these points, including other types of splines, or any other transformation.
This global deformation map (transform) 940, 1040 is an approximation of the deformation of the pattern, with accuracy limited by whatever level of detail the provided feature points or regions possess, and limited by the appropriateness of the chosen transformation (e.g., perspective, cylinder, or spline) for modeling that deformation.
The global deformation map of the invention can be used to un-do or otherwise reverse the deformation of the deformed pattern so as to provide an un-deformed pattern.
Other variants and embodiments will occur to those skilled in the art, without departing from the spirit and scope of the invention. Accordingly, the invention is not intended to be limited by the detailed description, except as set forth in the following claims.
This application is a continuation of U.S. patent application Ser. No. 10/625,205, entitled “Methods for finding and characterizing a deformed pattern in an image,” filed Jul. 22, 2003.
Number | Name | Date | Kind |
---|---|---|---|
3069654 | Hough | Dec 1962 | A |
3560930 | Howard | Feb 1971 | A |
3816722 | Sakoe et al. | Jun 1974 | A |
3898617 | Kashioka et al. | Aug 1975 | A |
3899240 | Gabor | Aug 1975 | A |
3899771 | Saraga et al. | Aug 1975 | A |
3936800 | Ejiri et al. | Feb 1976 | A |
3986007 | Ruoff | Oct 1976 | A |
4115702 | Nopper | Sep 1978 | A |
4115762 | Akiyama | Sep 1978 | A |
4146924 | Birk et al. | Mar 1979 | A |
4183013 | Agrawala et al. | Jan 1980 | A |
4200861 | Hubach et al. | Apr 1980 | A |
4213150 | Robinson et al. | Jul 1980 | A |
4295198 | Copeland et al. | Oct 1981 | A |
4441205 | Berkin et al. | Apr 1984 | A |
4441206 | Kuniyoshi et al. | Apr 1984 | A |
4441248 | Sherman et al. | Apr 1984 | A |
4567610 | McConnell | Jan 1986 | A |
4570180 | Baier et al. | Feb 1986 | A |
4581762 | Lapidus et al. | Apr 1986 | A |
4618989 | Tsukune et al. | Oct 1986 | A |
4637055 | Taylor | Jan 1987 | A |
4651341 | Nakashima et al. | Mar 1987 | A |
4672676 | Linger | Jun 1987 | A |
4675833 | Cheek et al. | Jun 1987 | A |
4685143 | Choate | Aug 1987 | A |
4688088 | Hamazaki et al. | Aug 1987 | A |
4707647 | Coldrenet et al. | Nov 1987 | A |
4736437 | Sacks et al. | Apr 1988 | A |
4763280 | Robinson et al. | Aug 1988 | A |
4783826 | Koso | Nov 1988 | A |
4783829 | Miyakawa et al. | Nov 1988 | A |
4799175 | Sano et al. | Jan 1989 | A |
4809348 | Meyer et al. | Feb 1989 | A |
4823394 | Berkin et al. | Apr 1989 | A |
4843631 | Steinpichler et al. | Jun 1989 | A |
4845765 | Juvin et al. | Jul 1989 | A |
4849914 | Medioni et al. | Jul 1989 | A |
4860374 | Murakami et al. | Aug 1989 | A |
4876457 | Bose | Oct 1989 | A |
4876728 | Roth | Oct 1989 | A |
4893346 | Bishop | Jan 1990 | A |
4903312 | Sato | Feb 1990 | A |
4903313 | Tachikawa | Feb 1990 | A |
4922543 | Ahlborm et al. | May 1990 | A |
4955062 | Terui | Sep 1990 | A |
4959898 | Landman et al. | Oct 1990 | A |
4972359 | Silver et al. | Nov 1990 | A |
4979223 | Manns et al. | Dec 1990 | A |
4980971 | Bartschat et al. | Jan 1991 | A |
5003166 | Girod | Mar 1991 | A |
5020006 | Sporon-Fiedler | May 1991 | A |
5027417 | Kitakado et al. | Jun 1991 | A |
5033099 | Yamada et al. | Jul 1991 | A |
5040231 | Terzian | Aug 1991 | A |
5046109 | Fujimori et al. | Sep 1991 | A |
5048094 | Aoyama et al. | Sep 1991 | A |
5054094 | Barski | Oct 1991 | A |
5060276 | Morris et al. | Oct 1991 | A |
5072384 | Doi et al. | Dec 1991 | A |
5086478 | Kelly-Mahaffey et al. | Feb 1992 | A |
5093867 | Hori et al. | Mar 1992 | A |
5111516 | Nakano et al. | May 1992 | A |
5113565 | Cipolla et al. | May 1992 | A |
5161201 | Kaga et al. | Nov 1992 | A |
5168530 | Peregrim et al. | Dec 1992 | A |
5177559 | Bachelder et al. | Jan 1993 | A |
5206917 | Ueno et al. | Apr 1993 | A |
5226095 | Okumura et al. | Jul 1993 | A |
5245674 | Cass et al. | Sep 1993 | A |
5253306 | Nishio | Oct 1993 | A |
5268999 | Yokoyama | Dec 1993 | A |
5272657 | Basehore et al. | Dec 1993 | A |
5280351 | Wilkinson | Jan 1994 | A |
5313532 | Harvey et al. | May 1994 | A |
5343028 | Figarella et al. | Aug 1994 | A |
5343390 | Doi et al. | Aug 1994 | A |
3531310 | Califano et al. | Sep 1994 | A |
5347595 | Bokser | Sep 1994 | A |
5351310 | Califano et al. | Sep 1994 | A |
5371690 | Engel et al. | Dec 1994 | A |
5384711 | Kanai et al. | Jan 1995 | A |
5398292 | Aoyama | Mar 1995 | A |
5406642 | Maruya | Apr 1995 | A |
5459636 | Gee et al. | Oct 1995 | A |
5471541 | Burtnyk et al. | Nov 1995 | A |
5481712 | Silver et al. | Jan 1996 | A |
5495537 | Bedrosian et al. | Feb 1996 | A |
5497451 | Holmes | Mar 1996 | A |
5500906 | Picard et al. | Mar 1996 | A |
5506942 | Mikuni et al. | Apr 1996 | A |
5513275 | Khalaj et al. | Apr 1996 | A |
5515453 | Hennessey et al. | May 1996 | A |
5524064 | Oddou et al. | Jun 1996 | A |
5537669 | Evans et al. | Jul 1996 | A |
5539841 | Huttenlocher et al. | Jul 1996 | A |
5544254 | Hartley et al. | Aug 1996 | A |
5545887 | Smith et al. | Aug 1996 | A |
5548326 | Michael | Aug 1996 | A |
5550763 | Michael et al. | Aug 1996 | A |
5550937 | Bell et al. | Aug 1996 | A |
5555317 | Anderson | Sep 1996 | A |
5555320 | Irie et al. | Sep 1996 | A |
5557684 | Wang et al. | Sep 1996 | A |
5559901 | Lobregt | Sep 1996 | A |
5568563 | Tanaka et al. | Oct 1996 | A |
5570430 | Sheehan et al. | Oct 1996 | A |
5586058 | Aloni et al. | Dec 1996 | A |
5602937 | Bedrosian et al. | Feb 1997 | A |
5602938 | Akiyama et al. | Feb 1997 | A |
5613013 | Schuette | Mar 1997 | A |
5621807 | Eibert et al. | Apr 1997 | A |
5623560 | Nakajima et al. | Apr 1997 | A |
5625707 | Diep et al. | Apr 1997 | A |
5625715 | Trew et al. | Apr 1997 | A |
5627912 | Matsumoto | May 1997 | A |
5627915 | Rosser et al. | May 1997 | A |
5631975 | Riglet et al. | May 1997 | A |
5633951 | Moshfeghi | May 1997 | A |
5638116 | Shimoura et al. | Jun 1997 | A |
5638489 | Tsuboka | Jun 1997 | A |
5640200 | Michael | Jun 1997 | A |
5650828 | Lee | Jul 1997 | A |
5657403 | Wolff et al. | Aug 1997 | A |
5663809 | Miyaza et al. | Sep 1997 | A |
5673334 | Nichani et al. | Sep 1997 | A |
5676302 | Petry | Oct 1997 | A |
5686973 | Lee | Nov 1997 | A |
5694482 | Maali et al. | Dec 1997 | A |
5694487 | Lee | Dec 1997 | A |
5703960 | Soest | Dec 1997 | A |
5703964 | Menon et al. | Dec 1997 | A |
5708731 | shmotori et al. | Jan 1998 | A |
5717785 | Silver | Feb 1998 | A |
5754226 | Yamada et al. | May 1998 | A |
5757956 | Koljonen et al. | May 1998 | A |
5768421 | Gaffin et al. | Jun 1998 | A |
5793901 | Matsutake et al. | Aug 1998 | A |
5796868 | Dutta-Choudhury et al. | Aug 1998 | A |
5815198 | Vachtsevanos et al. | Sep 1998 | A |
5822742 | Alkon et al. | Oct 1998 | A |
5825913 | Rostami et al. | Oct 1998 | A |
5825922 | Pearson et al. | Oct 1998 | A |
5828769 | Burns | Oct 1998 | A |
5828770 | Leis et al. | Oct 1998 | A |
5835622 | Koljonen et al. | Nov 1998 | A |
5845007 | Ohashi et al. | Dec 1998 | A |
5845288 | Syeda-Mahmood | Dec 1998 | A |
5848184 | Taylor et al. | Dec 1998 | A |
5848189 | Pearson et al. | Dec 1998 | A |
5850466 | Schott et al. | Dec 1998 | A |
5850469 | Martin et al. | Dec 1998 | A |
5859923 | Petry, III et al. | Jan 1999 | A |
5862245 | Renouard et al. | Jan 1999 | A |
5864779 | Fujimoto | Jan 1999 | A |
5871018 | Delp et al. | Feb 1999 | A |
5875040 | Matraszek et al. | Feb 1999 | A |
5881170 | Araki et al. | Mar 1999 | A |
5890808 | Neff et al. | Apr 1999 | A |
5912984 | Michael et al. | Jun 1999 | A |
5912985 | Morimoto et al. | Jun 1999 | A |
5917733 | Bangham | Jun 1999 | A |
5917962 | Chen et al. | Jun 1999 | A |
5926568 | Chaney et al. | Jul 1999 | A |
5930391 | Kinjo | Jul 1999 | A |
5933516 | Tu et al. | Aug 1999 | A |
5933523 | Drisko et al. | Aug 1999 | A |
5937084 | Crabtree et al. | Aug 1999 | A |
5940535 | Huang | Aug 1999 | A |
5943442 | Tanaka | Aug 1999 | A |
5950158 | Wang | Sep 1999 | A |
5974169 | Bachelder | Oct 1999 | A |
5974365 | Mitchell | Oct 1999 | A |
5982475 | Bruning et al. | Nov 1999 | A |
5987172 | Michael | Nov 1999 | A |
5995648 | Drisko et al. | Nov 1999 | A |
5995953 | Rindtorff et al. | Nov 1999 | A |
6002793 | Silver et al. | Dec 1999 | A |
6005978 | Garakani | Dec 1999 | A |
6021220 | Anderholm | Feb 2000 | A |
6023530 | Wilson | Feb 2000 | A |
6026186 | Fan | Feb 2000 | A |
6026359 | Yamaguchi et al. | Feb 2000 | A |
6035006 | Matui | Mar 2000 | A |
6035066 | Michael | Mar 2000 | A |
6052489 | Sakaue | Apr 2000 | A |
6061086 | Reimer et al. | May 2000 | A |
6064388 | Reyzin | May 2000 | A |
6064958 | Takahashi et al. | May 2000 | A |
6067379 | Silver | May 2000 | A |
6070160 | Geary et al. | May 2000 | A |
6078700 | Sarachik | Jun 2000 | A |
6081620 | Anderholm | Jun 2000 | A |
6111984 | Fukasawa | Aug 2000 | A |
6115052 | Freeman et al. | Sep 2000 | A |
6118893 | Li | Sep 2000 | A |
6122399 | Moed | Sep 2000 | A |
6128405 | Fujii | Oct 2000 | A |
6130959 | Li | Oct 2000 | A |
6137893 | Michael et al. | Oct 2000 | A |
6151406 | Chang et al. | Nov 2000 | A |
6154566 | Mine et al. | Nov 2000 | A |
6154567 | McGarry | Nov 2000 | A |
6173066 | Peurach et al. | Jan 2001 | B1 |
6173070 | Michael et al. | Jan 2001 | B1 |
6178261 | Williams et al. | Jan 2001 | B1 |
6178262 | Picard et al. | Jan 2001 | B1 |
6215915 | Reyzin | Apr 2001 | B1 |
6226418 | Miller et al. | May 2001 | B1 |
6246478 | Chapman et al. | Jun 2001 | B1 |
6252986 | Chang | Jun 2001 | B1 |
6272244 | Takahashi et al. | Aug 2001 | B1 |
6272245 | Lin | Aug 2001 | B1 |
6311173 | Levin | Oct 2001 | B1 |
6324298 | O'Dell et al. | Nov 2001 | B1 |
6324299 | Sarachik | Nov 2001 | B1 |
6327393 | Bruder | Dec 2001 | B1 |
6330358 | Nagaishi | Dec 2001 | B1 |
6345106 | Borer | Feb 2002 | B1 |
6363173 | Stentz et al. | Mar 2002 | B1 |
6378009 | Pinkston, II et al. | Apr 2002 | B1 |
6381366 | Taycher et al. | Apr 2002 | B1 |
6381375 | Reyzin | Apr 2002 | B1 |
6385340 | Wilson | May 2002 | B1 |
6393151 | Yamamoto et al. | May 2002 | B1 |
6393395 | Guha et al. | May 2002 | B1 |
6408109 | Silver et al. | Jun 2002 | B1 |
6411734 | Bachelder | Jun 2002 | B1 |
6421458 | Michael et al. | Jul 2002 | B2 |
6424734 | Roberts et al. | Jul 2002 | B1 |
6453069 | Matsugu et al. | Sep 2002 | B1 |
6457032 | Silver, et al. | Sep 2002 | B1 |
6462751 | Felser et al. | Oct 2002 | B1 |
6466923 | Young et al. | Oct 2002 | B1 |
6501856 | Kuwano et al. | Dec 2002 | B2 |
6516092 | Bachelder | Feb 2003 | B1 |
6529852 | Knoll et al. | Mar 2003 | B2 |
6532301 | Krumm et al. | Mar 2003 | B1 |
6563324 | Nichani | May 2003 | B1 |
6594623 | Wang et al. | Jul 2003 | B1 |
6614926 | Fix et al. | Sep 2003 | B1 |
6625303 | Young et al. | Sep 2003 | B1 |
6636634 | Melikian et al. | Oct 2003 | B2 |
6639624 | Bachelder et al. | Oct 2003 | B1 |
6658145 | Silver et al. | Dec 2003 | B1 |
6681039 | Roberts et al. | Jan 2004 | B1 |
6681151 | Weinzimmer et al. | Jan 2004 | B1 |
6687402 | Taycher et al. | Feb 2004 | B1 |
6690842 | Silver et al. | Feb 2004 | B1 |
6691126 | Syeda-Mahmood | Feb 2004 | B1 |
6691145 | Shibata et al. | Feb 2004 | B1 |
6714679 | Scola et al. | Mar 2004 | B1 |
6728582 | Wallack | Apr 2004 | B1 |
6748104 | Bachelder et al. | Jun 2004 | B1 |
6751338 | Wallack | Jun 2004 | B1 |
6751361 | Wagman | Jun 2004 | B1 |
6760483 | Elichai et al. | Jul 2004 | B1 |
6771808 | Wallack | Aug 2004 | B1 |
6785419 | Jojic et al. | Aug 2004 | B1 |
6836567 | Silver et al. | Dec 2004 | B1 |
6850646 | Silver | Feb 2005 | B1 |
6856698 | Silver et al. | Feb 2005 | B1 |
6859548 | Yoshioka et al. | Feb 2005 | B2 |
6909798 | Yukawa et al. | Jun 2005 | B1 |
6959112 | Wagman | Oct 2005 | B1 |
6973207 | Akopyan et al. | Dec 2005 | B1 |
6975764 | Silver et al. | Dec 2005 | B1 |
6985625 | Silver et al. | Jan 2006 | B1 |
6993177 | Bachelder | Jan 2006 | B1 |
6993192 | Silver et al. | Jan 2006 | B1 |
7006712 | Silver et al. | Feb 2006 | B1 |
7016539 | Silver et al. | Mar 2006 | B1 |
7043055 | Silver | May 2006 | B1 |
7043081 | Silver et al. | May 2006 | B1 |
7058225 | Silver et al. | Jun 2006 | B1 |
7065262 | Silver et al. | Jun 2006 | B1 |
7088862 | Silver et al. | Aug 2006 | B1 |
7139421 | Fix et al. | Nov 2006 | B1 |
7164796 | Silver et al. | Jan 2007 | B1 |
7190834 | Davis | Mar 2007 | B2 |
7239929 | Ulrich et al. | Jul 2007 | B2 |
7251366 | Silver et al. | Jul 2007 | B1 |
8081820 | Davis et al. | Dec 2011 | B2 |
20020054699 | Roesch et al. | May 2002 | A1 |
20050117801 | Davis et al. | Jun 2005 | A1 |
Number | Date | Country |
---|---|---|
06-160047 | Jun 1994 | JP |
3598651 | Sep 2004 | JP |
3598651 | Dec 2004 | JP |
9718524 | May 1997 | WO |
Number | Date | Country | |
---|---|---|---|
20070183668 A1 | Aug 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10625205 | Jul 2003 | US |
Child | 11670199 | US |