The invention relates to a method of reconstructing a surface of an object, where the object is represented by a 2-dimensional grid of measurements. For each grid point the measurements include corresponding information on a first slope of the surface in a first direction and a second slope of the surface in a different second direction. The invention further relates to software for executing the method and to a system for reconstructing the surface of an object.
Surfaces of objects, such as silicon wafers, can be reconstructed from measured slopes. The slopes are typically measured by scanning the surface along lines and measuring the slope. The measurements result in a 2-dimensional grid, where for each grid point a slope in a ‘horizontal’ direction and a slope in a ‘vertical’ direction is given. The measurements may be obtained using deflectometry, where light (e.g. from a laser) is projected onto the surface and an angle of reflection is measured, providing information on the slope.
For many applications the actual surface (i.e. the topography of the surface) needs to be determined based on the measured slopes. Current reconstruction algorithms are based on carrying out a line integral along a path through the measurement grid. For example, by performing such a line integral along each ‘horizontal’ path (ie. each path parallel to one of the coordinate lines) the topography can be reconstructed. For each point along the path, the line integral uses the slope measured at the grid point in the direction of the path. In general the measured slopes contain measurement errors. Integration along the path accumulates all measurements errors in the slopes in the direction of the path. In this way, the topography of the surface determined at a grid point is therefore not determined uniquely but depends on the path chosen though the grid. For example, a line integral along a closed path like the path from (i,j) to (i+1,j), to (i+1, j+1) to (i, j+1) and back to (i,j) will in general not give the starting value for the surface topography.
In general, the measurements will not result in the regular equidistant measurement grid of
It is an object of the invention to provide an improved method of reconstruction of a topography of a surface. It is a further object to provide software for performing such a method and a system for executing the method.
To meet the object of the invention, the method of reconstructing a surface of an object, where the object is represented by a 2-dimensional grid of measurements, where for each grid point the measurements include corresponding information on a first slope of the surface in a first direction and a second slope of the surface in a different second direction, includes selecting a 2-dimensional part of the grid and fitting a corresponding part of the surface to the measurements of all grid points in the selected part, where the fitting for each grid point of the selected part is based on both the corresponding first and second slope information. By performing a fitting based on all measured slopes of the selected part, the effect of a localized measurement error is significantly reduced to mainly the area of the error. According to the method, much more measurements are fully used for the reconstruction. Instead of performing an integration operation along a one-dimensional path, now a 2-dimensional fitting operation is performed, involving much more measured data. Moreover, instead of using only one measured slope of each involved grid point, now both slopes are used. This enables significant reduction in propagation of measurement errors. Preferably, a user can indicate the area in which accurate reconstruction according to the invention is desired. Outside the selected area, a conventional reconstruction may be carried out In a preferred embodiment, as described in the dependent claim 4, the fitting according to the invention is performed over substantially the entire surface represented by the grid measurements.
According to the measure of the dependent claim 2, the fitting is performed through a least-square minimization operation. This is an effective way of minimizing fitting errors.
According to the measure of the dependent claim 3, the least square minimization operation is performed by solving an equation that describes a shape of a soap film loaded with a pressure field equal to a divergence of a slope vector including the first and second slope information. The inventor had the insight that in this way the surface fitting according to the invention can be expressed in a way similar to describing a shape of a soap film loaded with a pressure field. This enables using known methods for determining such a soap film shape to determine the topography of the surface.
According to the measure of the dependent claim 5, for each point of the grid the first and second slope are measured using deflectometry.
To meet the object of the invention, a computer program product operative to cause a processor to perform the steps of the method as claimed in claim 1.
To meet the object of the invention, a system for reconstructing a surface of an object includes an input for receiving a 2-dimensional grid of measurements representing a surface of an object, where for each grid point the measurements include corresponding information on a first slope of the surface in a first direction and a second slope of the surface in a different second direction; a processor for, under control of a program, selecting a 2-dimensional part of the grid and fitting a corresponding part of the surface to the measurements of all grid points in the selected part, where the fitting for each grid point of the selected part is based on both the corresponding first and second slope information; and an output for providing a representation of at least the reconstructed surface part.
According to the measure of the dependent claim 8, the system includes a measurement unit for measuring for each measurement point of a measurement grid the corresponding first and second slope information.
According to the measure of the dependent claim 9, the measuring is performed along non-straight lines; the measurement grid being directly used for the reconstruction. The method and system according to the invention perform a fitting that works as long as a connectivity between measurement points (analogous to the nodes belonging to a finite element in a FEM mesh) can be established. It is not required that the grid is neatly arranged, e.g. that the measurement points in the two directions form an equidistant x, y or r, φ grid). No calibration of the measurement grid to a grid used for the reconstruction is required, avoiding the introduction of additional errors.
According to the measure of the dependent claim 10, the measurement unit includes a deflectometry measurement unit.
These and other aspects of the invention are apparent from and will be elucidated with reference to the embodiments described hereinafter.
In the drawings:
The input 120 is also able to receive input from a user. Shown are input devices, such as a mouse 140 and keyboard 150. Output to a user may be supplied via an output device 160, that may include a display. In particular the input may enable the user to indicate an area of the surface (and/or grid) in which accurate reconstruction of the surface is required. For other areas, conventional reconstruction may take place. Such conventional reconstruction may be used to reconstruct the edge of the selected area. In the remainder, the reconstruction method according to the invention will be described.
Reconstruction method:
Consider a domain D⊂R2 on which the topography of an unknown surface is measured with a deflectometry measurement system. Using this measurement system, the slopes {right arrow over (N)}({right arrow over (x)}) of the unknown surface z=z({right arrow over (x)}) are measured. If no measurement errors would occur, the unknown function that describes the surface satisfies
{right arrow over (∇)}z({right arrow over (x)})={right arrow over (N)}({right arrow over (x)}), {right arrow over (x)}εD (1)
Hence, the surface z({right arrow over (x)}) is determined apart from a constant function z=z0. A unique surface is obtained by prescribing the surface at some point {right arrow over (x)}0εD, hence z({right arrow over (x)}0)=z0.
In general the measured slopes contain measurement errors. Then, it is most likely that no function z({right arrow over (x)}) exists that satisfies(1), because in all cases where rot({right arrow over (N)})={right arrow over (∇)}×{right arrow over (N)}≠0 no function exists that satisfies (1). However, it is possible to integrate (1) along a path Γ({right arrow over (x)},{right arrow over (x)}0) from {right arrow over (x)}0 to {right arrow over (x)} in the domain D to obtain values for the surface topography
Note, that if rot({right arrow over (N)})≠0 these values are dependent on the path Γ({right arrow over (x)},{right arrow over (x)}0) and are therefore not unique. This is seen by carrying out the line integration (2) along a closed path Γ({right arrow over (x)}0,{right arrow over (x)}0) enclosing a surface ΩΓ and using Stokes theorem hence
where {right arrow over (n)}Ω is the unit normal on ΩΓ in R3. Next, a method is proposed to find a unique function that approximately satisfies (1). Hence, the reconstructed surface obtained by the proposed method is independent of the fact that rot({right arrow over (N)}) is zero or not.
The unknown surface topography is approximated by a function z({right arrow over (x)}) that satisfies (1) in a least squares sense, hence it is the function with z({right arrow over (x)}0)=z0 that minimizes the functional
where the integration is carried out over the measurement domain D. In order to be a minimum for every disturbance δz({right arrow over (x)}) of z({right arrow over (x)}) the minimizing function z({right arrow over (x)}) has to satisfy
This last formulation of the solution of the minimization problem (4) is the weak formulation of
{right arrow over (∇)}·{right arrow over (∇)}z={right arrow over (∇)}·{right arrow over (N)}, {right arrow over (x)}εD (6)
with boundary condition
z({right arrow over (x)}0)=z0; {right arrow over (n)}·{right arrow over (∇)}z={right arrow over (n)}·{right arrow over (N)}, {right arrow over (x)}ε∂D (7)
where {right arrow over (n)} is the unit normal at the boundary ∂D.
The formulation (6) is also directly found by taking the divergence of the left and right hand side of (1). The equation (6) also describes the solution of the mechanical problem of determining the shape of a soap film loaded with a pressure distribution equal to {right arrow over (∇)}·{right arrow over (N)}. Note, that in the weak formulation (5) the order of differentiation is one, while it is two in the formulation (6). Hence, solving (5) instead of (6) means that it is sufficient that the unknown function z({right arrow over (x)}) lies in the Sobolev space
and is not necessarily in C1(D) (first order derivatives exist and are continuous). Furthermore, in the formulation (6) the first order derivatives of the measured slope {right arrow over (N)} must exist.
The advantage of solving (5) instead of carrying out the path integration (2) is that:
Both measured slope signals are used simultaneously to determine the topography of the measured surface.
All measured slope data is used to reconstruct the topography of the measured surface.
The determined topography is independent of an integration path which has to be chosen using the simple line integration methods.
Analogous to the loaded soap film problem, the effect of errors (inaccuracies) in the measured slope data on the determined topography is mainly limited to the location of the inaccuracy. With the line integration methods a local error propagates along the remaining integration path and hence has a larger effect (larger error) on the reconstructed topography.
Preferably, equation (5) is solved using a Finite Element Method (FEM). Of course other methods may be used to solve that equation, e.g. using a spectral method. Alternatively, equation (6) can be solved with e.g. a finite difference method. The formulation of the Finite Element Method to solve (5) will be carried out in Cartesian coordinates. For other coordinate systems the formulation is analogous to the presently discussed one.
Consider a Cartesian coordinate system (x, y, z). Suppose that the measurement grid DM⊂D⊂R2 consists of n·m discrete points (xij, yji), i=1 . . . n, j=1 . . . m, with xi,j<xi+1,j and yj,i<yj+1,i. With these discrete measurement points a quadrilateral finite element mesh is established by connecting the points (xi,j, yj,i), (xi+1,j,yj,i+1), (xi+1,j+1,yj+1,j+1) and (xi,j+1, yi+1,j) for i=1 . . . n-1 and j=1 . . . m-1, as shown in
The unknown surface topography z=z(x, y) is written as a linear combination of a finite set of approximating functions φk(x, y) k=1 . . . n·m, hence
Substitution of (8) in (3) and minimizing the functional J(z) with respect to the coefficients ak, or equivalently substitution of (8) in (4) with δz=φ1(x, y), yields
This singular set of linear equations is made regular by replacing the lth equation, where l is the index at which |φ1({right arrow over (x)}0)| has a maximum, by the condition z({right arrow over (x)}0)=z0. The solution of this set of linear equations determines the approximation (8) of the measured surface topography.
In the finite element approximation the subdivision of the measurement domain D in the finite elements De is used to write the integrals in (9) as
The functions φk are chosen to be bi-linear per element and have the value 1 in one node and 0 in all other nodes, as shown in
For the evaluation of the integrals over the elements an iso-parametric transformation of an actual quadrilateral element to the standard quadrilateral element is carried out
where {right arrow over (x)}=(x,y)T, {right arrow over (ξ)}=(ξ,η)T and the node number function k(i) is such that the actual 4 nodes of an element are used. Then an integral of a function f({right arrow over (x)}) over an element De is seen to be
where J({right arrow over (ξ)}) is the determinant of the Jacobian matrix
The bilinear approximating or basis functions φk(ξ,η) are seen to be
and their gradients are
In the evaluation of the integrals in the right hand side of (9), integrals involving measured slope values occur. Using (10), (11) and (12) these integrals are transformed to integrals over the standard quadrilateral element. On the standard element the variation of the slope vector is approximated with a bilinear function
Substitution of (21) in the expression obtained by (10), (11) and (12) yields integrals of the form
These integrals can be evaluated analytically. However, in the present work a 4 point Gaussian quadrature rule is applied. The integration points and weights of this method are
Carrying out all integrations, the element matrices and vectors are assembled in the large matrix and vector. Now the condition z({right arrow over (x)}0)=z0 is incorporated into the equations, as discussed before and the resulting set of linear discrete equations
Alkak=fl (28)
has to be solved. Several techniques exist to solve (28). It is preferred to use a Gaussian elimination procedure (LU decomposition), which is a direct method. If the system of equations is very large, iterative procedures can be used to solve (28), e.g. Gauss-Seidel, Multigrid, etc.
In this section the accuracy and the efficiency of the proposed method is investigated using virtual measurement data.
Suppose the measurement domain is D=[0,1]×[0,1]⊂R2. The test surface is
z(x, y)=sin2(2πx)sin2(2πy) (29)
with exact slope vector
The initial surface and reconstructed surface obtained from the exact slopes (30) with the presently proposed method using an equidistant measurement grid of 21×21 points are shown in
First, the discretization error to reconstruct the prescribed test surface with a finite discrete mesh is investigated. The discretization error to reconstruct the prescribed test surface with a finite discrete mesh are shown in Table 1, where ∥f‘L
∥f∥L
and ∥f∥∞ is the infinity (or max) norm
The discretization error reduces quadratically with the mesh size (i.e. a typical dimension of and element, e.g. the radius of the largest circle that fits in an element). This behavior is expected using the bi-linear elements.
Secondly, using the same mesh (measurement grid) white noise (random values) with an amplitude equal to the amplitude of the slope values is added to the slope vector
and rx({right arrow over (x)}) and ry({right arrow over (x)}) generate random values in the range
In this case the difference between the reconstructed and the initial test surface is caused by a discretization error and by the noise in the slope data.
It should be noted that the above-mentioned embodiments illustrate rather than limit the invention, and that those skilled in the art will be able to design many alternative embodiments without departing from the scope of the appended claims. In the claims, any reference signs placed between parentheses shall not be construed as limiting the claim. The words “comprising” and “including” do not exclude the presence of other elements or steps than those listed in a claim. The invention can be implemented by means of hardware comprising several distinct elements, and by means of a suitably programmed computer. Where the system/device/apparatus claims enumerate several means, several of these means can be embodied by one and the same item of hardware. The computer program product may be stored/distributed on a suitable medium, such as optical storage, but may also be distributed in other forms, such as being distributed via the Internet or wireless telecommunication systems.
Number | Date | Country | Kind |
---|---|---|---|
03075110.1 | Jan 2003 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB03/06299 | 12/24/2003 | WO | 7/11/2005 |