The invention relates to the field of measuring the surfaces of three-dimensional (3D) objects and more particularly to nano topography of processed and unprocessed wafers, the surface determination of optical elements such as reference mirrors or aspheric lenses, and to free-forms in ophthalmic and optics industry.
Obtaining the true measurement and mapping of a three-dimensional surface was traditionally done by mechanical probes. These probes comprised a diamond needle or stylus which was moved with a high precision over the surface while being a mechanical contact with that said surface. The measured profiles of subsequent stylus scans are stitched together to form a 3D-topography. However, mechanical probes are very slow and are more suited for measuring profiles than for measuring the full three-dimensional topography. Moreover, in many applications mechanical contact with the object is not allowed.
Generally known is the use of interferometry for the purpose of determining the three-dimensional topography. This widely used technique however faces a few basic limitations. One problem is that the measurement height-range is limited, as the fringe density is not allowed to be too high. Another disadvantage is that a lateral resolution is limited to the resolution of the sensor, which in most cases is a CCD-sensor.
Another possibility for obtaining a true measurement and mapping of a three-dimensional surface is the use of an apparatus performing slope measurements, and in particular optical slope measurements. These apparatus yield physical data which are slopes of the surface profile. These data will be called slope data in the description which follows. The surface profile is expressed by the mathematical function g({right arrow over (x)})=0, whereby {right arrow over (x)} denotes a location on the surface of the object. It has generally the form g({right arrow over (x)})=f(x1, x2)−x3, which in the case of a Cartesian coordinate system becomes g({right arrow over (x)})=z(x, y)−z·x3, or z respectively, is the quantity to be measured. Then the slope or gradient {right arrow over (∇)}g({right arrow over (x)}) is determined by these apparatus. A numerical integration, e.g. a linear integration, is carried out in order to get the surface topography g({right arrow over (x)})=0.
A basic problem with slope measurements is that a numerical integration is only successful when the raw data, this means the slope data, do not show significant errors. Thus, defective slope measurement values produce wrong height-values or attempt to propagate or smear out if simple linear integration schemes are used. More advanced integration methods known to the man skilled in the art may reduce this problem to some degree. However, the problem still exists. As an example, one such method is disclosed in WO 2004/063666 which is incorporated by reference.
It is an object of the present invention to determine whether slope data obtained from an apparatus for mapping the surface topography g({right arrow over (x)})=0 of a surface of an object contain incorrect slope values.
Another object of the invention is to correct these incorrect slope values in the case of systematic errors.
This object and other objects are solved by the features of the independent claims. Preferred embodiments of the invention are described by the features of the dependent claims. It should be emphasized that any reference signs in the claims shall not be construed as limiting the scope of the invention.
A first aspect of the invention refers to an apparatus for mapping the surface profile g({right arrow over (x)})=0 of a surface of an object. This is an apparatus comprising a sensor for measuring the gradient of the surface profile at predetermined measurement locations {right arrow over (x)} on said surface. The sensor is an optical slope sensor which preferably consists of a lens and a position sensitive device at its focal plane. {right arrow over (∇)}g({right arrow over (x)}) is the true or error-free gradient of the surface profile whereas the measurement values of this true gradient are denoted by {right arrow over (S)}({right arrow over (x)}) and contain errors. The apparatus further comprises a computational entity for processing the measurement values {right arrow over (S)}({right arrow over (x)}). This computational entity is adapted to calculate, for at least a portion of the surface, the curl of the measurement values {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}). This is done for determining surface locations (error locations) at which the measurement values exhibit measurement errors, as error locations show values of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) which deviates from zero. In other words the error locations are determined by values of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) which are substantially non-zero.
The adaptation of the computational entity according to the present invention is motivated by the idea that for a smooth function g({right arrow over (x)}) vector analysis rules that
{right arrow over (∇)}×{{right arrow over (∇)}g({right arrow over (x)})}={right arrow over (0)} (equation 1)
In the ideal case of no measurement errors an apparatus for mapping the surface profile g({right arrow over (x)}) of a surface yields measurement values {right arrow over (S)}({right arrow over (x)})={right arrow over (∇)}g({right arrow over (x)}), and this means that
{right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)})={right arrow over (0)}={right arrow over (∇)}×{{right arrow over (∇)}g({right arrow over (x)})}. (equation 2)
However, if there are measurement errors, the value of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) deviates from zero indicating a measurement error. All the locations where this deviation exceeds a certain threshold value will be regarded as locations at which the measurement value is not correct.
The apparatus measures the slopes at the surface locations in two directions. When these two directions are perpendicular to each other they represent two axes, namely the x-axis and the y-axis. In this case the height of the surface profile at a given location is given by the value of the z-axis which is perpendicular to the x- and y-axis. If the slope measured in the x-direction is denoted by Sx and the slope in the y-direction is denoted by Sy then in the case of a 3D Cartesian coordinate system {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)})={right arrow over (0)} means that
as the first two components of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) are identically zero. Thus the computational entity calculates equation 3 for all measurement locations on the surface, and identifies measurement errors by means of a deviation of its value from zero.
According to a preferred embodiment of the invention the curl of measurement values are visualized by means of a display. If a more or less flat surface should be investigated, it is possible to define a Cartesian coordinate system as described above. In this case the (components of the) curl of the measurement values can be plotted along a z-axis versus x and y. In this case the xy-plane represents the flat surface area. A visualization in which the curl of the measurement values is plotted shall be called curl map in the description which follows. The curl map gives a visual help in determining which types of errors might be relevant in the current set of slope data. The characteristics of this plot will show the man skilled in the art whether the measurement errors are predominantly random errors or are predominantly systematic errors. Random errors in this plot are characterized by peaks or spikes, whereas systematic errors show a more continuous and regular pattern. Furthermore, and as will be described below in more detail, an identification of the locations on the surface of the object at which the measurement values show significant measurement errors makes it possible to correct the measurement values. In this case a visualization of the curl map before and after the correction will demonstrate visually that the data quality has been improved, and to which degree.
According to another embodiment of the invention the computational entity is adapted to use the curl of the measurement values {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) for self-calibration. In this case the self-calibration is performed by the apparatus in such a way that the curl of the measurement values as a function of the calibration parameters is minimized. This can be done for a part of the surface, and is preferably done for the whole surface of this object. During the self-calibration, which might be called self-correction as well, apparatus parameters are modified and the computational entity tries to minimize the curl map searching for an optimum set of parameters. In this way the calibration for detector rotation can be improved, and it can be scanned for non-linearities or pixel-grid variations, for sensor-anisotropy. Other parameters to be optimized during the calibration process are the ratio between the y- and y-grid calibration constants, the ratio between the slope sensitivity constants in x- and y-direction, parameters to transfer measured voltages into slope values, or parameters to the measurement grid on the surface to be measured. As a matter of fact the parameters which are optimized during the self-calibration depend on the apparatus type, e.g. a deflectometer, which is used. All these parameters are however known to the man skilled in the art and thus need no further explanation.
This self-calibrating process can be repeated with the same object in a tilted and/or a laterally shifted position and/or with a different rotational orientation with respect to an axis of the coordinate system. As a matter of fact, this can be combined with measuring new objects. The result of all these measurements and parameter variations is a curl map having a minimized average squared curl, whereby averaging is carried out over the whole surface or over a part of the surface area. Furthermore an optimum set of apparatus parameters is found and the instrument is ready for use.
In an ideal situation the optimum set of apparatus parameters found in the calibration process mentioned above is constant over the lifetime of the apparatus (if the apparatus is stable). In real-life situations these optimum parameters will change over the time when a new self-calibration is carried out. The sets of apparatus parameters derived from these calibration steps can be used to monitor the stability and correctness of the apparatus.
Another preferred embodiment consists of a computational entity which is adapted to identify random defects on the surface of an object. A location on a surface of an object is thus identified to show a random defect by means of the curl of its measurement value and the deviation of this curl value from a threshold value. One possibility is to see whether the curl of the measurement value deviates from corresponding curl values of nearby locations. If there is a significant deviation, e.g. by more than a threshold value, the deviation is indicative of a random error. A second possibility is to compare the curl of the measurement value with the curl of an interpolated slope value, the interpolation being performed by means of slope values from the surroundings of the location. Again, if there is a significant deviation, e.g. by more than a threshold value, the deviation is indicative of a random error. In both cases this knowledge can be used in the integration step for reconstructing the 3D topography to get a more accurate topography. The defective slope value can be substituted with the interpolated slope value, or it can be attached a lower weight during the integration process.
If a surface quality has to be controlled in a production process, for example in a production of wafers, an apparatus for mapping the surface profile will map the surface profile of a multitude of wafers. In this case it is advantageous that the computational entity is adapted to compare the values of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}), or synonymously the values according to equation 3, of a multitude of wafers. This will be done by storing the curl map of each wafer, or of the data associated with each curl map, such that it can be used for a comparison. This comparison makes it possible to search for regular patterns among the curl maps in order to detect systematic errors in the production process which can be corrected accordingly. As a matter of fact, this approach is not restricted to wafers but can be applied in other cases as well.
According to a preferred embodiment of the invention the comparison mentioned in the last paragraph includes searching for error locations being common to all objects of said multitude of objects. If all the objects show error locations at the same position this is indicative of a systematic error in the production process of the objects. This systematic error might be indicative of dust particles on optical elements in an apparatus for producing wafers. In other cases the error locations determined by the method according to the invention represent areas on a wafer where polishing is insufficient, e.g. because polishing has been carried out with a tilted polisher. As can be derived from this explanation searching for error locations being common to all objects is helpful for finding systematic errors in the production process of theses objects. Then, the operator has two possibilities:
A first possibility is to determine whether the magnitude of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) at these error locations determined in the first step correlates with the time at which the object have been produced. For that purpose it is necessary that each object has a time stamp associated with it such that the time at which the object has been produced is known. Such an change in the magnitude of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) over the time is representative for a change in or at the production machine.
Furthermore, this change of magnitude can be analysed in more detail. If the magnitude of {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) changes gradually in time, this can be indicative of a drift in the measurement apparatus. Hence, one or more calibration parameters are changing in time. This is very important for the measurement apparatus. Hence, during normal measurements of products a possible drift in the measurement apparatus can be detected automatically. In addition, this drift can be corrected by minimizing the average squared {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) over part or whole of the measurement area.
A second possibility is to monitor the size of the area represented by error locations over the time. Such a change indicates that the area where {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}) deviates from zero changes, or in other words that the area changes where slopes cannot be measured accurately. This can be representative for a change in or at the production machine.
In a further preferred embodiment the computational entity is adapted to correct the measurement values exhibiting measurement errors. This will only be possible in the case of systematic errors.
A correction can be done in the following way. The surface profile g({right arrow over (x)}) to be measured can be described by a function
g({right arrow over (x)})=g(x,y,z)=z(x,y)−z=0 (equation 4)
where for the sake of simplicity a 3D Cartesian coordinate system is used. When the surface profile is measured the slopes
are obtained. A systematic error of the apparatus can be described by functions having parameters α1, α2 . . . αn, whereby n is an integer. These parameters are characteristic for a systematic deviation of the slopes Sx and Sy from their true values. For instance, the following cases are possible:
1. The systematic deviation is caused by an incorrect orientation of the slope sensor. In this case the relation between the measured slopes which containing an error due to this misorientation, denoted by {right arrow over (S)}measured, and the real slopes which would have been obtained without this misorientation, denoted by {right arrow over (S)}real, is
whereby α is the tilt angle representing the incorrect orientation.
2. If a small calibration error in one slope component, e.g. Sy, occurs, the relation between measured slopes and real slopes is
Sxmeasured=Sxreal (equation 6)
and
Symeasured=λSyreal (equation 7)
with λ being a real number.
3. If a small deviation in the pixel grid occurs, e.g. the y-direction, the relation between measured slopes and the real slopes is
Sxmeasured=Sxreal (equation 8)
and
Symeasured=Syreal (equation 9)
However, the relation between the expected grid coordinates and the actual grid coordinates being used is
xactual=xreal (equation 10)
and
yactual=vyreal (equation 11)
whereby v, a real number, is a proportionality factor.
In a further preferred embodiment the computational entity is adapted to correct the measurement values exhibiting measurement errors for systematic errors, whereby the systematic error is represented by parameters α1, α2 . . . αn, and that for correcting the measurement values the functional
is minimized, whereby the multitude of locations constitute the surface A of the object.
With this approach the fact is used that only a potential function of a vector field exists if the curl of that vector field is zero. In this case the parameters α1, α2 . . . αn defining the systematic deviation in a measurement values can be derived. Thus a minimization of the functional
is carried out, whereby
{right arrow over (S)}
real
={right arrow over (F)}(α1, . . . αn,{right arrow over (S)}measured)={right arrow over (E)}−1(α1, . . . αn,{right arrow over (S)}measured) (equation 14)
with
{right arrow over (S)}measured={right arrow over (E)}(α1, . . . αn,{right arrow over (S)}real) (equation 15)
describe the relation between the measured slopes and the real slopes. After determining the parameters αn the measured slope components can be corrected by using the relation
{right arrow over (S)}real={right arrow over (F)}(α1, . . . αn,{right arrow over (S)}measured) (equation 16)
between real slopes and measured slopes.
The approach mentioned in the last paragraph can also be extended by including weighing functions in the integrand. Using these weighing functions influences certain parts of the measurement domain by making them larger or smaller in weight in comparison to other parts.
As can be derived from the paragraphs above the computational entity being part of the apparatus for mapping a surface profile is adapted to calculate the curl of the measurement values for determining error locations. This computational entity can be a computer and/or a computer program product. In the simplest case a computer only consists of an EPROM or an ASIC, or it comprises a processor, memory and software running on this hardware.
According to a preferred embodiment of the invention the sensor is an optical sensor. In this way the apparatus might be adapted to carry out deflectometry, wave front sensing, shearing interferometry, phase imaging, carry out the Schlieren & shadowgraph method or ellipsometry.
Another aspect of the invention refers to a computer program product designed to work in the apparatus disclosed above. When the computer program product is executed it carries out the following steps:
In a first step a multitude of measurement values are accessed, e.g. by a read command. Each measurement value represents the gradient of the surface profile at a surface location on the surface of an object. The multitude of surface locations represent at least a portion of the surface of the object.
In a second step the curl of the measurement values are calculated for at least a portion of the surface. In a third step surface locations are identified at which the curl of the measurement values deviates more in a predetermined threshold value from zero. At these locations the measurement values exhibit a measurement error.
These and other aspects of the invention will be apparent from and elucidated with reference to the embodiments described thereafter. It should be noted, that the use of reference signs shall not be construed as limiting the scope of the invention.
Detailed description of the drawings and of the preferred embodiments
The deflectometer contained a sensor 3, namely a Shack-Hartmann sensor for detecting light from the surface 1 of a wafer 2 as indicated by the arrow. The light originated from a laser
A focal spot on the surface 1 of the wafer 2 was circular and had a diameter of 110 micrometers. The control unit 7 insured a step wised scaling of the surface by means of a sensor 3. The acquired data were transferred to computational entity 5 and stored on a storage means 8, namely a hard disc.
The computational entity 5 processed the measurement values. It calculated {right arrow over (∇)}×{right arrow over (S)}({right arrow over (x)}), which as the x- and y-components are identically zero in the case that g(x, y, z) has the usual form g(x, y, z)=z−z(x, y), the relevant condition for the measured slopes follows from the z-component. Hence, in the ideal case the measured slope components have to satisfy
The values of this term can be derived from
In the next step these data has been corrected. In a first correction step the orientation of the slope sensor has been corrected, whereby it has been assumed that the error in orientation has been small. In this case the relation between the real slope and the measured slope is
Then the third component of the
curl of the slope vector becomes
The function to be minimized becomes
This function has its minimum for
Hence, the angle α can be determined and the slope data has been corrected for this small orientation error of the slope sensor.
In a second step a small calibration error in one slope component, for example the Y-component, has been corrected. In this case the relationship between the measured slope and the real slope is
In this case λ is a proportionality factor. In this case the inverse relation is
In this case the function to be minimized is
This function has its minimum at the value
This correction has been performed to the y-component.
Number | Date | Country | Kind |
---|---|---|---|
05105736.2 | Jun 2005 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB06/52122 | 6/27/2006 | WO | 00 | 12/20/2007 |