The present invention relates to integrated circuit design, and more particularly, to techniques for estimating yield of an integrated circuit design.
Integrated circuit design requires adherence to a basic set of design ground rules. Additional recommended rules may apply when one wants to make design changes to improve production yield of a particular design. However, even when these rules are followed, some design changes can conflict. For example, adding redundant wiring vias improves the yield with regard to electrical opens, but can degrade the yield with regard to electrical shorts as a result of the expanded metal shapes associated with the additional vias.
Thus, determining the effects certain design changes will have on yield is an important factor in integrated circuit development. In most instances, it is impractical (if at all possible) to physically implement design changes and then ascertain how those changes impact the yield, especially given the costs associated with manufacturing today's high-density circuits. Take for instance the case of very-large-scale integration (VLSI) macros which contain hundreds of thousands to millions of elements. It would be impractical, both from a time and budgetary standpoint, to ‘mock up’ different designs in hopes of determining which design provides the best yield.
The most effective solution to this problem would be a process by which the yield of a given design could be predicted before any actual manufacturing takes place. With VLSI, however, the sheer number of elements present prevents conventional yield estimation techniques from operating in a time-effective manner. Thus, manufacturing capabilities become severely limited by the design process.
Therefore, techniques that permit yield prediction in real time for high-density integrated circuits, such as VLSI, would be desirable.
The present invention provides techniques for estimating yield of an integrated circuit design. In one aspect of the invention, a method for determining a probability of failure of a very-large-scale integration (VLSI) query design is provided. The method includes the following steps. A Voronoi diagram is built comprising a set of shapes that represent the design, wherein each edge of a given one of the shapes represents a separate Voronoi cell in the Voronoi diagram. The Voronoi diagram is converted into a rectangular grid comprising 2t×2s rectangular cells, wherein t and s are chosen so that one rectangular cell contains from about one to about five Voronoi cells. A probability of failure is computed for each of the cells in the grid. The cells in the grid are merged pairwise. A probability of failure for the merged cells is recomputed which accounts for a spatial correlation between the cells. The pairwise merge and recompute steps are performed s+t times to determine the probability of failure of the design.
In another aspect of the invention, a method for estimating yield of a wafer having a plurality of chips of a given design printed thereon is provided. The method includes the following steps. The chip design is divided into a plurality of rectangular cells, wherein each of the cells is chosen to be small enough such that focus and dose values across the cell can be assumed to be constant. A process window is determined for each of the cells. The focus and dose values on the wafer are measured. The measured focus and dose values are used to determine a Gaussian random component of the focus and dose values. The focus and dose values on the wafer are represented as a sum of a systematic component of the focus and dose values and the Gaussian random component of the focus and dose values. Wafer yield is estimated based on a number of the chips on the wafer for which at each point (x, y) the focus and dose values, as represented as the sum of the systematic component of the focus and dose values and the Gaussian random component of the focus and dose values, belong to a corresponding one of the process windows.
A more complete understanding of the present invention, as well as further features and advantages of the present invention, will be obtained by reference to the following detailed description and drawings.
In step 102, a database is built of patterns of shapes which can potentially cause a loss of yield of a design. The most likely candidates are the patterns which break some recommended design rules and are only a couple of nanometers (nm) away from breaking some design ground rule. For example, a typical ground rule is that two wires cannot be closer than 90 nm to each other. Therefore, if two wires in a given pattern are 92 nm away from each other, then that pattern is only two nm away from breaking the ground rule. This database has to be built only once for a given technology, and can then be used to predict yield for all query designs.
All occurrences of the patterns from the database in the design are detected (also referred to herein as “hotspots”). This seemingly very hard problem solves easily in O(NlogN) time by means of Voronoi diagram. Namely, in step 104, a Voronoi diagram is built of a set of shapes that represent the query design and which belong to a universal bounding box. Each edge of a shape represents a separate Voronoi cell in the Voronoi diagram (wherein an edge of the Voronoi diagram is a subset of locus points equidistant from some two edges of the original shapes). Each Voronoi cell is the locus of points which are closer to a given shape edge than to any other shape edge (i.e., the Voronoi diagrams are built with respect to the shape edges (segments), not the shapes themselves, and as such there is a one-to-one correspondence between shape edges and Voronoi cells). By way of example only, each rectangle of the design has exactly four Voronoi cells corresponding to it. In step 106, based on the Voronoi diagram, all occurrences of the patterns are then detected in a single pass through the edges of the Voronoi diagram by examining some simple quantitative characteristics of the adjacent Voronoi cells. This process is described in detail in U.S. application Ser. No. 12/174,924, entitled “Implementing Integrated Circuit Yield Estimation Using Voronoi Diagrams,” filed by M. Monkowski et al., filed on Jul. 17, 2008 (hereinafter “Monkowski”). By way of example only, in Monkowski a lithography simulation layout is partitioned into Voronoi regions using an octal distance metric, wherein each exterior Voronoi edge region is bounded by a single edge of a design shape and two or more bisectors. Additional bisectors or transition boundaries may be added for Voronoi regions containing vertices not connected by a bisector to the design shape to simplify the Voronoi regions to three or four sides. Failure probabilities can be pre-computed (and then obtained from lookup tables followed by a simple arithmetic computation) as a function of edge orientation and spacing (on the Voronoi Diagram).
The probability of failure can be obtained by considering the edges of the Voronoi diagram one at a time, independently of each other (i.e., in a “single pass”) as the edges are disjoint from one another. By comparison, if the original shapes are used, groups of interacting shapes have to be considered. These groups (vicinity clusters) can overlap one another (not disjoint) and it is not an easy task to identify them. The Voronoi diagram is an excellent means for identifying the vicinity clusters of interacting shapes, as one Voronoi edge equates with one cluster. See also, Mervyn Y. Tan, “A Survey of Distance Metrics Approximating L2 in the Construction of Voronoi Diagrams for VLSI Applications,” 20th Computer Science Seminar (2004) and Luo et al., “An IC Manufacturing Yield Model Considering Intra-Die Variations,” 43rd DAC (2006).
The term “patterns of shapes,” as used herein, refers to the vicinity clusters of shapes (the shapes being the original design shapes, such as the shapes that represent the query design (see description of step 104 above)). As highlighted above, each cluster corresponds to one Voronoi edge. With Voronoi diagrams there is a one-to-one correspondence between its edges and the groups of interacting shapes which match one of a given number of patterns (vicinity cluster patterns).
Binary subdivision is then used to predict yield of the query design, wherein yield is equal to 100 percent (%) minus the probability of failure. In step 108, the Voronoi diagram is converted into a rectangular grid comprising a plurality of rectangular cells. Namely, D is the maximum diameter of the Voronoi cells in the design. The bounding box of the design is partitioned into 2t×2s rectangular cells with side lengths between D and 2D, wherein t and s are chosen so that one rectangular cell contains from about one to about five Voronoi cells. Voronoi cells and rectangular cells of the grid should be approximately equal in size, with the best proportion being one rectangular cell for about two Voronoi cells. However, because the correlation between process parameters at any two hotspots at a distance less than 3,000 nm (which is greater than or equal to 10 times the diameter of a voronoi cell) is practically 100%, any proportion (of rectangular cell(s) to Voronoi cell(s)) between 1:10 and 10:1 will give the same final result.
In step 110, a probability of failure is computed for each of the cells in the grid. Since the sizes of the cells in the grid are typically so small that the value of the process parameters (e.g., dose, focus, photoresist thickness) do not vary in a single cell (for example, for 12 s technology the cells in the grid have sides of from about 200 nm to about 500 nm), it may be assumed that the random events of having a failure in Voronoi cells C1, C2, : : : Ck whose centers belong to the same grid cell are completely correlated. That is, the probability of failure (Pfail) of the whole rectangular cell is equal to the probability of failure of the pattern within that rectangular cell most vulnerable to deviation of process parameters from their standard values, i.e.,
Pfail(the rectangular cell)=max(Pfail(C1),Pfail(C2), . . . ,Pfail(Ck)).
The result of steps 108 and 110 is a 2t×2s rectangular grid with the computed probabilities of failures for each rectangle (see
The next step is, given a list of pairs {coord. of the center of Voronoi cell, the yield loss in the cell} find the total yield loss (i.e., the probability of failure or 100%−yield) of the whole design. This problem would be easy to solve if the random events of failures at different cells were independent.
Unfortunately it is not so. Suppose Voronoi cell C1 produces a failure. There has to be a reason behind this. The reason is usually a large deviation of dose, focus or some other process parameter from its nominal value (if the manufacturing process is perfect at a given point and the design complies with all ground rules it is impossible to have a failure). That means that the deviation of the process parameters from their nominal values is most probably large in any cell C2 which is close to C1. Consequently the event “C1 fails” implies with high probability that “C2 fails.” If the formula for independent events (Pfail(C1 or C2)=Pfail(C1)+Pfail(C2)−Pfail(C1)·Pfail(C2)) is used, the probability of failure of the design will be greatly overestimated. In order to provide a good yield estimation, the spatial correlation between the failures at different points must be taken into account.
Provided herein are techniques for fast and accurate prediction of the probability of failure of the whole design given the probabilities of failures and the coordinates of all the patterns detected from the Voronoi diagram and the spatial correlation parameter C (where C depends only on the manufacturing process, not on the design).
Specifically, given a two dimensional array of probabilities of failure of each cell in the rectangular grid (see, e.g., steps 108 and 110, described above), the estimated probability of failure of the whole design is determined in s+t number of steps. At each step cells are merged horizontally or vertically by two and the probabilities are recomputed. For example, in step 112, the cells in the grid are merged horizontally and/or vertically in a pairwise manner. The merging of cells is demonstrated, for example, in
In order to find the right function ƒ(p1, p2, r), some reasonable assumptions are made about the physical nature of the failures. The correctness of these assumptions can be checked by comparing the predicted probability of failure with the actual probability of failure obtained experimentally.
The simplest way would be to assume that the failures in all cells are independent. In that case one would have:
f(p1,p2,r)=p1+p2−p1p2,
which is a “first order” or “no correlation” model. Unfortunately the first order model fails to give an accurate yield estimate for a majority of designs. In reality, local failures are caused by deviations of local process parameters such as focus, dose and photoresist thickness from their nominal values. The values of these parameters are not independent in neighboring cells. Rather, the values are to be modeled as Gaussian random variables at each point with positive pairwise correlations. The closer the points are to one another, the larger the correlation. For example, if there are 100 instances of a pattern all positioned at a very small distance from a fixed point on the design and one instance contributes 0.001% to the probability of failure, then all 100 instances will contribute again only 0.001% (not 100·0.001%) because the random events of having a failure at each instance are almost totally correlated.
In the present techniques, several assumptions are made. First, it is assumed that the cause of failure in a cell with center (x, y) is the deviation of some “universal” process parameter ζ(x, y) from its nominal value. Without loss of generality, it is assumed that this nominal value is zero at each point. The universal process parameter ζ(x, y) is introduced solely for the purpose of building the model, it does not correspond to any real physical quantity. It is assumed that ζ(x, y) is a two dimensional Gaussian stochastic process with expectation zero. In particular, at each point, ζ(x, y) is a Gaussian random variable with expectation zero. The deviation σ(x,y) of ζ(x, y) at each point is chosen so that the probability of failure of each cell is equal to the probability of failure computed from the Voronoi diagram (see below).
It is also assumed that, given a random event, the cell (x, y) causes a failure if ζ(x, y) does not belong to the segment [−1, 1]. Then at each point (x, y), σ(x, y) and the probability of failure p(x, y) are functions of each other:
at point (x, y):
wherein
is the normal Gaussian cumulative distribution function, and wherein
Equation 1 is depicted graphically in
Since the probabilities of failure for each cell are known from the Voronoi diagram, σ(x, y) is chosen according to Equation 1 (above) and the random Gaussian variables ζ(x, y) at the center (x, y) of each cell become well defined. However, the Gaussian stochastic process y) is not yet well defined. Namely, only marginal distributions of ζ(x, y) at each fixed point are defined, but not the joint distribution. To define ζ(x,y) completely, the correlations (see below) between the marginal distributions at each pair of points need to be described (see immediately below).
An additional assumption is made about the process, namely that ζ(x, y) is Markovian. That is, for any three points ν1, ν2, ν3 such that ν2 belongs to the segment
∀cεIR: the random variables ζ(ν1)|(ζ(ν2)=c) and ζ(ν3)|(ζ(ν2)=c) are independent.
This assumption is a natural assumption about physical processes such as dose or off-focus distance. It is known from the theory of stochastic processes (see, for example, G. Grimmett et al., Probability and Random Processes, ISBN 0-19-857222-0, Oxford University Press (2003), p. 407, equations (11) and (12)) that the correlations between the values of a Markovian Gaussian process at points ν1, ν2, ν3; ν2,ε[ν1, ν3] satisfy
Cor(ν1,ν2)Cor(ν2,ν3)=Cor(ν1,ν3),
which implies the following expression for the spatial correlation: for any two points w1 and w2 Cor (ζ(w1), ζ(w2))=e−C·distance (w1, w2) for some constant C>0 be used instead of Markovian expC*dist.
In the case of the Markovian process, the constant C can be determined by a linear regression method using analysis of manufacturing data. See for example, Cho et al., “A Data-Driven Statistical Approach to Analyzing Process Variation in 65 nm SOI Technology,” Proceedings of the Int'l Symposium on Quality Electronic design (ISQED), pages 699-702 (2007).
This spatial correlation function is the simplest and most natural for process parameters, just as a Gaussian distribution is the most natural distribution to assume about a physical random variable. In general, not every monotonically decreasing function can be a spatial correlation function. For a detailed description of possible spatial correlation functions, see, for example, J. Xiong et al., “Robust Extraction of Spatial Correlation,” ISPD, pgs. 2-9 (2006). If some special information is known about the behavior of the process parameters, one of these functions may need to be used instead of Markovian e−C·dist.
The discrete version of ζ(x, y) is a multivariate Gaussian variable with one coordinate per each cell. It is now well defined wherein the expectation is:
Mζ(x,y)=0 at all points,
the deviation is:
where p(x, y) is known from the Voronoi diagram
and the correlation is:
Cor(ζ(x1,y1),ζ(x2,y2))=e−C√{square root over ((x
The scalar parameter C remains the same for all designs for a given technology and has to be defined experimentally.
Now an explicit expression for ƒ(p1, p2, r) can be written. A double cell, i.e., two merged cells, causes a failure if and only if at least one of its subcells, i.e., at least one of the two merged cells, causes a failure. That is a double cell fails if and only if (ζ(x1, y1), ζ(x2, y2)) does not belong to [−1, 1]×[−1, 1], wherein (x1, y1), (x2, y2) are the centers of the two subcells (see, for example,
ƒ(p1, p2, r) does not express via elementary functions. The best way to compute ƒ(p1, p2, r) in practice is to use linear interpolation by a set of points in the cube σ1ε[0, 1], σ2ε[0, 1], p(r)ε[0, 1] (a 21×21×21 set used in the implementation seems to give a satisfactory precision).
The above binary subdivision yield prediction technique provides a realistic estimate for the yield of VLSI designs using only a linear runtime and a linear amount of memory in the number of Voronoi cells and consequently in the number of elementary shapes in the design. The present binary subdivision yield prediction technique is only a heuristic, i.e., it does not guarantee the correct result in all cases.
The reason for not making an exact determination is the strict runtime constraint. VLSI designs contain hundreds of thousands to millions of elements. Thus, to make a yield estimator that is able to run in an interactive mode, it must be restricted to operations which can be run in linear time (e.g., N2 operations would already require 1012 floating point operations, each of which takes at least 10 clock cycles).
A mathematically ‘correct’ way of computing the probability of failure of a design is to compute the whole N-by-N covariance matrix of ζ(x, y), wherein N is the number of cells in the Voronoi diagram, and then find the probability that all the coordinates of ζ(x, y) belong to [−1, 1] (by a numerical integration or Monte Carlo method). Unfortunately, this method requires N2 memory and at least N3 runtime which makes it practically useless.
The following description provides some basic facts about multivariate Gaussian distributions. With regard to a one dimensional Gaussian distribution with expectation μ and deviation σ, the standard normal Gaussian density function is:
The general Gaussian density function is:
With regard to a standard normal multivariate Gaussian distribution, let ζ be a random variable taking values in IRn. ζ is called standard normal Gaussian if it has density function:
With regard to a multivariate Gaussian distribution with expectation vector μ and deviation linear symmetric positive definite operator S, ζ is called Gaussian if ζ=Aξ+μ for some standard normal Gaussian random variable ζ, non-degenerate linear operator A: IRn→IRn and vector μεIR. This is equivalent to the statement that ζ has density function:
To get the graph of distribution of ζ=Aξ+μ, apply the affine transform x→Ax+μ to the graph of standard normal Gaussian distribution and then rescale the color intensity by |det A|−1 times. See, for example,
The following statement can then be made that any non-degenerate linear operator A:IRn→IRn can be represented uniquely as a product of a symmetric positive definite operator S and an orthogonal operator C:
A=SC.
Obviously, the distribution of Aξ+μ=SCξ+μ does not depend on C.
The linear symmetric positive definite operator S is called “deviation” of Gaussian random variable SCξ+μ. Vector μ is the mathematical expectation of SCξ+μ. The following statement is then also made that there is a one to one correspondence between distributions of Gaussian random variables and pairs
With regard to a multivariate Gaussian distribution as a joint distribution of coordinates, tensor notation is used. For example, instead of vector ν one writes νi (a onetime contravariant tensor), instead of linear functional l one writes li (a onetime covariant tensor) and instead of bilinear functional B one writes Bij (a twice covariant tensor). The small letter indexes are reserved for the tensor notation only. Assigning values to these indexes makes no sense. The capital letters and numbers are used as regular indexes, i.e., to enumerate elements of a finite set. For example, vectors a1, a2, . . . , aN in tensor notation write as a1i, a2i, . . . , aNi.
Let ζi=Sjiζj+μi be a Gaussian random variable and {x1i, x2i, . . . , xNi} be an orthogonal basis in IRN. In this basis, μi is a column of coordinates and Sji is a symmetric positive definite matrix. The distribution of ζi becomes the joint distribution of the coordinates 1 . . . N of ζi:xiKζi, K=1 . . . N , where {xi1, xi2, . . . , xiN} is the basis of conjIRN conjugate to {x1i, x2i, . . . , xNi}.
The following statement is then made that any marginal distribution of a joint Gaussian distribution is Gaussian. The following definition is then presented that the covariance of two (jointly distributed) random variables φ, and ψ
Cov(φ,ψ)
is equal to
M((φ−Mφ)(ψ)).
It is notable that the covariance of two independent variables is zero.
The following statement is then made that:
∀1≦I≦N,1≦J≦N:Cov(xmIζm,xnJζn)=M((xmISpmξp)(xnJSqnξq))=xmISpmxnJSqnM(ξpξq)=xmISpmxnJSqnδpq=xmISkmSknxnJ.
That is the covariance of the I-th coordinate of ζk and the J-th coordinate of ζk is equal to the element (1,j) of the matrix SST.
The following definition is then presented that bivector Vij
and the covariance matrix
wherein μ1, μ2, . . . , μN denote the corresponding coordinates of μi and V11, . . . , VMM denote the corresponding elements of the matrix representing Vij.
In particular, each coordinate of ζi is a Gaussian random variable with
Var(xkIζk)=element(I,I) of V and M(xkIζk)=coordinate I of μ.
It is notable that the analog of the above statement for the deviation matrix S will not hold. That is, the deviation matrix of the joint distribution of the first N coordinates of ζk is (generally) not equal to the [1 . . . N]×[1 . . . N] submatrix of S.
The following definition regarding correlation is then presented that the correlation of two scalar jointly distributed random variables φ, ψCor (φ, ψ) is equal to
Let scalar variables x and y have a joint Gaussian distribution. Denote Cor(x, y) by ρ. Then the covariance matrix has form
Consider the normalized random variables:
Thus, the correlation of x and y has the following sense:
ρ is close to −1:
with high probability is “nearly equal” to
ρ=0: x and y are independent,
ρ is close to 1:
with high probability is “nearly equal” to
The following statement is then made that if x1, x2, . . . , xn are scalar random variables with a joint Gaussian distribution, then the one dimensional distributions of xi, 1≦i≦n together with the pairwise correlations Cor(xi,xj) 1≦I≦j≦n uniquely define the joint distribution, and vice versa.
Also provided herein is a methodology for finding the wafer yield for a given VLSI design. Wafer yield is defined herein as an average percentage of chips on a wafer which will be manufactured correctly. The methodology is based on the following main ideas (which will be described in further detail below). First, physical data (obtained by scatterometry) is used to determine one or more characteristics of the lithographical equipment being used for fabricating the design. These characteristics include, but are not limited to, the systematic component of focus and dose values across the wafer and the covariance kernel (i.e., the dependency of correlation on distance wherein the correlation of the values of process parameters (such as off focus distance or dose) at any two given points depends only on distance between these two points) for the random deviation from the systematic component of the focus and dose values across the wafer. A systematic component is what repeats from one exposure to another (see, for example,
If all design ground rules (see above) are satisfied, then it is assumed that a process window (i.e., a range of process parameter (e.g., focus and dose) values, see description of
Specifically,
Litho simulations are then used to define a process window, i.e., a set of process parameters under which the printed image of the chip design is good. Specifically, in step 904, a process window is determined for each cell by running several optical simulations for different values of focus and dose for each cell. For example, each simulation tests a pair of parameters (focus, dose) and the result of each test is either “pass” or “fail.”
In step 906, the systematic component of focus and dose values are measured by a scatterometry method for the entire wafer. This process is shown illustrated in
A “covariance kernel” of a stationary Gaussian stochastic process R(x, y) is a function K (R(xa, ya), (xb, yb)) that computes the covariance between values of the process between two points a=(xa, ya) and b=(xb, yb). This covariance kernel completely defines the stationary Gaussian stochastic process. In step 908, the scatterometry data (from step 906) is used to determine the variance and the covariance kernel of the random Gaussian component R(x, y) of focus and dose values by linear regression. The process for determining the variance and covariance kernel would be apparent to one of skill in the art and thus is not described further herein. This way, in step 910, the values of focus and dose at any given point (x, y) on the wafer for a single lithographical exposure can be represented as a sum of the systematic component S(x, y) (known from step 906) and the Gaussian random component R(x, y) (see, for example,
Now, when the Gaussian stochastic processes Focus (x, y) and Dose (x, y) are well defined, in step 912, a number of iterations of a Monte Carlo simulation are run to generate a set of values for the Gaussian random component of focus and dose for every one of the cells on each chip. The output of each iteration is thus the number of chips on the wafer for which at each point (x, y) (corresponding to a point within each chip) the values of focus and dose belong to (i.e., fall within) the corresponding process window. The output of the simulation is the arithmetic mean of the outputs for each iteration, i.e., the wafer yield which is the (expected) number of chips on the wafer that have no process window violations.
Simulating (sampling) a Gaussian stochastic process with a given covariance matrix generally takes O(k2) time, wherein k is the number of points at which the value of the process is computed. The random component of the focus and dose is shift invariant, i.e., it does not depend on what chip on the wafer is chosen. Thus,
i.e., k ranges approximately from 1×107 to 1×108. In this situation the quadratic runtime is obviously not acceptable.
However, in the case when the covariance matrix is obtained from the covariance kernel a special technique can be used which allows the runtime to be reduced to just O(rk), wherein r is about 20. This technique is described in detail below.
As shown in
As highlighted above, the next step is to measure the systematic component of focus and dose for the wafer using a scatterometry method. This process is shown illustrated in
What follows is a description of how the systematic component of focus and dose values across a wafer is determined by a scatterometry method. The variation of focus and dose across small regions (of size ˜0.1 millimeters (mm)) consists only of the random component (assuming the systematic component to be constant). So the values of focus and dose are modeled as random processes with the mean value equal to that constant value S(x, y) of the systematic component. The latter is determined by a scatterometry method.
The wafer is then divided into a regular grid G, with each grid cell of this size. For a fixed piece of lithography equipment, the values S_focus(x, y) and S_dose(x, y) over these grid cells form two dimensional functions, like the ones shown on
By way of example only,
These characteristics of the resist can then be used to determine the mean values of focus and dose for each cell in the grid G, defined over the wafer (i.e., mean values of focus and dose are measured by shooting light, see above). These mean values form two two dimensional functions Sfocus(x,y) and Sdose(x, y) which are required for the complete description of a Gaussian random process (see, for example, the description of
What follows is a description of Fast Monte Carlo sampling by Eigenvalue decomposition of a covariance kernel. With Eigenvalue decomposition of a stochastic process, consider a two dimensional stochastic process R(x, y) over some closed domain D. For example, the random values of the random component of focus over a chip can be such a stochastic process, i.e., the normally distributed random focus component at any location (x, y) on the chip area can be the normally distributed random variable R(x, y).
If K(a; b) is the covariance kernel of R(x, y), where a=(xa, ya) and b=(xb, yb) are any two points on D, then the orthogonal decomposition of R(x, y) is given by the Karhunen-Loeve expansion:
where λj is the j-th largest eigenvalue of the covariance kernel K and ƒj(x, y) is the corresponding eigenfunction of K. The eigenpairs (λj,ƒj) are solutions of the integral equation
∫DK(a,b)ƒ(a)da=λƒ(b) (5)
where ƒj are orthonormal. The random variables (RVs) ξj are uncorrelated. From Equation 4, it can be seen that the j-th eigenvalue λj is a measure of the contribution of the j-th RV ξj to the overall variance of the process.
The Karhunen-Loeve expansion can be understood as follows. The stochastic process R(x, y) contains an infinitely large number of random variables (RVs), one for each location on the domain D. These RVs may be correlated, as represented by the covariance kernel K. The Karhunen-Loeve expansion provides a new set of RVs (ξj) that can reproduce all these location-defined RVs, as per Equation 4. However, these new RVs possess two useful properties. First, they are uncorrelated, unlike the original RVs in the process. Second, they are arranged so as to maximally capture the statistical variance of the process in the minimum number of RVs. In other words, the first r terms of the expansion (Equation 4) capture the maximum possible variance of the original process R(x, y) that is captureable by any set of r uncorrelated RVs.
With the eigenvalues λj arranged in descending order of magnitude, the summation in Equation 4 is truncated to the first r terms, as
where r is small (e.g., 25). This truncation provides a reasonable approximation of the process R, because of the second property listed above. Here, r is chosen using a pre-defined criterion of truncation accuracy. Using this truncation, all the random values R(x, y) for all locations on D can be generated using just r random variables ξ1, . . . , ξr. Hence, the random component of focus and dose across the entire chip can be generated using a total of only 2r random variables.
What follows is a description of computing the eigendecomposition of a covariance kernel. It can now be seen how the eigenpairs (λj,ƒj(x, y)) can be computed, using as an example covariance kernel a two dimensional exponential kernel,
K(a,b)=e−C
See R. Ghanem et al., “Stochastic Finite Elements: a Spectral Approach,” Dover, revised edition, pages 27-29 and 148-149 (2003) for detailed derivations of the following mathematical results. If (Lx, Ly) are the dimensions of the chip, then the eigenpairs of this kernel are given by:
wherein αj is the solution of the following equations,
cx−αj tan(Lxαj)=0 for odd j, and αj+cx tan(Lxαj)=0 for even j, (10)
and βj is the solution of the same equations, but with cx replaced by cy and Lx replaced by Ly.
What follows is a description of Fast Monte Carlo simulation using a reduced number of uncorrelated random variables. The random component of the focus value at any location (x, y) on the chip is given by Equation 6. The eigenpairs (λj, ƒj(x, y)) for j=1, . . . , r for a given manufacturing process are pre-computed. The wafer yield is the expected number of chips on the wafer that have no process window violations. This yield can be estimated using Monte Carlo simulation. In each iteration of the simulation, a set of values is generated for the random component of the focus and dose for every cell on one chip. This set of random values for focus or dose is called a sample. As highlighted above, the values of focus and dose at point (x, y) for a single lithographical exposure can be represented as a sum of the systematic component S(x,y) and the Gaussian random component R(x, y). For various positions of the chip on the wafer, a check is made for process window violations. In this way the number of chips on a single wafer that have no process window violations for this sample can be counted. This process is repeated for several samples and finally the arithmetic mean is taken of the number of violation-free chips from each iteration. This arithmetic mean is the estimate of the yield. Normally, if there are k cells on the chip, k random values of the random component of focus would need to be generated using a random number generator and impose a k×k covariance matrix, for each sample. This operation has a computational cost that is proportional to k2, and is, hence, prohibitively expensive for the usual large values of k. However, with Equation 6, only r random values ξ1, . . . , ξr, need to be generated, that are uncorrelated, and then the random component of focus at every cell using Equation 6 can be computed. Now, the computational cost is proportional to only rk, where r is much smaller than k. This can be thousands to millions of times faster than the previous method. The same arguments apply to the case of the random component of dose.
Turning now to
Apparatus 1600 comprises a computer system 1610 and removable media 1650. Computer system 1610 comprises a processor device 1620, a network interface 1625, a memory 1630, a media interface 1635 and an optional display 1640. Network interface 1625 allows computer system 1610 to connect to a network, while media interface 1635 allows computer system 1610 to interact with media, such as a hard drive or removable media 1650.
As is known in the art, the methods and apparatus discussed herein may be distributed as an article of manufacture that itself comprises a machine-readable medium containing one or more programs which when executed implement embodiments of the present invention. For instance, when apparatus 1600 is configured to implement one or more of the steps of methodology 100 the machine-readable medium may contain a program configured to build a Voronoi diagram comprising a set of shapes that represent the design, wherein each edge of a given one of the shapes represents a separate Voronoi cell in the Voronoi diagram; convert the Voronoi diagram into a rectangular grid comprising 2t×2s rectangular cells, wherein t and s are chosen so that one rectangular cell contains from about one to about five Voronoi cells; compute a probability of failure for each of the cells in the grid; pairwise merge the cells in the grid; recompute a probability of failure for the merged cells which accounts for a spatial correlation between the cells; and perform the pairwise merge and recompute steps s+t times to determine the probability of failure of the design.
When apparatus 1600 is configured to implement one or more of the steps of methodology 900, the machine-readable medium may contain a program configured to divide the chip design into a plurality of rectangular cells, wherein each of the cells is chosen to be small enough such that focus and dose values across the cell can be assumed to be constant; determine a process window for each of the cells; measure the focus and dose values on the wafer; use the measured focus and dose values to determine a Gaussian random component of the focus and dose values; represent the focus and dose values on the wafer as a sum of a systematic component of the focus and dose values and the Gaussian random component of the focus and dose values; and estimate wafer yield based on a number of the chips on the wafer for which at each point (x, y) the focus and dose values, as represented as the sum of the systematic component of the focus and dose values and the Gaussian random component of the focus and dose values, belong to a corresponding one of the process windows.
The machine-readable medium may be a recordable medium (e.g., floppy disks, hard drive, optical disks such as removable media 1650, or memory cards) or may be a transmission medium (e.g., a network comprising fiber-optics, the world-wide web, cables, or a wireless channel using time-division multiple access, code-division multiple access, or other radio-frequency channel). Any medium known or developed that can store information suitable for use with a computer system may be used.
Processor device 1620 can be configured to implement the methods, steps, and functions disclosed herein. The memory 1630 could be distributed or local and the processor device 1620 could be distributed or singular. The memory 1630 could be implemented as an electrical, magnetic or optical memory, or any combination of these or other types of storage devices. Moreover, the term “memory” should be construed broadly enough to encompass any information able to be read from, or written to, an address in the addressable space accessed by processor device 1620. With this definition, information on a network, accessible through network interface 1625, is still within memory 1630 because the processor device 1620 can retrieve the information from the network. It should be noted that each distributed processor that makes up processor device 1620 generally contains its own addressable memory space. It should also be noted that some or all of computer system 1610 can be incorporated into an application-specific or general-use integrated circuit.
Optional video display 1640 is any type of video display suitable for interacting with a human user of apparatus 1600. Generally, video display 1640 is a computer monitor or other similar video display.
Although illustrative embodiments of the present invention have been described herein, it is to be understood that the invention is not limited to those precise embodiments, and that various other changes and modifications may be made by one skilled in the art without departing from the scope of the invention. The contents of each of the references mentioned above are hereby incorporated by reference herein.
This application is a divisional of U.S. application Ser. No. 12/718,567 filed on Mar. 5, 2010, now U.S. Pat. No. 8,276,102, the contents of which are incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5754432 | Komatsuzaki et al. | May 1998 | A |
6178539 | Papadopoulou et al. | Jan 2001 | B1 |
6210983 | Atchison et al. | Apr 2001 | B1 |
6308304 | Devgan et al. | Oct 2001 | B1 |
6553559 | Liebmann et al. | Apr 2003 | B2 |
6901564 | Stine et al. | May 2005 | B2 |
6947806 | Wang | Sep 2005 | B2 |
7143371 | Allen et al. | Nov 2006 | B2 |
7260444 | Chen et al. | Aug 2007 | B2 |
7260790 | Allen et al. | Aug 2007 | B2 |
7386418 | Lin et al. | Jun 2008 | B2 |
7503020 | Allen et al. | Mar 2009 | B2 |
7512921 | Shibuya | Mar 2009 | B2 |
7747978 | Ye et al. | Jun 2010 | B2 |
8230371 | Borjon | Jul 2012 | B2 |
8250498 | Huang et al. | Aug 2012 | B2 |
20050055121 | Wang | Mar 2005 | A1 |
20060150130 | Allen et al. | Jul 2006 | A1 |
20060190224 | Allen et al. | Aug 2006 | A1 |
20070044049 | Adams et al. | Feb 2007 | A1 |
20070118242 | Stine et al. | May 2007 | A1 |
20070143720 | Bickford et al. | Jun 2007 | A1 |
20070174797 | Luo et al. | Jul 2007 | A1 |
20070220455 | Joshi et al. | Sep 2007 | A1 |
20070240085 | Bickford et al. | Oct 2007 | A1 |
20080189664 | Bickford et al. | Aug 2008 | A1 |
Entry |
---|
E. Papadopoulou, “Critical area computation via Voronoi diagrams,” IEEE Transactions on Computer Aided Design of Integrated Circuits and Systems, V 18 N4, p. 463-474 (1999). |
Mervyn Y. Tan, “A Survey of Distance Metrics Approximating L2 in the Construction of Voronoi Diagrams for VLSI Applications,” 20th Computer Science Seminar (2004). |
Luo et al., “An IC Manufacturing Yield Model Considering Intra-Die Variations,” 43rd DAC (2006). |
G. Grimmett et al., Probability and Random Processes, ISBN 0-19-857222-0, Oxford University Press (2003), p. 407, equations (11) and (12)). |
Cho et al., “A Data-Driven Statistical Approach to Analyzing Process Variation in 65nm SOI Technology,” Proceedings of the Intl Symposium on Quality Electronic design (ISQED), pp. 699-702 (2007). |
J. Xiong et al., “Robust Extraction of Spatial Correlation,” ISPD, pp. 2-9 (2006). |
T.A. Brunner et al., “Process Monitor Gratings,” Proc. of SPIE, 6518 (2007). |
J.A.G. Jess et al., “Statistical Timing for Parametric Yield Prediction of Digital Integrated Circuits,” DAC 2003, Jun. 2-6, Anaheim, CA (2003). |
F. Pikus, “Integrated dfm Framework for Dynamic Yield Optimization,” Proc. of SPIE, 6349 (2006). |
A. Singhee et al., “Exploiting Correlation Kernels for Efficient Handling of Intra-die Spatial Correlation, With Application to Statistical Timing,” In Proc. of Design Automation and test in Europe (2008). |
R. Ghanem et al., “Stochastic Finite Elements: a Spectral Approach,” Dover, revised edition, pp. 27-29 and 148-149 (2003). |
Number | Date | Country | |
---|---|---|---|
20120311510 A1 | Dec 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12718567 | Mar 2010 | US |
Child | 13590300 | US |