1. Field of the Invention
The present invention relates to VLSI device layout data structures, and more particularly to reducing the size and complexity of the data structure.
2. Background Art
Current manufacturing techniques for fabricating VLSI devices require the insertion of non-functional structures, commonly known as dummy features, in order to ensure the planarity of subsequent dielectric and conductive layers in locations where there is no circuitry. VLSI layers commonly populated with these dummy features include the metal, polysilicon and field isolation layers. These dummy features are normally electrically non-functional, although they may be interconnected between different layers, and in some cases dummy features have been used to alter the capacitance of some functional elements. All dummy features used within a layer are normally, but not always, identical.
Depending on the application, data structures of the multiple layers of the VLSI device may be generated from the physical device to verify the circuit design or for the reverse-engineering extraction of the circuitry. These data structures are normally constructed in a vector-based format, known commonly in the industry as GDSII. The dummy features, if not removed from the generated data structure, add more complexity to signal tracing and/or analysis of the circuits; and reduce the clarity with which multiple layers may be seen when overlaid. Additionally they significantly increase the size of the already large vector-based data structures, without significantly adding function. When processing these data structures to recognize function, dummy features add needless processing time.
There exists in the art a method to compress the dummy features in a vector-based data structure to reduce the size of the data. U.S. Pat. No. 6,594,801, which issued to Dishon et al. on Jul. 15, 2003, provides a loss-less method for compressing a data structure representing a layout of a multi-layered VLSI device. This method comprises the steps of (a) generating compressed non-functional element data structures that represent each of the non-functional elements of each layer within the layout data structure, (b) deleting representations of non-functional elements from the layout data structure and (c) adding the compressed non-functional element data structures to generate a compressed data structure representing the layout. While this technique does reduce the amount of data in the data structure, it is a complex compression process requiring intensive computing power. Further, as the technique is directed towards the re-use of the non-functional elements, the method simply compresses the data within the vector-based data structure but does not remove the non-functional elements. The non-functional elements are still present in the data structure and needlessly increase its size and processing time. Furthermore, when the data structure for the entire IC from this method is visualized, the lower metal layers of connectivity are obscured by the dummy features on the upper levels. This complicates signal tracing and analysis for an observer. Still furthermore, the method does not teach how to locate the non-functional elements within the data structure, and as such would not be useful in data structures other than GDSII format data structures.
Therefore there is a need for a method and apparatus to remove dummy features from data structures.
The present invention is directed to a method and apparatus to reduce occurrences of electrically non-functional elements, known as dummy features, from a source data structure. The source data structure may be image data provided by a high-resolution image acquisition system to image electronic circuits and embedded features of an integrated circuit (IC). Alternatively, the source data structure may be vector based data provided in the industry standard GDSII format. In accordance with the present invention, dummy features in the source data structure are detected and then deleted from the source data structure.
In accordance with an aspect of this invention, dummy features in a source data structure are detected by selecting a representative dummy feature pattern or polygon as a reference pattern or polygon, depending on the type of source data structure, and comparing the selected reference pattern or polygon to feature patterns or polygons in the source data structure.
In accordance with a further aspect of the invention, a dummy feature pattern may be selected by framing the dummy feature reference pattern by a pixel matrix of m×n pixels and selecting a cut-off correlation threshold value. A dummy feature polygon may be selected by forming the dummy feature reference polygon by extracting points of interest from the dummy feature and then selecting a cut-off correlation threshold value.
In accordance with another aspect of the invention, the step of comparing the selected reference pattern to feature patterns in the source data structure comprises computing the correlation coefficients between the reference pattern and the feature patterns in the source data structure and comparing computed correlation coefficients to the selected cut-off correlation threshold value. However, the comparing of selected reference polygons to feature polygons in the source data structure includes computing the correlation coefficients between points of interest in the feature polygons in the source data structure and the reference polygon.
In accordance with a specific aspect of the invention, the computed correlation coefficients may be based on gray scale values or may be calculated using a sum of squared differences equation:
where:
I (i, j) is the image array;
P is the reference pattern array;
SSD (i, j) is the correlation coefficient,
(i, j) are the coordinates in the image array.
In accordance with a further aspect of the invention, feature patterns or polygons are selectively removed based on a comparison between their correlation coefficients and the selected cut-off correlation threshold value. A new threshold value may be selected to remove all dummy features in the source data structure or to prevent removal of non-dummy features. In the case of differently shaped dummy features in the same data structure, another reference pattern or polygon will be selected and the process repeated. Once the identified dummy features have been deleted from the source data structure, another data structure may be loaded and the above process repeated.
In accordance with another aspect of the invention, the source data structure with the removed dummy features may be stored in a memory together with the selected dummy feature pattern or polygon and the last selected cut-off correlation threshold.
Other aspects and advantages of the invention, as well as the structure and operation of various embodiments of the invention, will become apparent to those ordinarily skilled in the art upon review of the following description of the invention in conjunction with the accompanying drawings.
The invention will be described with reference to the accompanying drawings, wherein:
For purposes of explanation, specific embodiments are set forth to provide a thorough understanding of the present invention. However, it will be understood by one skilled in the art, from reading this disclosure, that the invention may be practiced without these specific details. Moreover, well-known elements, devices, process steps and the like are not set forth in detail in order to avoid obscuring the scope of the invention described.
The present invention provides a method and apparatus for creating a processed data structure representation of an IC layout with reduced occurrences of electrically non-functional elements, known as dummy features, from a source data structure. The source data structure may be in the form of image data provided by a high-resolution image acquisition system to image electronic circuits and embedded features of an integrated circuit (IC). Alternatively, this source data structure may be provided as a vector-based representation of the layout in the industry standard GDSII format. The source data structure could also be in other formats known to one skilled in the art. The non-functional elements are normally in the form of dummy features which can be used to maintain the planarity of the device between the various interconnect layers.
The apparatus in
When the source data structure is an image-based data structure, the dummy features to be removed are detected by comparing the patterns of features in the source data structure to a user defined dummy feature reference pattern and using a selected cut-off threshold. A correlation coefficient is calculated using the gray-scale values of the pixels in each of the reference pattern and the feature pattern. In the general sense, any patterns in the source data structure, that have a correlation coefficient value better than the threshold value are deemed to be dummy features and are deleted. Those patterns, having a value worse than the threshold value, are deemed not to be dummy features and remain in the data structure. The relationship between the correlation coefficient and the threshold value is dependent on the particular equation used to calculate the correspondence. The selected threshold value may require updating by changing the tolerances in order to remove all dummy features within the data structure. A more detailed description of these steps is provided below with reference to the figures.
The basic steps of the present invention are summarized in the flowchart of
One embodiment of the calibration stage is described in detail below with reference to
After the correlation coefficient is calculated between the dummy reference pattern and the feature pattern, a comparison is made between the calculated correlation coefficient and the selected cut-off threshold value. Once a feature pattern is identified as corresponding to the reference pattern by showing correlation better than the selected threshold value, it is deleted 20 from the layout data structure.
The following formula details the process by which the correlation coefficient may be calculated 18 using a sum of squared difference calculation:
where:
I (i+k,j+c) is the source image array;
P (k,c) is the reference pattern array;
SSD (i,j) is the correlation coefficient for all (i,j);
(i,j) are the pixel coordinates in the source image array;
k is an integer value ranging from 1 to n; and
c is an integer value ranging from 1 to m.
After the comparison is made, the system iterates the coordinates of the feature pattern to compare the next portion of the calibration data structure. This continues until the system has calculated the correlation coefficients for the entire calibration data structure.
When a dummy feature is detected, it is removed 20. Removal means the deletion of the feature from the source data structure, what remains is the background information of the source data structure. In the case of image data this means the replacement of the pixel space occupied by the feature, with pixel data corresponding to background. Information indicating the former presence of a dummy feature will not be available.
A human operator examines the calibration area file to determine if all the dummy features have been removed 34 using the selected 16 cut-off correlation threshold. The operator may update the cut-off correlation threshold by selecting 16 a new value for the cut-off threshold value if an insufficient number of dummy features were removed. If there are dummy features remaining, the operator may choose to lower 16 the correlation cut-off threshold value. Also, if the operator finds that features that are not dummy-features have been removed, the operator may choose to raise 16 the correlation cut-off threshold value. For example, an exact match between the reference pattern 14 and a pattern of interest would require the values for both the defined 14 reference pattern and the pattern of interest to be identical. Due to the non-uniform illumination and noise in an image-based data-structure, the gray-scale levels on identical dummy feature patterns will vary slightly. A more realistic cut-off correlation threshold value may be selected 16, permitting a slight variance between patterns.
It should be noted by those skilled in the art that other methods besides calculating the gray-scale values of dummy feature patterns may be used to calculate correlation without departing from the scope of the invention. As discussed earlier, if the data structure took alternate formats, such as a GDSII format, gray-scale data would not be available, but alternate data could be used for comparison. One skilled in the art would be able to examine the vector-based data structure to extract points of interest from the dummy feature to form a reference polygon. These points of interest could be compared to the feature polygons in the data-structure, which would enable a similar correlation comparison made for the gray-scale data. A correlation threshold could be set for correlation between points of interest in the reference polygon as compared to the feature polygon, identifying the dummy features for removal. Also, one skilled in the art would be able to create a labeled pixel data structure from the GDSII information, wherein the pixel values would correspond to whether or not the pixel was part of the background, a metal line, or a via. For the sake of simplicity, we will not discuss these alternates in detail here, but it should be understood that gray-scale data could be substituted by other types of data upon which a correlation could be made without departing from the scope of the invention. Alternate correlation methods could also be used depending on the format of the source data structure, the other methods for example could include, FFT (Fast Fourier Transform), geometric hashing or feature-based algorithms. It should also be noted that the steps of determining the presence of dummy features and adjusting the cut-off threshold may also be performed algorithmically without departing from the scope of the invention.
The remaining dummy features are detected using the newly updated threshold value. This updating step 34 may be repeated several times until a sufficient number of dummy features have been detected and deleted. Once this is done, the “best fit” cut-off selected 16 threshold value, that is, the last threshold value computed and the defined 14 reference dummy feature pattern are stored 38 in memory.
In another embodiment of the present invention, a user may find that the selected dummy feature reference pattern is not the best example of the dummy feature pattern in the source data structure. If an operator discovers a poor correlation between the reference pattern and the feature patterns; one may chose a new dummy feature pattern as a better representation.
While the invention has been described according to what is presently considered to be the most practical and preferred embodiments, it must be understood that the invention is not limited to the disclosed embodiments. Those ordinarily skilled in the art will understand that various modifications and equivalent structures and functions may be made without departing from the scope of the invention as defined in the claims. Therefore, the invention as defined in the claims, must be accorded the broadest possible interpretation so as to encompass all such modifications and equivalent structures and functions.
Number | Name | Date | Kind |
---|---|---|---|
3909602 | Micka | Sep 1975 | A |
4805123 | Specht et al. | Feb 1989 | A |
5060282 | Molley | Oct 1991 | A |
5060284 | Klees | Oct 1991 | A |
5138672 | Hirabayashi et al. | Aug 1992 | A |
5287856 | Treiber | Feb 1994 | A |
5361311 | Wilson | Nov 1994 | A |
5481625 | Suzuki | Jan 1996 | A |
5544256 | Brecher et al. | Aug 1996 | A |
5548326 | Michael | Aug 1996 | A |
5550936 | Someya et al. | Aug 1996 | A |
5608816 | Kawahara et al. | Mar 1997 | A |
5613013 | Schuette | Mar 1997 | A |
5640200 | Michael | Jun 1997 | A |
5781656 | Hagino et al. | Jul 1998 | A |
5861910 | McGarry et al. | Jan 1999 | A |
5887080 | Tsubusaki et al. | Mar 1999 | A |
5917953 | Ausbeck, Jr. | Jun 1999 | A |
5933522 | Sugimoto | Aug 1999 | A |
6005985 | Brison et al. | Dec 1999 | A |
6047084 | Kent et al. | Apr 2000 | A |
6075905 | Herman et al. | Jun 2000 | A |
6088483 | Nakano et al. | Jul 2000 | A |
6236746 | Chamberlain et al. | May 2001 | B1 |
6290572 | Hofmann | Sep 2001 | B1 |
6295374 | Robinson et al. | Sep 2001 | B1 |
6305000 | Phan et al. | Oct 2001 | B1 |
6333141 | Carter et al. | Dec 2001 | B1 |
6473536 | Chiba et al. | Oct 2002 | B1 |
6477685 | Lovelace | Nov 2002 | B1 |
6567949 | Heinen et al. | May 2003 | B2 |
6581193 | McGhee et al. | Jun 2003 | B1 |
6587579 | Bass | Jul 2003 | B1 |
6594801 | Dishon et al. | Jul 2003 | B1 |
6609235 | Ramaswamy et al. | Aug 2003 | B2 |
6658145 | Silver et al. | Dec 2003 | B1 |
6674890 | Maeda et al. | Jan 2004 | B2 |
6691052 | Maurer | Feb 2004 | B1 |
6706456 | Miyashita et al. | Mar 2004 | B2 |
6731991 | Michalski et al. | May 2004 | B1 |
6751343 | Ferrell et al. | Jun 2004 | B1 |
6846597 | Narukawa et al. | Jan 2005 | B2 |
6865727 | Frerichs et al. | Mar 2005 | B2 |
6870951 | Cai | Mar 2005 | B2 |
6901574 | LaCour et al. | May 2005 | B2 |
6930782 | Yi et al. | Aug 2005 | B1 |
6969762 | Ehrlich et al. | Nov 2005 | B2 |
6975755 | Baumberg | Dec 2005 | B1 |
7003758 | Ye et al. | Feb 2006 | B2 |
7014955 | Chang et al. | Mar 2006 | B2 |
7016539 | Silver et al. | Mar 2006 | B1 |
7020866 | Kamon | Mar 2006 | B2 |
7075704 | Kurashina | Jul 2006 | B2 |
7124386 | Smith et al. | Oct 2006 | B2 |
7206443 | Duvdevani et al. | Apr 2007 | B1 |
7236634 | Miyakoshi et al. | Jun 2007 | B2 |
7236643 | Albertelli et al. | Jun 2007 | B2 |
7239738 | Yasukawa et al. | Jul 2007 | B2 |
7242095 | Tabara et al. | Jul 2007 | B2 |
7278121 | Aitnouri et al. | Oct 2007 | B2 |
7363099 | Smith et al. | Apr 2008 | B2 |
7383521 | Smith et al. | Jun 2008 | B2 |
7409260 | David et al. | Aug 2008 | B2 |
7412676 | Cobb et al. | Aug 2008 | B2 |
7433508 | Sakai et al. | Oct 2008 | B2 |
7448010 | Lenahan et al. | Nov 2008 | B1 |
20020144224 | Frerichs et al. | Oct 2002 | A1 |
20030035592 | Cornog et al. | Feb 2003 | A1 |
20030044059 | Chang et al. | Mar 2003 | A1 |
20030073010 | Narukawa et al. | Apr 2003 | A1 |
20030076361 | Hatanaka et al. | Apr 2003 | A1 |
20030226757 | Smith et al. | Dec 2003 | A1 |
20040098674 | Vuong et al. | May 2004 | A1 |
20040151392 | Miyakoshi et al. | Aug 2004 | A1 |
20040170326 | Kataoka et al. | Sep 2004 | A1 |
20040234135 | Nomizu | Nov 2004 | A1 |
20050096887 | Rice et al. | May 2005 | A1 |
20050129305 | Chen et al. | Jun 2005 | A1 |
20050132306 | Smith et al. | Jun 2005 | A1 |
20050251771 | Robles | Nov 2005 | A1 |
20050271264 | Ito et al. | Dec 2005 | A1 |
20050286755 | Maali | Dec 2005 | A1 |
20060045325 | Zavadsky et al. | Mar 2006 | A1 |
20060050953 | Farmer et al. | Mar 2006 | A1 |
20060059452 | Whitefield et al. | Mar 2006 | A1 |
20060098893 | Kondo et al. | May 2006 | A1 |
20060104103 | Colineau et al. | May 2006 | A1 |
20060161403 | Jiang et al. | Jul 2006 | A1 |
20060245631 | Levenson et al. | Nov 2006 | A1 |
20070062284 | Machida | Mar 2007 | A1 |
20070256039 | White | Nov 2007 | A1 |
20080059920 | Ouali et al. | Mar 2008 | A1 |
Number | Date | Country | |
---|---|---|---|
20070011628 A1 | Jan 2007 | US |