-
2005-03-15
10/212,385
2002-08-05
US 6,867,866 B1
2005-03-15
-
-
Richard A. Rosenberger
2023-08-05
A method for modeling optical scattering includes an initial step of defining a zero-th order structure (an idealized representation) for a subject including a perturbation domain and a background material. A Green's function and a zero-th order wave function are obtained for the zero-th order structure using rigorous coupled wave analysis (RCWA). A Lippmann-Schwinger equation is constructed including the Green's function, zero-th order wave function and a perturbation function. The Lippmann-Schwinger equation is then evaluated over a selected set of mesh points within the perturbation domain. The resulting linear equations are solved to compute one or more reflection coefficients for the subject.
Get notified when new applications in this technology area are published.
The present application claims priority to U.S. Provisional Patent Applications Ser. No. 60/311,427, filed Aug. 10, 2001, Ser. No. 60/378,525, filed May 7, 2002 and Ser. No. 60/394,556, filed Jul. 9, 2002 all of which are incorporated herein by reference.
The subject invention relates to a technique for determining the scattering response of a periodic structure using a Green's function approach in combination with rigorous coupled wave analysis.
Over the past several years, there has been considerable interest in using optical scatterometry (i.e., optical diffraction) to perform critical dimension (CD) measurements of the lines and structures included in integrated circuits. Optical scatterometry has been used to analyze periodic two-dimensional structures (e.g., line gratings) as well as three-dimensional structures (e.g., patterns of vias or mesas). Scatterometry is also used to perform overlay registration measurements. Overlay measurements attempt to measure the degree of alignment between successive lithographic mask layers.
Various optical techniques have been used to perform optical scatterometry. These techniques include broadband scatterometry (U.S. Pat. Nos. 5,607,800; 5,867,276 and 5,963,329), spectral ellipsometry (U.S. Pat. No. 5,739,909) as well as spectral and single-wavelength beam profile reflectance (BPR) and beam profile ellipsometry (BPE) (U.S. Pat. No. 6,429,943). In addition it may be possible to employ single-wavelength laser BPR or BPE to obtain CD measurements on isolated lines or isolated vias and mesas.
Most scatterometry systems use a modeling approach to transform scatterometry signals into critical dimension measurements. For this type of approach, a theoretical model is defined for each physical structure that will be analyzed. The theoretical model predicts the empirical measurements (scatterometry signals) that scatterometry systems would record for the structure. A rigorous coupled wave theory can be used for this calculation. The theoretical results of this calculation are then compared to the measured data (actually, the normalized data). To the extent the results do not match, the theoretical model is modified and the theoretical data is calculated once again and compared to the empirical measurements. This process is repeated iteratively until the correspondence between the calculated theoretical data and the empirical measurements reaches an acceptable level of fitness. At this point, the characteristics of the theoretical model and the physical structure should be very similar.
The calculations discussed above are relatively complex even for simple models. As the models become more complex (particularly as the profiles of the walls of the features become more complex) the calculations become exceedingly long and complex. Even with high-speed processors, real time evaluation of these calculations can be difficult. Analysis on a real time basis is very desirable so that manufacturers can immediately determine when a process is not operating correctly. The need is becoming more acute as the industry moves towards integrated metrology solutions wherein the metrology hardware is integrated directly with the process hardware.
A number of approaches have been developed to overcome the calculation bottleneck associated with the analysis of scatterometry results. Many of these approaches have involved techniques for improving calculation throughput, such as parallel processing techniques. An approach of this type is described in a co-pending application Ser. No. 09/818,703 filed Mar. 27, 2001 which describes distribution of scatterometry calculations among a group of parallel processors. In the preferred embodiment, the processor configuration includes a master processor and a plurality of slave processors. The master processor handles the control and the comparison functions. The calculation of the response of the theoretical sample to the interaction with the optical probe radiation is distributed by the master processor to itself and the slave processors.
For example, where the data is taken as a function of wavelength, the calculations are distributed as a function of wavelength. Thus, a first slave processor will use Maxwell's equations to determine the expected intensity of light at selected wavelengths scattered from a given theoretical model. The other slave processors will carry out the same calculations at different wavelengths. Assuming there are five processors (one master and four slaves) and fifty wavelengths, each processor will perform ten such calculations per iteration.
Once the calculations are complete, the master processor performs the best fit comparison between each of the calculated intensities and the measured normalized intensities. Based on this fit, the master processor will modify the parameters of the model as discussed above (changing the widths or layer thickness). The master processor will then distribute the calculations for the modified model to the slave processors. This sequence is repeated until a good fit is achieved.
This distributed processing approach can also be used with multiple angle of incidence information. In this situation, the calculations at each of the different angles of incidence can be distributed to the slave processor. Techniques of this type are an effective method for reducing the time required for scatterometry calculations. At the same time, the speedup provided by parallel processing is strictly dependent on the availability (and associated cost) of multiple processors. Amdahl's law also limits the amount of speedup available by parallel processing since serial portions program portions are not improved. At the present time, neither cost nor ultimate speed improvement is a serious limitation for parallel processing techniques. As geometries continue to shrink, however it becomes increasingly possible that computational complexity will outstrip the use of parallel techniques alone.
Another approach is to use pre-computed libraries of predicted measurements. This type of approach is discussed in PCT application WO 99/45340, published Sep. 10, 1999 as well as the references cited therein. In this approach, the theoretical model is parameterized to allow the characteristics of the physical structure to be varied. The parameters are varied over a predetermined range and the theoretical result for each variation to the physical structure is calculated to define a library of solutions. When the empirical measurements are obtained, the library is searched to find the best fit.
The use of libraries speeds the analysis process by allowing theoretical results to be computed once and reused many times. At the same time, library use does not completely solve the calculation bottleneck. Construction of libraries is time consuming, requiring repeated evaluation of the same time consuming theoretical models. Process changes and other variables may require periodic library modification or replacement at the cost of still more calculations. For these reasons, libraries are expensive (in computational terms) to build and to maintain. Libraries are also necessarily limited in their resolution and can contain only a finite number of theoretical results. As a result, there are many cases where empirical measurements do not have exact library matches. One approach for dealing with this problem is to generate additional theoretical results in real time to augment the theoretical results already present in the library. This combined approach improves accuracy, but slows the scatterometry process as theoretical models are evaluated in real time. A similar approach is to use a library as a starting point and apply an interpolation approach to generate missing results. This approach avoids the penalty associated with generating results in real time, but sacrifices accuracy during the interpolation process.
For these reasons and others, there is a continuing need for faster methods for computing theoretical results for scatterometry systems. This is true both for systems that use real time evaluation of theoretical models as well as systems that use library based problem solving. The need for faster evaluation methods will almost certainly increase as models become more detailed to more accurately reflect physical structures.
The present invention provides a method for modeling optical diffraction. The modeling method is intended to be used in combination with a wide range of subjects including semi-conductor wafers and thin films. A generic subject includes a scatterer sandwiched between a foreground material and a background material. The scatterer is a periodic or isolated structure and may be two or three-dimensional. The background material includes each of the layers of the subject that are situated below the scatterer. The foreground material includes all of the substances (in some cases this includes layers of the subject) that overlay the scatterer.
The modeling method begins with the construction of an idealized representation (also known as the zero-th order structure) for the subject being modeled. The idealized representation is based on one of three templates. The templates are referred to as the G0, G1 and Ga structures, respectively. Each of these templates is a combination of the subject's background material and a perturbation domain. The perturbation domain contains the scatterer and is treated differently by each template. The perturbation domain in the G0 structure has a dielectric response that is equivalent to the subject's foreground. For the G1 structure, the perturbation domain includes a grating. The grating consists of a limited number of square slabs arranged in a repeating pattern closely modeling the scatterer. For the Ga case, the perturbation domain contains a uniform medium. A wide range of functions may be used to define the dielectric properties of the uniform medium. For one such function, the TE mode response is defined to be a weighted average of the dielectric function for the scatterer and the foreground material. The TM mode response is similar except that the inverse of the dielectric function is used to compute the weighted average.
One or more Lippmann-Schwinger wave equations are used to represent the idealized representation. Each wave equation includes a wave function for the zero-th order structure, a Green's function for the zero-th order structure and a perturbation function. The wave function for the zero-th order structure and the Green's function arm obtained using rigorous coupled wave analysis. The perturbation function describes the dielectric properties of the perturbation domain. By definition, the perturbation function is defined to be zero at all points outside of the perturbation domain. As a result, numerical evaluation of the Lippmann-Schwinger wave equations may be limited to the area within the perturbation domain, greatly accelerating numerical evaluation of the scattering response.
The perturbation domain is subdivided into a series of segments or layers. The Lippmann-Schwinger wave equations are then evaluated in each segment. The result of this repeated evaluation is a system of linear equations. Each equation within the system relates the terms of the wave equations obtained in a particular segment of the perturbation domain for a particular coupled wave.
The system of linear equations is solved to obtain one or more reflection coefficients for the idealized representation. This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also be used.
In this way, an efficient method for modeling optical diffraction is provided. The efficiency of this method is enhanced because the numerical evaluation is limited to the perturbation domain of the idealized representation. Efficiency is further enhanced because the boundaries between the perturbation domain and the remaining layers of the zero-th order structure are intrinsically accounted for by the Green's function.
FIG. 1 shows a cross sectional representation of a generic subject for which optical diffraction may be modeled.
FIG. 2 is a flowchart showing the steps associated with a method for modeling optical scattering as provided by an embodiment of the present invention.
FIG. 3 is a cross sectional representation of the G0 structure as used by an embodiment of the present invention.
FIG. 4 is a cross sectional representation of the G1 structure as used by an embodiment of the present invention.
FIG. 5 is a cross sectional representation of the perturbation domain of the G0 structure after subdivision.
FIG. 6 is a cross sectional representation of the perturbation domain of the G0 structure after an alternate subdivision.
FIG. 7 is block diagram of an optical metrology shown as a representative application for the modeling method of the present invention.
Overview
The present invention provides a method for modeling optical diffraction. The modeling method is intended to be used in combination with a wide range of subjects including semi-conductor wafers and thin films. As shown in FIG. 1, the cross section for a generic subject reveals a scatterer sandwiched between a foreground material and a background material. The scatterer is a periodic or isolated structure and may be two or three-dimensional. For semi-conductor wafers, single lines are typical examples of two-dimensional isolated scatterers. Parallel groups of lines evenly spaced are a common example of two-dimensional periodic scatterers. Single vias are an example of isolated three-dimensional scatterers. In groups, vias can be an example of periodic three-dimensional scatterer.
The background material includes each of the layers situated below the scatterer. For the case of semi-conductor wafers, the background material would typically be a multilayer dielectric film. The foreground material includes all of the substances that overlay the scatterer. Where the scatterer forms the surface of the subject, the foreground material includes the overlaying gas, fluid or vacuum. In cases where the scatterer is submerged within the subject, the foreground material includes the overlaying layers.
The modeling method begins with a subject (such as the subject of FIG. 1) and computes one or more reflection coefficients. A high level flowchart showing the steps associated with this method is shown in FIG. 2. As may be seen in step 202 of that figure, the modeling method begins with the construction of an idealized representation (also known as the zero-th order structure) for the subject being modeled.
The idealized representation is based on one of three templates. The templates are referred to as the G0, G1 and Ga structures, respectively. As shown in FIG. 3, the G0 structure retains the background material described for the generic subject shown in FIG. 1. The scatterer is replaced by a uniform medium that has a dielectric response that is equivalent to the subject's foreground.
The G1 structure (shown in FIG. 4) includes the same background material described for the G0 structure. Unlike the G0 structure, the perturbation domain of the G1 structure includes a grating. The grating consists of a limited number of square slabs arranged in a repeating pattern. The square slabs closely model the scatterer.
The Ga structure (not shown) shares the background material of the G0 and G1 structures. The perturbation domain of the Ga case contains a uniform medium. A wide range of functions may be used to define the dielectric properties of the uniform medium. For one such function, the TE mode response is defined to be a weighted average of the dielectric function for the scatterer and the foreground material. The TM mode response is similar except that the inverse of the dielectric function is used to compute the weighted average.
The G0, G1, and Ga structures offer various tradeoffs for computational speed and accuracy. The G1 structure is generally the most computationally intensive. The G0 is generally the least computationally intensive. Selection of a particular structure is also dependent on the type of subject. The G1 structure works best when used for two-dimensional analysis. This type of analysis is appropriate for subjects that include two-dimensional scatterers (scatterers that exhibit a translational symmetry along an axis). The G0 and Ga structures, on the other hand, may be used for both two and three dimensional analysis. In step 202, one of the three structures is selected and used to create the idealized representation for the subject.
The remaining steps of the modeling method are devoted to numerical evaluation of the scattering response of the idealized representation. To avoid confusion, it should be noted that several derivations have been developed to perform this evaluation. This overview section briefly describes one of these derivations with additional description for all derivations provided in subsequent portions of this document. For each derivation, the numerical evaluation is based on the use of one or more Lippmann-Schwinger equations to represent one or more wave functions for the idealized representation. In the coupled wave basis, each of these equations has a form similar to (and for some derivations identical to):
Ξ¨(z)βΞ¨0(z)=β«dzβ²G(z, zβ²)V(zβ²)Ξ¨(zβ²).ββ(1.1)
Within Equation (1.1) Ξ¨0(z) and G(z, zβ²) are the wave and Green's functions for the zero-th order structure. V(zβ²) is known as the perturbation function and describes the dielectric properties of the perturbation domain. By definition, the perturbation function is defined to be zero at all points outside of the perturbation domain. As a result, numerical evaluation of Equation (1.1) may be limited to the area within the perturbation domain, greatly accelerating numerical evaluation of the scattering response.
To evaluate Equation (1.1), the modeling method subdivides the perturbation domain into a series of segments, each having the same thickness (see step 204). This type of subdivision for a G0-type perturbation domain is shown in FIG. 5.
Equation (1.1) is then evaluated in each segment (see step 206). The result of this repeated evaluation is a system of linear equations. Each equation within the system relates the terms of Equation (1.1) obtained in a particular segment of the perturbation domain for a particular coupled wave.
The system of linear equations is then solved to obtain one or more reflection coefficients for the idealized representation (see step 208). This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also be used.
The modeling method of FIG. 2 provides an efficient method for modeling optical diffraction. The efficiency of this method is enhanced because the numerical evaluation is limited to the perturbation domain of the idealized representation. Efficiency is further enhanced because the boundaries between the perturbation domain and the remaining layers of the zero-th order structure are intrinsically accounted for by the Green's function. As described above, the modeling method is suitable for the analysis of TE modes for two-dimensional structures (i.e., structures that exhibit a translational symmetry in one direction). The following sections describe derivations for two and three dimensional structures for TE and TM modes.
Equation Section 2Wave Equations for Two-dimensional Structures
This section describes derivations for separate TE and TM mode wave equations for two-dimensional structures. The wave equations allow the modeling method to be used to predict the diffraction response of two-dimensional structures (i.e., structures that exhibit translational symmetry in at least one direction). For semi-conductor wafers, this can include patterns of lines and other periodic structures.
For TE modes the wave function Ο(x, z) of concern is the y-component of the electric field (Ey). From Maxwell's equations, Ey satisfies the following differential equation:
[βx2+βz2+k02β(x, z)]Ο(x, z)=0,ββ(2.1)
where β(x, z) is the position-dependent dielectric function, k0=2Ο/Ξ»0, and Ξ»0 is the wavelength of the incident radiation in free space. Equation (2.1) is subject to the boundary conditions that Ο and βzΟ are continuous. Replacing β(x, z) with β0(x, z) yields a similar equation for the zero-th order structure:
[βx2+βz2+k02β0(x, z)]Ο0(x, z)=0,
A corresponding Green's function G(x, z; x, zβ²) may be formulated as:
[βx2+βz2+k02β0(x, z)]G(x, z; xβ², zβ²)=Ξ΄(zβzβ²)Ξ΄(xβxβ²)ββ(2.2)
subject to the same boundary conditions that Ο and βzΟ0 are continuous.
To determine the scattering response of the idealized representation, it is necessary to account for the dielectric properties of the perturbation domain. This perturbation is denoted V. Within the perturbation domain (0<z<d) V(x, z)=[β(x, z)ββ0]k02. At all other points, V is zero.
The perturbation function V, the Green's function G(x, z; x, zβ²), and the wave function for the zero-th order structure Ο0 are used to obtain a wave function Ο for the idealized representation. Ο is a Lippmann-Schwinger equation having the following form:
Ο(x, z)βΟ0(x, z)=β«dxβ²dzβ²G(x, z; xβ², zβ²)V(xβ², zβ²)Ο(xβ², zβ²).ββ(2.3)
Projecting equation (2.3) into the coupled wave basis with <x|n>=eβ²k0x/β{square root over (p)}(kn=k0x+2Οn/p), yields:
Ξ¨(z)βΞ¨0(z)=β«dzβ²G(z, zβ²)V(zβ²)Ξ¨(zβ²),ββ(2.4)
where Ξ¨ and Ξ¨0 are N dimensional column vectors with entries given by: Ξ¨n(z)=<n|Ο> and Ξ¨n0(z)=<n|Ο0>. G and V are NΓN matrices with elements given by Gn,nβ²(z, zβ²)=<n|G|nβ²> and Vn,nβ²(z)=<n|V|nβ²>.
For TM modes the wave function Ο(x, z) of concern is the y-component of the magnetic field (Hy). From Maxwell's equations, (Hy) satisfies the following differential equation:
[βxββ1βx+βzββ1βz+k02]Ο(x, z)=0ββ(2.5)
subject to the boundary conditions that Ο(x, z) and ββ1βzΟ(x, z) are continuous across a z boundary and Ο(x, z) and ββ1βxΟ(x, z) are continuous across a x boundary. Note that the discontinuity of βxHy across x boundaries causes slow convergence in the coupled-wave method. So, more plane waves are needed for the expansion of Hy field than for the Ey field. Replacing β(x, z) with β0(x, z) yields a similar differential equation for the unperturbed system (zero-th order structure):
[βxβ0β1βx+βzβ0β1βz+k02]Ο0(x, z)=0ββ(2.6)
A corresponding Green's function G(x, z; x, zβ²) may be formulated as:
[βxβ0β1βx+βzβ0β1βz+k02]G0(x, z; xβ², zβ²)=Ξ΄(xβxβ²)Ξ΄(zβzβ²)ββ(2.7)
subject to the same set of boundary conditions required for Ο0(x, z).
To construct a wave equation for TM modes, Equation (2.7) is multiplied by Ο(xβ², zβ²)βΟ0(xβ², zβ²) and integrated over xβ² and zβ². Equation (2.6) is multiplied by G(x, z; xβ², zβ²) and integrating over xβ² and zβ². The difference of the two resulting equations yields a Lippmann-Schwinger equation for the TM modes having the following form:
Ο
β‘
(
x
,
z
)
-
Ο
0
β‘
(
x
,
z
)
=
β«
β
x
β²
β’
β
z
β²
β‘
[
β
x
β²
β’
G
β‘
(
x
,
z
;
,
x
β²
,
z
β²
)
]
β’
V
β‘
(
x
β²
,
z
β²
)
β‘
[
β
x
β²
β’
Ο
β‘
(
x
,
z
;
,
x
β²
,
z
β²
)
]
+
β«
β
x
β²
β’
β
z
β²
β‘
[
β
z
β²
β’
G
β‘
(
x
,
z
;
,
x
β²
,
z
β²
)
]
β’
V
β‘
(
x
β²
,
z
β²
)
β‘
[
β
z
β²
β’
Ο
β‘
(
x
β²
,
z
β²
)
]
,
(
2.8
)
where V(x, z)=ββ1(x, z)ββ0β1(x, z) is the perturbation in inverse dielectric function. To derive Equation (2.8), integration by parts is used. The boundary terms generated in the process vanish exactly due to the fact that the derivatives of Ο (or G) divided by β (or β0) are continuous across the corresponding boundaries.
Projecting the above equations into the coupled wave basis yields:
Ξ¨(z)βΞ¨0(z)=β«dzβ²[G(z, zβ²)K{tilde over (V)}(zβ²)KΞ¨(zβ²)+βzβ²G(z, zβ²)V(zβ²)βzβ²Ξ¨(zβ²)],ββ(2.9)
where K is a diagonal matrix with the n-th diagonal entry given by kn.
For TM modes, two types of perturbation matrices are used: V and {tilde over (V)}. The first type is defined as V=PβP0, where P(P0) is a matrix of the inverse dielectric function with elements given by Pn,nβ²(z)=<n|1/β|nβ²>. The second type is defined as: {tilde over (V)}=Eβ1βE0β1, where Eβ1 is the inverse of dielectric function matrix (E), whose matrix elements are En,nβ²(z)=<n|β|nβ²> and similarly for E0. V and {tilde over (V)} are identical when a complete set of coupled-wave basis functions is used. In practice, a finite number of coupled-wave basis functions are used, and to achieve fast convergence, {tilde over (V)} is used for terms involving x-derivatives and V for terms involving z-derivatives. The use of V and {tilde over (V)} perturbation matrices takes advantage of the observation that calculation of a Fourier transform involving a continuous function [1/β(x)][βxΟ(x)] which is the product of two discontinuous functions [1/β(x)] and [βxΟ(x)] converges more rapidly if the resulting product matrix is expressed as [β]β1[Ο] rather than [1/β][Ο]. This observation is discussed in (L. Li, J. Opt. Soc. Am. A 2758 (1997)). That article is incorporated in this document by reference.
Efficient Transfer-matrix Method for RCWA
In order to optimize the efficiency of the algorithm, an efficient transfer-matrix method is used to calculate the matrices and wave functions needed for constructing the Green's function within the coupled-wave basis. The derivation for this method takes advantage of the symmetry properties of the matrices whenever possible, thus making the coding more efficient.
For both TE and TM modes, the differential equations projected within the coupled-wave basis (i.e., equations (2.4) and (2.9)) can be cast into the general form:
(
β
β
z
β’
D
β‘
(
z
)
β’
β
β
z
+
H
β‘
(
z
)
)
β’
Ξ¨
β’
(
z
)
=
0.
(
2.10
)
D and H are square matrices of dimension N and Ξ¨ is a vector of dimension N (the number of coupled waves used). For TE modes, D=1 and H(z)=E(z)k02βK2, where E(z) is the dielectric matrix. For TM modes, D=P(z) (P is the matrix of inverse dielectric function) and H(z)=k02βKEβ1(z)K, where K is a diagonal matrix with elements kn=k0x+2Οn/p. Both D(z) and H(z) are piecewise-constant functions of z.
The general solution to the wave function Ξ¨(z) in each layer of the structure where D and H are independent of z can be expressed as:
Ξ¨
=
β
n
β’
s
n
β’
e
-
q
n
β’
z
β’
f
n
+
β
n
β’
s
n
β’
e
q
n
β’
z
β’
g
n
β‘
Se
-
Qz
β’
f
+
Se
Qz
β’
g
,
(
2.11
)
β
Ξ¨
β
β
n
β’
s
n
β‘
(
-
q
n
)
β’
e
-
q
n
β’
z
β’
f
n
+
β
n
β’
s
n
β’
q
n
β’
e
q
n
β’
z
β’
g
n
β‘
SQe
-
Qz
β’
f
+
SQe
Qz
β’
g
,
(
2.12
)
where f and g are the vectors formed by fn's and gn's which are to be determined by the boundary conditions. Q is a diagonal matrix formed by the exponents qn. The wave functions are arranged in such a way that eβqnz represents the decaying (evanescent) wave in the positive z-direction when the real part of qn is non-zero, and it is the physical forward propagating wave when qn is imaginary. eqnz represents the growing wave and is therefore not allowed in the substrate region. The S matrix consists of the eigenvectors of Equation (2.10), and satisfies:
βHS=Ξ»DS,
which can be solved via a standard LAPACK routine. The exponents are related to the eigenvalues of H via β{square root over (βΞ»n)}=qn2 with non-negative real parts. Note that both H and D are symmetric matrices. As a result, the relation Sβ1=STD applies, where ST is the transpose of S. This relation will be used to evaluate Sβ1 directly without performing the time-consuming matrix inversion.
The boundary conditions are determined by requiring that the wave function Ξ¨(z) and the generalized current be continuous across material boundaries. In the present case, the current is proportional to D(z)βzΞ¨(z) yielding:
(
Ξ¨
D
β’
β
z
β’
Ξ¨
)
=
β’
(
S
S
-
DSQ
-
DSQ
)
β’
(
e
-
Qz
0
0
e
Qz
)
β’
(
f
g
)
β
=
β’
(
S
0
0
-
DSQ
)
β’
(
1
1
1
-
1
)
β’
(
e
-
Qz
0
0
e
Qz
)
β’
(
f
g
)
(
2.14
)
β‘
β’
(
S
0
0
J
)
β’
Ο
β‘
(
e
-
Qz
0
0
e
Qz
)
β’
(
f
g
)
.
(
2.15
)
(
2.13
)
where J stands for generalized current matrix. Note that all the elements are themselves matrices. The matrix Ο has the property that:
Ο
-
1
=
1
2
β’
Ο
.
Throughout this description, z in the wave functions for each layer l is measured relative to the interface between layers lβ1 and l. The boundary conditions are usually in the following form:
(
S
l
0
0
J
l
)
β’
Ο
β‘
(
e
-
Q
l
β’
d
l
0
0
e
Q
l
β’
d
l
)
β’
(
f
l
g
l
)
=
(
S
l
+
1
0
0
J
l
+
1
)
β’
Ο
β‘
(
f
l
+
1
g
l
+
1
)
(
2.16
)
Denoting:
Mlβ‘Slβ1Sl+1, Nlβ‘Jlβ1Jl+1ββ(2.17)
produces the relation:
(
f
l
g
l
)
=
1
2
β’
(
e
Q
l
β’
d
l
0
0
e
-
Q
l
β’
d
l
)
β’
(
1
1
1
-
1
)
β’
(
M
l
0
0
N
l
)
β’
(
1
1
1
-
1
)
β’
(
f
l
+
1
g
l
+
1
)
β’
β
β’
(
2.18
)
=
1
2
β’
(
e
Q
l
β’
d
l
0
0
e
-
Q
l
β’
d
l
)
β’
(
M
l
+
N
l
M
l
-
N
l
M
l
-
N
l
M
l
+
N
l
)
β’
(
f
l
+
1
g
l
+
1
)
β’
β
β’
(
2.19
)
=
β’
(
e
Q
l
β’
d
l
0
0
e
-
Q
l
β’
d
l
)
β’
(
M
l
+
M
l
-
M
l
-
M
l
+
)
β’
(
f
l
+
1
g
l
+
1
)
β‘
(
f
l
+
1
g
l
+
1
)
β’
β
β’
(
2.20
)
This is the starting point of the transfer matrix approach. Let t be the transmission coefficient at the substrate layer (labeled by L), this yields: ( f l g l ) = β l = j L - 1 β’ β β’ Ο 1 β‘ ( t 0 ) β‘ T l - β‘ ( t 0 ) = ( Ο 11 Ο 12 Ο 21 Ο 22 ) β’ ( t 0 ) = ( Ο 11 β’ t Ο 21 β’ t )
It is important to note that only the first column of the matrix Tl is needed. This fact reduces transfer matrix computational time.
The transfer matrix formalism can be unstable due to exponentially growing factors eQldl, even in the spirit of the above format (although a simple scaling can be applied in the single component case). It turns out that it is possible to overcome this difficulty, provided that the growing and decaying waves are cleanly separated. To achieve this goal, the following equation is used:
(
f
l
g
l
)
=
(
f
l
R
l
β’
f
l
)
(
2.21
)
Equation (2.20) gives:
fl=eQldl(Ml++MlβRl+1)fl+1ββ(2.22)
Rlfl=eQldl(Mlβ+Ml+Rl+1)fl+1ββ(2.23)
These equations may be rewritten as:
f
l
+
1
=
(
M
l
+
+
M
l
-
β’
R
l
+
1
)
-
1
β’
e
-
Q
l
β’
d
l
β’
f
l
β‘
T
l
β’
e
-
Q
l
β’
d
l
β’
f
l
(
2.24
)
R
l
=
e
-
Q
l
β’
d
l
β‘
(
M
l
-
+
M
l
+
β’
R
l
+
1
)
β’
(
M
l
+
+
M
l
-
β’
R
l
+
1
)
-
1
β’
e
-
Q
l
β’
d
l
=
e
-
Q
l
β’
d
l
β‘
(
M
l
-
+
M
l
+
β’
R
l
+
1
)
β’
T
l
β’
e
-
Q
l
β’
d
l
(
2.25
)
Using Rlβ‘eβQldl{overscore (R)}leβQldl, gives:
{overscore (R)}l=(Mlβ+Ml+eβQl+1dl+1{overscore (R)}l+1eβQl+1dl+1)Tl.ββ(2.26)
Equation (2.25) is obtained by replacing fl+1 within Equation (2.23) with the derivation for fl+1 obtained in Equation (2.24) and then equating the coefficient of fl. The recursion process is stable. If the wave function is not required, Equation (2.24) is not needed. In that case, Equation (2.25) is solved by starting with the base case RL=0 (in the substrate layer). If the wave function is required, Tl is calculated using Equation (2.24). Equation (2.24) is then used to recursively obtain fl, with f0 the incident wave function which is known, then gl=Rlfl. The growing wave is also well controlled since Rl=eβQldl{overscore (R)}leβQldl, where {overscore (R)}l is finite, and eQlzRlfl=eβQl(dlβz){overscore (R)}leβQldlfl is well defined.
For calculating the Green's function (which will be discussed below), it is necessary to obtain a transfer matrix calculation that starts from the incident medium. For this derivation, define mlβ‘Mlβ1=Sl+1β1Sl=Ql+1β1NlTQl and nlβ‘Nlβ1=Jl+1β1Jl=Ql+1MlTQlβ1. Note that the calculation of ml and nl only involves a matrix transposition. Equation (2.19) becomes: ( f l + 1 g l + 1 ) = 1 2 β’ ( m l + n l m l - n l m l - n l m l + n l ) β’ ( e - Q l β’ d l 0 0 e Q l β’ d l ) β’ ( f l g l ) ( 2.27 )
Similar to the forward cases, define fl={overscore (r)}lgl, and the above equation becomes:
(
r
l
+
1
β’
g
l
+
1
g
l
+
1
)
=
1
2
β’
(
m
l
+
n
l
m
l
-
n
l
m
l
-
n
l
m
l
+
n
l
)
β’
(
e
-
Q
l
β’
d
l
0
0
e
Q
l
β’
d
l
)
β’
(
r
_
l
β’
g
l
g
l
)
(
2.28
)
which can be rewritten as:
g
l
+
1
=
β’
(
m
+
+
m
-
β’
e
-
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
β’
e
Q
l
β’
d
l
β’
g
l
r
_
l
+
1
β’
g
l
+
1
=
β’
(
m
-
+
m
+
β’
e
-
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
β’
e
Q
l
β’
d
l
β’
g
l
g
l
=
β’
e
-
Q
l
β’
d
l
β‘
(
m
+
+
m
-
β’
e
-
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
-
1
β’
g
l
+
1
β‘
β’
e
Q
l
β’
d
l
β’
t
l
β’
g
l
+
1
(
2.29
)
r
_
l
+
1
=
β’
(
m
-
+
m
+
β’
e
-
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
β’
(
m
+
+
m
-
β’
e
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
-
1
β‘
β’
(
m
-
+
m
+
β’
e
-
Q
l
β’
d
l
β’
r
_
l
β’
e
-
Q
l
β’
d
l
)
β’
t
l
(
2.30
)
Note that the backward and forward transfer matrix formalisms are the same, (compare this equation with Equation (2.26)). The difference only lies in the reference point for z.
Green's Function within the Coupled-wave Basis
To calculate Green's functions for a multi-component layered system, it is best to use a source term that is more convenient than the wave function expansion. In this way, the Green's function is calculated in the same way as the wave function except for the complication originated from the source term. Within the coupled-wave basis: ( β β z β’ D β‘ ( z ) β’ β β z + H β‘ ( z ) ) β’ G β‘ ( z , z β² ) = Ξ΄ β‘ ( z - z β² ) . ( 2.31 )
Since there is no incident wave, the wave propagates from the source in both directions. Thus, in either the substrate or incident medium there are only decaying waves. The coefficients of the decaying waves must be zero. Using the notations defined for the wave functions, the coefficients g in the substrate and f in the incident medium must be zero, which are the governing boundary conditions for Green's function calculations.
If the source is located inside layer l and G(z, zβ²) is continuous across the plane z=zβ², then integrating the equation of motion over z near the boundary plane yields:
(
G
β‘
(
z
β²
+
,
z
β²
)
-
G
β‘
(
z
β²
-
,
z
β²
)
G
β²
β‘
(
z
β²
+
,
z
β²
)
-
G
β‘
(
z
β²
-
,
z
β²
)
)
=
(
0
D
-
1
β‘
(
z
β²
)
)
(
2.32
)
where Gβ²(z, zβ²)β‘βzG(z, zβ²). The general solution of G(z, zβ²) may be written as:
G(z, zβ²)=S[eβQzfΒ±(zβ²)+eQzgΒ±(zβ²)],ββ(2.33)
where fΒ±(zβ²) and gΒ±(zβ²) are square matrices of dimension N to be solved by matching the boundary conditions. The Β± sign are for z>zβ² and z<zβ², respectively. Due to the fact that the Green's function is originated from the source only, the wave function below the source (z>zβ²) should be obtained using the transfer matrix starting from the substrate and the wave function above the source (z<zβ²) should be obtained by starting from the incident medium. For this reason:
gΒ±=Rf+ and fβ={overscore (r)}gβ,
where {overscore (r)} and R are the reflection matrices obtained from the incident medium and substrate respectively. Subsequently:
(
G
β‘
(
z
β²
+
,
z
β²
)
-
G
β‘
(
z
β²
-
,
z
β²
)
G
β²
β‘
(
z
β²
+
,
z
β²
)
-
G
β‘
(
z
β²
-
,
z
β²
)
)
=
(
S
0
0
-
S
β’
β
β’
Q
)
β’
Ο
β‘
(
e
-
Q
z
0
0
e
Q
z
)
β’
(
f
+
-
f
-
g
+
-
g
)
=
(
S
0
0
-
S
β’
β
β’
Q
)
β’
Ο
β‘
(
e
-
Q
z
0
0
e
Q
z
)
β’
(
1
r
_
R
1
)
β’
(
f
+
-
g
1
)
(
2.34
)
Relating Equation (2.33) to Equation (2.34) yields:
(
f
+
-
g
-
)
=
(
(
1
-
r
_
β’
β
β’
R
)
-
1
-
r
_
β‘
(
1
-
R
β’
β
β’
r
_
)
-
1
-
R
β‘
(
1
-
r
_
β’
β
β’
R
)
-
1
(
1
-
R
β’
β
β’
r
_
)
-
1
)
β’
b
β‘
(
z
β²
)
(
2.35
)
β
β’
=
(
1
-
r
_
β’
β
β’
u
β’
β
β’
R
-
r
_
β’
β
β’
u
-
u
β’
β
β’
R
u
)
β’
b
β‘
(
z
β²
)
(
2.36
)
where uβ‘(1βR{overscore (r)})β1 and:
b
β‘
(
z
β²
)
β‘
1
2
β’
(
e
Q
z
β²
-
e
-
Q
z
β²
)
β’
Q
-
1
β‘
(
D
β’
β
β’
S
)
-
1
=
1
2
β’
(
e
Q
z
β²
-
e
-
Q
z
β²
)
β’
Q
-
1
β’
S
T
.
(
2.37
)
It can be seen that both f+ and gβ have been uniquely determined. The second form (Equation (2.36)) is required since it guarantees absolute numerical stability for the evaluation of the Green's functions, since explicitly: ( f + g - ) = 1 2 β’ ( e Qz β² + r _ β’ β β’ u β‘ ( Re Qz β² + e - Qz β² ) u β‘ ( Re Qz β² + e - Qz β² ) ) β’ Q - 1 β’ S T . ( 2.38 )
Note that all exponentially growing factors eQzβ² are accompanied by the factor R=eβQd{overscore (R)}eβQd. Thus, in actual calculations {overscore (R)} and the combined factor eQ(zβ²βd) are always evaluated to guarantee numerical stability. Hence when both z and zβ² are inside the same layer, the Green's function is written as: G β‘ ( z , z β² ) = S β‘ [ 1 2 β’ e - Q β’ ο z - z β² ο β’ Q - 1 β’ S T + e - Qz β’ r _ β’ β β’ g - β‘ ( z β² ) + e Qz β’ R β’ β β’ f + β‘ ( z β² ) ] . ( 2.39 )
Note that the first term is singular, which is different for z>zβ² and z<zβ². The remainder is a regular function, which is the same whether z>zβ² or z<zβ².
For z and zβ² located in different layers, the transfer-matrix method (similar to that for the wave function as discussed in the previous section) is used to obtain G(z, zβ²) starting from the solution for z at layer lβ², in which zβ² is located. For z in a layer l below (z>zβ²), Equation (2.20) is used repeatedly to obtain the coefficient fl+ starting from flβ²β. Similarly, for z in a layer l above (z<zβ²), Equation (2.29) is used repeatedly to obtain the coefficient glβ starting from glβ²β.
The G0 Case
For the G0 case, evaluation of the Green's function is limited to the incident medium (air) that makes up the perturbation domain (i.e., 0<z, zβ²<d). For the backward transfer, there is no reflection in the incident medium. Thus, {overscore (r)}=0 and S=const. This yields: ( f 0 + - g 0 - ) = ( e Qz - ( R β’ β β’ e Qz β² + e - Qz β² ) ) β’ 1 2 β’ Q - 1 . ( 2.40 ) G β‘ ( z , z β² ) = S 2 2 β‘ [ e - Q β’ ο z - z β² ο + e - Q β‘ ( d - z ) β’ R _ β’ β β’ e - Q β‘ ( d - z ) ] β’ Q - 1 ( 2.41 )
Here {overscore (R)} is a diagonal matrix with the n-th diagonal entry equal to rn, which corresponds to the reflection coefficient of order n for the zero-th order structure shown in FIG. 3.
The Ga case
For the Ga case, Green's function must be evaluated in the perturbation domain (0<z, zβ²<d), in which the structure has multiple slices of uniform dielectric medium (labeled with s) with an effective dielectric function β*s. β*s=(βs(z)β1)(ws(z)/p)+1 is used for TE modes and 1/β*s=(1/βsβ1)(ws/p)+1 is used for TM modes, where βs is the dielectric function of the grating material and ws is the width of grating in slice s at different z. The Green's function is still given by Equation (2.39). However, since all layers are uniform in the x-y plane, all matrices in this equation are diagonal and they can be evaluated much more efficiently.
Numerical Implementation for Two-dimensional Wave Equations
This section describes the use of modeling method to numerically evaluate the two waves equations for two-dimensional structures (Equations (2.4) and (2.9)). This numerical implementation allows the Green's function approach to be used within optical metrology and other systems that require diffraction modeling for two-dimensional structures.
As previously described, the modeling method begins with the creation of an idealized representation for the scatterer (see step 202 of FIG. 2). In the following step (step 204), the perturbation domain (0<zβ²<d) of the idealized representation is subdivided into a series of Mβ1 segments. As shown in FIG. 5, the boundaries between the Mβ1 segments have zβ² values labeled by z0, z1 and so on through zMβ1 (with z0=0 and zMβ1=d). Within each segment, the perturbation V is assumed to be constant. For the simplest case, each segment has the same thickness. In many cases, however, it is desirable to vary the thickness of individual segments to increase accuracy of the numerical implementation. Typically, and as shown in FIG. 5, this is used to provide more segments near boundaries.
The next two steps (206 and 208) are performed separately for TE and TM modes. The TE mode case is described first, followed by the description for TM modes. In step 206 (for TE modes) the Green's function for the G1 case Equation (2.33) is substituted into the Lippmann-Schwinger equation for TE modes Equation (2.4). The resulting integral:
Ξ¨(z)βΞ¨0(z)=β«dzβ²S[eβQzfΒ±(zβ²)+eQzgΒ±(zβ²)]V(zβ²)Ξ¨(zβ²)ββ(2.42)
is evaluated for each of the segments defined in step 204. To perform this series of evaluations, the wave function within each segment is approximated by a linear interpolation formula. For segment j (zjβ1<zβ²<zj), the interpolation formula is:
Ξ¨(zβ²)=Ξ¨(zjβ1)+Ξ¨β²(zj)(zβ²βzjβ1); j=1, Mβ1,
where Ξ¨β²(zj)β‘[Ξ¨(zj)βΞ¨(zjβ1)]/Ξz, is the z-derivative of Ξ¨(zβ²) in segment j and Ξzj=zjβzjβ1, is mesh size in segment j. In each iteration, the wave function Ξ¨ on the boundary mesh point zj is updated by carrying out the integral over zβ² within each segment analytically, thus converting the Lippmann-Schwinger equation into a simple sequence of matrix-vector multiplications.
To increase accuracy, the numerical implementation decomposes the Green's function G(z, zβ²) into two integrals, one proportional to analytic the function eβQzβ² and the other proportional to eQzβ² [see Equation (2.41)]. These separate terms are contained in each of the G0, G1 and Ga cases. For each segment j, the integrals are: 1 2 β’ β« z j - 1 z j β’ β z β² β’ e - Qz β² β’ Q - 1 β’ S T β’ Ξ¨ β‘ ( z β² ) = e - Qz j - 1 β‘ [ W j β’ Ξ¨ β‘ ( z j - 1 ) + W j ( - ) β’ Ξ¨ β² β‘ ( z j ) ] and: 1 2 β’ β« z j - 1 z j β’ β z β² β’ e Qz β² β’ Q - 1 β’ S T β’ Ξ¨ β‘ ( z β² ) = e Qz j β‘ [ W j β’ Ξ¨ β‘ ( z j - 1 ) + W j ( + ) β’ Ξ¨ β² β‘ ( z j ) ] , β’ where: W j β‘ 1 2 β’ ( 1 - e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 2 β’ S T , β’ W j ( - ) β‘ 1 2 β’ ( W j - Ξ β’ β β’ z j β’ e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 2 β’ S T W j ( + ) β‘ 1 2 β’ ( Ξ β’ β β’ z j - W j ) β’ Q - 2 β’ S T .
This decomposition is essential for making the Lippmann-Schwinger equations numerically accurate, since it brings down a factor of Qβ1 that decays like 1/n as the order of the coupled-wave basis increases. Without this extra factor, the TM mode calculation is slow convergent (decaying like 1/n), and a direct numerical evaluation of the Lippmann-Schwinger equation on a finite mesh may be inaccurate.
Evaluating Equation (2.42) over zβ² in each segment j results in the following system of linear equations:
ΓXβ‘XβS({overscore (G)}VX+{overscore (G)}β²VXβ²)=X0,ββ(2.43)
where X0, X, and Xβ² are NM-dimensional column vectors with entries Xn0(j)=<n|Ξ¨0(zj)>, Xn(j)=<n|Ξ¨(zj)>, and Xβ²n(j)=<n|Ξ¨β²(zj)>. N is the number of coupled waves and M is the number of mesh points in z. V, {overscore (G)}, and {overscore (G)}β² are NMΓNM matrices with matrix elements:
β
β’
V
n
,
n
β²
β‘
(
j
,
j
β²
)
=
Ξ΄
j
,
j
β²
β’
β©
n
β’
ο
V
β‘
(
z
j
)
ο
β’
n
β²
βͺ
,
β’
G
_
n
,
n
β²
β‘
(
j
,
j
β²
)
=
{
β©
n
β’
ο
e
-
Q
β‘
(
z
j
-
z
f
)
β’
W
j
β²
+
e
-
Qz
j
β’
r
_
β’
β
β’
g
-
β‘
(
j
β²
)
+
e
Qz
j
β’
R
β’
β
β’
f
+
β‘
(
j
β²
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
β₯
j
β²
β©
n
β’
ο
e
-
Q
β‘
(
z
j
-
z
f
-
1
)
β’
W
j
β²
+
e
-
Qz
j
β’
r
_
β’
β
β’
g
-
β‘
(
j
β²
)
+
e
Qz
j
β’
R
β’
β
β’
f
+
β‘
(
j
β²
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
<
j
β²
β’
β’
G
_
β²
n
,
n
β²
β‘
(
j
,
j
β²
)
=
{
β©
n
β’
ο
e
-
Q
β‘
(
z
j
-
z
f
)
β’
W
j
β²
(
+
)
+
e
-
Qz
j
β’
r
_
β’
β
β’
g
β²
-
β‘
(
j
β²
)
+
e
Qz
j
β’
R
β’
β
β’
f
β²
+
β‘
(
j
β²
)
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
β₯
j
β²
β©
n
β’
ο
e
Q
β‘
(
z
j
-
z
f
-
1
)
β’
W
j
β²
(
-
)
+
e
-
Qz
j
β’
r
_
β’
β
β’
g
β²
-
β‘
(
j
β²
)
+
e
Qz
j
β’
R
β’
β
β’
f
β²
+
β‘
(
j
β²
)
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
<
j
β²
β’
β’
β
β’
where:
β
β
β’
(
f
+
β‘
(
j
)
g
-
β‘
(
j
)
)
=
(
e
Qz
j
+
r
_
β’
β
β’
u
β‘
(
R
β’
β
β’
e
Qz
j
+
e
-
Qz
j
-
1
)
u
β‘
(
R
β’
β
β’
e
Qz
j
+
e
-
Qz
j
-
1
)
)
β’
W
j
,
β’
β
β’
and:
(
2.44
)
β
β’
(
f
β²
+
β‘
(
j
)
g
β²
-
β‘
(
j
)
)
=
(
e
Qz
j
β’
W
j
(
+
)
+
r
_
β’
β
β’
u
β‘
(
R
β’
β
β’
e
Qz
j
β’
W
j
(
+
)
+
e
-
Qz
j
-
1
β’
W
j
(
-
)
)
u
β‘
(
R
β’
β
β’
e
Qz
j
+
e
-
Q
j
-
1
β’
W
j
(
-
)
)
)
.
(
2.45
)
In step 208, the system of linear equations is solved This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also be used. In the case where QMR is used, the initial guess of the wave function is taken to be Ξ¨0(zβ²) and is calculated via RCWA on the boundary mesh points zj (j=1, . . . Mβ1).The matrices S, R, {overscore (r)}, and u are also calculated and stored. These matrices are independent of the perturbation V, allowing them to be computed once and reused. The following numerical procedures are then performed iteratively:
Once the convergent solutions to X and consequently Y and Yβ² are obtained, the modeling method completes at step 208 where the following projected Lippmann-Schwinger equation is used to calculate the TE mode reflection coefficients:
r=r0+β«G(0, zβ²)V(zβ²)Ξ¨(zβ²)dzβ²β‘r0+GsY+Gβ²sYβ²ββ(2.46)
where Gs, and Gβ²s are row vectors with entries defined by:
Gns(j)=<0|S(1+{overscore (r)})gβ(j)|n>, and
Gβ²ns(j)=<0|S(1+{overscore (r)})gβ²β(j)|n>,
As mentioned, steps 206 and 208 are repeated separately for TE and TM modes (this separation is logical and the operations may be combined for some implementations). The description for TE modes has just been completed. In step 206 (for TM modes) the Green's function for the G1 case Equation (2.33) is substituted into the Lippmann-Schwinger equation for TM modes Equation (2.9). The resulting integral:
Ξ¨
β‘
(
z
)
-
Ξ¨
0
β‘
(
z
)
=
β«
β
z
β²
β’
{
S
β‘
[
e
-
Qz
β’
f
Β±
β‘
(
z
β²
)
+
e
Qz
β’
g
Β±
β‘
(
z
β²
)
]
β’
K
β’
V
~
β‘
(
z
β²
)
β’
K
β’
β
β’
Ξ¨
β‘
(
z
β²
)
+
β
z
β²
β’
S
β‘
[
e
-
Qz
β’
f
Β±
β‘
(
z
β²
)
+
e
Qz
β’
g
Β±
β‘
(
z
β²
)
]
β’
V
β‘
(
z
β²
)
β’
β
z
β²
β’
β
β’
Ξ¨
β‘
(
z
β²
)
}
,
(
2.47
)
is evaluated for each of the segments defined in step 204. To perform this series of evaluations, the wave function within each segment is approximated using the same linear interpolation formula used for TE modes. The same method for enhancing the accuracy of the Lippmann-Schwinger equation is also used (i.e., decomposition to form two integrals).
Evaluating equation (2.47) over zβ² in each segment j results in the following system of linear equations:
ΓXβ‘XβS({overscore (G)}K{tilde over (V)}KX+{overscore (G)}β²K{tilde over (V)}KVXβ²+d{overscore (G)}VXβ²)=X0,ββ(2.48)
where K, {tilde over (V)}, and V are the same matrices as introduced in Equation (2.9). d{overscore (G)} is a NMΓNM matrix with elements:
d
β’
β
β’
G
n
,
n
β²
β‘
(
j
,
j
β²
)
=
{
β©
n
β’
ο
e
-
Q
β‘
(
z
j
-
z
j
β²
)
β’
Q
β’
β
β’
W
j
β²
+
e
-
Q
z
j
β’
r
β’
β
β’
g
z
-
β‘
(
j
β²
)
+
e
Q
z
β’
R
β’
β
β’
f
z
+
β‘
(
j
β²
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
β₯
j
β²
β©
n
β’
ο
-
e
Q
β‘
(
z
j
-
z
j
-
1
)
β’
Q
β’
β
β’
W
j
β²
+
e
-
Q
z
j
β’
r
β’
β
β’
g
z
-
β‘
(
j
β²
)
+
e
Q
z
β’
R
β’
β
β’
f
z
+
β‘
(
j
β²
)
ο
β’
n
β²
βͺ
,
for
β’
β
β’
j
<
j
β²
,
(
2.49
)
β
β’
where:
β’
β’
β
β’
(
f
z
+
β‘
(
j
)
g
z
-
β‘
(
j
)
)
=
(
e
Q
z
+
r
_
β’
β
β’
u
β‘
(
Re
Q
z
j
-
e
-
Q
z
j
-
1
)
u
β‘
(
Re
Q
z
j
-
e
-
Q
z
j
-
1
)
)
β’
Q
β’
β
β’
W
j
.
β
In step 208, the system of linear equations is solved. This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also be used. In the case where QMR is used, the initial guess of the wave function is taken to be Ξ¨0(zβ²) and is calculated via RCWA on the boundary mesh points zj (j=1, . . . , Mβ1). The matrices S, R, {overscore (r)}, and u are also calculated and stored. These matrices are independent of the perturbation V, allowing them to be computed once and reused. The following numerical procedures are then performed iteratively:
The numerical implementation is then completed at step 208 where the following the following projected Lippmann-Schwinger equation is used to calculate the TM mode reflection coefficients:
r
=
β’
r
0
+
β«
G
β‘
(
0
,
z
β²
)
β’
V
β‘
(
z
β²
)
β’
Ξ¨
β‘
(
z
β²
)
β’
β
z
β²
+
β’
β«
β
z
β²
β’
G
β‘
(
0
,
z
β²
)
β’
V
β‘
(
z
β²
)
β’
Ξ¨
β²
β‘
(
z
β²
)
β’
β
z
β²
β’
β
z
β²
β‘
β’
r
0
+
G
s
β’
Y
1
+
G
β²
β’
β
β’
s
β’
Y
2
+
d
β’
β
β’
G
s
β’
Y
β²
(
2.50
)
where Gs, Gβ²s and dGs are row vectors with entries defined by:
Gns(j)=<0|S(1+{overscore (r)})gβ(j)|n>,
Gβ²ns(j)=<0|S(1+{overscore (r)})gβ²β(j)|n>, and
dGns(j)=<0|S(1+{overscore (r)})gzβ(j)|n>.
Multi-layer Evaluation
If the perturbation domain contains more than one layer of materials, the transfer-matrix method is used to calculate {overscore (G)}Y=B (and similarly for Bβ², B1, and B2) due to contributions from zβ² in different material layers. When z (where the updated wave function is to be evaluated) is in layer l, B is defined as the summation:
B
=
β
l
β²
β’
B
(
l
β’
β
β’
l
β²
)
,
where B(llβ²) is the contribution from all zβ² in layer lβ². B(llβ²) is obtained according to procedure 3 described above. For l>lβ², each B(llβ²) is defined as:
B(llβ²)(j)=(eβQlzj+eQlzjR){overscore (T)}lβ1{overscore (T)}lβ²Fr(lβ²),
and for l<lβ², each B(llβ²) is defined as:
B(llβ²)(j)=(eβQlzj{overscore (r)}+eQlzj){overscore (t)}l{overscore (t)}lβ²β1Gr(lβ²),
where {overscore (T)}lβ‘TleβQldl and {overscore (t)}lβ‘eβQldltl.
Finally, the Born approximation may be used for the G1 case when the zero-th order structure chosen is very close to the physical structure. In this case, the wave function Ξ¨ is replaced by the zero-th order wave function Ξ¨0 and Equations (2.46) and (2.50) are used to directly evaluate the reflection coefficients.
Equation Section 3E Field Wave Equation for Three-dimensional Structures
This section describes an E field derivation for a wave equation for three-dimensional structures. The E field wave equation allows the modeling method to be used to predict the diffraction response of three-dimensional structures (i.e., structures that do not exhibit translational symmetry in any one direction). For semi-conductor wafers, this can include patterns of vias and other periodic and non-periodic structures. The E field wave equation may also be used to model scattering for conical incidence.
To describe this derivation, consider a two-dimensional periodic array of three-dimensional gratings. The primitive lattice vectors within this array are labeled a1 and a2. The corresponding primitive reciprocal lattice vectors are denoted b1 and b2 with biΒ·aj=2ΟΞ΄ij. For this system, the wave function and Green's function may be expanded in terms of the plane wave ei{right arrow over (k)}nβ²Ξ΄, where {right arrow over (k)}n; n=1, . . . , N denotes a series of N reciprocal lattice vectors. The x and y components of {right arrow over (k)}n are conveniently denoted as kxn and kyn.
The equations for electric fields are:
βΓβΓE=βk02E.
βΒ·βE=0,
where k0=Ο/c is the wave number. The electric field is related to the magnetic field via:
H(r)β‘βΓE(r)
The dyadic Green's function for the uniform multilayer material is denoted G and satisfies the following equation:
βΓβΓGββn(z)k02G=ββΒ·Gββn(z)k02G=Ξ΄(rβ²βr)ββ(3.1)
where βn is the dielectric constant of the host medium and with the boundary conditions that G and βΓG are continuous across z boundaries.
Within the perturbation domain (i.e., 0<zβ²<d), the periodic nature of the system allows G to be written in terms of coupled-wave basis as: G β‘ ( r β² - r ) = β n β’ e ik n Β· ( Ο ~ - Ο ~ β² ) β’ G n β‘ ( z , z β² ) = β n β’ e ik xn β‘ ( x - x β² ) + ik yn β‘ ( y - y β² ) β’ G n β‘ ( z , z β² ) .
Substituting this into Equation (3.1) yields:
[(ikn+{circumflex over (z)}βz)(ikn+{circumflex over (z)}βz)Β·Gn+(kn2ββz2)Gn]ββnk02Gn=IΞ΄(zβzβ²),
where I is a 3Γ3 identity matrix. Taking the dot product of (ikn+{circumflex over (z)}βz) with the above gives:
ββn(z)k02(ikn+{circumflex over (z)}βz)Β·Gn=(ikn+{circumflex over (z)}βz)Ξ΄(zβzβ²).ββ(3.2)
or:
(
q
n
2
-
β
z
2
)
β’
G
n
=
[
I
+
(
ik
n
+
z
^
β’
β
z
)
β’
(
ik
n
+
z
^
β’
β
z
)
Ι
a
β’
k
0
2
]
β’
Ξ΄
β‘
(
z
-
z
β²
)
,
(
3.3
)
where qn2β‘kn2ββnk02. It is convenient to choose a different coordinate frame (xβ², yβ²) for each index n, such that kn is parallel to the xβ² axis. The following equations are used to make this transformation:
{circumflex over (x)}=cos Οn{circumflex over (x)}β²βsin ΟnΕ·β²,
Ε·=sin Οn{circumflex over (x)}β²βcos ΟnΕ·β²,
where Οn=tanβ1(kyn/kxn). In this frame, G takes the simplified form:
G
=
(
G
xx
0
G
xz
0
G
yy
0
G
zx
0
G
zz
)
with the boundary conditions that:
G
xx
,
G
xz
,
G
yy
,
Ι
a
β‘
(
z
)
q
n
2
β’
β
z
β’
G
xx
,
Ι
n
β‘
(
z
)
q
n
2
β’
β
z
β’
G
xz
,
and
β’
β
β’
β
z
β’
G
yy
are all continuous across z boundaries.
The yβ²yβ² component of G is simply:
G
yy
=
1
2
β’
q
n
β‘
[
e
-
q
n
β’
ο
z
-
z
β²
ο
+
e
q
n
β’
z
β²
β’
R
n
β’
f
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
β
n
β’
g
n
β‘
(
z
)
]
,
where fn(z) and gn(z) are given by (in column vector form):
(
f
g
)
=
(
e
Qz
+
r
_
β’
u
β‘
(
Re
Qz
+
e
-
Qz
)
u
β‘
(
Re
Qz
+
e
-
Qz
)
)
,
(
3.4
)
where uβ‘(1βR{overscore (r)})β1. Q denotes a square matrix with diagonal entries qn. R and {tilde over (r)} are the forward and backward transfer matrices which can be obtained by the transfer matrix method.
Gxx and Gxz are given by:
G
xx
=
-
q
n
2
β’
Ι
n
β’
k
0
2
β‘
[
e
-
q
n
β’
ο
z
-
z
β²
ο
+
e
q
n
β’
z
β²
β’
R
~
n
β’
f
~
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
~
n
β’
g
~
n
β‘
(
z
)
]
,
β’
G
xz
=
β
β’
β
β’
k
n
2
β’
Ι
n
β’
k
0
2
β‘
[
sgn
β‘
(
z
β²
-
z
)
β’
e
-
q
n
β’
ο
z
-
z
β²
ο
-
e
q
n
β’
z
β²
β’
R
~
n
β’
f
~
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
~
n
β’
g
~
n
β‘
(
z
)
]
,
where {tilde over (f)}n and {tilde over (g)}n takes the same as fn and gn except the related {tilde over (R)}n and {tilde over (r)}n are obtained with different boundary conditions.
Equations (3.2) and (3.3) are used to relate the remaining two components to Gxx and Gxz via:
G
zx
=
-
ik
n
q
n
2
β’
β
z
β’
G
xx
G
zz
=
1
q
n
2
β‘
[
-
ik
n
β’
β
z
β’
G
xz
+
Ξ΄
β‘
(
z
-
z
β²
)
]
.
resulting in:
G
zx
=
ik
n
2
β’
Ι
a
β’
k
0
2
β‘
[
sgn
β‘
(
z
β²
-
z
)
β’
e
-
q
n
β’
ο
z
-
z
β²
ο
-
e
q
n
β’
z
β²
β’
R
~
n
β’
f
~
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
~
n
β’
g
~
n
β‘
(
z
)
]
,
β
G
zz
=
k
n
2
2
β’
q
n
β’
Ι
a
β’
k
0
2
β‘
[
e
-
q
n
β’
ο
z
-
z
β²
ο
+
e
q
n
β’
z
β²
β’
R
~
n
β’
f
~
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
~
n
β’
g
~
n
β‘
(
z
)
]
-
1
Ι
a
β’
k
0
2
β’
Ξ΄
β‘
(
z
-
z
β²
)
,
where
β’
:
β
(
f
_
g
_
)
β‘
(
Q
-
1
β’
β
β
z
β’
f
~
Q
-
1
β’
β
β
z
β’
g
~
)
=
(
e
Qz
+
r
~
β’
u
~
(
R
~
β’
e
Qz
+
e
-
Qz
)
u
~
(
R
~
β’
e
Qz
+
e
-
Qz
)
)
.
(
3.5
)
Note that G(r, rβ²) is symmetric, which implies G(kn; z, zβ²)=GT(βkn; zβ², z). Here: G(kn; z, zβ²)=Gn(z, zβ²). Rotating back to the original coordinates yields: G n = ( G 11 G 12 G 13 G 21 G 22 G 23 G 31 G 32 G 33 ) = ( cos 2 β’ Ο n β’ G xx + sin 2 β’ Ο n β’ G yy cos β’ β β’ Ο n β’ sin β’ β β’ Ο n β‘ ( G xx - G yy ) cos β’ β β’ Ο n β’ G xz cos β’ β β’ Ο n β’ sin β’ β β’ Ο n β‘ ( G xx - G yy ) sin 2 β’ Ο n β’ G xx + cos 2 β’ Ο n β’ G yy sin β’ β β’ Ο n β’ G xz cos β’ β β’ Ο n β’ G zx sin β’ β β’ Ο n β’ G zx G zx ) .
It can be shown that the following Lippmann-Schwinger equation holds:
Ξ¨(z)βΞ¨0(z)=β«dzβ²G(z, zβ²)V(zβ²)Ξ¨(zβ²),ββ(3.6)
where Vβ‘(β(z)ββn)k02. Note that β(z) is anisotropic in the laminated film in the grating region:
Ι
=
(
P
-
1
0
0
0
Ι
0
0
0
Ι
)
,
where P as a matrix in the coupled-wave basis is the inverse of the β matrix. For 3D gratings, it is assumed that the dielectric tensor takes the form:
Ι
=
(
P
-
1
0
0
0
P
-
1
0
0
0
Ι
)
.
The three-component Lippmann-Schwinger equation can be reduced to a two-component Lippmann-Schwinger equation by utilizing the transverse condition βΒ·βE=0 to eliminate one component (Ex). The resulting equation is:
{tilde over (E)}xβ‘Pβ1Ex=Kxβ1[iβz(βEz)βKy(βEy)].
Substituting this into the Lippmann-Schwinger equation (for the y and z components) yields:
Ey(z)βEy0(z)=β«dzβ²[G21{tilde over (V)}{tilde over (E)}x+G22VEy+G23VEz],ββ(3.7)
Ez(z)βEz0(z)=β«dzβ²[G31{tilde over (V)}{tilde over (E)}x+G32VEy+G33VEz],ββ(3.8)
where {tilde over (V)} is defined as:
{tilde over (V)}β‘(1βPβn)k02 .
Note that both V and {tilde over (V)} can be factored out as the product of a complex number and a real toeplitz matrix, and the product βEi=VEi+βnEi, i=x, y can be calculated quickly once VEi are obtained. In the special case with Ky=0, Ez is proportional to Kxββ1Hy, and the above Lippmann-Schwinger equations reduce to two decoupled integral equations, one for the TE mode (Ey) and the other for the TM mode (Hy). The resulting decoupled Lippmann-Schwinger equations are identical to those derived previously for the special limit (G0 approach):
β
β’
E
y
β‘
(
z
)
-
E
y
0
β‘
(
z
)
=
β«
β
z
β²
β’
G
22
β’
β
β‘
(
z
,
z
β²
)
β’
V
β’
β
β’
E
y
,
(
3.9
)
H
y
-
E
~
z
0
β‘
(
z
)
=
β«
β
z
β²
β‘
[
β
z
β²
β’
G
_
β‘
(
z
,
z
β²
)
β’
V
~
β’
β
z
β²
β’
H
y
+
G
_
β‘
(
z
,
z
β²
)
β’
K
x
β’
V
β’
β
β’
Ι
-
1
β’
K
n
β’
H
y
]
,
(
3.10
)
where:
G
_
β‘
(
z
,
z
β²
)
=
1
2
β’
β
β’
q
n
β’
k
0
2
β‘
[
e
-
q
n
β’
ο
z
-
z
β²
ο
-
e
q
n
β’
z
β²
β’
R
~
n
β’
f
_
n
β‘
(
z
)
+
e
-
q
n
β’
z
β²
β’
r
~
n
β’
g
_
n
β‘
(
z
)
]
.
Numerical Evaluation for the E Field Wave Equation for Three-Dimensional Structures
This section describes the use of modeling method to numerically evaluate the wave equation for three-dimensional structures (Equation (3.6)). This numerical implementation allows the Green's function approach to be used within optical metrology and other systems that require diffraction modeling for three dimensional structures.
As previously described, the modeling method begins with the creation of an idealized representation for the scatterer (see step 202 of FIG. 2). In the following step (step 204), the perturbation domain (0<zβ²<d) of the idealized representation is subdivided into a series of M segments. As shown in FIG. 6, the width of each jth segment is labeled Ξzj. The corresponding midpoint of each jth segment is labeled zj. Within each segment, the perturbation function V is assumed to be constant. For the simplest case, each segment has the same thickness. In many cases, however, it is desirable to vary the thickness of individual segments to increase accuracy of the numerical implementation. Typically, and as shown in FIG. 6, this is used to provide more segments near boundaries.
In step 206, Equation (3.6) is evaluated for each of the segments defined in step 204. To perform this series of evaluations, the wave function within each segment is approximated by its value at the midpoint zj. In each iteration, the wave function Ξ¨ on the boundary mesh point zj is updated by carrying out the integral over zβ² within each segment analytically, converting the Lippmann-Schwinger wave equation into a sequence of matrix-vector multiplications.
Note that in all cases the green's function G(z, zβ²) contains terms that are proportional to the analytic functions eβQzβ² or eQzβ². The Lippmann-Schwinger equation contains the following integrals, which are carried out analytically within each segment. For segment j, the integrals are:
β«zjβzj+dzβ²eβQzβ²Ξ¨(zβ²)=eβQ(zjβ)WjΞ¨(zj)
and
β«zjβzj+dzβ²eQzβ²Ξ¨(zβ²)=eQ(zj+)WjΞ¨(zj)
where zjΒ±β‘zjΒ±Ξzj/2 and
Wjβ‘(1βeβQΞzj)Qβ1.
The above procedure is essential for making the Lippmann-Schwinger equations accurate, since it brings down a factor of Qβ1 which decays like 1/n as the order of the coupled-wave basis increases. Without this extra factor, the calculation is slow convergent (decaying like 1/N), and a direct numerical evaluation of the Lippmann-Schwinger equation on a finite mesh may be inaccurate. Performing an average of the resulting function of Equation (3.6) over z within each segment j further improves accuracy. This brings down another factor of Qβ1. If z and zβ² fall into the same segment j, the result is:
β«zjβzj+dzβ«zjβzj+dzβ²eβQ[zβzβ²]=Wj0.ββ(3.11)
where:
Wj0=2[Ξzβ(1βeβQΞz)Qβ1]Qβ1.
βand:
β«zjβzj+dzβ«zjβzj+dzβ²sgn(zβ²βz)eβQ[zβzβ²]=0.
The result of the double integration is the following system of linear equations:
ΓXβ‘Xβ{overscore (G)}VX+(VX)zβnk02=X0,ββ(3.12)
Within Equation (3.12) X0 and X are 3NM-dimensional column vectors where N is the number of coupled waves in each direction of x and y, and M (as previously discussed) is the number of subdivisions of the perturbation domain. The elements of X0 and X are defined as:
Xn0(j)=<n|Ξ¨0(zj)> and
Xn(j)=<n|Ξ¨(zj)>.
V and {overscore (G)} are 3NMΓ3NM matrices with matrix elements given by:
V
n
,
n
β²
β‘
(
j
,
j
β²
)
=
I
β’
β
β’
Ξ΄
j
,
j
β²
β’
n
β’
ο
V
β‘
(
z
j
)
ο
β’
n
β²
,
β’
G
_
β‘
(
j
,
j
β²
)
=
{
S
0
β’
W
j
0
β’
Ξ΄
j
,
j
β²
+
W
j
[
Se
-
Q
β’
ο
z
j
-
-
z
j
β²
+
ο
β’
ΞΈ
β‘
(
j
>
j
β²
)
+
S
β²
β’
e
-
Q
β’
ο
z
j
+
-
z
j
β²
-
ο
β’
ΞΈ
β‘
(
j
<
j
β²
)
+
RF
β‘
(
j
)
β’
e
Qz
j
β²
+
+
r
_
β’
G
β‘
(
j
)
β’
e
-
Qz
j
-
]
β’
W
j
β²
}
where R({overscore (r)}) is a 3NΓ3N matrix with diagonal elements being {tilde over (R)}n({tilde over (r)}n) for the xβ²xβ² and zz components and Rn({overscore (r)}n) for the yβ²yβ² component. S0, S, Sβ², f(j) and g(j) are 3NΓ3N matrices with the nth diagonal block given by:
S
n
=
(
-
q
n
2
Ι
a
β’
k
0
2
0
-
ik
n
β’
q
n
Ι
a
β’
k
0
2
0
1
0
-
ik
n
β’
q
n
Ι
a
β’
k
0
2
0
k
n
2
q
n
β’
Ι
a
β’
k
0
2
)
/
2
β’
q
n
β’
Ξ
β’
β
β’
z
S0 is obtained from S by eliminating the off-diagonal terms.
S
n
β²
=
(
-
q
n
2
Ι
a
β’
k
0
2
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
0
1
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
0
k
n
2
Ι
a
β’
k
0
2
)
/
2
β’
q
n
β’
Ξ
β’
β
β’
z
F
n
β‘
(
j
)
=
(
-
q
n
2
Ι
a
β’
k
0
2
β’
f
_
n
β‘
(
j
)
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
β’
f
_
n
β‘
(
j
)
0
f
n
β‘
(
j
)
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
β’
f
_
n
β‘
(
j
)
0
-
k
n
2
Ι
a
β’
k
0
2
β’
f
_
n
β‘
(
j
)
)
/
2
β’
q
n
β’
Ξ
β’
β
β’
z
G
n
β‘
(
j
)
=
(
-
q
n
2
Ι
a
β’
k
0
2
β’
g
_
n
β‘
(
j
)
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
β’
g
_
n
β‘
(
j
)
0
g
n
β‘
(
j
)
0
ik
n
β’
q
n
Ι
a
β’
k
0
2
β’
g
_
n
β‘
(
j
)
0
k
n
2
Ι
a
β’
k
0
2
β’
g
_
n
β‘
(
j
)
)
/
2
β’
q
n
β’
Ξ
β’
β
β’
z
β’
(
f
β‘
(
j
)
g
β‘
(
j
)
)
=
(
e
Qz
j
+
+
r
_
β’
u
β‘
(
Re
Qz
j
+
-
e
-
Qz
j
-
)
u
β‘
(
Re
Qz
j
+
+
e
-
Qz
j
-
)
)
.
{tilde over (f)}n and {tilde over (g)}n takes the same as fn and gn except Rn and {overscore (r)}n are replaced by {tilde over (R)}n and {tilde over (r)}n. ( f _ β‘ ( j ) g _ β‘ ( j ) ) = ( e Qz + r _ β’ u _ β‘ ( R _ β’ e Qz j + - e - Qz j - ) u _ β‘ ( R _ β’ e Qz j + - e - Qz j - ) ) .
In step 208, the system of linear equations is solved. This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also be used.
In the case where QMR is used, the initial guess of the wave function Ξ¨(zβ²) is taken to be Ξ¨0(zβ²) which is evaluated on the mesh points zj (j=1, . . . , M). The following numerical procedures are then performed:
Note that the eigen-values of Γ are all close to 1 if the magnitude of GV is small compared to 1. This feature makes the QMR method a fast converging one. The iteration procedure involves repeated multiplication of the form ΓX.
Two-component Equation Section 4H Field Wave Equation for Three-dimensional Structures
This section describes a derivation for an H field wave equation for three-dimensional structures. The H field wave equation allows the modeling method to be used to predict the diffraction response of three-dimensional structures (i.e., structures that do not exhibit translational symmetry in any one direction). For semi-conductor wafers, this can include patterns of vias and other periodic and non-periodic structures. The H field wave equation may also be used to model scattering for conical incidence.
The derivation for TM modes begins with the equation:
βΓββ1βΓ{right arrow over (H)}=k02{right arrow over (H)}
where k0 is the wave number and is equal to Ο/c. In coupled wave terms, this can be rewritten as:
{right arrow over (H)}(x, y, z)={right arrow over (H)}(z)et(Kxx+Kyy),
where H(z) is a column vector of dimension N2, and Kx, Ky denote N2ΓN2 square matrices with diagonal entries equal to (k0x+2nΟ/p) and (k0y+2mΟ/p); n, m=1, . . . , N. kz=βiβz remains a scalar. The requirement (from the Maxwell equations) that βΒ·{right arrow over (H)}=0 gives:
kzHz=β(KxHx+KyHy)
leading to the following equations for magnetic fields:
β{circumflex over (x)}Β·{{right arrow over (k)}Γββ1[β(KxHzβkzHx)Ε·β(KxHyβKyHx){circumflex over (z)}]}
=βkzββ1(KxHzβkzHx)βKyββ1(KxHyβKyHx)
=kzββ1kzβ1(KxKyHy+KxKxHx)+kzββ1kzHxβKyββ1(KxHyβKyHx)
=k02Hx
βΕ·Β·{{right arrow over (k)}Γββ1[(KyHzβkzHy){circumflex over (x)}+(KxHyβKyHx){circumflex over (z)}]}
=βkzββ1(KyHzβkzHy)+Kxββ1(KxHyβKyHx)
=kzββ1kzβ1(KyKxHxβKyKyHy)+kzββ1kzHy)+Kxββ1(KxHyβKyHx)
=k02Hy
or:
(
k
0
2
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
x
2
-
K
y
β’
Ι
-
1
β’
K
y
K
y
β’
Ι
-
1
β’
K
x
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
x
β’
K
y
K
x
β’
Ι
-
1
β’
K
y
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
y
β’
K
x
k
0
2
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
y
2
-
K
x
β’
Ι
-
1
β’
K
x
)
β’
β
β’
(
H
x
H
y
)
β’
β
=
k
z
β’
Ι
-
1
β’
k
z
β‘
(
H
x
H
y
)
(
4.1
)
The relationship between magnetic fields and electric fields can be obtained as:
βk0βEx=kzHyβKyHz=kzHy+kzβ1Ky(KxHx+KyHy),
k0βEy=kzHxβkxHz=kzHx+kzβ1Kx(KxHx+KyHy).
or:
βk0kzβEx=kz2Hy+KyKxHx+Ky2Hy,
k0kzβEy=kz2Hx+Kx2Hx+KxKyHy.
Assuming that:
Ξ¨
=
(
H
x
H
y
)
β’
β
β’
and
β’
β
β’
Ξ¨
β²
=
(
E
y
-
E
x
)
,
produces the following differential equations:
[βzP(z)βzβL(z)]Ξ¨=0,ββ(4.2)
Ξ¨β²=P(z)βzΞ¨,ββ(4.3)
where:
L
β‘
(
z
)
=
-
k
0
2
β’
I
+
(
K
y
β’
Ι
-
1
β’
K
y
-
K
y
β’
Ι
-
1
β’
K
x
-
K
x
β’
Ι
-
1
β’
K
y
+
K
x
β’
Ι
-
1
β’
K
x
)
,
(
4.4
)
where I is the identity matrix, and:
P
β‘
(
z
)
=
(
Ι
-
1
0
0
Ι
_
-
1
)
β‘
[
I
+
(
K
x
2
K
x
β’
K
y
K
y
β’
K
x
K
y
2
)
β’
k
z
-
2
]
β‘
(
Ι
-
1
0
0
Ι
_
-
1
)
β’
(
I
+
Ξ·
β’
β
β’
k
z
-
2
)
.
The wave function Ξ¨ satisfies the boundary conditions that Ξ¨(z) and P(z)βzΞ¨(z) are continuous across z boundaries.
The derivation for TE modes begins with the equation:
βΓβΓ{right arrow over (E)}=βk02{right arrow over (E)}.
where k0 is the wave number and is equal to Ο/c. In coupled wave terms, this can be rewritten as:
{right arrow over (E)}(x, y, z)={right arrow over (E)}(z)et(Kxx+Kyy),
where E(z) is a column vector of dimension N2, and Kx, Ky denote N2ΓN2 square matrices with diagonal entries equal to (k0x+2nΟ/p) and (k0y+2mΟ/p); n, m=1, . . . , N. kz=βiβz remains a scalar. The requirement (from the Maxwell equations) that βΒ·{right arrow over (E)}=0 gives:
kzβEz=β(KxβEx+KyβEy)
leading to the following equations for electric fields:
β{circumflex over (x)}Β·{{right arrow over (k)}Γ[β(KxEzβkzEx)Ε·β(KxEyβKyEx){circumflex over (z)}]}
βkz(KxEzβkzEx)βKy(KxEyβKyEx)
=kzββ1kzβ1(KxKyβEy+KxKxβEx)+kzkzExβKy(KxEyβKyEx)
=βk02Ex
βΕ·Β·{{right arrow over (k)}Γ[(KyEzβkzEy){circumflex over (x)}+(KxEyβKyEx){circumflex over (z)}]}
βkz(KyEzβkzEy)+Kx(KxEyβKyEx)
=Kykzββ1kzβ1(KxβEx+KyβEy)+kzkzEy)+Kx(KxEyβKyEx)
=βk02Ey
or:
(
β
β’
Ιk
0
2
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
x
2
β’
Ι
-
K
y
2
K
y
β’
Ι
-
1
β’
K
x
β’
Ι
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
x
β’
K
y
β’
Ι
K
x
β’
K
y
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
y
β’
K
x
β’
Ι
Ι
β’
β
β’
k
0
2
-
k
z
β’
Ι
-
1
β’
k
z
-
1
β’
K
y
2
β’
Ι
-
K
x
β’
K
x
β’
β
)
β’
(
β
β’
E
x
E
y
β’
β
)
=
k
z
2
(
β
β’
E
x
E
y
β’
β
)
(
4.5
)
The relationship between magnetic fields and electric fields can be obtained as:
βk0βEx=kzEyβKyEz=kzEy+kzβ1Ky(KxEx+KyEy),
k0βEy=kzExβkxEz=kzEx+kzβ1Kx(KxEx+KyEy).
or:
βk0kzβEx=kz2Ey+KyKxEx+Ky2Ey,
k0kzβEx=kz2Ex+Kx2Ex+KxKyEy.
Assuming that:
Ξ¨
=
(
E
x
E
y
)
β’
β
β’
and
β’
β
β’
Ξ¨
β²
=
(
E
y
-
E
x
)
,
produces the following differential equations:
[βzP(z)βzβL(z)]Ξ¨=0,ββ(4.6)
Ξ¨β²=P(z)βzΞ¨,ββ(4.7)
where:
L
β‘
(
z
)
=
-
k
0
2
β’
I
+
(
K
y
β’
Ι
-
1
β’
K
y
-
K
y
β’
Ι
-
1
β’
K
x
-
K
x
β’
Ι
-
1
β’
K
y
+
K
x
β’
Ι
-
1
β’
K
x
)
,
(
4.8
)
where I is the identity matrix, and:
P
β‘
(
z
)
=
Ι
-
1
β‘
[
I
+
(
K
x
2
K
x
β’
K
y
K
y
β’
K
x
K
y
2
)
β’
k
z
-
2
]
β‘
Ι
-
1
β‘
(
I
+
Ξ·
β’
β
β’
k
z
-
2
)
.
The wave function Ξ¨ satisfies the boundary conditions that Ξ¨(z) and P(z)βzΞ¨(z) are continuous across z boundaries.
The Green's function for the G0 structure is defined by:
G
β‘
(
G
x
G
xy
G
yx
G
y
)
,
which satisfies:
[βzP0(z)βzβL0(z)]G(zβzβ²)=Ξ΄(zβzβ²)I,ββ(4.9)
where:
P0(z)=β0(z)β1(I+Ξ·kzβ2)
L
0
=
-
k
0
2
β’
I
+
(
K
y
β’
Ι
0
-
1
β’
K
y
-
K
y
β’
Ι
0
-
1
β’
K
x
-
K
x
β’
Ι
0
-
1
β’
K
y
K
x
β’
Ι
0
-
1
β’
K
x
)
.
Note that for uniform multilayer systems, β0β1 commutes with Kx and Ky with the result that: [βzP0(z)βzβL0(z)]=[βzβ0(z)β1βz+β0(z)β1(Kx2+Ky2)βk02]I. The Green's function must satisfy the same boundary conditions for Ξ¨. Namely that G(z, zβ²) and P0(z)βzG(z, zβ²) are continuous across z boundaries.
For coupled wave within the perturbation domain (for 0<z<d):
G
=
1
p
2
β’
β
m
,
n
β’
e
ik
xn
β‘
(
x
-
x
β²
)
+
ik
ym
β‘
(
y
-
y
β²
)
β’
1
q
nm
β’
β
β‘
[
e
-
q
nm
β’
ο
z
-
z
β²
ο
+
e
q
nm
2
β’
β
β’
R
nm
β’
e
q
nm
β’
z
β²
]
,
where qnm=β{square root over (kxn2+kym2ββ0k02)}. In the coupled-wave basis, G can be expressed as a 2N2-dimensional square matrix in the form:
G
β‘
(
z
,
z
β²
)
=
1
2
β’
Q
-
1
β‘
[
e
-
Q
β’
ο
z
-
z
β²
ο
+
e
Qz
β’
Re
Qz
β²
]
,
(
4.10
)
where Q is a diagonal matrix with entries qnm.
The reflection matrix R is obtained by the transfer matrix method. It is convenient to choose a different coordinate frame (xβ², yβ²) for each index nm, such that P0(z) is diagonal. This produces:
Hxβ²=cos ΟnmHx+sin ΟnmHy,
Hyβ²=βsin ΟnmHx+cos ΟnmHy,
where Οnm=tanβ1(kym/kxn). The reflection amplitudes for Hxβ² and Hyβ² fields are simply Rnmx=βRnms and Rnmy=Rnmp. Here s and p denote the TE and TM modes for a conically incident wave with wave vector (kxn, kym, k0z). Rotating back to the original coordinates yields:
R
nm
=
(
cos
2
β’
Ο
nm
β’
R
nm
x
+
sin
2
β’
Ο
nm
β’
R
nm
p
cos
β’
β
β’
Ο
nm
β’
sin
β’
β
β’
Ο
nm
β‘
(
R
nm
x
-
R
nm
p
)
cos
β’
β
β’
Ο
nm
β’
sin
β’
β
β’
Ο
nm
β‘
(
R
nm
x
-
R
nm
p
)
sin
2
β’
Ο
nm
β’
R
nm
x
+
cos
2
β’
Ο
nm
β’
R
nm
p
)
.
Note that P0(z), L0 and G are all symmetric matrices. Taking the transpose of Equation (4.5) yields:
[βzβ²P0(zβ²)βzβ²G(zβ²βz)βG(zβ²βz)L0(zβ²)]=Ξ΄(zβzβ²)I,ββ(4.11)
Multiplying the above equation by (Ξ¨βΞ¨0) and Equation (4.1) by G(z, zβ²) and integrating each result over zβ² produces the following equations:
β«dzβ²[ββzβ²P0(zβ²)βzβ²G(zβ², z)+G(zβ², z)L0(z)][Ξ¨(zβ²)βΞ¨0(zβ²)]=Ξ¨(z)βΞ¨0(z)
and
β«dzβ²G(z, zβ²)[βzβ²P(zβ²)βzβ²βL(z)]Ξ¨(zβ²)=0.
Subtracting these equations and performing an integration by parts leads to the Lippmann-Schwinger equation:
Ξ¨(z)βΞ¨0(z)=β«dzβ²[G(z, zβ²)V(zβ²)Ξ¨(zβ²)+(βzβ²G(z, zβ²))Ξ(zβ²)(βzβ²Ξ¨(zβ²))],ββ(4.12)
V
β‘
L
β‘
(
z
)
-
L
0
β‘
(
z
)
=
(
K
y
β’
D
β‘
(
z
)
β’
K
y
-
K
y
β’
D
β‘
(
z
)
β’
K
x
-
K
x
β’
D
β‘
(
z
)
β’
K
y
K
x
β’
D
β‘
(
z
)
β’
K
x
)
,
(
4.13
)
D(z)=ββ1(z)ββ0β1(z), and Ξ(z)=P(z)βP0(z)=D(z)(I+Ξ·kzβ2). Note that the boundary terms generated by the integration by parts vanish due to the fact both Ξ¨(z)P0(z)βzG(z, zβ²) and G(z, zβ²)P(z)βzΞ¨(z) are continuous across a z boundary. Here kzβ‘βiβz and kzβ1β‘βiβ«zβdz. kzβ1 is defined in this way so that kzkzβ1=1. This avoids an arbitrary constant term, since Ξ¨(z)=0 as zββ. V(z) and D(z) are non-zero only in the perturbation domain 0<z<d. However, the last term in Equation (4.7) involves an integration operator kzβ1, which means that Ξ¨(z) must be solved for 0<z<β. The problem is simplified by defining an integration constant Cβ‘β«dβΞ¨(z) so that Equation (4.7) now reads: Ξ¨ β‘ ( z ) - Ξ¨ 0 β‘ ( z ) = β« 0 d β’ β z β² β’ { G β‘ ( z , z β² ) β’ V β‘ ( z β² ) β’ Ξ¨ β‘ ( z β² ) + [ β z β² β’ G β‘ ( z , z β² ) ] β’ D β‘ ( z β² ) β‘ [ β z β² β’ Ξ¨ β‘ ( z β² ) + Ξ· β‘ ( C + β« z β² d β’ Ο β‘ ( z β³ ) β’ β z β³ ) ] } ( 4.14 )
Integrating Equation (4.7) over z in the domain d<z<β produces the following auxiliary equation for C:
C
-
C
0
=
β«
0
d
β’
β
z
β²
β’
{
G
β‘
(
z
β²
)
β’
V
β‘
(
z
β²
)
β’
Ξ¨
β‘
(
z
β²
)
+
[
β
z
β²
β’
G
β‘
(
z
β²
)
]
β’
D
β‘
(
z
β²
)
β‘
[
β
z
β²
β’
Ξ¨
β‘
(
z
β²
)
+
Ξ·
β‘
(
C
+
β«
z
β²
d
β’
Ο
β‘
(
z
β³
)
β’
β
z
β³
)
]
}
(
4.15
)
where C0β‘β«dβdzΞ¨(z) and G(zβ²)β‘β«dβdzG(z, zβ²), which can be carried out analytically. The above two coupled equations can now be solved via numerical method. For the incident waves
Ξ¨
0
=
(
0
H
x
0
)
is used for TM modes and
Ξ¨
0
=
(
H
y
0
0
)
is used for TE modes. In the perturbation domain 0<z<d this produces:
Hy0β‘eik0xx+ik0zz+rpeik0xxβik0zz.
Hx0β‘eik0xx+ik0zz+rxeik0xxβik0zz.
Ey0β‘eik0xx+ik0zz+rseik0xxβik0zz.
Note that Hx0 Ey0 are related by Hx0=kzEy0/k0 with rs=βrx. The final result for the reflection amplitude obtained for the Hx field must also change sign to get the reflection amplitude for TE modes.
For a layer l in the region z>d>zβ², Ξ¨0 and G take the form:
Ξ¨0(z)=[eβQlzl+eQlzlRl]Cl,
G(z, zβ²)=[eβQlzl+eQlzlRl]fl(zβ²),
where zl=zβtl is the z coordinate relative to the position of the interface between layers L and lβ1. Rl is the reflection matrix at layer l and Cl and fl are obtained via the recursion relation:
Cl+1=TleβQldlCl
fl+1(zβ²)=TleβQldlfl(zβ²)
starting from l=1 (for 0<zβ²<d) with Cl and:
f
1
β‘
(
z
β²
)
=
1
2
β’
e
Q
1
β’
z
β²
β’
Q
1
-
1
.
Cl is a 2N2 column vector with the only non-zero entry at n=m=0 for the Hx or Hy component. Tl is the transfer matrix defined above. This produces:
C
0
=
β
l
=
2
L
β’
C
l
[
1
-
e
-
Q
l
β’
d
l
+
R
l
β‘
(
e
Q
l
β’
d
l
-
1
)
]
β’
Q
l
-
1
+
C
L
+
1
β’
Q
L
+
!
-
1
β’
β’
and
β’
:
β’
β’
G
β‘
(
z
β²
)
=
β’
β
l
=
2
L
β’
f
l
β‘
(
z
β²
)
β‘
[
1
-
e
-
Q
l
β’
d
l
+
R
l
β‘
(
e
Q
l
β’
d
l
-
1
)
]
β’
Q
l
-
1
+
f
L
+
1
β‘
(
z
β²
)
β’
Q
L
+
1
-
1
β‘
β’
1
2
β’
Fe
Q
1
β‘
(
z
β²
-
d
)
β’
Q
1
-
1
,
where dl is the thickness of layer l;l=1, . . . , L and dl=d. L+1 is the label for the substrate material. Denote the results for F(C0) obtained above for Hxβ² and Hyβ² in the (xβ², yβ²) frame for nm(00)-component as Fnmx(Cx0) and Fnmy(Cy0). Rotating back to the original frame yields:
F
nm
=
(
cos
2
β’
Ο
nm
β’
F
nm
x
+
sin
2
β’
Ο
nm
β’
F
nm
y
cos
β’
β
β’
Ο
nm
β’
sin
β’
β
β’
Ο
nm
β‘
(
F
nm
x
-
F
nm
y
)
cos
β’
β
β’
Ο
nm
β’
sin
β’
β
β’
Ο
nm
β‘
(
F
nm
x
-
F
nm
y
)
sin
2
β’
Ο
nm
β’
F
nm
x
+
cos
2
β’
Ο
nm
β’
F
nm
y
)
,
β’
and
β’
:
C
0
β‘
(
cos
β’
β
β’
Ο
00
β’
C
x
0
-
sin
β’
β
β’
Ο
00
β’
C
y
0
sin
β’
β
β’
Ο
00
β’
C
x
0
cos
β’
β
β’
Ο
00
β’
C
y
0
)
.
Numerical Evaluation for the H-field Wave Equation for Three-dimensional Structures
This section describes the use of modeling method to numerically evaluate the wave equation for three-dimensional structures (Equation (4.12)). This numerical implementation allows the Green's function approach to be used within optical metrology and other systems that require diffraction modeling for three dimensional structures.
As previously described, the modeling method begins with the creation of an idealized representation for the scatterer (see step 202 of FIG. 2). In the following step (step 204), the perturbation domain (0<zβ²<d) of the idealized representation is subdivided into a series of Mβ1 segments. As shown in FIG. 5, the boundaries between the Mβ1 segments have zβ² values labeled by z0, z1 and soon through zMβ1 (with z0=0 and zMβ1=d). Within each segment, the perturbation V is assumed to be constant. For the simplest case, each segment has the same thickness. In many cases, however, it is desirable to vary the thickness of individual segments to increase accuracy of the numerical implementation. Typically, and as shown in FIG. 5, this is used to provide more segments near boundaries.
In step 206, the Green's function for the G0 case Equation (4.10) is substituted into the Lippmann-Schwinger equation [Equation (4.12)] and the resulting integral is evaluated for each of the Mβ1 segments. To perform this series of evaluations, the wave function within each segment is approximated by a linear interpolation formula. For segment j (zjβ1<zβ²<zj), the interpolation formula is:
Ξ¨(zβ²)=Ξ¨(zjβ1)+Ξ¨β²(zj)(zβ²βzjβ1); j=1, Mβ1,
where Ξ¨β²(zj)β‘[Ξ¨(zj)βΞ¨(zjβ1)]/Ξzj is the z-derivative of Ξ¨(zβ²) in segment j. Ξzj=zjβzjβ1 is mesh size in segment j. In each iteration, the wave function Ξ¨ on the boundary mesh point zj is updated by carrying out the integral over zβ² within each segment analytically, thus converting the Lippmann-Schwinger equations into a simple sequence of matrix-vector multiplications.
To increase accuracy, the numerical implementation decomposes the Green's function G(z, zβ²) into two integrals, one proportional to analytic the function eβQzβ² and the other proportional to eQzβ² [see Equation (4.10)]. These separate terms are contained in each of the G0, G1 and Ga cases. For each segment j, the integrals are: 1 2 β’ β« z j - 1 z j β’ β z β² β’ e - Qz β² β’ Q - 1 β’ S T β’ Ξ¨ β‘ ( z β² ) = e - Qz j - 1 β‘ [ W j β’ Ξ¨ β‘ ( z j - 1 ) + W j ( - ) β’ Ξ¨ β² β‘ ( z j ) ] and β’ : 1 2 β’ β« z j - 1 z j β’ β z β² β’ e Qz β² β’ Q - 1 β’ S T β’ Ξ¨ β‘ ( z β² ) = e Qz j β‘ [ W j β’ Ξ¨ β‘ ( z j - 1 ) + W j ( + ) β’ Ξ¨ β² β‘ ( z j ) ] n where β’ : W j β‘ 1 2 β’ ( 1 - e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 2 β’ S T , β’ W j ( - ) β‘ 1 2 β’ ( ( 1 - e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 1 - Ξ β’ β β’ z j β’ e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 2 β’ S T W j ( + ) β‘ 1 2 β’ ( Ξ β’ β β’ z j - ( 1 - e - Q β’ β β’ Ξ β’ β β’ z j ) β’ Q - 1 ) β’ Q - 2 β’ S T .
This decomposition is essential for making the Lippmann-Schwinger equations numerically accurate, since it brings down a factor of Qβ1 that decays like 1/n as the order of the coupled-wave basis increases. Without this extra factor, the TM mode calculation is slow convergent (decaying like 1/N), and a direct numerical evaluation of the Lippmann-Schwinger equation on a finite mesh may be inaccurate.
Substituting Equation (4.10) into the L-S equation [Equation (4.12)] and carrying out the integral over zβ² in each segment j results in the following system of linear equations:
ΓXβ‘Xβ[{overscore (G)}VX+{overscore (G)}β²VXβ²+d{overscore (G)}D(Xβ²+Ξ·(C+{tilde over (X)}))]=X0,ββ(4.16)
with:
ΓCβ‘Cβ[{overscore (G)}VX+{overscore (G)}β²VXβ²+d{overscore (G)}D(Xβ²+Ξ·(C+{tilde over (X)}))]=C0
where X0, X, Xβ² and {tilde over (X)} are N2M-dimensional column vectors with entries:
Xnm0(j)=<nm|Ξ¨0(zj)>,
Xnm(j)=<nm|Ξ¨(zj)>,
Xβ²nm(j)=<nm|Ξ¨β²(zj)>, and
{tilde over (X)}nm(j)=nm|β«zjddzΞ¨β²(zj).
N is the number of coupled waves in each direction of x and y, and M is the number of mesh points in z. V {overscore (G)}, {overscore (G)}β², and d{overscore (G)} are 2N2MΓ2N2M matrices with matrix elements:
Vnm,nβ²mβ²(j, jβ²)=Ξ΄j,jβ²<nm|V(zj)|nβ²mβ²>,
G
_
nm
,
n
β²
β’
m
β²
β‘
(
j
,
j
β²
)
=
β’
Ξ΄
nm
,
n
β²
β’
m
β²
β’
{
(
e
-
Q
(
z
j
-
z
f
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
]
β’
W
j
,
for
β’
β
β’
j
β₯
j
β²
(
e
Q
(
z
j
-
z
f
-
1
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
)
β’
W
j
,
for
β’
β
β’
j
<
j
β²
G
_
β²
nm
,
n
β²
β’
m
β²
β‘
(
j
,
j
β²
)
=
β’
Ξ΄
nm
,
n
β²
β’
m
β²
β’
{
(
e
-
Q
(
z
j
-
z
f
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
]
β’
W
j
(
+
)
,
for
β’
β
β’
j
β₯
j
β²
(
e
Q
(
z
j
-
z
f
-
1
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
)
β’
W
j
(
-
)
,
for
β’
β
β’
j
<
j
β²
d
β’
G
_
nm
,
n
β²
β’
m
β²
β‘
(
j
,
j
β²
)
=
β’
Ξ΄
nm
,
n
β²
β’
m
β²
β’
{
(
e
-
Q
(
z
j
-
z
f
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
]
β’
QW
j
,
for
β’
β
β’
j
β₯
j
β²
(
-
e
Q
(
z
j
-
z
f
-
1
)
+
e
Qz
j
β’
R
nm
β’
e
Qz
f
)
β’
QW
j
,
for
β’
β
β’
j
<
j
β²
.
where {tilde over (R)}β‘R(1+{overscore (r)}uR), {overscore (G)}, {overscore (G)}β², and d{overscore (G)} are 2N2Γ2N2M matrices with matrix elements:
{overscore (G)}nm,nβ²mβ²(jβ²)=Ξ΄nm,nβ²mβ²FnmeQ(zjβ²βd)Wjβ²,
{overscore (G)}β²nm,nβ²mβ²(jβ²)=Ξ΄nm,nβ²mβ²FnmeQ(zjβ²βd)Wjβ²(+),
d{overscore (G)}nm,nβ²mβ²(jβ²)=Ξ΄nm,nβ²mβ²FnmeQ(zjβ²βd)QWjβ².
In step 208, the system of linear equations is solved. This can be done using any iterative solver. Typical solvers include the quasi-minimal-residue (QMR), TMRES and Krylov subspace solvers. Other suitable techniques may also he used. In the case where QMR is used, the initial guess of the wave function is taken to be Ξ¨0(zβ²) and is calculated via RCWA on the boundary mesh points zj (j=1, . . . , Mβ1). The following numerical procedures are then performed iteratively:
Note that the eigen-values of Γ are all close to 1 if the magnitude of GV is small compared to 1. This feature makes the QMR method a fast converging one. The iteration procedure involves repeated multiplication of the form ΓX.
Once the convergent solutions to X and C and consequently Y, Yβ², and Yz are obtained, the modeling method completes at step 208 where the following projected Lippmann-Schwinger equation is used to calculate the reflection coefficients:
r
=
r
0
+
β«
G
β‘
(
0
,
z
β²
)
β’
V
β‘
(
z
β²
)
β’
Ξ¨
β‘
(
z
β²
)
β’
β
z
β²
+
β«
β
z
β²
β’
G
β‘
(
0
,
z
β²
)
β’
Ξ
β‘
(
z
β²
)
β’
Ξ¨
β²
β‘
(
z
β²
)
β’
β
z
β²
β‘
r
0
+
G
s
β’
Y
+
G
β²s
β’
Y
β²
+
β
G
β²
β’
Y
z
(
4.17
)
Gs,Gβ²s and dGs are row vectors with entries defined by:
Gnms(j)=<0|[eβQzj+ReQzj]Wj|nm>,
Gβ²nms(j)=<0|[eβQzj+ReQzj]Wj(β)|nm>,
dGnms(j)=<0|[eβQzj+ReQzj]QWj|nm>.
Representative Application
The modeling method and the associated derivations can be used to predict the optical scattering produced by a wide range of structures. FIG. 7 shows the elements of a scatterometer which may be used to generate empirical measurements for optical scattering. As shown in FIG. 7, the scatterometer 700 generates a probe beam 702 using an illumination source 704. Depending on the type of scatterometer 700, the illumination source 704 may be mono or polychromatic. The probe beam 702 is directed at a subject 706 to be analyzed. The subject 706 is generally of the type shown in FIG. 1. The reflected probe beam 708 is received by a detector 710. Once received, changes in reflectivity or polarization state of the probe beam are measured as a function of angle of incidence or wavelength (or both) and forwarded to processor 712.
To analyze the changes measured by detector 710, a hypothetical structure is postulated for the subject 706. Method 100 is then used to calculate one or more predicted reflection coefficients for the hypothetical structure. The hypothetical structure is then changed, and Method 100 repeated, until the predicted reflection coefficients match the results empirically observed by detector 710 (within some predetermined goodness of fit). At this point the hypothetical structure is assumed to closely match the actual structure of subject 706. In practice, modeling method 100 has been found to impart a high degree of efficiency to this process, allowing the analysis of results in real or near real-time. Modeling method 100 may also be used to pre-compute results for a hypothetical structure or for a series of variations to a hypothetical structure. Typically, the pre-computing of results is used as part of a library-based approach where the measurements recorded by detector 710 are compared (at least initially) to predicted reflection coefficients that have been computed and stored ahead of time. This sort of approach may be mixed with the real-time analysis where modeling method 100 is used to refine an analysis initially performed using the library-based approach.
1. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising:
defining a zero-th order structure for the subject, the zero-th order structure including a perturbation domain to represent a scatterer within the subject, the zero-th order structure also including a background material to representing the material within the subject that is below the scatterer;
solving a K space Lippmann-Schwinger equation including terms for a wave function for the zero-th order structure, a Green's function for the zero-th order structure and a perturbation function for the perturbation domain.
2. A method as recited in claim 1 wherein the zero-th order structure in the perturbation domain has an optical response equivalent to a foreground material, where the foreground material is the substance that overlays the scatterer.
3. A method as recited in claim 1 wherein the perturbation domain consists of a limited number of square slabs arranged in a repeating pattern.
4. A method as recited in claim 1 wherein the perturbation domain consists of a uniform medium that has an optical response that is computed as a function of the dielectric function for the scatterer and the dielectric function of the substance that overlays the scatterer.
5. A method as recited in claim 1 that further comprises the steps of:
generating a system of linear equations by evaluating the wave equation for the zero-th order structure at a series of points within the perturbation domain; and
solving the system of linear equations to obtain one or more reflection coefficient for the zero-th order structure.
6. A method as recited in claim 5 further comprising the step of using an iterative technique to solve the system of linear equations.
7. A method as recited in claim 5 that further comprises the steps of:
subdividing the perturbation domain into a series of segments; and
evaluating the wave equation for the zero-th order structure within each segment.
8. A method as recited in claim 7 that further comprises the steps of:
decomposing the Green's function for the zero-th order structure into a first integral proportional to eβQzβ² and a second integral proportional to eQzβ²; and
analytically evaluating the first and second integral for each segment.
9. A method as recited in claim 7 that further comprises the step of approximating the wave function for the zero-th order structure within each segment.
10. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising the step of evaluating a k-space volume integral of a Green's function without boundary terms.
11. A method as recited in claim 10 that further comprises the step of: defining a zeroth order structure for the subject, the zero-th order structure including a perturbation domain to represent a scatterer within the subject and a background material to represent the material within the subject that is below the scatterer.
12. A method as recited in claim 11 wherein the zero-th order structure in the perturbation domain has an optical response equivalent to a foreground material, where the foreground material is the substance that overlays the scatterer.
13. A method as recited in claim 11 wherein the perturbation domain consists of a limited number of square slabs arranged in a repeating pattern.
14. A method as recited in claim 11 wherein the perturbation domain consists of a uniform medium that has an optical response that is computed as a function of the dielectric function for the scatterer and the dielectric function of the substance that overlays the scatterer.
15. A method as recited in claim 11 that further comprises the step of solving a K space Lippmann-Schwinger equation including terms for a wave function for the zero-th order structure, a Green's function for the zero-th order structure and a perturbation function for the perturbation domain.
16. A method as recited in claim 15 that further comprises the steps of:
generating a system of linear equations by evaluating the wave equation for the zero-th order structure at a series of points within the perturbation domain; and
solving the system of linear equations to obtain a reflection coefficient for the zero-th order structure.
17. A method as recited in claim 16 further comprising the step of using an iterative technique to solve the system of linear equations.
18. A method as recited in claim 15 that further comprises the steps of:
subdividing the perturbation domain into a series of segments; and
evaluating the wave equation for the zero-th order structure within each segment.
19. A method as recited in claim 18 that further comprises the steps of:
decomposing the Green's function for the zero-th order structure into a first integral proportional to eβQzβ² and a second integral proportional to eQzβ²; and
analytically evaluating the first and second integral for each segment.
20. A method as recited in claim 18 that further comprises the step of approximating the wave function for the zero-th order structure within each segment.
21. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising evaluating a volume integral scattering equation where the wave vector has been reduced to two components using an integration operator to k inverse to represent kz.
22. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising evaluating a volume integral of a Green's function with no boundary terms for the H field.
23. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising:
defining a perturbation domain to represent a scatterer within the subject where the perturbation domain consists of a limited number of square slabs arranged in a repeating pattern; and
evaluating a volume integral of a Green's function within the perturbation domain.
24. A method for modeling the diffraction resulting from the interaction of a probe beam with a subject, the method comprising:
defining a zero-th order structure for the subject, the zero-th order structure including a perturbation domain to represent a scatterer within the subject, the zero-th order structure also including a background material to representing the material within the subject that is below the scatterer; and
using a separable property of the Green's function to solve a Lippmann-Schwinger wave equation for the zero-th order structure.
25. A method of optically inspecting and evaluating a subject comprising the steps of:
(a) illuminating the subject with a probe light beam;
(b) measuring the light reflected from the subject to generate at least one empirical reflection coefficient;
(c) defining a hypothetical structure corresponding to the subject;
(d) calculating a predicted reflection coefficient for the hypothetical structure by evaluating a k-space volume integral of a Green's function without boundary terms; and
(e) repeating steps (c) and (d) until the difference between the predicted reflection coefficient and the empirical reflection coefficient is minimized.
26. A method as recited in claim 25 that further comprises the step of:
defining a zero-th order structure for the subject, the zero-th order structure including a perturbation domain to represent a scatterer within the subject and a background material to represent the material within the subject that is below the scatterer.
27. A method as recited in claim 26 wherein the zero-th order structure in the perturbation domain has an optical response equivalent to a foreground material, where the foreground material is the substance that overlays the scatterer.
28. A method as recited in claim 26 wherein the perturbation domain consists of a limited number of square slabs arranged in a repeating pattern.
29. A method as recited in claim 26 wherein the perturbation domain consists of a uniform medium that has an optical response that is computed as a function of the dielectric function for the scatterer and the dielectric function of the substance that overlays the scatterer.
30. A method as recited in claim 26 that further comprises the step of solving a K space Lippmann-Schwinger equation including terms for a wave function for the zero-th order structure, a Green's function for the zero-th order structure and a perturbation function for the perturbation domain.
31. A method as recited in claim 30 that further comprises the steps of:
generating a system of linear equations by evaluating the wave equation for the zero-th order structure at a series of points within the perturbation domain; and
solving the system of linear equations to obtain a reflection coefficient for the zero-th order structure.
32. A method as recited in claim 31 further comprising the step of using an iterative technique to solve the system of linear equations.
33. A method as recited in claim 30 that further comprises the steps of:
subdividing the perturbation domain into a series of segments; and
evaluating the wave equation for the zero-th order structure within each segment.
34. A method as recited in claim 33 that further comprises the steps of:
decomposing the Green's function for the zero-th order structure into a first integral proportional to eβQzβ² and a second integral proportional to eQzβ²; and
analytically evaluating the first and second integral for each segment.
35. A method as recited in claim 33 that further comprises the step of approximating the wave function for the zero-th order structure within each segment.