The present invention relates to lithographic apparatus and lithographic processing cells, and the methods of operating such.
A lithographic apparatus is a machine that applies a desired pattern onto a target portion of a substrate. Lithographic apparatus can be used, for example, in the manufacture of integrated circuits (ICs). In that circumstance, a patterning device, such as a mask, may be used to generate a circuit pattern corresponding to an individual layer of the IC, and this pattern can be imaged onto a target portion (e.g. comprising part of, one or several dies) on a substrate (e.g. a silicon wafer) that has a layer of radiation-sensitive material (resist). In general, a single substrate will contain a network of adjacent target portions that are successively exposed. Known lithographic apparatus include so-called steppers, in which each target portion is irradiated by exposing an entire pattern onto the target portion in one go, and so-called scanners, in which each target portion is irradiated by scanning the pattern through the projection beam in a given direction (the “scanning”-direction) while synchronously scanning the substrate parallel or anti-parallel to this direction.
In a factory, commonly referred to as a “fab” or “foundry”, in which semiconductor devices are manufactured, each lithographic apparatus is commonly grouped with a “track” comprising substrate handling devices and pre- and post- processing devices to form a “lithocell”. Both the lithographic apparatus and the track typically have supervisory control systems which are themselves under the control of a further supervisory control system. Substrates, which may be blank or have already been processed to include one or more process or device layers, are delivered to the lithocell in lots (also referred to as batches) for processing. A lot is, in general, a group of substrates which are to be processed by the lithocell in the same way and is accompanied by a “recipe” which specifies the processes to be carried out. The lot size may be arbitrary or determined by the size of carrier used to transport substrates around the fab. The recipe may include details of the resist coating to be applied, temperature and duration of pre- and post- exposure bakes, details of the pattern to be exposed and the exposure settings for that, development duration, etc. A large number of tasks must be performed to complete the recipe for a given batch and there are many possible ways these can be done, as in many cases both the track and lithographic apparatus are capable of performing multiple tasks at once, e.g. if the track includes multiple spin coaters or multipurpose stations or if the lithographic apparatus is a dual stage apparatus having measurement and exposure stations. Thus scheduling the tasks to be performed, and optimizing that schedule, e.g. to maximize throughput, is a complex task.
In most cases, on-the-fly scheduling is limited and most sequences of tasks are hard-coded in the control software of the apparatus or the supervisory control system. A more flexible approach to scheduling is to construct a tree based on tasks to be completed and their precedence relation. In such a tree, starting from an origin, branches represent possible tasks that may be carried out and lead to leaves, from which further branches represent tasks that may then be carried out, and so on. Scheduling then becomes a matter of selecting a path through the tree. However such scheduling may not take into account the restrictions caused by the physical layout of the apparatus, nor the possibility of choices between tasks.
Accordingly, it would be advantageous, for example, to provide an improved method of scheduling tasks in a machine such as a lithographic apparatus and lithographic processing cell.
According to an aspect, there is provided a method of generating a schedule for operation of a machine forming at least a part of a lithographic apparatus or a lithographic processing cell, the method comprising:
The method may enable improvements in machine behavior, as a run-time (optimized) schedule can be generated. Heuristics capturing effective intuitive rules for the application domain are used to direct the schedule generation process. By design-time simulation/verification, it can be ensures that the generated schedule will be valid. Techniques for verification are discussed below. Optimization of the schedule, by iterating through possible/promising schedules, dynamically adapting to a better schedule as soon as one is found, while the machine continuously remains active can improve throughput and/or the quality of the manufactured devices with no additional overhead. Further optimization of the schedule by means of a post-processing step on a complete schedule, for example thus taking timing knowledge of an entire lot of substrates into account, is possible.
Optimization of a schedule may include adjustment of parameters of a task. For example, an exposure or alignment task may be more accurate if performed at a slower scan speed and so optimization of the schedule may allow a slower scan speed, especially if that does not affect the critical path.
In an embodiment, the generation of schedules is carried out with reference to a model of the machine. The model of the machine basically comprises of tasks (the things to do) and resources (the things that can be employed to execute tasks). The execution order of tasks is restricted by precedence relations.
An embodiment of the present invention can be considered as an extension of generalized job shop scheduling techniques, which conventionally consider only the order of tasks and the assignment of resources. The extension comprises considering alternatives with respect to tasks, optional tasks, material constraints, resource conflicts and deadlock avoidance.
Alternatives with respect to tasks are, in an embodiment of the invention, handled by defining groups of equivalent tasks—in a particular embodiment a group is defined as a set of nodes where a node may be a task, a cluster of tasks or another group—and a limit on the number of tasks that may be selected from the group. The number of tasks that can be selected may be a specific value, e.g. 1, indicating that exactly that number of tasks must be selected from the group, or a set of values, allowing choice over the number of tasks selected. Thus for optional tasks, the limit may be set as 0 or more. By way of an example, a substrate may be provided with 25 marker pairs of which 16 pairs must be scanned to provide a minimum level of alignment accuracy. Scanning additional marker pairs may provide additional accuracy. Thus tasks may be defined to scan each marker and clustered in pairs. The clusters are put in a group which has a selection limit of 16 to 25.
According to another aspect of the invention, there is provided a method of operating a machine forming at least a part of a lithographic apparatus or a lithographic processing cell, the method comprising:
A schedule is generated in a constructive way, starting from the beginning to determine the next “valid” or “eligible” tasks (i.e. obeying constraints of the machine and the manufacturing process) to perform. Instead of determining all possible schedules, heuristic filters can be used to direct the schedule generation. Examples of heuristic rules are First Start First, Preferred Resources, and Priority Tasks.
The dispatch of partial schedules in the case that the machine is idle, eliminates any scheduling overhead. Such partial schedules may consist of only one task so also providing the benefits of state-based control.
The durations of tasks are taken into account, including the duration needed for resource preparation or setup, which may depend on the previously executed task(s) and the state in which the resource is left. Durations can be determined by several means: 1) by design, or calibration—for tasks which will always have the same duration in different contexts, the timing of each task can be measured once, and stored in the system; 2) by using dedicated mathematical functions—for tasks which depend on many parameters, which are only known during runtime, e.g. coordinate, dose, speed, acceleration, etc.; and/or 3) by dynamically monitoring durations, and using moving average (MA) values—for tasks of which the duration may change slowly over time.
The default heuristic to schedule a task may be “As Soon As Possible” (ASAP). If the machine is idle, the first task chosen will be dispatched immediately, which can be done as the schedule is generated in a constructive way. In this approach, (possibly) sub-optimal schedule solutions are permitted in favor of just getting the machine to start work. If the system is not idle, the next tasks will be added to a queue, comparable to a “heap of pieces” and a post processing step may be performed on the resulting schedule, to optimize it.
The post-processing step may involve adjusting the relative timings of tasks and adjustable parameters of tasks but not the tasks selected, the order of tasks in the schedule or resource allocations. In particular, a transport task, such as the transfer of a substrate from a substrate table after exposure or from a pre-aligner to a substrate table for exposure, may be scheduled to be carried out “As Late As Possible”—that is as late as the task can be carried out without delaying the critical path. Determination of when as late as possible is may take account of other tasks using the resource and other tasks that may interfere with the task being delayed. This approach may be beneficial where the transport task involves moving the substrate from a resource where it is conditioned, e.g. temperature controlled or bathed in clean air, since it ensures that the minimum time is spent in unconditioned surroundings.
In many cases, multiple solutions are possible for “valid/eligible” tasks. While the system is already working on a (possibly sub-optimal) schedule, the scheduler may iterate through the schedule generating process, each time selecting different valid paths, in an attempt to find a better schedule. Possibilities are explored from the beginning to the end, for the same reason as the constructive schedule generation. Each time a better schedule is found, the scheduler may change to this better schedule (cache), taking into account the tasks that have already been executed or dispatched.
To ensure that workable schedules are created, various configurable constraints may be applied. These may relate to logistic integrity, material flow deadlocks and hardware interference.
For example, to preserve logistic integrity, the scheduler may ensure that the resources assigned to execute certain tasks in the ‘life of a material’ are consistent: e.g. if a substrate is loaded onto a first substrate table in a dual stage apparatus, it must also be processed on that substrate table thereafter. Also, the scheduler may ensure that the combination of resources involved in material transport is feasible. For example, a mask may only be transported from a transfer robot onto one turret elevator, not onto the other. A further example is to ensure that the material capacities of the resources of the machine, either individually or in sets, are not exceeded. For example, a mask library may only be able to contain a limited number of masks, a mask table may only have one, etc. To satisfy these additional constraints, logistic task information is defined, and logistic bookkeeping is integrated in the scheduler. Throughout construction of the schedule, the constraints are checked.
How deadlocks in a material's life may be dealt with can be illustrated by an example: if a mask is to be preloaded from a mask input lock to a turret by two subsequent tasks lock-robot, and robot-turret, it must be possible to not only execute lock-robot, but also robot-turret subsequently. To avoid this type of deadlock, ‘tied precedences’ can be used. The decision to schedule one of the tasks that are ‘tied together’ considers the eligibility of the entire ‘tie’. In other words, the first task is only scheduled if the entire tie can be scheduled. An example of a deadlock concerning multiple material lives is the limit that the turret and the mask table may contain only two masks in total. This means that there can be no preload if there is already a mask on the mask table and another on the turret. To avoid this type of deadlocks, a Work In Process constraint is employed.
Hardware interference constraints include that some resources have to move synchronously for certain moves: e.g. substrate table swap. These situations can be defined and taken into account by the scheduler when determining ‘setup’ or ‘preparation’ tasks. Another constraint is that some resources can collide in certain collision-hazardous areas. To avoid this type of interference, each collision-hazardous area can be defined as a mutually exclusive resource. These resources are then automatically assigned by the scheduler if the physical resource (e.g. robot) crosses the area.
The machine may be the whole of a lithographic processing unit, comprising a lithographic apparatus and a track unit comprising substrate handling devices and pre- and post-processing devices, or just the lithographic apparatus or just the track unit or just a subsystem within the lithographic apparatus or track unit.
According to a further aspect of the invention, there is provided a supervisory control system to operate a machine forming at least a part of a lithographic apparatus or a lithographic processing cell, the control system comprising:
According to further aspect, there are provided a lithographic processing cell, a lithographic apparatus and a track unit, each including a control system as described above.
Although specific reference may be made in this text to the use of lithographic apparatus in the manufacture of ICs, it should be understood that the lithographic apparatus described herein may have other applications, such as the manufacture of integrated optical systems, guidance and detection patterns for magnetic domain memories, liquid-crystal displays (LCDs), thin-film magnetic heads, etc. The skilled artisan will appreciate that, in the context of such alternative applications, any use of the terms “wafer” or “die” herein may be considered as synonymous with the more general terms “substrate” or “target portion”, respectively. The substrate referred to herein may be processed, before or after exposure, in for example a track (a tool that typically applies a layer of resist to a substrate and develops the exposed resist) or a metrology or inspection tool. Where applicable, the disclosure herein may be applied to such and other substrate processing tools. Further, the substrate may be processed more than once, for example in order to create a multi-layer IC, so that the term substrate used herein may also refer to a substrate that already contains multiple processed layers.
The terms “radiation” and “beam” used herein encompass all types of electromagnetic radiation, including ultraviolet (UV) radiation (e.g. having a wavelength of 365, 248, 193, 157 or 126 nm) and extreme ultra-violet (EUV) radiation (e.g. having a wavelength in the range of 5-20 nm), as well as particle beams, such as ion beams or electron beams.
The term “patterning device” used herein should be broadly interpreted as referring to any device that can be used to impart a projection beam with a pattern in its cross-section such as to create a pattern in a target portion of the substrate. It should be noted that the pattern imparted to the projection beam may not exactly correspond to the desired pattern in the target portion of the substrate. Generally, the pattern imparted to the projection beam will correspond to a particular functional layer in a device being created in the target portion, such as an integrated circuit.
A patterning device may be transmissive or reflective. Examples of patterning devices include masks, programmable mirror arrays, and programmable LCD panels. Masks are well known in lithography, and include mask types such as binary, alternating phase-shift, and attenuated phase-shift, as well as various hybrid mask types. An example of a programmable mirror array employs a matrix arrangement of small mirrors, each of which can be individually tilted so as to reflect an incoming radiation beam in different directions; in this manner, the reflected beam is patterned. In each example of a patterning device, the support structure may be a frame or table, for example, which may be fixed or movable as required and which may ensure that the patterning device is at a desired position, for example with respect to the projection system. Any use of the terms “reticle” or “mask” herein may be considered synonymous with the more general term “patterning device”.
The term “projection system” used herein should be broadly interpreted as encompassing various types of projection system, including refractive optical systems, reflective optical systems, and catadioptric optical systems, as appropriate for example for the exposure radiation being used, or for other factors such as the use of an immersion fluid or the use of a vacuum. Any use of the term “lens” herein may be considered as synonymous with the more general term “projection system”.
The illumination system may also encompass various types of optical components, including refractive, reflective, and catadioptric optical components for directing, shaping, or controlling the projection beam of radiation, and such components may also be referred to below, collectively or singularly, as a “lens”.
The lithographic apparatus may be of a type having two (dual stage) or more substrate tables (and/or two or more mask tables). In such “multiple stage” machines the additional tables may be used in parallel, or preparatory steps may be carried out on one or more tables while one or more other tables are being used for exposure.
The lithographic apparatus may also be of a type wherein the substrate is immersed in a liquid having a relatively high refractive index, e.g. water, so as to fill a space between the final element of the projection system and the substrate. Immersion liquids may also be applied to other spaces in the lithographic apparatus, for example, between the mask and the first element of the projection system. Immersion techniques are well known in the art for increasing the numerical aperture of projection systems.
Embodiments of the invention will now be described, by way of example only, with reference to the accompanying schematic drawings in which corresponding reference symbols indicate corresponding parts, and in which:
a and b are UML class diagrams of TRS definition levels 1 and 2;
FIGS. 12 to 16 depict various resource automata;
FIGS. 24 to 27 are automata of the resources of a particular embodiment of the invention;
FIGS. 29 to 32 are diagrams of the substrate handling arrangements of a particular embodiment showing possible deadlock situations;
As here depicted, the apparatus is of a transmissive type (e.g. employing a transmissive mask). Alternatively, the apparatus may be of a reflective type (e.g. employing a programmable mirror array of a type as referred to above).
The illuminator IL receives a beam of radiation from a radiation source SO. The source and the lithographic apparatus may be separate entities, for example when the source is an excimer laser. In such cases, the source is not considered to form part of the lithographic apparatus and the radiation beam is passed from the source SO to the illuminator IL with the aid of a beam delivery system BD comprising for example suitable directing mirrors and/or a beam expander. In other cases the source may be integral part of the apparatus, for example when the source is a mercury lamp. The source SO and the illuminator IL, together with the beam delivery system BD if required, may be referred to as a radiation system.
The illuminator IL may comprise an adjusting device AM for adjusting the angular intensity distribution of the beam. Generally, at least the outer and/or inner radial extent (commonly referred to as σ-outer and σ-inner, respectively) of the intensity distribution in a pupil plane of the illuminator can be adjusted. In addition, the illuminator IL generally comprises various other components, such as an integrator IN and a condenser CO. The illuminator provides a conditioned beam of radiation, referred to as the projection beam PB, having a desired uniformity and intensity distribution in its cross-section.
The projection beam PB is incident on the mask MA, which is held on the mask table MT. Having traversed the mask MA, the projection beam PB passes through the lens PL, which focuses the beam onto a target portion C of the substrate W. With the aid of the second positioning device PW and position sensor IF (e.g. an interferometric device), the substrate table WT can be moved accurately, e.g. so as to position different target portions C in the path of the beam PB. Similarly, the first positioning device PM and another position sensor (which is not explicitly depicted in
The depicted apparatus can be used in the following preferred modes:
Combinations and/or variations on the above described modes of use or entirely different modes of use may also be employed.
The lithographic apparatus LA shown in
Co-ordination of the mechatronic systems of the lithographic apparatus LA is the responsibility of supervisory machine control SMC, which is shown in
From the supervisory machine control point of view, the machine can be considered as a task resource system (TRS). A manufacturing process can be associated with a task, whereas a mechatronic system can be associated with a resource. Optimization of machine behavior can start from several TRS definition levels, as has been described in N. J. M. van den Nieuwelaar, J. M. van de Mortel-Fronczak, J. E. Rooda, “Design of Supervisory Machine Control”, European Control Conference 2003, which document is hereby incorporated in its entirety by reference. The higher the definition level, the more room there is for choices. By making choices, TRS definitions can be transformed to lower levels, to finally result in temporal machine behavior (TRS definition level 0: timed TRS, see
The following description of an embodiment of the invention has two parts. First, the definition level of the starting point of the optimization problem is raised from 1 to 2: an unselected TRS. Second, a solution for the optimization problem is presented that starts from a system definition of class 2, taking into account the technique considerations described in “Design of Supervisory Machine Control”. Important requirements for the approach are extendibility towards definition level 3, and run-time usability in SMC. This approach forms a basis for model-based supervisory control of manufacturing machines according to an embodiment of the invention, which has several advantages compared to the common used state-based control. Using the model, supervisory control can evaluate ‘what-if’ scenarios with respect to control decisions, and schedule tasks in time rather than just one after another. Moreover, as the model enables supervisory control to ‘look ahead’, it is possible to use this predictive information to synchronize with related (parts of) machines that are in another control scope. Furthermore, the approach is flexible, which improves its maintainability.
The optimization problem starting from an instantiated, unselected TRS definition ((D2) is formally defined below. Let fAB(D2)=D0 be the optimization function that performs transformations A and B on D2 to return the temporal machine behavior D0. The constraints that have to be satisfied for fAB(D2) are constructed by combining the constraints of the separate transformations A and B. First, the definitions D0 and D1 and the constraints concerning transformation A(fA(D1)) are summarized, which is an extraction from “Design of Supervisory Machine Control”. Subsequently, the alternatives that are relevant in the application domain of manufacturing machines are analyzed, and based on this analysis D2 is formulated. After that, the constraints to be taken into account when selecting from the alternatives defined in definition level 2 to reach definition level 1 (transformation B or fB(D2)) are discussed. Finally, the entire problem fAB(D2) is defined using the fact that fAB(D2)=fA(fB(D2)).
The timing behavior of timed TRS D0 can be described by a 5-tuple (T0,R,I0,τS
Note that, by convention, the definition level is added to each definition element in subscript. Definition elements which are not level specific have no suffix. Furthermore, note that D0 can be visualized as a Gantt chart.
The constraint that has to be satisfied for the instances of the definition elements is as follows:
The timing behavior of a task resource system is induced by physical state transitions of resources. Machine resources are mechatronic systems that have certain performance limitations. Therefore resources have to obey certain behavioral restrictions when executing physical state transitions. Tasks impose start and end states of these physical state transitions, as well as behavioral restrictions of the transition trajectories in between. Furthermore, tasks have to be executed in a certain order. A selected, untimed TRS D1 can be described by a 6-tuple (T1,R,I1,P1,Sb1,Se1):
P1 ∈ P(T1×T1) is the precedence relation between tasks.
Sb1,Se1:T1×R→S give the begin and the end (physical) states of each resource involved in a certain task, where S is the set of all possible physical resource states.
Constraints that have to be satisfied for the instances of the definition elements are as follows:
These definition elements are depicted as a UML class diagram in
Transformation A involves timing of the tasks of the untimed, selected TRS definition D1. Constraints that have to be satisfied for fA((D1) are as follows:
In complex manufacturing machines, alternatives exist with respect to different elements of D1. First of all, alternatives exist concerning precedences. Whereas the precedence relation in level 1 ensures chains of tasks per resource, this order is not essential. What is essential is that the tasks involved in the manufacturing process of the different manufacturing entities are performed in the right order per manufacturing instance. Furthermore, there is a mutual exclusive constraint: a resource can perform only one task at a time. Given the essential order imposed by the manufacturing process and the mutual exclusive constraint, several possibilities exist to interweave the different manufacturing entities. The alternatives with respect to precedences are analogous to the job shop scheduling (JSS) problem described in M. Pinedo, “Scheduling: Theory, Algorithms, and Systems”, Prentice Hall, Englewood Cliffs, (1995).
Second, alternatives exist concerning involved resources. In some cases, multiple resources of the same kind are present in a machine. Several resources can be chosen from to involve in or allocate to a certain task. This is also the case in the generalized job shop scheduling problem described in M. Wennink, “Algorithmic Support for Automated Planning Boards”, PhD Thesis, Eindhoven University of Technology, (1995).
Finally, alternatives exist concerning tasks. This is implied by the fact that in some cases multiple tasks exist in a system that have an equivalent effect on the manufacturing process. For instance, multiple paths to transport material from one place to another, or a set of (m) tasks of which only a subset (n) has to be selected. To determine the required expressiveness of the elements in D2 to outline the room for choices concerning tasks, some examples from a substrate scanner are analyzed. Regarding the exposure scanning of dies, a 1 out of 2 expressivity is required: a die can be exposed (scanned) in two directions, of which one must be selected. This is analogous to the Rural Postman Problem: n out of m, in which n=1, and m=2 (see E. L. Lawler, J. K. Lenstra, A. H. G. Rinnooy Kan, D. B, Shmoys. “The Traveling Salesman Problem: A Guided Tour of Combinatorial Optimization”, Chichester, Wiley-Interscience, pp. 177-178, (1985)). Regarding the measuring of marker pairs on a substrate, the requirements are more difficult. From the (m) marker pairs on a substrate, a minimum number (n) must be measured. A marker pair consists of several markers, each requiring a measure scan task in either direction (n0=1). In this case the task selection can be defined as a selection out of m, in which the number n0 of selected marker pairs must be an allowed number, and in which for all markers in the selected marker pairs one scan task is selected. From this, it can be concluded that nesting is needed (n0 in n) and that the allowed number of alternatives can be more than one number (n ∈ P(N+)). Furthermore, a complex machine may contain buffer places. At certain points in the manufacturing process, it is possible to buffer a manufacturing entity. To define this possibility in an intuitive way, it must be possible to describe the fact that also no buffering is allowed, or: 0 can also be an allowed number (n ∈ P(N)).
To outline the room for alternatives to select from, literature is followed as much as possible. To outline essential precedences, it is not necessary to introduce a new definition element. Similar to JSS, the precedence element is stripped with respect to level 1 to contain only the essential precedence relations: P2 ⊂ P1. The stripped precedence instances P1\P2 concern the scheduled interweaving of the instances that are the result of selection B. The precedence alternatives are outlined by P2 together with a constraint assuring mutual exclusiveness. To outline resource involvement, an additional definition element called capability is introduced: C, similar to generalized JSS. The involvement function is changed to indicate which capabilities are involved with a certain task: I2:T2→P(C). An additional availability function A: C→P(R) is introduced to describe which resources are available for a certain capability. The resource involvement selection implies selection of one available resource for each involved capability.
To outline the required room for alternatives with respect to tasks, literature can not be followed. Therefore, reasoning is started at the basics. In general, tasks and their precedence relation can be visualized by a graph of type ‘activity on node’. For the purpose of modeling selection alternatives concerning tasks, a more general node element N2 is introduced. Equivalent alternatives can consist of a cluster of nodes (nesting). To identify such clusters, an additional node type cluster (L2) is introduced. Function Ln2: L2→P(N2) is introduced to define which nodes belong to which cluster. Furthermore, it is possible that multiple numbers of alternative nodes are allowed to be selected, including the possibility to select none of them. To be able to define which nodes belong to such a group of alternatives, a node type group is introduced: G2. Function Gn2 is introduced to define which nodes are in which group, whereas function Ga2 is introduced to define how many of these nodes are allowed to be selected. The newly introduced definition elements, together with some selection constraints outline the room for selections with respect to tasks. The resulting model can express [n1out of m] or [n2out of m], etc., (aggregates of) tasks, which is abbreviated to [{n1, n2, . . . nx} out of m].
Summarizing this analysis, an instantiated, unselected TRS D2 can be defined by a 14-tuple (T2,L2,G2,N2,R,C,I2,A,P2,Ln2,Gn2,Ga2,Sb2,Se2):
I2:T2→P(C) gives the set of capabilities that are involved with a certain task.
A:C→P(R) gives the set of resources that are available for a certain capability.
P2 ∈ P(N2×N2) is the precedence relation between nodes.
Ln2:L2→P(N2) gives the set of nodes that are in a certain cluster.
Gn2:G2→P(N2) gives the set of nodes (alternatives) that a group consists of.
Ga2:G2→P(N)) gives the allowed numbers (including 0) of nodes to be selected from a group.
Sb2, Se2:T2×C→S give the begin and the end (physical) states of each capability involved in a certain task.
These definition elements are depicted as a UML class diagram in
Constraints that have to be satisfied for the instances of the model elements are as follows:
By making choice B, a TRS definition of class 2 is transformed to a TRS definition of class 1. One of the choices has to do with selection from alternatives with respect to tasks. We define a node to be selected if at least one of the tasks that is in it is selected. Let N1 be the set of selected nodes, then the constraints for fB(D2) can be formulated as follows:
The begin and end state definition is copied from the capability to the selected resource.
To complete the formal definition of the optimization problem, a goal function fg:D0→R is defined, that quantifies the quality of a certain temporal behavior. Examples of factors that play a role in this function are total system duration and number of tasks. Furthermore, two sets of valid functions for fA and fB are introduced, FA, and FB, respectively. With this, the optimization problem can be described as follows:
max fA, fB:fA ∈ FA, fB ∈ FB:fg(fA(fB)D2)) (1.1)
In a practical embodiment of the invention, the run-time usability requirement has important consequences. To avoid the machine being idle while waiting for its controller to compute ‘optimal’ schedules, the algorithm according to an embodiment of the invention is such that tasks can be dispatched to start execution with very small time delays. To achieve this, the schedule is determined in a constructive way, which means from the begin to the end in schedule time. This approach is also safe with respect to extendibility towards handling a TRS definition of level 3. Furthermore, it is possible to dispatch a partial schedule after each task that is added to it. To ensure that the dispatched schedule is an acceptable one, heuristic filters are used to direct the scheduling choices involving choice B. Note that if the algorithm is interrupted to dispatch the schedule, sub-optimal schedule solutions are taken for granted in favor of just getting the machine to work, and non-repetitive behavior might result. Moreover, heuristic filters can be configured such that behavior of a state-based control architecture is copied, which is convenient for software migration purposes. Concerning choice A, the duration of tasks and setup resource state transitions between tasks is determined using dedicated mathematical functions for efficiency and embedability in SMC. Furthermore, the default heuristic of the approach with respect to selection A is to schedule a selected task ‘As Soon As Possible’ ASAP, resulting in an ‘active’ schedule. For memory efficiency, a compact data structure is applied to store the result of selection B that is also compatible with the constructive and ASAP scheduling heuristic of selection A: a heap of pieces (see G. X. Viennot,. “Heaps of Pieces, I: Basic Definitions and Combinatorial Lemmas,” Combinatoire Enumerative, Labelle and Leroux, Eds., no. 1234 in Lect. Notes in Math., New York: Springer, pp. 321-350,(1986)). A piece defines a selected task and the selected involved resources, whereas the sequence of pieces in the heap defines the selected precedence relation. Depending on the goal function, a post-processing step is done with respect to selection A to postpone some tasks in order to improve the schedule. Subsequently, other choices with respect to selection B are considered. Taking the run-time aspect into account, the approach explores other alternatives at the beginning of the schedule first, as these tasks will be dispatched first. In
The first step of the method is to determine eligible tasks (pieces). During transformation functionality B, selected alternatives are stored in a heap of pieces. Piece p describes which task t ∈ T2 is selected, and the selected resources rr ⊂ R2 involved: p ∈ T2×P(R2). The sequence of pieces in the heap h ∈ P((T2×P(R2))*) describes the selected precedence relations in addition to the precedence relations in P2 (intrinsically satisfying constraint b1). If no alternatives with respect to tasks are taken into account, considering a heap h containing passed (=selected up to then) tasks tp ⊂ T2, a next piece p consisting of task t and involved resources rr is eligible to form an extended heap hp if and only if:
The set of feasible heaps H ⊂ P((T2×P(R2))*) can be defined by induction as follows:
ε ∈ H (1.5)
ε ∈ H {circumflex over ( )} p ∈ E(h)hp ∈ H (1.6)
In (1.5), ∈ denotes the empty heap.
Considering the alternatives with respect to tasks, function Et(h) must be extended. During the selection process, tasks that are not selected and will not be selected anymore are called ‘bypassed’. After the selection process, the set of bypassed tasks equals T2\T1. Function Et(h) needs to consider only tasks that are neither passed nor bypassed. For the tasks that are neither passed nor bypassed, the predecessor relation must be checked. In case no alternatives with respect to tasks are considered, all predecessors must be in the heap (see Equation 1.2). This condition is relaxed in case of predecessors of type group; all (possibly inherited, see constraint b3) predecessors must be ‘succeedable’.
Let function anc: N2→P(N2) be a recursive function that determines the ancestors of a node, which are those nodes in which a node n is contained:
anc(n)=(∪n′:n′∈ N2\T2 {circumflex over ( )} n ∈ Gn2(n′) ∪ Ln2(n′):{n′} ∪ anc(n′)) (1.7))
This recursion is finite as the nodes have a hierarchical structure, which is explored upwards only in this function.
Let function succ: N2→P(N2) be a function that determines the successors of a node n:
succ(n): (∪n′:n′∈ N2 {circumflex over ( )} (∃n″:n″∈ anc(n) ∪ {n}:(n″,n′) ∈ P2):{n′}) (1.8)
A task is succeedable when it is passed, and a cluster is succeedable when all nodes in it are succeedable. The non-succeedable nodes of a succeedable group may contain no passed tasks. Furthermore, if none of the nodes of a group is succeedable whereas zero is an allowed number, a group is succeedable when all of its predecessors are succeedable. In other cases, a group is succeedable when the (non zero) number of succeedable nodes of it is an allowed number.
Let ns: N2→B be a recursive function that determines whether a node n is succeedable:
This recursion is finite as the nodes have a hierarchical structure which is explored downwards only, and precedences have no loops and are explored backwards only. The set of succeedable nodes, ns, can be defined as follows: ns={n ∈ N2|ns(n)}.
Let ni be the set of initiated nodes. A node is initiated if it is not succeedable and contains a passed task. This set can be defined as follows:
ni→(∪n:n ∈ N2\ns {circumflex over ( )} (∃t:t ∈ tp:n ∈ anc(t)):{n}) (1.10)
A task is bypassed when it is not passed and when it is in a (node of a) group that is not succeedable or initiated whereas the maximum number of nodes of the group is succeedable or initiated, or if any succeeding node of it is succeedable. The set of bypassed tasks, tb, can be defined as follows.
Where function succnil: T2→P(N2) determines the successors of a task t, including the successors of succeeding nilgroups:
succnil(t)=succ(t) ∪ (∪n:n ∈ (succ(t) ∩ G2) {circumflex over ( )} 0 ∈ Gn2(n): succnil(n))
Using this, function Et(h) when considering alternatives with respect to tasks can be defined as follows:
Et(h)={t ∈ T2\tp\t6|(∀ n,n′:n ∈ anc(t){circumflex over ( )} (n′,n) ∈ P2: n′∈ ni)} (1.12)
The second step of the method is application dependent but the third step can be described generally.
An ‘As Soon As Possible’ (ASAP) heuristic for the choice concerning timing can be associated with an intuitive interpretation, namely that of a heap of pieces (see G. X. Viennot, “Heaps of Pieces, I: Basic Definitions and Combinatorial Lemmas,” Combinatoire Enumerative, Labelle and Leroux, Eds., no. 1234 in Lect. Notes in Math., New York: Springer, pp. 321-350, (1986)). Timing behavior of a TRS can be visualized using a Gantt chart. When a Gantt chart is turned 90° counter-clockwise, the resource occupation by tasks can be interpreted as a heap of pieces p ∈ T2×P(R). The first element of this tuple p0 equals the considered task, whereas the second element p1 equals the resources involved with this task: p=(t, I1(t)). Resources can be associated with the slots on the horizontal axis, whereas (task duration) time is represented on the vertical axis. Tasks are represented by rectangular pieces. The task duration τt
The upper contour of a heap is associated with the time until which the resources are occupied by the pieces in the heap. It is defined as the R-dimensional row vector uH(h), where uH(h,r) is the height of the heap on slot r. The upper contour state is defined as the R-dimensional row vector uHs(h), where uHs(h,r) is the (physical) state of resource r at time uH(h,r).
The horizontal ground convention (see constraint a2), which can be associated with time starting at 0, yields:
uH(ε)=(0, . . . ,0) (1.13)
The upper contour of heap hp that results after piling up a piece p on top of a heap h is equal to the finish time of task t for the resources that are occupied by t and equal to the upper contour of h for the other resources:
The upper contour state of heap hp that results after piling up a piece p on top of a heap h is equal to the end state of task t for the resources that are occupied by t and equal to the upper contour state of h for the other resources:
The finish time of a task t is obtained by adding its duration to its start time (see constraint a2):
τF
The start time of a task t associated with piece p being piled upon top of a heap h is influenced by two components: by its preceding tasks (see constraint a3) on the one hand and by the setup state transitions of the involved resources (see constraint a4) on the other. Note that this precedence constraint is an extension of that described in S. Gaubert and J. Mairesse, “Task Resource Models and (max, +) Automata,” in Idempotency, Cambridge, U.K. Cambridge University Press, pp. 133-144, 1998. It can be determined by taking the highest value of either the highest finish time of its preceding tasks, τS
τS
Regarding preceding tasks, the start time of task t equals the maximum finish time of the passed tasks that precede any node n that t is in:
τS
where function tpp:N2×(T2×P(R))*→P(T2) determines all passed tasks preceding a node. If any of these predecessors is an unselected nilgroup, the passed tasks in the predecessors of that nilgroup must be retrieved. Because of this, the function is recursive and is defined as follows:
Regarding resource setup, the start time of a task t can be obtained as follows:
The above general situation can be applied to a dual stage lithographic apparatus as described above. By way of an example, 3 lots each of 5 substrates of a double exposure recipe are considered. For each lot, different masks are needed: masks 1 and 2 for the first lot, masks 3 and 4 for the second lot and masks 5 and 6 for the third lot. Each substrate consists of 171 dies of size 26×13 mm2, in which the 13 mm is in the scanning direction. Prior to the exposure of the dies, each substrate must be measured. This measuring step involves measurement of alignment marker pairs. 25 alignment marker pairs are placed on each substrate, of which at least 16 pairs must be measured in either direction of each marker to reach the required minimum manufacturing accuracy.
For the purpose of this example, only the selection of tasks and their order is concerned.
Alternatives lie in the following areas:
In
For illustration, the timing behavior resulting from two different settings for the heuristic filters is described.
The description of the first setting, setting I, is as follows:
In
The description of the second heuristic setting, setting II, is as follows:
In
An embodiment of the present invention therefore provides a formal basis for model-based supervisory control of manufacturing machines starting from an instantiated, unselected TRS definition. To define the TRS behavior optimization problem formally, the choice making functionalities A and B are regarded as transformation functions. The same goes for the quantification of the quality of the behavior resulting from the choices made, which is done using a goal function. The constraints that have to be satisfied for transformations A and B are defined mathematically. With this, the behavior optimization problem is defined as the maximum value of the goal function for which the constraints concerning transformations A and B are satisfied.
An instantiated, unselected TRS in the domain of complex manufacturing machines leaves room for choices (selection B) with respect to tasks, resources and task order. To define the alternatives to choose from, the generalized JSS approach (see “Algorithmic Support for Automated Planning Boards” referenced above) is followed concerning alternatives with respect to resources and task order, whereas a new approach is developed concerning alternatives with respect to tasks. This approach is more expressive than previous approaches.
Choice functionality A and B are combined in an optimization approach that is suited for run-time application in supervisory machine control. The basis of the approach is a top-down iterative heuristically filtered beam search algorithm and that is coupled with the available search time to combine good behavior quality with little control overhead. The algorithm is extendable for machine-specific issues, which can be defined as additional selection constraints.
A second embodiment of the invention is applied to a lithographic apparatus employing extreme ultraviolet (EUV) radiation in the projection beam. As this radiation is absorbed by air, exposure must take place in vacuum, whereas the apparatus resides in atmospheric pressure. To bring the substrates from atmospheric pressure to vacuum two load locks L0, L1 are provided. To transport the substrates between the different subsystems two robots R0, R1 are provided. A schematic layout of the apparatus is depicted in
In
The state-transition diagrams or automata of the different mechatronic systems are shown in FIGS. 12 to 16. In these Figures, the initial state is denoted by an extra circle, and transitions are labeled with a time duration or a task name, which will be explained later. Switching of areas of the tables must be done synchronously to avoid collision of the substrate stages: chuck swap. This is depicted by the dashed connections between the diagrams of the two tables in
As discussed earlier, a scheduling problem can be associated with an instantiated, unselected TRS definition (level 2) in
Note that, by convention, the definition level is added to each definition element in subscript. Definition elements which are not level specific have no suffix.
Constraints that have to be satisfied for the instances of the definition elements are as follows:
However, in a complex machine multiple resources can exist which all are capable of the same work. Furthermore, some tasks involve synchronous transitions of multiple resources. As this can also be the case in job shops, the job shop scheduling problem has been generalized to incorporate this issue (see “Algorithmic Support for Automated Planning Boards ” referenced above)
A generalized job shop scheduling problem can be defined by a 8-tuple (T2,R,C,I2,A,P2,Sb2,Se2):
Constraints that have to be satisfied for the instances of the definition elements are as follows:
By selecting, which comes down to the assignment of resources to tasks, and determination of the order in which tasks are executed per resource, an unselected TRS is transformed into a selected, untimed TRS, which can be defined by a 6-tuple (T1,R,I1,P1,Sb1,Se1):
Constraints that have to be satisfied for the instances of the definition elements are as follows:
Constraints that have to be satisfied for the selecting transformation can be formulated as follows:
By timing, a selected, untimed TRS is transformed into a timed TRS, which can be defined by a 5-tuple (T0,R,I0,τS
Furthermore, note that a timed TRS can be visualized as a Gantt chart.
The constraint that has to be satisfied for the instances of the definition elements is as follows:
Constraints that have to be satisfied for the timing transformation are as follows:
The mapping of the scheduling problem of this embodiment onto the definition of a generalized job shop scheduling problem can be split into two sections: system-dependent elements and work-dependent elements. The system-dependent elements can be defined as follows:
There are 5 capabilities: stage, robot, aligner, lock and track:
C={S,R,A,L,T}.
There are 9 resources: stage0, stage1, robot0, robot1, aligner0, aligner1, lock0, lock1, track0:
R={S0, S1, R0, R1, A0, A1, L0, L1, T0}.
The available resources for each capability are defined as follows:
A={(S,{S0, S1}), (R, {R0, R1}), (A, {A0, A1}), (L, {L0, L1}), (T, {T0})}
To define the work-dependent elements, the sequence of tasks per substrate through the apparatus (life of a substrate) is analyzed. As shown in
However, when looking closer it appears that some of the tasks in
For one substrate, e.g. substrate 1, the work-dependent elements can be defined as follows:
T2={W1-T2L, W1-L2R, . . . }
P2={(W1-T2L, W1-L2R), (W1-L2R, W1-R2A), . . . }
I2={(W1-T2L, {T, L}), (W1-L2R, {L, R}), (W1-R2A, {R, A}), . . . }
Sb2={{(W1-T2L, T, rts), (W1-T2L, L, atm)}, {(W1-L2R, L, vac), (W1-L2R, R, @1)}, {(W1-R2A, R, (a), (W1-R2A, A, idle)}, {(W1-AL, A, idle)}, . . . }
Se2={{(W1-T2L, T, rtr), . . . }
Note that by convention, state names are in lower case whereas task names are in upper case and start with the material associated.
Although the generalized job shop scheduling definition described above forms a good basis for the scheduling problem in a complex machine, some essential constraints are missing to avoid unfeasible schedules. Some of these have to do with material logistics. For instance, whereas material transport is feasible from the track to any of the lock resources of the lock capability, this is not the case from any lock to any robot: logistic flow feasibility. Moreover, if for instance a substrate is transported into one of the locks it must be assured that it is taken from the same lock: logistic flow integrity. Furthermore it must be assured that not too many substrates are in one of the locks at the same time as physical room does not allow for that: material capacity feasibility.
Also resource interference causes additional constraints. Unlike in job shop scheduling, a setup may be constrained to be executed synchronous with other transitions only, for instance the stage swap. On the other hand, multiple setups may be constrained to be executed one at a time as they involve visiting the same hazardous area, for instance robot rotations in front of the locks. Both these complications may be appropriate for part of a setup transition only, for instance the robot rotation from state (a to state @l visits the hazardous area between the intermediate state @ca to state @l only. Therefore, a possibly compound state transition or setup must be decomposed in elementary transitions. The same goes for the state transition of a substrate stage from @e to @lm, which must go via state @u.
Finally, the required nanometer accuracy imposes constraints on some time windows. As the substrate is conditioned on the pre-aligner and the stage but not in between, the time in between should not be more than necessary. This means that tasks A2R and R2S should be executed without delay. Furthermore, the time between exposure and transport to the track (Post Exposure Bake time) should be as constant as possible, to achieve good imaging uniformity.
To ensure feasible machine behavior with respect to material, resources may not be overloaded as they have limited room for material. As material transport tasks also play a role, it must be possible to describe the fact that resources are occupied by material instances and the consequences of tasks for the location of material instances.
If choices with respect to resources did not play a role, and each resource would have room for one material instance, it would be possible to ensure feasible machine behavior without the introduction of the notion of material. A material instance, as well as the physical material location at a resource could be modeled as a resource. However, as material remains residing at a resource after the physical task, additional ‘material occupation’ tasks are introduced after each physical transport task. These ‘material occupation’ tasks indicate that a resource is occupied by some material instance, and can only be succeeded by a transport task, after which the material resides on another resource. The ‘material occupation’ tasks finish when subsequent transport tasks start. This is illustrated in
However, if choices with respect to resources do play a role, the approach presented earlier is deficient. In this case, not just any available resources are allowed to be chosen, as the integrity of the logistic flow of the material must be assured. For example: if two resources S1 and S2 of capability S exist, a material that is transported to resource SI must also be transported from S1. This implies that resource S2 is not eligible in this case, even though it is available. To describe the logistic integrity issues in an intuitive way, the notion of material is added to TRS definition level 2.
It is assumed that the logistic (material configuration) effect of a task on the involved material instances is the same for all involved material instances.
The following 5 elements are added to the unselected TRS definition (D2:
Additional constraints that have to be satisfied concerning (D2:
Let (P2m:D2×M→P(T2×T2): be a function describing for each material m ∈ M in a TRS definition D2 ∈ D2, a precedence relation between related tasks (the material ‘life’) without redundant edges and with matching capabilities:
Where function redundant: T2×T2×P(T2×T2)→B determines whether a precedence edge (t,t′) is redundant in a precedence relation P:
redundant(t,t′,P)=(∃t″:t″∈ T2 {circumflex over ( )} t″≠t {circumflex over ( )} t″≠t′: path(t,t″,P) {circumflex over ( )} path((t″,t′,P)) (2.2)
And where function path: T2×T2×P(T2×T2)→B determines whether there is a path between two tasks t and t′ in a precedence relation P:
The additional constraints that have to be satisfied for transformation B from D2 into Di are as follows:
Where a++b denotes concatenation of sequence a and b into ab.
Where function firstp: P(T1×T1)→T1×T1 determines the first precedence edge in a linear precedence relation P1:
firstp(P1)={(t,t′)|(t,t′) ∈ P1 {circumflex over ( )} (t″:t″∈ T1:(t″,t) ∈ P1)} (2.8)
Let Sm (r,s) be the material configuration of resource r after execution of task sequence s. Before executing any tasks, the material configuration of a resource is given and is defined as the initial material configuration: Sm(r,ε)=Sm-i(r). The material configuration after execution of task sequence st is defined as follows:
Sm(r,st)=Sm(r,s)\mat(Cb2(t),r) ∪ mat(Ce2(t),r) (2.9)
Where function mat: P(C×P(M))×R→P(M) returns the material associated with the capability that has the resource available for it.
mat(CM,r)={m|m ∈ cm.1 {circumflex over ( )} cm ∈ CM {circumflex over ( )} r ∈ A(cm.0)} (2.10)
Then the material capacity constraint for a TRS definition D1 ∈ D1 can be defined as follows:
(∀ r,st:r ∈ R {circumflex over ( )} t ∈ T1 {circumflex over ( )}st≦chainr(P1r(D1,r)):|Sm(r,st)|≦Rm(r)) (2.11)
Additional constraints are introduced that outline valid extension of a selection to avoid invalid behavior during constructive schedule construction.
Deadlock is possible if the system gets locked, e.g. the situation in the case as is shown in
In many cases, material transport is performed by resources that can contain only one material instance (one-lane logistic path). This means that the only possible next transport task for such a resource is to transport the material instance further. However, when a constructive scheduling algorithm is applied this can lead to deadlock, as there might be no resource available to receive material, whereas the same resource has to make room on these resources. To avoid these kinds of deadlock situations, the scheduling algorithm has to look a bit further in life of this material instance than the next task only.
To describe these situations, the concept of tied precedences Pt2 ⊂ P2 is introduced. When choice of tasks is not considered, like in the generalized job shop scheduling problem, this implies that the subsequent transport tasks of a certain material instance that have to be executed uninterrupted after another are connected by tied precedences. A tie is defined as a chain of tasks that are connected by tied precedences. An open tie is defined as a tie of which at least one but not all tasks are selected.
When considering a constructive scheduling algorithm, the additional constraints concerning ties are as follows:
In the following, we formulate the possible schedule extensions for a constructive scheduling algorithm.
Let T, T1p,I1p,P1p be the tasks, involved resources and precedence relation of partial selection D1p. Let T1e,I1e,P1e be the task t′, involved resources with t′ and precedence edges to t′ of selection extension D1e. Let T1p′,I1p′,P1p′ be the tasks, involved resources and precedence relation of extended partial selection D1p′, which is equal to T1p∪T1e,I1p∪I1e,P1p∪P1e.
Let function Et: (D2×D1)→P(T1) be the function that determines for a partial selection D1p all eligible tied next tasks, considering the tied precedence relation.
Et(D2,D1p)={t ∈ T2\T1p|∀ t′:(t′,t) ∈ P2:t′∈ T1p)} (2.13)
Let function Ett: (D2×D1)→(P(T1) be a function that determines for a partial selection D1p all eligible next tasks, considering the tied precedence relation:
Ett(D2,D1p)={t′|t′ ∈ Et(D2,D1p) {circumflex over ( )} (∃t:t ∈ T1p:(t,t′) ∈ P2t)} (2.14)
Let function Er: (D2×T1)→P(R) be a function that determines for a task all eligible sets of involved resources, considering the available resources for the capabilities involved.
Er(D2,t)={rr ⊂ R|(∀ r,c:r ∈ rr,c ∈ I2(t):r ∈ A(c))} (2.15)
Let function checkCb-i :through checkCb-iii :((D2×D1×T1×P(R))→B be functions that check whether or not for a next task t′ and involved resources rr′ constraints b-i through b-iii hold.
Let function checkb-iv:(D2×D1×T1×P(R)×P(P(R)×N)→B be a function that checks whether or not for a next task t′ and involved resources rr′ constraint b-iv holds.
checkCb-iv(D2,D1p,t′,rr,WIPceil)=(∀ (Rc,nc) ∈ WIPceil:(Σr:r′∈ Rc ∩ rr′:|Sm(r,tchainr(D1p,r)++t′)|)≦nc)) (2.19)
Let function E: (D2×D1)→P(T1×P(R)×P(T1×T1)) be the function that returns for an unselected TRS definition all possible extensions e in the form of task t′, involved resources rr′ and precedences pr′ with which partial schedule D1p can be extended to form an extended partial schedule D1p′. D1e can be determined from e by taking e.0 for T1e,(e.0, e.1) for I1e and e.2 for P1e. Then, function E can be defined as follows:
In function E, both the constraints involved in generalized job shop scheduling, and the additional machine-specific scheduling constraints b-i though b-vi can be recognized.
It is also possible to apply a deadlock-avoiding constraint that takes into account the direction of the material (instead of constraints b-iv through b-vi). Such a constraint can be formulated in the form of a configurable function, checking whether a certain material configuration Sm including the flow direction of this material (which can be derived from the remainder of the materials' lives) is safe (will not lead to deadlock). Such a function can, for example, be configured using a model checker, such as the Symbolic Model Verifier (SMV) software made available by Carnegie Mellon University, Pittsburgh, Pa. 15213-3890.
In the following text, first, additional machine-specific constraints are introduced to avoid unfeasible timing behavior, then the transformation function is described.
To describe hardware interference, some additional definition elements are defined. Subsequently, constraints are defined using these additional elements. Furthermore, the constraint that must be satisfied in order to time a selected TRS is described. Finally, constraints with respect to task start and finish time are described.
Some state transitions of some resources can only take place synchronously with state transitions of other resources.
Ts ∈ P(R×S×S) gives the subsets of synchronous resource state transitions.
In a machine, certain areas exist in which resources can collide. These areas are allowed to be visited by the resources mutually exclusively. This additional constraint is described by adding a resource to R for such hazardous areas, and involves this resource in every resource state transition that visits this area as described above. For the collision area resources, physical states do not play a role.
Rc is a finite set whose elements are called collision areas.
Tc:R×S×S→Rc ∪ {Ø} gives the collision area resource that is associated with a certain resource state transition.
The setup transitions might consist of several elementary subtransitions, each of which might be involved with forced synchronism or collision avoidance.
Te:R×S×S→(R×S×S)* gives the elementary subtransitions of a resource state transition. In case there are no elementary subtransitions, the original state transition is returned.
Constraints:
i Every task is elementary:
(∀ t,r:t ∈ T1 {circumflex over ( )} r ∈ I1(t) ∩ (R\Rc):Te(r,Sb1(t,r),Se1(t,r))=[(r,Sb1(t,r),Se1(t,r))])
ii Every task matches Ts, which implies that for each task t either the resource state transitions involved encapsulate some set of synchronous state transitions s from Ts, or none of the involved resource state transitions occurs in any s from Ts.
(∀ t:t ∈ T1:(∃s ∈ Ts:s ⊂ (∪r:r ∈ I1(t):{(r,Sb1(t,r),Se1(t,r))})) (∀ s:s ∈ Ts:s ∩ (∪ r:r ∈ I1(t):{(r,Sb1(t,r),Se1(t,r))})=Ø))
iii Every task matches Tc, which implies that for each task and each involved resource (excluding hazardous areas) that goes for each resource state transition any involved collision area is involved in the task too:
(∀ t,r:t ∈ T1 {circumflex over ( )} r ∈ I1(t) ∩ (R\Rc):Tc(r,Sb1(t,r),Se1(t,r)) ∈ I1(t))
Note that these constraints essentially hold for every TRS definition level (main=level 1).
Note that although a number of possible sequences of elementary resource state transitions between some possible resource state transition that is implied by selection may be allowed, only one transition is defined by function Te. Furthermore, for each elementary state transition, at most one collision area is defined by function Te.
When taking the issue of forced synchronous and elementary state transitions into account, it is possible that a setup state transition of a resource implies setup state transitions of other resources. These implied state transitions also have to match the states of the resource in turn, which might imply other state transitions, etcetera. To avoid an infinite chain reaction caused by loops, additional constraints are defined.
A core setup transition is defined as the resource state transition of a resource r from the end state of the previous task on r to the begin state of task t ∈ T2, in case these states do not match. Using this definition, the following constraints have to be satisfied to prevent loops during the transformation into a timeable TRS:
Due to the constraints to ensure one possible finite transformation A of a selected TRS D1 to a timeable selected TRS D1T, this transformation can be defined by a function. In the chain of tasks per resource of a definition D1, additional setup tasks are introduced such that a chain of tasks results that satisfies constraints i, ii, iii, and 1-t to result in a timeable selected TRS D1T.
Let insert be a function inserting setup tasks and precedence edges in a selected TRS D1 for all non-matching subsequent task end and begin states defined by insert(D1)=D1′ such that:
and T1′, P1′, I1′, Sb1′, and Se1′ are minimal.
Let e=Te(r, Sb1(t,r),Se1(t,r)). Let decomp be a function decomposing any compound transitions in setup tasks of a selected TRS to match Te defined by decomp(D1)=D1′ such that:
and T1′, P1′,I1′,Sb1′, and Se1′ are minimal.
Let notsync: D1→T1 be a function determining which tasks of a selected TRS are not matching Ts
notsync(D1)={t ∈ T1|∃s:s ∈ Ts:s {(r,Sb1(t,r),Se1(t,r))|r ∈ I1(t)})} (2.23)
Let addsync be a function adding forced synchronous resource state transitions to setup tasks of a selected TRS which are not matching Ts defined by addsync(D1)=D1′ such that:
Let addcoll be a function adding collision areas to setup tasks of a selected TRS which are not according Tc: addcoll(D1)=D1′ such that:
(∀ t,r:t ∈ T1 {circumflex over ( )} r ∈ I1(t) ∩ (R\Rc) {circumflex over ( )} Tc(r,Sb1(t,r))≠Ø:Tc(r,Sb1(t,r),Se1(t,r)) ∈ I1′(t)) (2.25)
To transform a selected TRS D1| that does not satisfy constraint 1-t into a selected D1T that does satisfy constraint 1-t, function transA-t:D1→D1′ is defined as follows:
Note that transA-t can also be used in a constructive algorithm.
The algorithm to optimize timing of a timeable selected TRS D1T given the timing constraints a is a linear programming problem that is solvable by well known techniques. Linear programming can also be used in a constructive algorithm.
For an example system, the additional elements can be defined as follows:
M={W1,W0, . . .}.
Cb2={(W1-T2L, {(T, {W1)), (L, { })}), (W1-L2R, {(L, {W1}), (R, { })}), . . . }.
Ce2={(W1-T2L,{(T, { }), L, {W1})}), . . . }
Rm={(T0,1), (L0,1), . . . }
Mf={(T0,L0),(L0,R0),(R0,A0)
Pt2={(W1-T2L, W1-L2R),(W1-L2R,W1-R2A),(W1-R2A,W1-AL), (W1-AL,W1-A2R),(W1-A2R, W1-R2S),(W1-S2R,W1-R2L), (W1-R2L,W1-L2T), . . . }
WIPceil={({L0,R0,A0,S0},2), ({L1,R1,A1,S1}],2)}
Ts={{(S0, @lm, @e), (S1, @e, @lm)}, {(S1, @lm, @e), (S0, @e, @lm)}}
Rc={HA}
Tc={((R0,@ca,@l),HA), . . . }
Te={((R0,@i, @,a),[(R0, @i, @ca), ),[(R0, @ca, @ca)]),((S0, @lm, @u), [(S0,@lm,@e),(R0,@e,@u)]), . . . }
Using a simple heuristic, namely fill up the system as much as possible and ‘Earliest Start First’, a feasible and valid schedule is obtained. Subsequently, a timing post-processing step is done to fulfill the additional time window constraints
τF
After this, the schedule of
The critical path as is displayed in
A third embodiment of the invention is a lithographic apparatus, using extreme ultraviolet radiation as the exposure radiation, connected to a track. The substrate flow of the third embodiment is schematically shown in
The track delivers fresh substrates to the lithographic apparatus and retrieves exposed substrates from the lithographic apparatus. A simple model of the track T is used for the purposes of this description, where each time a substrate is retrieved or a new substrate must be delivered, the track needs a certain amount of time to perform internal actions.
The load locks L0-L3 have room for one substrate and are bi-directional, which means that a single load lock can be used for both ingoing and outgoing substrates. After a substrate is put in a load lock, the pressure in the load lock is brought to vacuum for an ingoing substrate or to atmospheric for an outgoing substrate.
The robots R0, R1 in the substrate handler both have two arms, placed at 180° opposite of each other. Each arm can carry one substrate. The robots rotate their arms between the load locks and the chucks. A robot arm can reach two of the four locks when it is at the lock side and it can reach both chucks when it is at the chuck side.
The chucks or substrate tables WT0, WT1 each have room for one substrate. The substrate tables may adopt positions—the load/unload position, the measure position and the exposure position. However, it is also possible to combine the load/unload position with the measure position so that the substrate tables have only two positions. When the substrate table is at the measure position the substrate can be loaded or unloaded by one of the robots. Measurement also requires the substrate table in this position. Exposure takes place at the exposure position. Both substrate tables change positions synchronously during the so-called ‘chuck swap’.
As with the first and second embodiments, the system can be described as an instantiated, unselected TRS definition (class 2). The control strategy of the third embodiment is embodied in a heuristic filter configuration.
In this embodiment, there is one track and there are four load locks, two robots and two substrate tables, which would mean nine resources. However, instead of modeling the robots with a substrate capacity of two substrates, the robot arms of the robots are defined as separate resources that represent separate and unique substrate locations. This is done so because the location of a substrate must be known for the robot, as it influences the behavior concerning the robot rotations. When the robot is modeled as one resource with a material capacity of two substrates, it is unknown on which arm a substrate is residing. This means there are eleven resources, which are numbered from 0 through 10 and stored in R
It is clear that there are four capabilities in the model, namely track, lock, robot arm and substrate table. These capabilities are numbered from 0 through 3 and stored in C.
Several behaviors can be performed by the system. Most of the behaviors concern substrate transport between two resources. The strings representing these transport behaviors are of the form “capability2capability”. For example the transport from the track (T) to a load lock (L) is called “T2L”. There are six transport behaviors, namely “T2L”, “L2R”, “R2C”, “C2R”, “EL”, and “L2T”. Besides these transport behaviors, there are two other behaviors, “measure” and “expose”. All eight behaviors involve certain capabilities, which is defined in I2. It is clear that for the transport behaviors, the involved capabilities are those where the material is transported between. For the “measure” and “expose” behaviors the involved capability is a substrate table.
In A, the available resources per capability are defined, which is straightforward. All resources except the track have a material capacity of one substrate, which is defined in Rm. The track in the model has infinite room for substrates, but for convenience the material capacity of the track is set to 100 substrates. The possible material flow between resources is defined in Mf: From the track, substrates can be transported to each of the four load locks and from each load lock, substrates can transported to two of the four robot arms. Which robot arms those are, depends on the load lock number corresponding to the arrows in
In the track, there is one possible state transition that consists of elementary subtransitions, namely from ‘retrieved exposed substrate’ to ‘ready to retrieve’. This state transition is needed when the track retrieves two exposed substrates subsequently (which will happen at the end of the schedule). This transition consists of two elementary state transitions, namely, the track internal action from ‘retrieved exposed substrate’ to ‘ready to send’ (see
The transport tasks involving a lock do not change the state of the lock. Pumping down to vacuum and venting of air (which are both resource setups) are the possible state transitions that change the state. The automaton of a lock is shown in
The robot arms and the substrate tables both have two possible states with transitions between them. The robot arms have as state their position, either at lock side or at substrate table side. The state of a substrate table tells whether it is at measure position or at exposure position. The robots and the substrate tables both have forced synchronism, denoted with Ts in the automata of
These synchronous state transitions of the robot arms and of the substrate tables are defined in Ts.
Besides the static system definition described above, other static information must also be defined. The zero order durations for each behavior and for all elementary resource state transitions are defined in Dtz and Dsz, respectively. Because no higher order duration functions are defined which require the hardware capacities defined in Hc (like acceleration and maximum velocity), it is not necessary to define these hardware capacities. Finally, the resource descriptions are defined in resdescr.
The work configuration contains all dynamic information of the TRS, consisting of the dynamic system definition and the initial situation.
The dynamic system definition consists of the definition elements T2, L2, G2, Ln2, Gn2, Ga2, P2, Pt2, Tb2, Sb2, Se2, Cb2, and Ce2.
In the third embodiment, there are no alternatives concerning tasks, so only tasks are defined and no clusters or groups. For each substrate, eight tasks are defined which correspond to the behaviors mentioned in the previous section. To get a correct manufacturing process for each substrate, the essential precedence relations are defined in P2 between the eight tasks for one substrate, which results in the following life of a substrate: “T2L”, “L2R”, “R2C”, “measure”, “expose”, “C2R”, “R2L”, and finally “L2T”. Also the order of substrates going in the lithographic apparatus is defined using precedence relations between the ingoing tasks (in this case “T2L”) of the different lives of a substrate, resulting in an inflow order with increasing substrate numbers. None of these precedence relations is tied, so Pt2 is empty.
The behaviors mentioned above are assigned to each task in Tb2. The corresponding task graph that shows three lives of a substrate is shown in
In Sb2 and Se2, the begin and the end states of each involved capability are defined for each task. In the third embodiment, all transport tasks require the involved capabilities to be at the correct position, such that the transport can be performed. Their state (which is their position) remains unchanged during the task, so the end state is equal to the begin state (see also the automata in
Finally, the begin and the end material configurations are defined in Cb2 and Ce2, respectively. Obviously, for a transport, the delivering capability holds the material at the begin of the task and the receiving capability holds the material at the end of the task. For “measure” and “expose” tasks, the material stays on the capability (in this case a substrate table), so Cb2 and Ce2 are equal for these tasks.
Besides the dynamic system definition described above, the initial situation must be defined. The initial heap is empty, as no tasks are performed yet. For each resource, the initial time (defined in the initial contour) is zero. The initial contour also contains all initial resource states, which is ‘ready to send’ for the track and ‘at atmospheric pressure’ for the load lock. For the robot arms and substrate tables, the initial state is one of the two possible positions, whereas the opposite arm or the other substrate table has the other possible position as initial state.
Next, the heuristic filter configuration design for substrate flow in the third embodiment is described.
Material flow with logistic crossings in a TRS may lead to deadlock situations, which is the case in the present embodiment. After examination of the resource configuration and the possible material flows, the following possible deadlock situations are recognized. First, in a combination of two load locks and a robot, it is possible that both locks have fresh substrates in them and that both robot arms hold an exposed substrate. In this case there is no robot arm free for the fresh substrates and there is no empty lock for the exposed substrates, which means that no further tasks can be performed. An example of this type of deadlock is depicted in
Also behind the locks, between the robots and substrate tables, a deadlock situation may occur. This is the case when all four robot arms have fresh substrates and both substrate tables are occupied by exposed substrates. This situation is shown in
Because deadlocks are examples of invalid behavior, constraining filters are used to prevent them. In this case, WIP ceiling is used. For each of the three possible deadlock situations as described above (two lock-robot combinations and one behind the locks), a maxwip filter is defined that checks the WIP ceiling constraint for that group of resources. In the implementation of the T-ReCS scheduler, these three instances of the maxwip filter are combined into one maxwip filter with the three WIP ceiling constraints as filter parameters.
For both lock-robot combinations (two locks and two robot arms), a WIP ceiling of three substrates is set in the filter parameters. The parameters of these maxwip filters are the resource numbers of the two locks and the two robot arms, together with the maximum WIP of three substrates. With this heuristic filter, the type of deadlock depicted in
After analysis of the deadlock situation in the counterexample, it became clear that lowering the maximum WIP level behind the locks to four substrates would prevent this deadlock situation. Besides this situation, a similar deadlock situation as in
The design process described above only concerns the constraining filters, in this case resulting in four maxwip filters. All generated schedules within this heuristic filter configuration will have valid behavior, which in this case means that the verified property, deadlock freeness, is always satisfied. However, within the valid behavior, some behaviors are more preferred than others. Therefore, two comparing filters are added to the heuristic filter configuration.
To get high resource utilization, it is desired that the number of substrates in the lithographic apparatus is as high as possible. Therefore, the fillmaxwip filter is added to the heuristic filter configuration. The parameters of this filter are the resources where the WIP level should be as high as possible, so in this case all the resources except the track.
Finally, the total schedule time should be as low as possible. This can be accomplished by preferring tasks which have the lowest start times. Therefore, the earliest start first (ESF) filter is used.
Concluding, the heuristic filter configuration consists of four instantiations of the constraining maxwip filter (implemented in one filter), and two comparing filters, the fillmaxwip and the earliest start first (ESF) filter.
The resulting Gantt chart is shown in
However, looking at the inflow and the outflow of the substrates (see the substrate numbers in the figure), the order is not FIFO.
The next experiment demonstrates that it is possible to generate schedules with FIFO order concerning the inflow and the outflow of substrates. The scheduler is guided towards this behavior by applying an additional heuristic filter which makes sure that substrates cannot overtake each other. This filter is the incrmatnr filter that chooses the task with lowest material number when more tasks with the same behavior for different materials are eligible. This filter can be used, because all substrates follow the same logistic path and they enter the lithographic apparatus with increasing substrate number. The only filter parameter of the incrmatnr filter is a list containing the behaviors to which the filter must be applied. When this filter is applied to all behaviors, it is guaranteed that substrates cannot overtake each other and will come out of the system with increasing substrate numbers, which means FIFO order. When this heuristic filter configuration is used in the scheduler, the generated heap (using one shot scheduling) is indeed FIFO. The Gantt chart of this schedule with the substrate numbers is shown in
The final experiment concerns the flattening of the post expose bake (PEB) time variability embodiment. The timing post-processor tool is applied and after fine-tuning of the weight functions, the PEB time machine flow variability is reduced to zero. The Gantt chart of the FIFO schedule with flattened PEB time variability is shown in
Scheduling Verification
The schedules described above make use of heuristics to avoid creating schedules, or partial schedules, that may cause undesirable situations such as deadlock or collisions. It is desirable to verify that these heuristics are properly parameterized so as to function correctly. Such verification need only be performed at “design time”—when the scheduler is configured, i.e. its parameters set.
A conventional approach to verification of a model-based problem such as the schedulers described above would be to consider each possible state of the system or model of it to check whether it results in an undesirable situation (state space traversal). Various software model checkers exist to do this automatically. However, in a complex machine such as a lithographic apparatus or lithocell, the number of possible machine states is simply too large for verification by known model checkers, even at design time.
Therefore, in this embodiment of the invention, several approaches are taken to reduce the number of states that need to be considered by the model checkers.
Within the complete tree of all possible states—i.e. the physically feasible behavior of the apparatus as defined by the system definition—there is a reduced set of states, representing valid behavior, determined by deadlock avoidance rules and the like in the scheduler. Within the tree of valid behavior is a further reduced tree representing good or preferred behavior. The scheduler at run-time aims to find a schedule in this tree by the use of heuristics. At design time, it is desirable to check all states in the valid behavior tree to determine whether or not they are, or lead to, an undesirable situation such as a deadlock. If they do not, the scheduler will also not generate a schedule that ends in an undesirable situation at run-time.
To further reduce the processing required for this verification it is necessary to identify states that can be omitted in traversal of the state space. Some approaches to this are:
If two (or more) tasks B and C, which follow task A, can be executed in parallel, it does not matter in state space traversal, whether B or C is visited first (tasks having tau confluence). Thus, considering states in terms of states passed (tp) it is necessary only to consider the states:
Where the apparatus includes multiple resources of the same capability, e.g. substrate tables, load locks, elevators, etc., schedules can be mirrored in them. Thus, if following task A, task B can be performed on either substrate table 1 or substrate table 2, it is only necessary to check the state created by performing it on one of the tables.
Non-logistic tasks, i.e. those which do not affect the properties to be verified by the model checker, e.g. deadlock or the FIFO condition, may be omitted. Examples of such tasks are measurement and exposure tasks as all materials remain at the same resources then. This reduction, and the resource symmetry reduction, can be effected by a hash function.
Using these state space reduction techniques, combinatorial effects leading to state space explosion can be reduced such that practical cases can still be verified.
While specific embodiments of the invention have been described above, it will be appreciated that the invention may be practiced otherwise than as described. The description is not intended to limit the invention.
This application is a continuation-in-part of U.S. patent application Ser. No. 10/743,320 filed Dec. 23, 2003, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 10743320 | Dec 2003 | US |
Child | 10846854 | May 2004 | US |