The present invention relates generally to optical scanning systems, and more particularly, to a system and method for increasing a scan rate while maintaining a minimum resolution.
Digital scanning systems, such as those used in maskless photolithographic processing, require image data to be scanned onto a subject. The scanning may occur at a defined scan rate, which may be based on factors such as mechanical limitations and the speed with which data is processed and projected onto the subject. A system may also controllably alter the scan rate to achieve different objectives.
The amount of image data that must be processed in a digital scanning system is generally relatively large, and generally increases when higher resolutions are desired. Higher resolution may be desirable for a number of reasons. For example, a line may have a minimum width when projected at a certain resolution. This minimum width may be undesirable, for instance, because it limits the number of lines which may be projected onto the subject. Using a higher resolution may allow the line to be projected using a smaller minimum width, and so more lines may be projected onto the subject. In photolithography, the subject may be a substrate and the projected image may be a mask. Therefore, a higher resolution enables a more detailed mask to be projected onto the substrate without altering the size of the substrate.
Although sometimes desirable, higher resolutions may decrease the scan rate of a scanning system because of the amount of data that must be transferred. This is especially true if the scanning system has a fixed data rate which is operable to transfer a limited amount of data.
Therefore, certain improvements are needed in digital imaging systems. For example, it is desirable to increase the scan rate of a system while maintaining a desired minimum level of resolution. It is also desirable to maintain high light intensity, to provide high productivity, and to be more flexible and reliable.
A technical advance is provided by a novel system and method for increasing a scan rate while maintaining a minimum resolution in an optical imaging system. In one embodiment, the method comprises determining a minimum resolution and a spacing distance for a first discrete element and a second discrete element. A window size is calculated based on the minimum resolution and the spacing distance and the window size is set equal to the calculated size. An angle of rotation is calculated for the projection device relative to a subject based on the window size, where angle of rotation operable to offset the first discrete element from the second discrete element by the minimum resolution.
The present invention relates generally to optical scanning systems, and more particularly, to a system and method for increasing a scan rate while maintaining a minimum resolution. It is understood, however, that the following disclosure provides many different embodiments, or examples, for implementing different features of the invention. Specific examples of components and arrangements are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to limit the invention from that described in the claims. In addition, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed.
Referring now to
The pixel panel 108, which may be a digital mirror device (DMD), is provided with digital data via suitable signal line(s) 128 from the computer aided pattern design system 106 to create a desired pixel pattern (the pixel-mask pattern). The pixel-mask pattern may be available and resident at the pixel panel 108 for a desired, specific duration. Light emanating from (or through) the pixel-mask pattern of the pixel panel 108 then passes through the second lens system 112 and onto the subject 114. In this manner, the pixel-mask pattern is projected onto the resist coating 118 of the subject 114.
The computer aided mask design system 106 can be used for the creation of the digital data for the pixel-mask pattern. The computer aided pattern design system 106 may include computer aided design (CAD) software similar to that which is currently used for the creation of mask data for use in the manufacture of a conventional printed mask. Any modifications and/or changes required in the pixel-mask pattern can be made using the computer aided pattern design system 106. Therefore, any given pixel-mask pattern can be changed, as needed, almost instantly with the use of an appropriate instruction from the computer aided pattern design system 106. The computer aided mask design system 106 can also be used for adjusting a scale of the image or for correcting image distortion.
In some embodiments, the computer aided mask design system 106 is connected to a first motor 122 for moving the stage 116, and a driver 124 for providing digital data to the pixel panel 108. In some embodiments, an additional motor 126 may be included for moving the pixel panel. The system 106 can thereby control the data provided to the pixel panel 108 in conjunction with the relative movement between the pixel panel 108 and the subject 114.
Efficient data transfer may be one aspect of the system 106. Data transfer techniques, such as those described in U.S. provisional patent application Ser. No. 60/278,276, filed on Mar. 22, 2001, and also assigned to Ball Semiconductor, Inc., entitled “SYSTEM AND METHOD FOR LOSSLESS DATA TRANSMISSION” and hereby incorporated by reference as if reproduced in its entirety, may be utilized to increase the throughput of data while maintaining reliability. Some data, such as high resolution images, may present a challenge due in part to the amount of information needing to be transferred.
Referring now to
As the substrate 212 moves in the direction 214, a series of scan lines 218 indicate where the points 216 may be projected onto the substrate 212. The scan lines are separated by a distance “S”. Because of the alignment of the point array 210 with the substrate 212 and the scanning direction 214, the distance S between the scan lines 218 equals the distance D between the points 216. In addition, both S and D remain relatively constant during the scanning process. Achieving a higher resolution using this alignment typically requires that the point array 210 embodying the DMD be constructed so that the points 216 are closer together. Therefore, the construction of the point array 210 and its alignment in relation to the substrate 212 limits the resolution which may be achieved.
Referring now to
The magnitude of the angle θ may be altered to vary the distance S between the scan lines 218. If the angle θ is relatively small, the resolution increase may be minimal as the points 216 will remain in an alignment approximately equal to the alignment illustrated in FIG. 2. As the angle θ increases, the alignment of the points 216 relative to the substrate 212 will increasingly resemble that illustrated in FIG. 3. If the angle θ is increased to certain magnitudes, various points 216 will be aligned in a redundant manner and so fall onto the same scan line 218. Therefore, manipulation of the angle θ permits manipulation of the distance S between the scan lines 218, which affects the resolution of the point array 210. It is noted that the distance S may not be the same between different pairs of scan lines as the angle θ is altered.
Referring now to
An angle θ represents the angle between an axis 420 of the point array 410 and a corresponding axis 422 of a subject 412 (not shown). A series of scan lines 418 indicate where the points 416 may be projected onto the subject 412. Depending on the angle θ, the scan lines 418 may be separated by a constant distance or by varying distances, as described below. When no redundancy occurs (i.e., no two points 416 from the array 410 may fall on the same scan line 418), a variable “K” is equal to one, signifying a one to one correspondence between a point 416 and a scan line 418. A series of relationships may be developed using the values M, N, K, D and θ. The relationships enable various aspects of the rotation of the array 410 to be calculated in order to achieve a desired result.
A distance “B”, which designates the distance between the scan lines 418 of two adjacent points 416 in a row when the array 410 is rotated to angle θ, may be calculated by setting B equal to D*cos(θ). A distance “C” represents the distance between the scan lines 418 of two adjacent points 416 in a column when the array 410 is rotated to angle θ, and may be calculated by setting C equal to D*sin(θ). A distance “A” represents the distance between the scan lines 418 of the point 416 in the bottom row of a column and the point 416 in the top row of the next column when the array 410 is rotated to angle θ. For example, the scan lines associated with the point (15,12) and the point (16,1) are separated by the distance A, which may be calculated as B−(N−1)*D*sin(θ).
In the present example, the points 416 are uniformly distributed (i.e., the same distance separates each point 416 from the adjacent points 416 when projected onto the subject). When this uniformity occurs, A=C=D*sin(θ) and tan(θ)=K/N.
Using one or more of these relationships, the angle θ can be calculated to achieve a desired distance between the scan lines 418. For example, when N=600 and K=1, then θ=tan−1(1/600)≈0.0955 degrees. Therefore, rotating the point array 410 by 0.0955 degrees will enable the array 410 to be projected with the desired characteristics of A, B, C and D.
It should be noted that choosing a uniform distribution of points 416 may simplify the calculation of θ and its effect on the resolution provided by the spacing of the scan lines 418. This may be accomplished by selecting a desired resolution so that A=C=D*sin(θ).
Referring now to
The distance “D” separates each point 416 from the adjacent points 416. The total distance between the first and last points 416 in each row is equal to (M−1)*D, while the total distance between the first and last points 416 in each column is (N−1)*D. Using M, N, K, D and θ, a series of relationships may be developed for K=2. As in
The distance “B” designates the distance between the scan lines 418 of two points in a row separated by another point 416 when the array 410 is rotated to angle θ. For example, the point (14,12) is separated from the point (16,12) by the distance b, which may be calculated as B=K*D*cos(θ). The distance “C” may be calculated as C=D*sin(θ). The distance “A” may be calculated as A=B−(N−1)*D*sin(θ).
When the points 416 are uniformly distributed (i.e., the same distance separates each point 416 from the adjacent points 416 when projected onto the subject), then A=C=D*sin(θ) and tan(θ)=K/N.
Using one or more of these relationships, the angle θ can be calculated to achieve a desired distance between the scan lines 418. For example, when N (the number of rows) is equal to 600 and K=2, then θ=tan−1(2/600)≈0.19098 degrees.
Referring now to
The distance “D” separates each point 416 from the adjacent points 416. As in
The distance “B” designates the distance between the scan lines 418 of two points in a row separated by two other points 416 when the array 410 is rotated to angle θ. For example, the point (13,12) is separated from the point (16,12) by the distance B, which may be calculated as B=K*D*cos(θ). The distance “C” may be calculated as C=D*sin(θ). The distance “A” may be calculated as A=B−(N−1)*D*sin(θ). A distance “R” represents the distance between redundant points 416 on a scan line 418. For example, the point (15,5) is separated from the point (14,9) by the distance R. A distance “E” designates the distance between the scan lines 418 of two adjacent points in a row when the array 410 is rotated to angle θ, and may be calculated as E=C*N/K.
When the points 416 are uniformly distributed (i.e., the same distance separates each point 416 from the adjacent points 416 when projected onto the subject), then A=C=D*sin(θ), N/K is an integer, and tan(θ)=K/N.
Additional relationships may be developed using the above described equations.
cos(θ)2=N2/(N2+K2)
sin(θ)2=k2/(N2+K2)
R/C=1+(N/K)2
R=C*(1+(N/K)2)
Using one or more of these relationships, the angle θ can be calculated to achieve a desired distance between the scan lines 418. For example, when N (the number of rows) is equal to 600 and K=3, then θ=tan−1(3/600)≈0.286 degrees.
Angles for different relationships may be calculated by applying the above described equations. For example, if N=600 and K=20, then N/K=30, which is an integer. Therefore, there is a uniform distribution of points on the substrate surface and the angle θ may be calculated from tan(θ)=K/N. In this instance, θ≈1.91 degrees.
Referring now to
The memory 712 includes an image (not shown) such as may be used for a photolithographic mask. Therefore, portions of the image are located at appropriate S,T locations 714 in the memory 712. Individual points 716 of the array 710 are illustrated overlaying memory locations 714 so as to reflect the rotation of the array 710 (i.e., located in such a way that each point 716 can be identified by a set of S,T coordinates). The rotation of the array 710 is such that K=3, which means that three points 714 from the array 710 are in the same memory column S.
The size of the memory grid 712 is 130×94, which may be calculated as follows:
S=N+(M−1)*N/K=15+(24−1)*15/3=130
T=M+(N−1)*N/K=24+(15−1)*15/3=94.
Image data for the point array 710 may be retrieved memory row T by memory row T from the memory 712 and projected onto a subject (not shown). It is noted that a memory row T may not be equivalent to a point array row N, as the point array 710 has been rotated. As each memory row T is retrieved, a pointer 718 representing a starting address for the retrieved memory row T is updated to the address for the next memory row T to be retrieved. It is apparent that alternate retrieval strategies may be implemented to achieve the same result. For example, it may be preferable to retrieve multiple rows simultaneously, or it may be advantageous to retrieve the point array from memory on a column by column basis.
The point array 710 with its respective points 716, as illustrated in
Referring now to
Referring now to
Referring now to
Referring now specifically to
Referring now to
For purposes of illustration, the system 1110 utilizes point arrays 1124 (not shown) of M=848 columns and N=600 rows, such as are described in relation to
The memory size needed to store an 848×600 point array (a frame) may be calculated by inserting the values for M, N, and K into the previously described equations. Doing so results in a memory size of:
S=N+(M−1)*N/K=600+(848−1)*600/30=17540
T=M+(N−1)*N/K=848+(600−1)*600/30=12828
or 17540×12828. This can be viewed in terms of storage as approximately twenty-eight megabytes (MB).
In operation, the DSP device 1118 extracts a discrete unit, such as a frame embodied in one of the point arrays 1124, from the image 1126. The DSP device 1118 then calculates a position on the DMD 1122 for each point 1128 of the point array 1124. Because the DMD 1122 is rotated in relation to a subject 1130 (not shown), the position of each point 1128 enables proper projection of the associated point array 1126.
After the DSP device 1118 has calculated the DMD positions of the points 1128, the frame is transferred to the frame buffer 1120. In the current embodiment, the frame buffer 1120 is capable of storing a single 848×600 frame, which is approximately 62.1 kilobytes (KB) of data. The frame buffer 1120 then transfers the frame to the DMD 1122, where the frame is projected onto a subject. It is noted that a plurality of frame buffers 1120 may be utilized for increased efficiency and throughput. For example, dual frame buffers 1120 may be utilized so that, while one frame buffer is receiving data from the DSP device 1118, the other frame buffer is transferring its data to the DMD 1122.
Referring now to
The PC, utilizing the interface 1214, may interact with and/or control aspects of the system 1210. The shift register 1220 may be a single shift register or may be a plurality of shift registers suitable for a desired operation. For purposes of illustration, the shift register 1220 is a 64×53 bit register (i.e., it includes 53 registers operable to store 64 bits each). The DMD 1224 in the system 1210 includes a 53 bit data path, although other data path sizes may be used as desired, and has a native resolution of 848×600. The frame buffer 1222 includes a capacity for sixty-four 848×600 frames.
As in
The memory size needed to store an 848×600 point array (a frame) may be calculated by inserting the values for M, N, and K into the previously described equations. Doing so results in a memory size of:
S=N+(M−1)*N/K=600+(848−1)*600/30=17540
T=M+(N−1)*N/K=848+(600−1)*600/30=12828
or 17540×12828. This can be viewed in terms of storage as approximately 28 megabytes (MB).
In the present embodiment, the DSP device 1218 selects and extracts 64 bits of data from the memory 1216. The selection and extraction of data may be done by row or column, or by some other method. The DSP device 1218 then calculates the location for each of the 64 bits on the DMD 1224, and transfers the data into one of the 64 bit registers of the shift register 1220. The DSP device 1218 continues with this selection, extraction, calculation, and transfer process until all 53 of the 64 bit registers of the shift register 1220 are full.
The contents of the shift register 1220 are then transferred to the frame buffer 1222. Since each of the 64 frames included in the frame buffer 1222 is 848×600, the contents of the shift register 1220 may not be sufficient to fill a frame. Therefore, the process involving the DSP device 1216, the shift register 1220, and the frame buffer 1222 may be repeated until each frame of the frame buffer 1222 is filled. After 64 frames (or less, if 64 frames are not available) are stored in the frame buffer 1222, the frames are transferred to the DMD 1224 and projected onto a subject. The process then begins again in order to retrieve more data for the DMD 1224 as is illustrated in FIG. 13.
Referring now to
If the frames of the frame buffer 1222 are not full as determined in step 1322, the process returns to step 1312. This continues until the frames are full or until all the data has been transferred from the memory 1216. When the frames are full, the data is transferred for each frame in sequential order to the DMD 1224 in step 1324. If image data remains to be transferred as determined in step 1326, the process returns to step 1312. It is noted that the ordering of some steps of the method 1310 may be altered and that certain steps may be modified or removed. For example, it may be preferable to retrieve the 64 bits from the memory before calculating the addresses. In addition, it may be preferable to calculate a single address for each retrieved set of bits, rather than for each bit. These and other alterations may depend on a particular implementation of the system 1210, and so the described system and method are merely exemplary.
Referring again to
Referring now to
As in
In the present embodiment, the line buffer 1412 receives lines of data from a memory (not shown). For example, the line may be a row of memory such was described in relation to FIG. 7. The data line is retrieved from the line buffer 1412 by the DSP device 1420. The DSP device 1414 calculates the address for the line data so that its location on the DMD 1420 is known. The DSP device 1414 then transfers the line data into the frame buffer 1416. This process continues until all the line data has been placed into the appropriate frames. Therefore, the frame buffer 1416 includes a total number of frames for the image 1422.
After the line data is stored in the frame buffer 1416, the selector 1418 selects a frame and transfers the selected frame to the DMD 1420 for projection. This selection may be sequential or may use some other criteria for the order in which frames are selected and transferred.
It is noted that modifications to the system 1410 may be made as desired. For example, it may be desirable for the selector to transfer frames as they are filled, rather than waiting for the frame buffer 1416 to completely fill before beginning the selection and transfer process. In addition, the DSP device 1414 may insert the line data into the frames in a variety of ways. For example, the DSP device 1414 may insert the entire line into a single frame, or it may insert individual bits of the line data into appropriate but different frames.
The system 1410 may utilize more memory than some systems (for example, the system 1210 if FIG. 12), but is operable to prepare all the frames of an image for transfer at one time. Therefore, different systems may be used to accomplish different goals. In addition, systems or portions of systems may be combined so as to gain particular benefits as desired.
It is noted that memory usage may be effected by the value selected for K. As is illustrated below, a smaller K generally results in higher memory consumption, while a higher K results in a lower memory consumption.
For example, a point array of 848×600 with K=30 may have a memory array of 17540×12828, as calculated previously. A line buffer operable to buffer a complete line of data will need memory for 17540 bits, or approximately 3.3 KB. A frame buffer operable to hold all the frames may have a memory allowance for 12828×848×600 bits, or 816 MB.
In contrast, the same point array of 848×600, but with K=20, may have a memory array of 26010×18818. A line buffer operable to buffer a complete line of data will need memory for 26010 bits, or approximately 3.3 KB. A frame buffer operable to hold all the frames may have a memory allowance for 18818×848×600 bits, or 1.2 gigabytes (GB).
Referring now to
To increase the scan rate, it may be desirable to alter the unit travel length. However, while altering the unit travel length increases the scanning speed and may remove a certain amount of the redundancy previously represented by “K”, it may decrease the resolution to an undesirable level.
As illustrated in
The resolution of 0.2 μm may be realized by providing an offset distance (e.g., the distance 1518). The offset distance may be provided by rotating the pixels 1510-1514 in relation to a subject (not shown). For example, the rotation may be accomplished by rotating an x-axis 1520 and y-axis 1522 (fixed on the pixels 1510-1514) relative to an x-axis 1524 and y-axis 1526 defining the subject. By defining the unit travel length as the spacing of the pixels 1510-1514, rather than the distance 1518, the unit travel length may be increased from 0.2 μm to 2.2 μm. As described below in greater detail, this increase achieves the resolution of 0.2 μm while also maintaining a relatively high scan rate.
Referring now to
Referring now to
Portions of the design grid 1712 are illustrated as “windows” 1734-1740. The size of a single window is calculated based on the pixel spacing (e.g., 2.2 μm) and the minimum desired resolution (e.g., 0.2 μm), which results in a window size of 2.2 μm/0.2 μm=11. Accordingly, each window is 11×11 pixels, with each pixel representing a 2.2 μm area. As described in reference to
Referring now to
Referring again to
Therefore, each pixel in one of the windows 1734-1740 is offset by 0.2 μm in the succeeding window when the rotated pixel panel projects the pixels. Accordingly, a pixel will be completely shifted by 2.2 μm in every eleventh window.
Referring still to
Referring now to
Referring now to
Referring now to
Referring now to
While the invention has been particularly shown and described with reference to the preferred embodiment thereof, it will be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the invention. Therefore, the claims should be interpreted in a broad manner, consistent with the present invention.
This application claims priority to U.S. Provisional Patent Application Ser. No. 60/319,201, filed on Apr. 23, 2002.
Number | Name | Date | Kind |
---|---|---|---|
3534467 | Sachs et al. | Oct 1970 | A |
4126812 | Wakefield | Nov 1978 | A |
4744047 | Okamoto et al. | May 1988 | A |
4879466 | Kitaguchi et al. | Nov 1989 | A |
5049901 | Gelbart | Sep 1991 | A |
5079544 | DeMond et al. | Jan 1992 | A |
5082755 | Liu | Jan 1992 | A |
5106455 | Jacobsen et al. | Apr 1992 | A |
5109290 | Imai | Apr 1992 | A |
5121983 | Lee | Jun 1992 | A |
5131976 | Hoko | Jul 1992 | A |
5132723 | Gelbart | Jul 1992 | A |
5138368 | Kahn et al. | Aug 1992 | A |
5208818 | Gelbart et al. | May 1993 | A |
5269882 | Jacobsen | Dec 1993 | A |
5281996 | Bruning et al. | Jan 1994 | A |
5300966 | Uehira et al. | Apr 1994 | A |
5361272 | Gorelik | Nov 1994 | A |
5416729 | Leon et al. | May 1995 | A |
5431127 | Stevens et al. | Jul 1995 | A |
5461455 | Coteus et al. | Oct 1995 | A |
5691541 | Ceglio et al. | Nov 1997 | A |
5793473 | Koyama et al. | Aug 1998 | A |
5818498 | Richardson et al. | Oct 1998 | A |
5870176 | Sweatt et al. | Feb 1999 | A |
5892231 | Baylor et al. | Apr 1999 | A |
5900637 | Smith | May 1999 | A |
5905545 | Poradish et al. | May 1999 | A |
5909658 | Clarke et al. | Jun 1999 | A |
5949557 | Powell | Sep 1999 | A |
5955776 | Ishikawa | Sep 1999 | A |
5995129 | Sunagawa et al. | Nov 1999 | A |
5995475 | Gelbart | Nov 1999 | A |
5998069 | Cutter et al. | Dec 1999 | A |
6014203 | Ohkawa | Jan 2000 | A |
6048011 | Fruhling et al. | Apr 2000 | A |
6052517 | Matsunaga et al. | Apr 2000 | A |
6061118 | Takeda | May 2000 | A |
6071315 | Ramamurthi et al. | Jun 2000 | A |
6072518 | Gelbart | Jun 2000 | A |
6084656 | Choi et al. | Jul 2000 | A |
6107011 | Gelbart | Aug 2000 | A |
6124876 | Sunagawa | Sep 2000 | A |
6133986 | Johnson | Oct 2000 | A |
6205364 | Lichtenstein et al. | Mar 2001 | B1 |
6251550 | Ishikawa | Jun 2001 | B1 |
6658315 | Chan | Dec 2003 | B2 |
Number | Date | Country |
---|---|---|
0552953 | Jul 1993 | EP |
WO 9110170 | Jul 1991 | WO |
Number | Date | Country | |
---|---|---|---|
20040004699 A1 | Jan 2004 | US |
Number | Date | Country | |
---|---|---|---|
60319201 | Apr 2002 | US |