The invention relates to methods for adjusting process variables in a processing flow that comprises a sequence of processing steps. A typical application is the development of optimized process flows in the semiconductor industry, but other applications are envisioned as well.
The fabrication of integrated circuits (ICs) requires the processing of single-crystal (silicon) wafers in a large number of subsequent process steps. The total set of process steps that belongs to a specific technology is called a “process flow” or just simply a “flow.” During each step, the silicon and other involved materials are structured, modified, transformed or in other ways manipulated. The outcome of one process step is then passed on as input to the next. Prominent examples of process steps in semiconductor fabrication are epitaxy, oxidation, film deposition, lithography, etching, ion implantation, and diffusion.
Each process step is characterized by a great variety of process parameters. These correspond directly to specific equipment settings and/or programs (“recipes”) by which the actual fabrication process is determined and controlled. Examples of process parameters include things like growth- or deposition-rates, the composition of gas flows or chemical etchants, exposure times, etch times, furnace temperatures, implant species, implant energies and doses, bias voltages or currents, wait times, and the like.
Once a technology is fully developed, the corresponding process flow is “frozen.” From then on, all process parameters may only vary within a narrow range around previously defined “target” values. This narrow bandwidth is called the specification range or shortly the “spec range.”
Silicon wafers are typically processed in lots of 25, i.e., groups of 25 wafers receive the same treatment, either because they are indeed simultaneously processed in the same piece of equipment or because they are processed in a short sequence as a batch. To develop or improve a technology, it is fundamental to run experiments at various process steps. Therefore, the wafers of “experimental lots” are split up into groups. Different split groups vary at least at one process step in at least one process condition. Wafers that belong to the same split group undergo the same processing. The term “wafer split” (or simply “split”) is used as synonym for “process experiment” herein.
Whether a wafer lot has been split up or not, once it has passed the last process step, it will be more or less extensively tested. The data is then evaluated and analyzed and the results are fed back into the process flow. For standard production material (with typically no applied splits), this is done in order to monitor the process and to enable failure analysis for development material (typically including a number of different splits) to achieve and/or improve a certain device performance. In the context of the invention, focus is on the latter.
A fundamental feedback loop in semiconductor manufacture involves processing, test, evaluation and analysis. Parametric data analysis, however, quite naturally requires a different evaluation approach for device and process development than for monitoring high-volume production. In standard high-volume production (usually) a great many lots are processed in a uniform manner; whereas the wafer splits during development phases are typically applied on just a restricted number of lots. For development material, however, the application of rather complex experimental split matrices and a largely extended test depth, with parameter numbers easily ranging up to several thousands, literally demand for a new methodology to facilitate data evaluation. Evaluating the impact of experimental splits—not to mention possible cross-dependencies—on such extended numbers of (electrical) parameters is not only prone to errors, but in many cases proves to be impossible for more than just the primary parameters. Conventional statistical methods/concepts, such as correlation calculus, ANOVA, CPK, etc., are valuable, but simply not sufficient. Intelligent data reduction becomes the key to achieve and maintain efficiency (and cost effectiveness).
The invention provides an automated data assessment which enables the developer to quickly focus the analysis on those parameters that are truly and significantly affected by an experimental split and/or cross-split.
Specifically, the invention provides a method of adjusting process variables in a processing flow that comprises the following steps: testing processed samples to determine sample parameters of the tested samples; analyzing the sample parameters in relation to the process variables applied in the processing steps to determine the impact of the process variables on the sample parameters; modifying the process variables in an attempt to change the sample parameters towards predetermined target values; and repeating the sequence of processing steps with the modified process variables.
In described embodiments, the analyzing step includes, for given samples: automated matching between patterns of process variables applied for the samples and corresponding sample data sets of parameters determined from the samples; quantifying the degree of match in terms of score values associated with patterns of process variables; and determining the significance of the score values in terms of significance values based on the deviation of the parameters in the sample data sets from the predetermined target values.
In a preferred application, the processing flow is a semiconductor technology development flow and the processing steps involve application of different patterns of processing variables to different samples in a lot of semiconductor wafers. Because of the application of the invention, manual inspection is confined to a reduced data set, easily saving 90% or more of the usual time needed to analyze the full data.
Further aspects of the invention will become apparent from the following detailed description, with reference to the accompanying drawings, wherein:
With reference to
At “Test”, a distinction between “Etest” and “MultiProbe” (=MP) is made. Etest engineering-checks and verifies the electrical performance on the device level (i.e., it measures the parameters of individual devices such as transistors, diodes, capacitors, resistors, inductors, etc.; and is sometimes also called “parametric test”). MultiProbe engineering, on the other hand, checks and verifies the functionality on the circuit level. For the purpose of this disclosure, considerations are confined to parametrical, i.e., Etest data. This, however, should not in any way restrict the applicability of the disclosed method.
The suggested method has been developed to meet the need for an “intelligent” data reduction. To actually perform the automated data assessment, the method can be cast into a software tool, implemented as part of the fundamental feedback loop. The tool helps to largely speed up general split-lot evaluations. The algorithm in the inventive method executes the following six steps for a given process split matrix and the resulting set of parametric data:
1) automatically identifies parameters which are likely to be affected by a specific split;
2) determines possible cross-splits (i.e., superimposed primary splits given in the split matrix) and, as in 1), automatically identifies parameters which have a high possibility for being affected by the cross-split;
3) conducts, for every parameter in the data-set and all possible splits/cross-splits, an automated ranking which yields the best-fitting parameter split combination;
4) calculates a “significance value” for every best fitting parameter split combination by comparing it to a given specification (e.g., the process control document) and so determines an “overall score value”;
5) sorts all parameters according to this overall score value;
6) creates split graphs and statistical split summaries for the most significant parameter split combinations and formats them in a way that they can be readily analyzed;
Steps 1) and 2) are done by abstract pattern recognition. At the heart of the procedure is a general methodology that compares abstract split patterns with patterns found in parametric data. Based on a specific “sameness” methodology, various sets of score values are calculated that focus on different aspects of the comparison. Employing concepts of fuzzy logic operations, these subordinate score values get combined to an overall score value which is eventually used to do the ranking of the parameter split combinations (data reduction).
The basic concepts of the split pattern recognition and significance ranking procedure are outlined below by means of fictitious examples, which will also help to further illustrate some of the terminology.
The application of split matrices to wafer lots has been previously considered. A split matrix in this context is a schematic table that assigns process conditions to wafer numbers.
For the fictitious 25-wafer lot with number #1234567, there are two splits (i.e., process experiments) at two different process steps, namely an implant dose split (As=arsenic) and a diffusion temperature split. Each of the splits contains two split groups (wafer groups with varying process conditions). For the implant split, split-group1 consists of wafers 1-13 with an arsenic implant dose of 1.4E13 cm2 and split-group2 consists of wafers 14-25 with an arsenic-dose of 1.5E13 cm2. For the diffusion split, on the other hand, split-group1 consists of wafers 1-7 and 20-25 with a process temperature of 1000° C. and split-group2 consists of wafers 8-19 with a temperature of 1020° C. (see the corresponding numbers in front of the first column split-group descriptions, and in the two split rows below the wafer numbers). In this table form, there is a unique correlation between wafer number and split-group for every experimental split applied to a specific lot which is processed according to a specific flow. In general, as will be seen below, neither the number of splits nor the number of split-groups is limited to two as in this simple example. It should be kept in mind that the term “split” designates a certain process experiment (as a whole) and the term “split-group” designates a certain group of wafers which actually undergo the same process condition as part of a specific experiment (split).
The two splits of the previous example (i.e., the implant split and the diffusion split) will be called “primary splits” or splits of “cross-split level 1”, because they represent the real process conditions that have actually been applied to a certain lot. In reality, however, two or more splits will often have a “cross-impact” on certain electrical parameters, i.e., the variation of a specific Etest parameter will be influenced by more than just one process experiment. In the case of our example of
Every split-group of the cross-split represents a unique combination of the original split conditions of the two primary splits. In this case, there are 2×2 possible combinations, so that we have 4 new cross-split-groups in total.
This cross-split is a secondary split (cross-split level 2), because two primary splits have been superimposed to form the new split-groups. Analogously, the combination of three primary splits would yield a cross-split of level 3 and so on. (It goes without saying that there had to be at least three primary splits in the original split matrix to build such a tertiary cross-split.) For a given primary split matrix the developed algorithm automatically builds all possible cross-splits up to a user-defined cross-split level. Once they have been created, these cross-splits are treated exactly the same way as the original primary splits during the subsequent evaluation.
Now that the terms “split” and “split-group” on the one hand and the concept of “cross-splits” on the other hand have been introduced, we are not going to use this simple split matrix, whose only purpose was to provide an explanatory example. To illustrate the split pattern recognition and significance ranking methodology we need to proceed from concrete process conditions and use “abstract splits” (see
The evaluation methodology will be applied to a fictitious set of eight test parameters representing, e.g., a number of Etest reads. “Read” in this context is used as synonym for “parameter”.
Applying the split pattern recognition and significance ranking methodology on this test data yields the “score-table” in
By simple inspection we see that, of all splits, the pattern of cross-split “Split1 & Split2” bears the most apparent resemblance to the parametric variation. But why is that?
If we take “Split1”, for example, we would expect that the parametric values of wafers 1-13 (split-group1) are clearly distinct from those of wafers 14-25 (split-group2). Likewise we would expect that within each split-group the values should be approximately same. A quick glance at
If we take “Split3”, for example, the situation is completely different. This split shows an alternating pattern (one wafer of split-group1 is followed by a wafer of split-group2, etc.), i.e., for a parameter affected by this split we would therefore expect that it somehow mirrors this alternating pattern (as, e.g., can be found for “Parameter5”). However, we do not see any such behavior in
As we have just seen, the combination “Parameter4/Split1” already yields a relatively high split id score of 0.95. But what seems to be a good match can still be improved considering cross-splits as well. If we look at the superposition of “Split1” and “Split2” (→“Split1 & Split2”), for example, we obtain a cross-split pattern with four distinct split-groups composed of wafers 1-7, 8-13, 14-19 and 20-25 respectively (see
The columns in
It must be mentioned that the split id scores under real conditions normally do not reach values as high as in these explanatory examples. (There are mainly two reasons for this: 1) the distributions are usually broader (→data overlap); and 2) the differences between split group averages are typically not as pronounced as in the given examples.) For typical cases, split id scores exceeding 0.60 already indicate good, scores greater than 0.80 even excellent matches. On the other hand, if for a specific parameter the highest split id score is small (typically less than 0.20) or even minimal—as it is the case for “Parameter7” (with 0.01) or “Parameter8” (with 0.00)—no correspondence between the parametric variation and any of the split or cross-split patterns could be identified.
Once the list of the highest split id scores has been calculated, the most important step for the split pattern recognition and significance ranking has been done. The multitud” of possible parameter split assignments has been reduced to a 1:1 correlation (parameter best fitting split pattern), and with the split identification score value, we have a (first) cardinal measurable quantity which defines a transitive order on the assigned parameter split pairs.
However, what has been achieved so far is not fully sufficient to assess the impact of process splits on a set of parameters. For this, we need to consider yet another important aspect: the split identification score values we have been using so far can be determined completely independent of any additional (external) data. For their calculation, we only need to know the split pattern (as, e.g., given in
of the spec-range of “Parameter1”, but only
of the spec-range of “Parameter2”. This teaches us two things: Split id scores just quantify how good specific split patterns are mapped to certain parameters. They do not quantify the split-significance. This is true no matter whether parameters respond to the same split, as in the case above (“Split1”), or to different splits, as e.g. in the case of “Parameter2” and “Parameter3” (“Parameter3” has its highest split id score of 1.00 for “Split2”, see
That is the reason why the suggested methodology for a split identification is supplemented by a method for a significance ranking. The ratio of split-group offset to spec width, which has just been calculated, will be called the “significance value” of a split. When a split includes more than two split-groups, the split-group offset is defined as the difference between the average value of the highest and the lowest split-group.
The significance values of the splits with the highest split id scores are listed in
Now we have two separate characteristics—the split id score and the significance value—which must be combined to obtain the so-called “overall score value”. This overall score value is also a cardinal measurable quantity and constitutes the last column in the table of
The combination of the different characteristics (in order to obtain the split id scores and the overall score values) is done by employing basic principles of fuzzy logic operations.
As we can see, the combination of “Parameter4/Split1 & Split2” possesses the highest overall score value, although its split id score is slightly less than that of the pair “Parameter1/Split1”. This is due to the fact that the significance of the cross-split “Split1 & Split2” for “Parameter4” is twice as high as that of “Split1” for “Parameter1”.
A score-table as given in
The preceding disclosure illustrated what kind of input is needed (i.e., the actual parametrical data, the primary split matrix and the specifications for the various parameters), what sort of output will be obtained (i.e., the full split matrix including cross-splits, the split id score- and significance-table and the overall-score-table with the best-fitting parameter split-pairs ranked according to their overall-score value), and how this output must be interpreted in order to facilitate the following data analysis. Despite the fact that only basic elements of conventional statistics and fuzzy logic operation are utilized to conduct the split identification and significance ranking, the concrete methodology used therein is completely new. Furthermore, the underlying principle could also be taken as a basis for a more general approach for parametrical data assessment.
In order to calculate the score and significance values listed in
Process experiments (splits) usually lead to intended or unintended parameter variations which will be measured at Etest (see
In
To compare two distributions, in this context, means to determine a characteristic value which quantifies the degree of matching between the actual and the reference distribution. For this purpose the statistical sameness value is used. It is defined as
Quantities referring to the actual or the reference distribution are subscripted accordingly. The normalization factor is defined by the reference distribution:
NRef≡ΦRef(μRef+kσRef)−ΦRef(μRef−kσRef)
The non-normalized sameness NRef×S yields the probability to find a value x of the actually considered distribution within the k σRef range around the mean-value μRef of the reference distribution. In the example of
The criteria whether a split pattern matches a specific parameter variation are the following: 1) homogeneity of the parameter values within each split-group; and 2) distinguishable offsets between different split-groups. “Homogeneity” in this context simply means: Can a specific number of wafers be seen to form a coherent group, i.e., is the parametrical distribution of each wafer similar/same to the parametrical distribution defined by the other wafers within the same split-group? For the cross-split labeled “Split1 & Split2” in our example of
The notion “homogeneity” within the context of this disclosure is quantified as follows:
Based on the assumption/approximation that all encountered distributions are of normal-type, the sameness S can be written as a function of five parameters
S=S(μAct,σAct,μRef,σRef,k)
or
S=S(AVG(A),STD(A),AVG(R),STD(R),k)
where AVG(X) and STD(X) designate the average and standard deviation of a set of wafers for a specific parameter (X=A or R, where A=actual and R=reference). With the following additional definitions:
These definitions operationalize the term “homogeneity” according to what has been previously described. For each wafer w its “homogeneity-contribution” Phom(w) is determined by calculating the sameness value of its parametrical distribution with respect to the corresponding distribution found in the remaining split-group. If there is only one wafer included in the split-group (i.e., n (w)=1), Phom (w) is set to 1. The symbol ‘Phom’ has been chosen to indicate that this value can be interpreted as a probability that wafer w does not disturb the homogeneity of its own split-group SG(w).
The necessary sameness calculations are done with k=3. Every wafer contributes with the same statistical weight to the total split-group homogeneity-assessment Phomtotal. That is the reason why this value has been defined as the simple average of all individual values Phom(w). Phomtotal therefore assesses the overall homogeneity over all split-groups including all wafers.
In order to operationalize the second criterion, i.e., the split-group offset assessment, we need the following definitions:
The quantity Poff (i, j) measures the separability of split-group i from split-group j. In contrast to Phom (w), the definition of Poff (i, j) has been made symmetric, including the term (S(i, j)+S(j, i))/2, because this way each split-group simultaneously serves in every Poff (i, j) calculation as actual and as reference distribution, and none of the split-groups is given preference over the other.
The characteristic values for the separability of the split-groups have been denoted Poff and Pofftotal in order to indicate that they, too, may be interpreted as a sort of probabilities. The term (S(i, j)+S(j, i))/2 can be taken as the probability that split-group i is same to split-group j. Its complement 1−(S(i, j)+S(j, i))/2 can therefore be seen as the probability that split-group i is different from split-group j. Pofftotal then calculates the average of all individual offset probabilities Poff(i, j).
In the previous sections, characteristic values (probabilities) have been defined which assess two important, but subordinate aspects necessary for the split pattern identification (i.e., the split-groups' homogeneity and their offsets). Since there are many different split and cross-split patterns that usually have to be compared to a parametric signature, one obtains a great number of different Pofftotal and Pofftotal values (one pair for every parameter split combination). These must be sorted in order to be able to pick the best fitting pattern. For this purpose, we need to combine these subordinate characteristic values into a single split identification score value (split id score), which can then be used to select a certain parameter split pair.
In the context of this disclosure, combining Phomtotal and Pofftotal into just one single split id score is done employing very elementary fuzzy logic principles, since the classical logical functions “AND” and “OR” are not suited to solve this problem. Following classical Boolean logic, one can state that a given parametric variation reflects a specific split pattern the better, the less disturbed the homogeneity within “AND” the more distinct are the offsets between its split-groups. However, the values introduced to characterize the degree of homogeneity or the split-group offsets are not of binary type (i.e. “true” or “false”, “yes” or “no”, 1 or 0 etc.). They can take all values out of the range from 0 to 1. This corresponds to an interpretation as “more” or “less” rather than “yes” or “no”. In classical Boolean logic, however, only true binary-type values can be subjected to functions such as “AND”, “OR”, etc. That is the reason why fuzzy logic has to be employed in order to combine the different subordinate values.
In the theory of fuzzy sets, the logical values “true” and “false” (“yes” and “no”), which apply to any given logical statement, are replaced by the so-called membership functions p(x). Where in classical Boolean logic the element x is either a member of the set A or not
(x∈A) “=” true or (x∈A) “=” false
A(x)=1 or A(x)=0
is the degree of membership in fuzzy logic by nature “fuzzy”. The membership function quantifies this degree of membership:
A(x)=p(x)
When the membership function is normalized, i.e. 0≦p(x)≦1, it can be interpreted as the probability that the element belongs to the set.
For the purposes of the disclosed method, the fuzzy equivalent of a classical “AND” is needed: That is, “Are all values within the split-groups evenly (homogeneously) distributed?” AND “Are all offsets between the split-groups clearly distinguishable?”
Fuzzy theory provides different operators which generalize classical logical functions. For the disclosed method a simplified fuzzy operator corresponding to the classical logical “AND” is being used. Derived from the so-called gamma operator, it reads as follows:
The determination of Pidmax alone—as has been pointed out earlier—is not yet sufficient to finally rank the identified parameter split pairs. To achieve this goal, significance values of all best fitting parameter split pairs have to be determined in addition to the maximum split id scores calculated so far. The significance value (or simply significance) was introduced as the ratio of the maximum split-group offset relative to the spec width. In the following section this is put more formally:
Let us assume we are presently considering the parameter with the index v. Following the previously discussed methodology we may have determined Phomtotal and Pofftotal for all splits/cross-splits s and finally found the split/cross-split ŝ with the highest Pidmax value. This split indexed ŝ may now possess {circumflex over (N)}SG different split-groups.
We define:
AVG(i) designates the average of parameter v with respect to split-group i. We assume that split ŝ consists of {circumflex over (N)}SG split-groups, so that i ∈{1, . . . , {circumflex over (N)}SG}. MAX(ŝ) and MIN(ŝ) are then the group-maximum and -minimum obtained for split ŝ. The span of these two values is then to be compared with the spec width. It is therefore introduced:
NSPCH(v)=min{(USL(v)−TAR(v)),(TAR(v)−LSL(v))}
USL(v) and LSL(v) designate the upper and lower spec limit, TAR(v) the target value of parameter v. NSPCH(v), as the narrow spec-half, then selects the minimum of both sides of the spec. The significance of split/cross-split ŝ with respect to parameter v is then defined as:
This definition of the significance value becomes necessary, because parameters can be asymmetric in their specifications. It can be stated that for asymmetric limits the relevant range for parametric variations is generally given by the “narrow” spec-side. So that SGN(ŝ,v) has been defined dividing the split-span by 2×NSPCH(v) and not the full spec-width, i.e. USL(v)−LSL(v). For symmetrical specs there is no difference, i.e., 2×NSPCH(v)=USL(v)−LSL(v).
The significance values of the best fitting parameter split pairs for our example (see the split matrix in
To obtain the final overall score value, we need to combine the maximum split id score for every parameter Pidmax(v)=Pid(ŝ,v) with the corresponding significance value SGN(ŝ,v). Since the co-domain of the significance is [0,+∞[, we have to normalize it in order to obtain Psig (with 0≦Psig≦1), a value which (again) is going to be interpreted as a sort of probability. This probability is then used—employing the same fuzzy concept underlying the determination of Pid (s)—to combine it with the Pidmax value to eventually yield the overall score value. Psig is determined by:
As long as the a split significance is low, Psig(ŝ,v) varies linearly with SGN(ŝ,v). For large split significances, however, it levels off and approaches unity. This reflects the logical interpretation that, if a given split variation exceeds a certain limit (defined by the significance-fraction fsig), it simply becomes significant (i.e., Psig(ŝ,v)→1), no matter if it exceeds fsig by a factor of 10, 100 or even 1000.
The parameter fsig is called the “significance fraction”, because it defines the fraction of the spec range—actually 2×NSPCH(v), to be precise—from that on a certain split variation really starts getting relevant. For our purposes fsig=0.25 is used.
Once Psig(ŝ,v) has been calculated, the overall score value Posv(ŝ,v) for split ŝ and parameter v is defined by
For our example, Posv(ŝ,v) is given as percentage value in column 11 of
Number | Date | Country | Kind |
---|---|---|---|
10 2006 044 898 | Sep 2006 | DE | national |
Number | Name | Date | Kind |
---|---|---|---|
5408405 | Mozumder et al. | Apr 1995 | A |
5949678 | Wold et al. | Sep 1999 | A |
6549864 | Potyrailo | Apr 2003 | B1 |
6662061 | Brown | Dec 2003 | B1 |
6819963 | Riley et al. | Nov 2004 | B2 |
6912436 | Jones et al. | Jun 2005 | B1 |
6988017 | Pasadyn et al. | Jan 2006 | B2 |
7043403 | Wang et al. | May 2006 | B1 |
7082345 | Shanmugasundram et al. | Jul 2006 | B2 |
7174283 | Berkooz et al. | Feb 2007 | B2 |
7200459 | Bode et al. | Apr 2007 | B1 |
7225047 | Al-Bayati et al. | May 2007 | B2 |
7349753 | Paik | Mar 2008 | B2 |
7356377 | Schwarm | Apr 2008 | B2 |
7467023 | Brown | Dec 2008 | B2 |
7499897 | Pinto et al. | Mar 2009 | B2 |
20050234763 | Pinto et al. | Oct 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20080077256 A1 | Mar 2008 | US |