WO2010148139A2 - Counter and timer constraints - Google Patents
Counter and timer constraints Download PDFInfo
- Publication number
- WO2010148139A2 WO2010148139A2 PCT/US2010/038891 US2010038891W WO2010148139A2 WO 2010148139 A2 WO2010148139 A2 WO 2010148139A2 US 2010038891 W US2010038891 W US 2010038891W WO 2010148139 A2 WO2010148139 A2 WO 2010148139A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- counter
- task
- tasks
- update
- restriction
- Prior art date
Links
- 238000000034 method Methods 0.000 claims abstract description 39
- 230000009471 action Effects 0.000 claims abstract description 38
- 230000001419 dependent effect Effects 0.000 claims abstract description 9
- 238000012545 processing Methods 0.000 claims description 40
- 230000015654 memory Effects 0.000 claims description 21
- 230000008859 change Effects 0.000 claims description 7
- 238000004519 manufacturing process Methods 0.000 description 20
- 238000007689 inspection Methods 0.000 description 17
- 230000008569 process Effects 0.000 description 11
- 238000010586 diagram Methods 0.000 description 9
- 238000012360 testing method Methods 0.000 description 8
- 235000012431 wafers Nutrition 0.000 description 8
- 239000004065 semiconductor Substances 0.000 description 7
- 230000003287 optical effect Effects 0.000 description 5
- 230000005291 magnetic effect Effects 0.000 description 4
- 238000013500 data storage Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 230000003068 static effect Effects 0.000 description 3
- 238000004590 computer program Methods 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 241000219470 Mirabilis Species 0.000 description 1
- 240000005860 Portulaca grandiflora Species 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 230000007274 generation of a signal involved in cell-cell signaling Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- PXUQTDZNOHRWLI-OXUVVOBNSA-O malvidin 3-O-beta-D-glucoside Chemical compound COC1=C(O)C(OC)=CC(C=2C(=CC=3C(O)=CC(O)=CC=3[O+]=2)O[C@H]2[C@@H]([C@@H](O)[C@H](O)[C@@H](CO)O2)O)=C1 PXUQTDZNOHRWLI-OXUVVOBNSA-O 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/418—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM]
- G05B19/41865—Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM] characterised by job scheduling, process planning, material flow
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/4881—Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/06—Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/30—Nc systems
- G05B2219/32—Operator till task planning
- G05B2219/32396—Job shop, batch production system
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/30—Nc systems
- G05B2219/45—Nc applications
- G05B2219/45031—Manufacturing semiconductor wafers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/06—Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
- G06Q10/063—Operations research, analysis or management
- G06Q10/0631—Resource planning, allocation, distributing or scheduling for enterprises or organisations
- G06Q10/06312—Adjustment or analysis of established resource schedule, e.g. resource or task levelling, or dynamic rescheduling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/06—Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
- G06Q10/063—Operations research, analysis or management
- G06Q10/0631—Resource planning, allocation, distributing or scheduling for enterprises or organisations
- G06Q10/06316—Sequencing of tasks or work
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02P—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
- Y02P90/00—Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
- Y02P90/02—Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]
Definitions
- Figure IA is a block diagram illustrating a scheduling system utilizing a counter constraint
- Figure 4 is a diagram schematically illustrating an example of a scheduling system using a counter constraint for placing scheduling restrictions on some tasks and not other tasks;
- the provisional schedule and any data related to the provisional schedule are provided to constraint managers, including the counter constraint manager 107.
- the constraint managers perform updates based on the provisional schedule. Additional provisional scheduling may be performed and additional updates may be performed until an entire schedule is constructed.
- the scheduling system 105 can provide the entire schedule to a dispatcher 103.
- the dispatcher 103 can be integrated through the MES 101 to dispatch, for example, wafer lots accordingly.
- Figure IB illustrates a block diagram of one embodiment of a counter constraint manager 150 executing on an exemplary computing environment.
- Computing environment can be implemented as a server, client, workstation, desktop, tablet, or any other machine. It can also be implemented in one or more small portable platforms such as a notebook, a PDA (personal digital assistant), or wireless web devices, and other devices.
- the counter constraint manager 150 can be part of a scheduling system (e.g., scheduling system 105 of Figure IA) and can include a counter constraint creator 152, a counter constraint creation user interface (UI) 154, a counter constraint configuration UI 156, a data store 158, a counter updator 160 and a counter monitor 162.
- UI counter constraint creation user interface
- a restriction can be used to place a general restriction in scheduling tasks (e.g., no more than 52 of product A (203) can be produced by three o'clock in the afternoon) and a specific restriction in scheduling a particular task (e.g., a task to produce product A cannot start unless the counter has a value of less than 52).
- a general restriction in scheduling tasks e.g., no more than 52 of product A (203) can be produced by three o'clock in the afternoon
- a specific restriction in scheduling a particular task e.g., a task to produce product A cannot start unless the counter has a value of less than 52.
- a counter constraint 301 can model the scenario where a use-task (305, 307, 309) can only start if the counter 303 has a value that is less than ten.
- the industrial engineer may further want additional use-tasks (e.g., use-task-w 309) to resume using the reticle tool 329 after the inspection of the tool is completed.
- the counter constraint 301 can model a scenario where the value of the counter 303 is reset to zero after the inspection task 311 is completed and thus, a use-task (e.g., use-task-w 309) can start since the counter value is less than ten.
- each update can include an action (A 1 , A 2 , A n ) to describe that the value of the counter 303 is incremented by one each time a use-task (305, 307, 309) uses the resource 329.
- Update (313, 315, 317) for each use-task can also include an update time (UT 1 , UT 2 , UT n ) to be associated with the start time (S 1 , S 2 , S n ) variable of its corresponding use-task.
- Restriction for each use-task can also include a restriction time (RT 1 , RT 2 , RT n ) which is associated to the start time variable (S 1 , S 2 , S n ) of the corresponding use-task (305, 307, 309).
- RT 1 , RT 2 , RT n restriction time which is associated to the start time variable (S 1 , S 2 , S n ) of the corresponding use-task (305, 307, 309).
- Station- 1 (409A)
- Station-2 there are two stations (e.g., Station- 1 (409A) and Station-2
- An update (413) can be created to set the value of the counter 411 to one after the send-ahead lot (e.g., lot-task-1 (403)) has completed testing.
- An update can be created having an action (A 1 ) specifying that "five hours after the lot has been provided, the counter is set to one" and an update time (UT 1 ) associated with the task end time (RT 1 ) of lot-task-1. Therefore, five hours after lot-task-1 (403) has been provided, the value of the counter 411 is set to one.
- Lot-task-2 (405) can then provide a lot to Station- 1 (409A).
- Counter constraint 501 uses two updates for each product- task.
- the first update for each product- task (515 A, 517A) can include an action (A 1 , A n ) to describe how the value of counter- 1 (505A) is updated.
- each update- 1 can include an action describing that the value of the counter- 1 (505A) is incremented by one when a product-task (507,509) produces product A (503).
- each update- 1 (515A, 517A) includes an update time (UT 1 , UT H ) associated with the end time variable (E 1 , E n ) of its corresponding product-task.
- Figure 6 illustrates one embodiment of a method 600 for generating a counter constraint for tracking a value.
- Method 600 can be performed by processing logic that can comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (e.g., instructions run on a processing device), or a combination thereof.
- method 600 is performed by a computer system hosting a counter constraint manager 150 of Figure IB.
- processing logic identifies a plurality of tasks to be performed.
- a task can be a representation of an action related to the manufacture of a product (e.g., semiconductor).
- FIG. 7 illustrates one embodiment of a method 700 for scheduling tasks using a counter.
- Method 700 can be performed by processing logic that can comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (e.g., instructions run on a processing device), or a combination thereof.
- method 700 is performed by a computer system hosting a counter constraint manager 150 in Figure IB.
- processing logic determines whether the counter value meets a threshold in relation to an additional condition (e.g., a specific time is reached, a specific change io a tasj state has occurred, etc.).
- processing logic can determine whether the counter has a value equal to ten after the completion of a use-task. If not, processing logic continues to monitor the counter at block 707. If so, processing logic triggers a scheduling action with respect to a task at block 715. For example, processing logic causes the reticle to be inspected.
- Figure 8 illustrates a diagrammatic representation of a machine in the exemplary form of a computer system 800 within which a set of instructions, for causing the machine to perform any one or more of the methodologies discussed herein, may be executed.
- the machine may be connected (e.g., networked) to other machines in a LAN, an intranet, an extranet, or the Internet.
- the machine may operate in the capacity of a server or a client machine in a client- server network environment, or as a peer machine in a peer-to-peer (or distributed) network environment.
- Processor 801 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, the processor 801 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or a processor implementing other instruction sets or processors implementing a combination of instruction sets. The processor 801 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. The processor 801 is configured to execute the instructions 825 for performing the operations and steps discussed herein. [0075] The computer system 800 may further include a network interface device
- the data storage device 815 may include a computer-readable storage medium 823 on which is stored one or more sets of instructions 825 (e.g., software) embodying any one or more of the methodologies or functions described herein.
- the instructions 825 may also reside, completely or at least partially, within the main memory 803 and/or within the processor 801 during execution thereof by the computer system 800, the main memory 803 and the processor 801 also constituting computer- readable storage media.
- the instructions 825 may further be transmitted or received over a network 817 via the network interface device 821.
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Economics (AREA)
- Human Resources & Organizations (AREA)
- Strategic Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Automation & Control Theory (AREA)
- Manufacturing & Machinery (AREA)
- Game Theory and Decision Science (AREA)
- Educational Administration (AREA)
- Marketing (AREA)
- Operations Research (AREA)
- Tourism & Hospitality (AREA)
- General Business, Economics & Management (AREA)
- Development Economics (AREA)
- Software Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Multi Processors (AREA)
- General Factory Administration (AREA)
Abstract
A method and system for scheduling tasks using a counter constraint. A method may include identifying multiple tasks to be performed, receiving dependency data indicating that scheduling of at least one task is dependent on whether a counter satisfies a threshold in relation to an additional condition, and upon determining, during scheduling, that the counter satisfies the threshold in relation to the additional condition, triggering a scheduling action with respect to at least one task.
Description
COUNTER AND TIMER CONSTRAINTS
RELATED APPLICATIONS
[0001] This application claims the benefit of U.S. Provisional Application No.
61/187,579, filed on June 16, 2009.
TECHNICAL FIELD
[0002] Embodiments of the present invention relate to scheduling generally, and more particularly, to scheduling one or more tasks using a counter constraint. BACKGROUND OF THE INVENTION
[0003] Constraint programming can be used in a wide variety of constraint problems including job shop and flow shop scheduling, where a scheduling problem involves time and/or value restrictions placed in scheduling the tasks. Constraint programming can be used to find a solution which can satisfy all of the constraints. Constraint programming includes a set of search variables, domains that set boundaries for the possible values for each of the variables, and a set of constraints. Typical scheduling problems involve creating two search variables for each task: one variable to represent the equipment that can process a task and another variable to represent the start time for the task. Unfortunately, the typical creation of two search variables provides limited capability for modeling common situations. For example, if an industrial engineer wishes to limit the production of a product during the first twelve hours of a day, the current state of the art does not provide a general constraint to place a restriction when creating a manufacturing schedule. Rather, an industrial engineer has to do it from scratch using basic tools of constraint programming.
[0004] BRIEF DESCRIPTION OF THE DRAWINGS
[0005] The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which:
[0006] Figure IA is a block diagram illustrating a scheduling system utilizing a counter constraint;
[0007] Figure IB is a block diagram of one embodiment of a counter constraint manager;
[0008] Figure 2 is a diagram schematically illustrating an example of a scheduling system using a counter constraint for placing a time and value restriction in scheduling tasks;
[0009] Figure 3A is a diagram schematically illustrating an example of a scheduling system using a counter constraint for scheduling tasks associated with a resource;
[0010] Figure 3B is a diagram schematically illustrating an example of a scheduling system using a timer constraint for scheduling tasks associated with a resource;
[0011] Figure 4 is a diagram schematically illustrating an example of a scheduling system using a counter constraint for placing scheduling restrictions on some tasks and not other tasks;
[0012] Figure 5 is a diagram schematically illustrating an example of a scheduling system using a counter constraint having more than one counter for scheduling tasks;
[0013] Figure 6 illustrates one embodiment of a method for generating a counter constraint for scheduling tasks;
[0014] Figure 7 illustrates one embodiment of a method for scheduling tasks using a counter constraint; and
[0015] Figure 8 illustrates an exemplary computer system executing embodiments of the invention.
DETAILED DESCRIPTION
[0016] Embodiments of the invention are directed to a method and system for scheduling tasks using a counter. A scheduling system identifies multiple tasks to be performed. The scheduling system receives dependency data indicating that scheduling of at least one task is dependent on whether a counter value satisfies a threshold in relation to an additional condition (e.g., a specified time is reached or a specified change in the state of at least one task has occurred). During task operation, the scheduling system periodically determines whether the counter value satisfies the threshold in relation to the additional condition. If so, the scheduling system triggers a scheduling
action (e.g., starting a task, completing a task, pausing a task, resuming a task, etc.) with respect to at least one task.
[0017] Figure IA is a block diagram illustrating a manufacturing system 100 including a scheduling system 105 that utilizes one or more counter constraints 107. Manufacturing system 100 can include a fabrication system data source (e.g., manufacturing execution system (MES) 101), a dispatcher 103, and a scheduling system 105. The MES 101, dispatcher 103, and scheduling system 105 can be individually hosted by any type of computing device including server computers, desktop computers, laptop computers, handheld computers or similar computing device. Alternatively, a combination of MES 101, dispatcher 103, and scheduling system 105 can be hosted on a single computing device including server computers, desktop computers, laptop computers, handheld computers or similar computing device. The scheduling system 105 obtains data reflecting a current state of the factory. For example, the scheduling system 105 can receive data identifying tasks to be performed and possible start times for each task. In one embodiment, the scheduling system 105 is coupled to a factory system data source (e.g., MES 101, Enterprise Resource Planning (ERP) system, etc.) to receive lot and equipment status data. In one embodiment, scheduling system 105 can include a graphical user interface (GUI) generator 111 to create and provide a user interface 109 (e.g., GUI) to a user (e.g., an industrial engineer). User interface 109 can receive data from a user identifying tasks to be performed and data indicating the restrictions to place in a schedule for performing the tasks.
[0018] The scheduling system 105 uses the data to provisionally schedule the times for various tasks to be performed. The scheduling system 105 can create and use constraints, including one or more counter constraints, to place restrictions in scheduling the tasks. In one embodiment, the scheduling system 105 includes a counter constraint manager 107 that uses a new programming constraint referred to as a counter constraint for placing a time and/or value restriction in scheduling tasks. The counter constraint manager 107 can determine the value of a counter periodically and/or at a specific point in time. In one embodiment, the scheduling system 105 provides user interface (e.g., a graphical user interface) to enable a user (e.g., an industrial engineer) to model a provisional schedule utilizing a counter constraint. The provisional schedule and any data related to the provisional schedule are provided to constraint managers, including
the counter constraint manager 107. The constraint managers perform updates based on the provisional schedule. Additional provisional scheduling may be performed and additional updates may be performed until an entire schedule is constructed. The scheduling system 105 can provide the entire schedule to a dispatcher 103. The dispatcher 103 can be integrated through the MES 101 to dispatch, for example, wafer lots accordingly.
[0019] Figure IB illustrates a block diagram of one embodiment of a counter constraint manager 150 executing on an exemplary computing environment. Computing environment can be implemented as a server, client, workstation, desktop, tablet, or any other machine. It can also be implemented in one or more small portable platforms such as a notebook, a PDA (personal digital assistant), or wireless web devices, and other devices. The counter constraint manager 150 can be part of a scheduling system (e.g., scheduling system 105 of Figure IA) and can include a counter constraint creator 152, a counter constraint creation user interface (UI) 154, a counter constraint configuration UI 156, a data store 158, a counter updator 160 and a counter monitor 162. [0020] The counter constraint creator 152 creates one or more counter constraints for tasks to be performed. As will be discussed in more detail below, a counter constraint can be task specific (e.g., constraining a specific ask), general (e.g., constraining all tasks), or a combination of both (e.g., constraining all tasks in one way and constraining a specific task(s) in a different way). A counter constraint is based on a counter and can be created using an initial value of the counter, a set of updates for the counter and a set of restrictions imposed on the counter. An update can be associated with an action that describes how the counter should be updated and the time of the update. A task may be tied to one or more updates (e.g., via the task's start or end time), or it may not be tied to any updates. A restriction provides limitations to be imposed on the counter. A restriction can be a general restriction that imposes a threshold limitation on the counter for all the tasks, or a task specific restriction that imposes a threshold limitation on the counter for a specific task. A task specific condition can be tied to a task via, for example, the task's start or end time). Each task may be associated with one or more restrictions.
[0021] A counter constraint creation UI 154 can receive data defining tasks to be performed and data defining a plurality of variables for each task and a domain for each
variable. Task variables may include task state variables (e.g., task start, task end, task pause, task resume, etc.), task equipment variables, etc. A domain for a variable defines allowed values for that variable. The counter constraint creation UI 154 can also receive the initial value of the counter, a set of updates and a set of restrictions. For each update, one or more update parameters may be defined, including for example an update action and an update time. Restriction parameters may include, for example, a restriction value and a restriction time.
[0022] In one embodiment, the counter constraint creator 152 includes a programming tool (not shown) to define counter constraint logic using task variables, domains, updates and constraints. Examples of a programming tool may include tools for programming in Java, C++, Perl and Python. The resulting code can be converted into operable information (e.g., executable file) using a compiler, and stored in the data store 158, which may be hosted by a main memory (not shown) or other data storage device (not shown).
[0023] Prior to starting the tasks execution process, a user may configure the counter constraint using the counter constrain configuration UI 156. In particular, the user can provide update data and restriction (or dependency) data. The update data can specify an action for updating the counter (e.g., increment, decrement, set to a value, etc.), and an event that should cause an update (e.g., completion of a task, reaching a certain time, etc.). The restriction data can specify the threshold to which the counter value should be compared and when the comparison should be performed (e.g., when a specific change in the state of a task occurs or a specific time is reached). The above data may be stored in the data store 158 or some other store.
[0024] During the tasks execution process, the counter updator 160 monitors various events and determines whether the counter needs to be updated. If so, the counter updator 160 updates the counter according to the update data. The counter monitor 162 periodically determines whether the counter has reached a threshold in relation to an additional condition (e.g., at a specified time or at a specified state of a task). If so, the counter monitor triggers a scheduling action associated with a task (e.g., starting a task, ending a task, pausing a task, resuming a task, etc.). [0025] Accordingly, the use of counter constrains provide significant flexibility for scheduling tasks. Not only can a task be scheduled to start when a counter is below a
specific number, but a task can be scheduled to start when the counter is below a specific number and a condition with respect to another task is satisfied (e.g., another task is completed), or the counter is below a specific number at a specified time, or the counter is below a specific number in relation to some other additional condition. [0026] Figure 2 schematically illustrates an example of a scheduling system 200 using a counter constraint 201 for placing a time and value restriction in scheduling tasks. A task can be a task used in the manufacturing of semiconductors. Examples of tasks include a task to manufacture product A, a task to use a reticle, a task to inspect a reticle, a task to process a lot of wafers, etc. An example of a counter constraint used to schedule tasks on a reticle and to inspect the reticle is described in greater detail below in conjunction with Figure 3A. An example of a counter constraint used to schedule tasks to process one or more lots of wafers is described in greater detail below in conjunction with Figure 4.
[0027] Scheduling system 200 uses a counter constraint 201 for scheduling tasks which produce product A (203). The tasks to produce product A (203) are represented by product- task- 1 (205), and product-task- 2 (207) through product-task-w (209). [0028] Scheduling system 200 is an illustration of placing a general restriction in scheduling tasks. For example, a user (e.g., an industrial engineer) may want no more than 52 of product A (203) to be produced by three o'clock in the afternoon. Counter constraint 201 can model a scenario where at three o'clock in the afternoon, the counter 211 must have a value of less than or equal to 52. In one embodiment, scheduling system 200 provides a graphical user interface enabling a user (e.g., an industrial engineer) to model a scheduling scenario using a counter constraint. In addition, scheduling system 200 can use counter constraint 201 to implement task-specific restrictions which are restrictions associated with a search variable of a task. Using the example above, where no more than 52 of product A (203) may be produced by three o'clock in the afternoon, specific restrictions can be created such that a task that produces product A cannot be performed unless the value of the counter 211 is less than 52. If the counter 211 has a value of greater than or equal to 52, none of the tasks to produce product A will be performed and the search variables' domains are updated to reflect this. [0029] In scheduling system 200, constraint programming search variables are defined for each task (e.g., product-task-1, 2, ή). Each product-task (205, 207, 209) has a
start time variable (S1, S2, Sn) that represents the start time for the task to produce product A (203) and an end time variable (E1, E2, En) that represents the end time for the task to produce product A (203). Each search variable (e.g., S1, S2, Sn, E1, E2, En) has a domain (not shown). A domain assigns a set of possible values to a variable. In this way, the values within a domain can become constraints in and of themselves. Domains can be expressed as discrete independent ranges for variables or as expressions which include more than one value.
[0030] A counter constraint 201 can be built using a counter 211, a set of updates
(213, 215, 217) and a set of restrictions (219, 221, 223, 225). A counter 211 can have a value which can be an integer value. An update (213, 215, 217) affects the value of the counter 211. For example, an update can set the value of the counter to zero, increment the value of the counter by ten, or decrement the value of the counter by an amount (e.g., an integer value). A restriction (219, 221, 223, 225) places a restriction on the scheduling of tasks (e.g., product-task-1, 2 to n) using the counter 211 value. A restriction can be used to place a general restriction in scheduling tasks (e.g., no more than 52 of product A (203) can be produced by three o'clock in the afternoon) and a specific restriction in scheduling a particular task (e.g., a task to produce product A cannot start unless the counter has a value of less than 52).
[0031] The counter 211 can have an initial value of zero. In one embodiment, the set of updates (213, 215, 217) includes an update for each product-task (205, 207, 209). In another embodiment, described in greater detail below in conjunction with Figure 3B, each task does not include an update. Returning to Figure 2, each update (215, 217, 219) can include an action (A1, A2, An) to describe how the value of the counter 211 is updated. For example, an update can include an action describing that the value of the counter 211 is incremented by one when a product- task (205, 207, 209) produces product A (203). Each update (213, 215, 217) can also include an update time (UT1, UT2, UTn) associated with the end time variable (E1, E2, En) of its corresponding product-task to reflect that the counter 211 should be updated when a task 205, 207 or 209 ends. [0032] The set of restrictions (219, 221, 223, 225) includes a general restriction
225 and a restriction (219, 221, 223) for each product-task (205, 207, 209). The general restriction 225 represents the scheduling restriction that at three o'clock in the afternoon the counter 211 must have a value of less than or equal to 52. The restriction (219, 221,
223) for each product-task (205, 207, 209) represents that each task to produce product A cannot be performed unless the counter 211 has a value of less than 52. A restriction can include a restriction time (RT1, RT2, RTW, RTG), relational operator (R1, R2, Rn, RG) (e.g., greater than, less than, equal to, etc.), and a restriction value (V1, V2, Vn, VG1, VG2) to describe a restriction imposed on the counter 211.
[0033] The general restriction 225 can include a restriction time (RTG) which is associated to a clock 227, a restriction value (VGO representing, for example, three o'clock in the afternoon (e.g., 54,000 seconds), a relational operator (RG) of, for example, "less than or equal to," and a restriction value (VG2) of, for example, "52," such that the value of the counter 211 must have a value of less than or equal to, for example, 52 at 3 o'clock in the afternoon. The restriction (219, 221, 223) for each product-task (205, 207, 209) can include a restriction time (RT1, RT2, RTW) which is associated to the start time variable (S1, S2, Sn) of the corresponding product-task (205, 207, 209) to reflect the dependency between a task start and the counter value. Each restriction for each product- task can also include a relational operator (R1, R2, Rn) of, for example, "less than" and a restriction value (V1, V2, Vn) of, for example, "52," such that each product- task (205, 207, 209) cannot start to produce product A (203) unless the counter 211 has a value of less than 52.
[0034] Figure 3A schematically illustrates an example of a scheduling system
300 using a counter constraint 301 for scheduling tasks associated with a resource 329, according to one embodiment of the invention. A resource can be a resource used in the manufacturing of semiconductors. Semiconductor manufacturing entails the formation of various patterns on wafers and an example of a resource 329 is a reticle, which contains a pattern image for printing directly onto wafers or for printing onto masks that transfer the images onto wafers. A user (e.g., an industrial engineer) may want the reticle to be inspected after the reticle has been used ten times. A task that uses the resource 329 can be represented as a use-task (305, 307, 309) and a task that inspects the resource 329 can be represented as an inspection-task 311.
[0035] A counter constraint 301 can model a scenario where an inspection-task
311 can only be performed if the counter 303 has a value that is greater than ten. Likewise, a counter constraint 301 can model the scenario where a use-task (305, 307, 309) can only start if the counter 303 has a value that is less than ten. The industrial
engineer may further want additional use-tasks (e.g., use-task-w 309) to resume using the reticle tool 329 after the inspection of the tool is completed. The counter constraint 301 can model a scenario where the value of the counter 303 is reset to zero after the inspection task 311 is completed and thus, a use-task (e.g., use-task-w 309) can start since the counter value is less than ten.
[0036] The counter constraint 301 can be built using a counter 303, a set of updates (313, 315, 317, 319), and a set of restrictions (321, 323, 325, 327). The counter 303 can have an initial value of zero. Each use-task (305, 307, 309) has a start time variable (S1, S2, Sn) that represents the start time for the task using the resource. In one embodiment, there is an update (313, 315, 317) for each use-task. In another embodiment, described in greater detail below in conjunction with Figure 3B, each use- task does not include an update. In scheduling system 300, each update can include an action (A1, A2, An) to describe that the value of the counter 303 is incremented by one each time a use-task (305, 307, 309) uses the resource 329. Update (313, 315, 317) for each use-task can also include an update time (UT1, UT2, UTn) to be associated with the start time (S1, S2, Sn) variable of its corresponding use-task.
[0037] The set of restrictions (321, 323, 325, 327) includes a restriction for each task (e.g., the inspection-task 311 and each use-task 305,307,309). The restriction (321, 323, 325) for each use-task can include a relational operator (R1, R2, Rn) (e.g., "less than") and a restriction value (V1, V2, Yn) (e.g., "10"), such that each use-task (305, 307, 309) cannot start to use the reticle 329 unless the counter 303 has a value of less than ten. Restriction for each use-task can also include a restriction time (RT1, RT2, RTn) which is associated to the start time variable (S1, S2, Sn) of the corresponding use-task (305, 307, 309).
[0038] The inspection-task 311 has a start time variable (SIN) that represents the start time of the inspection of the resource 329 and an end-time variable (EN1N) that represents the end time of the inspection of the resource. The restriction 327 for the inspection-task 311 can include a relational operator (R1N) of "equal to" and a value (V IN) of "10," such that the inspection-task 311 does not start to use the reticle 329 unless the counter 303 has a value equal to ten. As such, the restriction 327 for the inspection-task can also include a restriction time (RT1N) which is associated to the start time variable (SIN) of the inspection-task 311. Where a user (e.g., an industrial engineer) further wants
tasks (e.g., use-task-w) to resume using the reticle tool after the inspection completes, the counter constraint 301 can include an update 319 for the inspection-task to reset the value of the counter 303 to zero after the inspection task is completed. The update 319 can include an action (AIN) describing that the value of the counter 303 is set to zero and an update time (UTIN) associated with the end time (ENIN) of the inspection-task 311. [0039] Figure 3B schematically illustrates an example of a scheduling system
350 using a timer constraint 351 for scheduling tasks associated with a resource 373, according to one embodiment of the invention. In this example, a task is scheduled based on time, rather than a number of uses of the resource. For example, an industrial engineer may want a reticle tool to be inspected after the reticle has been used for 24 hours. In this case, a timer constraint 351 can model a scenario where an inspection-task 363 can only be performed if the value of a counter 353 is greater than 24 hours. In one embodiment, the value of the counter 353 is expressed in seconds. Likewise, a timer constraint 351 models the scenario where a use-task (355, 357, 359) can only start if the value of the counter 353 is less than 24 hours.
[0040] The counter 353 can have an initial value of zero. There is a restriction for each task (e.g., the inspection-task 363 and each use-task 355, 357, 359). The restriction (365, 367, 369) for each use-task can include a relational operator (R1, R2, Rn) of "less than" and a restriction value (V1, V2, Vn) of "86,400" seconds, such that each use-task (355, 357, 359) does not start to use the reticle 373 unless the counter 353 has a value of less than 86,400. As such, each restriction (365, 367, 369) for each use-task can also include a restriction time (RTi, RT2, RTW) which is associated to the start time variable (S1, S2, Sn) of the corresponding use-task (265, 267, 269). The restriction 371 for the inspection-task 363 can include a relational operator (RIN) of "equal to" and a restriction value (VIN) of "86,400" seconds, such that the inspection-task 363 does not start to use the reticle 373 unless the counter 353 has a value equal to 84,600. As such, the restriction 371 for the inspection-task can also include a restriction time (RTIN) which is associated to the start time variable (Sm) of the inspection-task 363. [0041] With every second that passes by on clock 375, the value of the counter
353 is incremented by one second. Therefore, in this embodiment, each use-task (355, 357, 359) does not include an update to update the counter 353. An update, however, can be included for an inspection-task 363 to reset the value of the counter 353 after the
inspection of the reticle is completed. For example, where a user (e.g., an industrial engineer) further wants tasks (e.g., use-task-w) to resume using the reticle tool after the inspection completes, the timer constraint 351 can include an update 363 for the inspection-task to reset the value of the counter 353 to zero after the inspection task is completed. The update 363 can include an action (AIN) describing that the value of the counter 353 is set to zero and an update time (UT1N) associated with the end time (ENπsr) of the inspection-task 363.
[0042] Figure 4 schematically illustrates an example of a scheduling system 400 using a counter constraint 401 for placing scheduling restrictions on some tasks and not other tasks, according to one embodiment of the invention. For example, a user (e.g., an industrial engineer) can schedule one or more lots of wafers to be processed on a station that requires a send- ahead lot and other lots of wafers to be processed on a station that does not require a send-ahead lot. A 'station' can refer to manufacturing equipment, a manufacturing tool, a component of manufacturing equipment, or a component of a manufacturing tool. Semiconductor manufacturing, at times, includes testing lots to determine whether a station will process the lot correctly. For some stations, therefore, a lot is first processed on the station and then the lot is tested after it has been processed. A test lot can be referred to as "send-ahead" lot. Other lots, however, cannot be processed on that particular station requiring a send-ahead lot until the testing of the send-ahead lot is completed.
[0043] For example, there are two stations (e.g., Station- 1 (409A) and Station-2
(409B)) that can process a number of lots. Station- 1 (409A) requires a send-ahead lot to ensure that Station- 1 (409A) will process each lot correctly. Station-2 (409B) does not require a send-ahead lot. A first lot is processed on Station- 1 (409A) as a send-ahead lot and other lots to be processed on Station- 1 (409A) cannot start until the testing of the send-ahead lot is complete. Whereas, lots processed on Station-2 (409B) can be processed without having to wait for a send-ahead lot since a send-ahead lot is not required on Station-2 (409B). A counter constraint 401 can model such a scenario using a counter 411 to track the completion of the testing for the send- ahead lot. For example, lots cannot be processed on Station- 1 (409A) unless the value of the counter 411 is greater than or equal to one. The counter 411 can have an initial value of zero. After the
testing of the send-ahead lot is complete, the counter 411 can be set to one, whereby other lots can be processed on Station- 1 (409A).
[0044] A task can provide one lot to be processed on a station and be referred to as a lot-task (e.g., lot-task- 1 (403), and lot-task-2 (405) through lot-task-n (407)). The lot-tasks (403, 405, 407) will provide a lot to either Station- 1 (409A) or Station-2 (409B). Each lot-task can have a start time (S1, S2, Sn) variable to represent the process start time of the lot, an end time (E1, E2, En) variable to represent the process end time of the lot, and an equipment variable (EQ1, EQ2, EQW) to represent which station the lot will be processed on. In one embodiment, search variables are assigned Boolean values. For example, where lot-task- 1 (403) and lot-task-2 (405) will be processed on Station- 1 (409A), the equipment variables (EQ1, EQ2) for lot-task- 1 (403) and lot-task-2 (405) can be assigned a TRUE value to indicate that lot-task- 1 (403) and lot-task-2 (405) will be processed on the station requiring a send-ahead lot (Station- 1). Likewise, where lot-task- n (407) will be processed on Station-2 (409B), the equipment variable (EQn) for lot-task- n (407) can be assigned a FALSE value to indicate that lot-task-w (407) will be processed on the station that does not require a send- ahead lot (Station-2).
[0045] If lot-task- 1 (403) is designated to provide the send-ahead lot, a restriction can be created for lot-task-2 (405) through lot-task-n (407) to ensure that any lot to be performed on the station that requires the send-ahead lot is not provided to this station until the send- ahead lot has completed testing. A restriction (421, 423) can be created for each task (405,407), attaching the restriction time (RT2, RTn) to the start time variable (S2, Sn) of the corresponding task, such that a lot cannot be provided by tasks (405, 407) unless the counter 411 has a value of greater than or equal to one. Each restriction can include a relational operator (R2, Rn) of "greater than or equal to" and a restriction value (V2, Vn) of "1." If llot-task-w (407) will provide a lot for Station-2 (409B), and the restriction (423) for lot-task-w (407) will not apply to lot-task-w (407) because a condition (C1E») is not met.
[0046] Counter constraint 401 can include conditions which define the circumstances of when to apply an update or restriction. One or more conditions can be specified in a restriction in order to turn the restriction "on" or "off." In this example, each restriction can have a condition to turn a restriction "on" (to apply the restriction to a task). The condition (CIE2, C1E») can specify that the equipment variable ( EQ2, EQW)
of a task must have a TRUE value to turn the restriction "on." As described above, the equipment variable (EQ«) for lot-task-w (407) is assigned a FALSE value to indicate that lot-task-w (407) will provide a lot to a station that does not require a send-ahead lot (Station-2). Therefore, in this example, the restriction (423) for lot-task-w (407) is not turned "on" and will not apply to lot-task-w because the condition (C1E») for lot-task-w is not met. Lot-task-w (407), therefore, can be processed on Station-2 (409B) without regard to the value of the counter 411.
[0047] The equipment variable (EQ2) for lot-task-2 (405), however, has a TRUE value since lot-task-2 will be processed on the station requiring a send-ahead lot (Station- 1). The restriction (421) for lot-task-2, therefore, meets the condition (CIE2)- Thus, lot- task-2 (405) cannot start processing on Station- 1 (409A) unless the counter 411 has a value of greater than or equal to one. In this example, lot-task- 1 (403) is the send-ahead lot and does not have a restriction since lot-task 1 (403) will provide a lot to Station- 1 (409A) regardless of the value of the counter 411.
[0048] The counter 411 can have an initial value of zero and therefore, lot-task-2
(405) cannot yet start. An update (413) can be created to set the value of the counter 411 to one after the send-ahead lot (e.g., lot-task-1 (403)) has completed testing. An update can be created having an action (A1) specifying that "five hours after the lot has been provided, the counter is set to one" and an update time (UT1) associated with the task end time (RT1) of lot-task-1. Therefore, five hours after lot-task-1 (403) has been provided, the value of the counter 411 is set to one. Lot-task-2 (405) can then provide a lot to Station- 1 (409A).
[0049] Figure 5 schematically illustrates an example of a scheduling system 500 using a counter constraint 501 having more than one counter for scheduling tasks, according to one embodiment of the invention. For example, a user may want no more than a quantity of 50 of product A (503) to be manufactured in the first 12 hours of a day (e.g., midnight to noon) and no more than a quantity of 75 of product A (503) to be manufactured in the second 12 hours of the day (e.g., noon to midnight). There are two counters (505A, B). Counter- 1 (505A) can track a value corresponding to the first 12 hours of a day (e.g., midnight to noon). Counter-2 (505B) can track a value corresponding to the last 12 hours of a day (e.g., noon to midnight). A counter constraint 501 can model a scenario where a product-task (507, 509) to produce product A can start
in the first 12 hours of the day if the value of counter- 1 (505A) is less than 50. The counter constraint 501 can also model a scenario where a product-task (507, 509) to produce product A can start in the second 12 hours of the day if the value of counter- 1 (505B) is less than 75.
[0050] A counter (505A, B) can have an initial value of zero. There can be more than one restriction for each task. Counter constraint 501 uses two restrictions for each product-task. The first restriction (51 IA, 513A) places a restriction on the start time (S1, Sn) of a product- task if the start time of the product- task is planned for the first 12 hours of a day (e.g., midnight to noon). The second restriction (51 IB, 513B) places a restriction on the start time (S1, Sn) of a product-task if the start time of the product- task is planned for the last 12 hours of a day (e.g., noon to midnight). Each restriction for each product-task can include a restriction time (RT1, RTW) which is associated to the start time variable (S1, Sn) of the corresponding product-task (507, 509). The first restriction (51 IA, 513A) for each product-task is associated with counter-1 (505A) and can include a relational operator (R1, Rn) of "less than" and a restriction value (V1, Yn) of "50," such that each product-task (507, 509) does not start to produce product A (503) unless counter-1 (505A) has a value of less than 50. A condition (CIR1, C1RW) can be specified for each restriction- 1 (51 IA, 513A) to turn the restriction-1 "on" if the start time of the corresponding product-task falls in the first 12 hours of a day (e.g., midnight to noon). Therefore, if product- task- 1 (507) has a planned start time (S1) of ten o'clock in the morning, the restriction-1 (51 IA) will require that counter-1 (505A) have a value that is less than 50 before product- task- 1 can start to produce product A. However, if product- task- 1 (507) has a planned start time (S1) of four o'clock in the afternoon, the restriction- 1 (51 IA) will not be turned on.
[0051] The second restriction (51 IB, 513B) for each product-task can be associated with counter-2 (505B) and can include a relational operator (R1, Rn) of "less than" and a restriction value (V1, Yn) of "75," such that each product-task (507, 509) does not start to produce product A (503) unless counter-2 (505B) has a value of less than 75. A condition (CIR1, C1RW) can be specified for each restriction-2 (5 HB, 513B) to turn the restriction-2 "on" if the start time of the corresponding product-task falls in the last 12 hours of a day (e.g., noon to midnight). Therefore, if product- task- 1 (507) has a planned start time (S1) of seven o'clock in the evening, the restriction-2 (51 IA) will be
turned on and require that counter-2 (505A) have a value that is less than 75 before product- task- 1 can start to produce product A. However, if product-task- 1 (507) has a planned start time (S1) of eleven o'clock in the morning, the restriction-2 (51 IA) will not be turned on.
[0052] There can be more than one update for each task. Counter constraint 501 uses two updates for each product- task. The first update for each product- task (515 A, 517A) can include an action (A1, An) to describe how the value of counter- 1 (505A) is updated. For example, each update- 1 can include an action describing that the value of the counter- 1 (505A) is incremented by one when a product-task (507,509) produces product A (503). As such, each update- 1 (515A, 517A) includes an update time (UT1, UTH) associated with the end time variable (E1, En) of its corresponding product-task. A condition (Clui, Clu») can be specified for each update-1 (515A, 517A) to turn the update- 1 "on" if the start time of the corresponding product-task falls in the first 12 hours of a day (e.g., midnight to noon). Therefore, if product- task- 1 (507) has a planned start time (S1) of seven o'clock in the morning, the update-1 (51 IA) can increment counter- 1 (505A) by one when product- task- 1 has finished its production of product A. [0053] The second update for each product-task (515B, 517B) can include an action (A1, An) describing that the value of the counter-2 (505B) is incremented by one when a product-task (507,509) produces product A (503). As such, each update-2 (515B, 517B) includes an update time (UT1, UTW) associated with the end time variable (E1, En) of its corresponding product-task. A condition (Clui, Clu») can be specified for each update-2 (515B, 517B) to turn the update-2 "on" if the start time of the corresponding product-task falls in the last 12 hours of a day (e.g., noon to midnight). Therefore, if product- task- 1 (507) has a planned start time (S1) of nine o'clock in the evening, the update-2 (511B) can increment counter-2 (505B) by one when product- task- 1 has finished its production of product A.
[0054] Figure 6 illustrates one embodiment of a method 600 for generating a counter constraint for tracking a value. Method 600 can be performed by processing logic that can comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (e.g., instructions run on a processing device), or a combination thereof. In one embodiment, method 600 is performed by a computer system hosting a counter constraint manager 150 of Figure IB.
[0055] At block 602, processing logic identifies a plurality of tasks to be performed. A task can be a representation of an action related to the manufacture of a product (e.g., semiconductor). Examples of tasks include a task to represent the use of a resource (e.g., the use of a reticle), a task to represent the inspection of a resource (e.g., inspection of a reticle), a task to represent a lot being processed on a station, a task to represent a particular type of product being manufactured, etc. In one embodiment, the tasks are identified by receiving input from a user (e.g., an industrial engineer) via a user interface (e.g., GUI).
[0056] At block 604, processing logic creates one or more variables for each task. Examples of variables include a start time variable, end time variable, send-ahead variable and equipment variable. The start time variable can represent the start time of a task and the end-time variable can represent the end time of a task. A send-ahead variable can represent whether a task representing a lot to be processed is a send-ahead lot. Variables can be assigned Boolean values. For example, if a task represents a send- ahead lot, the send-ahead variable can have a true value. An equipment variable can represent the station capable of performing a task. A domain is created for each variable. A domain sets boundaries for the possible values for each of the variables. [0057] At block 606, processing logic creates one or more counters. A counter can be used as a mechanism to track a value. A counter can represent a quantity (e.g., a number of times a resource has been used, the number of products that have been manufactured, etc.). A counter can have an integer value. Alternatively, a counter can represent time (e.g., time in seconds). A counter can be used as a mechanism to trigger a scheduling action with respect to a task (e.g., a lot cannot be provided to a station requiring a send-ahead lot unless the counter has a value greater than or equal to one). At block 606, the counter is set to an initial value (e.g., zero).
[0058] At block 608, processing logic creates an update for one or more tasks.
An update affects the value of a counter. An update is created using an action and an update time. In one embodiment, computing environment receives user input (e.g., via a GUI) to create an action and an update time. An action describes how the counter value is updated. For example, an action can set the value of the counter to zero, increment the value of the counter by an amount (e.g., an integer value, for example, 10), and decrement the value of the counter by an amount (e.g., 10). An update time represents
when the action to update the counter takes place. An update time can be "tied" to another variable. For example, an update time can be tied to a start time variable of a task (e.g., start time of a use-task), such that the action is not performed on the counter until the start time of the task (e.g., increment the counter value by 1 when a task begins to use a reticle). In another example, an update is tied to an end-time of a task (e.g., end-time of the inspection task), such that the action is not performed on the counter until the end- time of the task (e.g., reset the counter to zero after the reticle has been inspected). In another embodiment, an update time is not tied to another variable, but can be a time specified by a user via a GUI. For example, an industrial engineer can specify that the counter value is set (reset) to zero at midnight.
[0059] There can be an update for each task. For example, there can be an update for an inspection task to reset the counter value to zero after the reticle has been inspected and an update for each use-task to increment the counter value by one when a task uses the reticle. In another embodiment, however, an update may not be created for each task. For example, a task can be defined to inspect a reticle every 24 hours, rather than based on the number of times the reticle has been used. A counter can be used as a timer where the counter value is based on time. The counter can have an initial value of zero, where with every second that passes, the counter value can be incremented by one second. In this example, each use-task does not have an update to increment the counter by one since the counter is being incremented based on time. There is an update only for the inspection-task to reset the counter after the reticle has been inspected. [0060] An update can also have zero or more conditions. At block 608, processing logic can specify conditions for an update to define when to turn an update "on." In the previous example, where a lot can be provided to a station requiring a send- ahead lot or a station that does not require a send-ahead lot, an update was created for each task. A condition was specified to turn the update "on" if the task provided a send- ahead lot such that the counter would be updated (e.g., set the counter to one) five hours after the send-ahead lot was provided. In this example, the update was not turned "on" for any task that did not provide the send-ahead lot.
[0061] At block 610, processing logic creates a restriction for one or more tasks.
A restriction places a dependency on the scheduling of tasks using the counter value. A restriction can be a general restriction (e.g., at three o'clock in the afternoon the counter
must have a value of less than 52). A restriction can also be task-specific (e.g., an inspection-task can only be performed if the counter value is greater than 10). A restriction is created using a relational operator, value and a restriction time. In one embodiment, computing environment receives user input (e.g., via a GUI) to create a relational operator, value and restriction time. A restriction places a restriction in scheduling tasks by using a counter value, relational operator and restriction value. Examples of relational operations include greater than, less than, equal to, greater than or equal to, less than or equal to, etc. A restriction value can represent a quantity and be expressed as an integer value. A restriction value can represent time and be expressed in seconds.
[0062] A restriction time represents when the restriction is applied. A restriction time can be "tied" to another variable. For example, a restriction time can be tied to a start time variable of a task (e.g., start time of a use-task), such that the restriction is applied at the start-time of the task (e.g., the task cannot start to use the reticle unless the counter is less than 10). This example has a relational operator of "less than," a restriction value "10," and restriction time "tied" to the start time variable of the use-task. In another embodiment, a restriction time is not tied to another variable, but can be a time specified by a user (e.g., via a GUI). For example, an industrial engineer can specify that at three o'clock in the afternoon, the counter must have a value less than 52. [0063] A restriction can also have zero or more conditions. At block 610, processing logic can specify one or more conditions to define when to turn a restriction "on." In the previous example, where a lot can be processed on a station requiring a send-ahead lot or on a station that does not require a send-ahead lot, an update was created for each task. A condition was specified to turn a restriction "on" if the task provided a lot to be processed on a station requiring a send-ahead lot. If the task did provide a lot to be processed on the station requiring a send- ahead lot, the restriction would be turned "on" such that the task could not start unless the counter had a value of greater than or equal to one. In this example, the restriction was not turned "on" for any task that provided a lot to be processed on a station that did not require a send-ahead lot. [0064] In some embodiments, processing logic specifies that domain variables should be updated to ensure that the constraint is satisfied. For example, the constraint may require that none of the tasks producing a product be performed if the counter has a
value of greater than or equal to x (e.g., '52' as discussed above in conjunction with Figure 2), and the search variables' domains of the tasks should be updated to reflect this.
[0065] At block 612, processing logic creates a counter constraint using the counter, updates and restrictions. At block 614, processing logic defines logic using the plurality of variables, domains, counter, updates, restrictions and counter constraint. At block 616, processing logic creates an executable based on the logic. [0066] Figure 7 illustrates one embodiment of a method 700 for scheduling tasks using a counter. Method 700 can be performed by processing logic that can comprise hardware (e.g., circuitry, dedicated logic, programmable logic, microcode, etc.), software (e.g., instructions run on a processing device), or a combination thereof. In one embodiment, method 700 is performed by a computer system hosting a counter constraint manager 150 in Figure IB.
[0067] In one embodiment, a counter constraint has been built using a representation for one or more tasks (e.g., product-task- 1, inspection-task, use-task- 1, lot-task- 1, etc.), variables and domains for each task, a counter, a set of updates, a set of restrictions and conditions. At block 701, processing logic identifies one or more tasks to be performed. Examples of tasks include the use of a resource (e.g., the use of a reticle), the inspection of a resource (e.g., inspection of a reticle), a lot being processed on a station, a particular type of product being manufactured. In one embodiment, the tasks are identified by receiving input from a user (e.g., an industrial engineer) via a GUI. [0068] At block 703, processing logic receives dependency data indicating that scheduling of a task is dependent on whether the counter meets a threshold in relation to an addition condition (e.g., at a specific state of a task, at a specified time, etc.). For example, processing logic can receive data from a user who schedules the manufacture of a semiconductor product, indicating that the reticle tool must be inspected after the reticle has been used for 24 hours before the reticle tool can further be used in the manufacturing of the semiconductor product. In this example, the start time of the inspection task is dependent on a counter having a value of greater than or equal to 24 hours in relation to the reticle tool. In another example, for a task of inspecting a reticle after the reticle has been used 10 times, the start time of the inspection task is dependent on a counter value equal to 10, and for a task that uses the reticle, the start time of the
task is dependent on the counter having a value of less than 10. In one embodiment, processing logic generates and displays a GUI to receive the dependency data from a user (e.g., an industrial engineer). In one embodiment, processing logic stores the dependency data in a data store.
[0069] At block 705, processing logic receives update data indicating when and how to update the value of the counter. The update data can indicate a value. For example, the update data can specify to set the value of the counter to zero, increment the value of the counter by an integer value (e.g., one), and decrement the value of the counter by ten. The update data can also indicate an event that should cause an update of the value of the counter. For example, for a schedule requiring a reticle tool to be inspected after the reticle has been used 10 times, the update data can indicate that the counter is updated (e.g., incremented by one) after each use of the reticle. In one embodiment, the update data is received from a user (e.g., an industrial engineer) via a GUI. In one embodiment, processing logic stores the update data in a data store. [0070] At block 707, processing logic initiates execution of tasks and begins monitoring update events and the value of the counter. At block 709, processing logic makes a determination as to whether to update the value of the counter based on the received data (whether a counter update event is detected) (block 709). The counter can have an initial value (e.g., zero). Using the example above, processing logic can increment the counter by one after each use of the reticle. If processing logic determines to not update the counter (block 709), processing logic returns to block 707, otherwise the counter is updated at block 711.
[0071] At block 713, processing logic determines whether the counter value meets a threshold in relation to an additional condition (e.g., a specific time is reached, a specific change io a tasj state has occurred, etc.). In the above example, where the reticle is inspected after the reticle has been used ten times, processing logic can determine whether the counter has a value equal to ten after the completion of a use-task. If not, processing logic continues to monitor the counter at block 707. If so, processing logic triggers a scheduling action with respect to a task at block 715. For example, processing logic causes the reticle to be inspected.
[0072] Figure 8 illustrates a diagrammatic representation of a machine in the exemplary form of a computer system 800 within which a set of instructions, for causing
the machine to perform any one or more of the methodologies discussed herein, may be executed. In alternative embodiments, the machine may be connected (e.g., networked) to other machines in a LAN, an intranet, an extranet, or the Internet. The machine may operate in the capacity of a server or a client machine in a client- server network environment, or as a peer machine in a peer-to-peer (or distributed) network environment. The machine may be a personal computer (PC), a tablet PC, a set-top box (STB), a Personal Digital Assistant (PDA), a cellular telephone, a web appliance, a server, a network router, switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. Further, while only a single machine is illustrated, the term "machine" shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.
[0073] The exemplary computer system 800 includes a processing device
(processor) 801, a main memory 803 (e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM) or Rambus DRAM (RDRAM), etc.), a static memory 805 (e.g., flash memory, static random access memory (SRAM), etc.), and a data storage device 815 (e.g., drive unit), which communicate with each other via a bus 807.
[0074] Processor 801 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, the processor 801 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or a processor implementing other instruction sets or processors implementing a combination of instruction sets. The processor 801 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. The processor 801 is configured to execute the instructions 825 for performing the operations and steps discussed herein. [0075] The computer system 800 may further include a network interface device
821. The computer system 800 also may include a video display unit 809 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)), an alphanumeric input device 811
(e.g., a keyboard), a cursor control device 813 (e.g., a mouse), and a signal generation device 819 (e.g., a speaker).
[0076] The data storage device 815 may include a computer-readable storage medium 823 on which is stored one or more sets of instructions 825 (e.g., software) embodying any one or more of the methodologies or functions described herein. The instructions 825 may also reside, completely or at least partially, within the main memory 803 and/or within the processor 801 during execution thereof by the computer system 800, the main memory 803 and the processor 801 also constituting computer- readable storage media. The instructions 825 may further be transmitted or received over a network 817 via the network interface device 821.
[0077] The computer-readable storage medium 823 may also be used to store data structure sets that define user identifying states and user preferences that define user profiles. Data structure sets and user profiles may also be stored in other sections of computer system 800, such as static memory 805.
[0078] While the computer-readable storage medium 823 is shown in an exemplary embodiment to be a single medium, the term "computer-readable storage medium" should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term "computer-readable storage medium" shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies for embodiments of the present invention. The term "computer-readable storage medium" shall accordingly be taken to include, but not be limited to, solid-state memories and optical and magnetic media.
[0079] Some portions of the detailed description above are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored,
transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. [0080] It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as "identifying", "receiving," "monitoring," "causing", or the like, refer to the actions and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (e.g., electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
[0081] Embodiments of the invention also relates to an apparatus for performing the operations herein. This apparatus can be specially constructed for the required purposes, or it can comprise a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program can be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
[0082] The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general purpose systems can be used with programs in accordance with the teachings herein, or it may prove convenient to construct a more specialized apparatus to perform the method steps. The structure for a variety of these systems will appear from the description below. In addition, embodiments of the present invention are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages can be used to implement the teachings of embodiments of the invention as described herein.
[0083] A machine-readable storage medium can include any mechanism for storing information in a form readable by a machine (e.g., a computer), but is not limited to, floppy diskettes, optical disks, Compact Disc, Read-Only Memory (CD-ROMs), and magneto-optical disks, Read-Only Memory (ROMs), Random Access Memory (RAM), Erasable Programmable Read-Only memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM), magnetic or optical cards, flash memory, or the like.
[0084] It is to be understood that the above description is intended to be illustrative, and not restrictive. Many other embodiments will be apparent to those of skill in the art upon reading and understanding the above description.
Claims
1. A computer-implemented method comprising: identifying, by a computer system, a plurality of tasks to be performed; receiving, by the computer system, dependency data indicating that scheduling of at least one of the plurality of tasks is dependent on whether a counter satisfies a threshold in relation to an additional condition; and upon determining, during scheduling, that the counter satisfies the threshold in relation to the additional condition, triggering a scheduling action with respect to the at least one of the plurality of tasks.
2. The method of claim 1 further comprising: receiving update data for changing a value of the counter; determining that the counter value is to be updated; and updating the counter value based on the update data.
3. The method of claim 2 wherein the update data comprises an indication of how to change the counter value, and an update event indicating when to change the counter value.
4. The method of claim 3 wherein the update event is any one of a specified state of the task and a specified time of a clock.
5. The method of claim 1 wherein the additional condition is at least one of an occurrence of a specified state of the task and reaching a specified time.
6. The method of claim 1 wherein the scheduling action is any one of starting a task, completing the task, pausing the task, and resuming the task.
7. The method of claim 1 further comprising: creating a counter constraint for the plurality of tasks; configuring the counter constrain using the dependency data; and scheduling the plurality of tasks using the counter constraint.
8. The method of claim 7 wherein creating the counter constraint comprises: creating one or more domain variables for each of the plurality of tasks, each variable having a domain; creating one or more counters for the plurality of tasks; creating one or more updates for the plurality of tasks; creating one or more restrictions for the plurality of tasks; and creating one or more conditions upon the updates or restrictions for the plurality of tasks.
9. The method of claim 8 wherein: each update includes an update action parameter and an update time parameter; and each restriction includes a restriction value parameter and a restriction time parameter.
10. A system comprising: a memory; and a processor, coupled to the memory, to cause a scheduling system to: identify a plurality of tasks to be performed; receive dependency data indicating that scheduling of at least one of the plurality of tasks is dependent on whether a counter satisfies a threshold in relation to an additional condition; and upon determining, during scheduling, that the counter satisfies the threshold in relation to the additional condition, trigger a scheduling action with respect to the at least one of the plurality of tasks.
11. The system of claim 10 wherein the processor is to further cause the scheduling system to: receive update data for changing a value of the counter; determine that the counter value is to be updated; and update the counter value based on the update data.
12. The system of claim 11 wherein the update data comprises an indication of how to change the counter value, and an update event indicating when to change the counter value, wherein the update event is any one of a specified state of the task and a specified time of a clock.
13. The system of claim 10 wherein: the additional condition is at least one of an occurrence of a specified state of the task and reaching a specified time; and the scheduling action is any one of starting a task, completing the task, pausing the task, and resuming the task.
14. The system of claim 10 wherein the processor is to further cause the scheduling system to: create a counter constraint for the plurality of tasks; configure the counter constrain using the dependency data; and schedule the plurality of tasks using the counter constraint.
15. The system of claim 14 wherein the processor is to cause the scheduling system to create a counter constraint for the plurality of tasks by: creating one or more domain variables for each of the plurality of tasks, each variable having a domain; creating one or more counters for the plurality of tasks; creating one or more updates for the plurality of tasks, wherein each update includes an update action parameter, an update time parameter and zero or more update condition parameters; creating one or more restrictions for the plurality of tasks, wherein each restriction includes a restriction value parameter, a restriction time parameter and zero or more restriction condition parameters; and creating one or more conditions upon the updates or restrictions for the plurality of tasks.
16. A computer readable storage medium including instructions that, when executed by a processing system, cause the processing system to perform a method comprising: identifying, by a computer system, a plurality of tasks to be performed; receiving, by the computer system, dependency data indicating that scheduling of at least one of the plurality of tasks is dependent on whether a counter satisfies a threshold in relation to an additional condition; and upon determining, during scheduling, that the counter satisfies the threshold in relation to the additional condition, triggering a scheduling action with respect to the at least one of the plurality of tasks.
17. The computer readable storage medium of claim 16 wherein the method further comprises: receiving update data for changing a value of the counter; determining that the counter value is to be updated; and updating the counter value based on the update data.
18. The computer readable storage medium of claim 16 wherein: the additional condition is at least one of an occurrence of a specified state of the task and reaching a specified time; and the scheduling action is any one of starting a task, completing the task, pausing the task, and resuming the task.
19. The computer readable storage medium of claim 16 wherein the method further comprises: creating a counter constraint for the plurality of tasks; configuring the counter constrain using the dependency data; and scheduling the plurality of tasks using the counter constraint.
20. The computer readable storage medium of claim 16 wherein creating the counter constraint comprises: creating one or more domain variables for each of the plurality of tasks, each variable having a domain; creating one or more counters for the plurality of tasks; creating one or more updates for the plurality of tasks, each update including an update action parameter, an update time parameter and zero or more condition update parameters; creating one or more restrictions for the plurality of tasks each restriction including a restriction value parameter, a restriction time parameter and zero or more restriction condition update parameters.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020127001223A KR101752807B1 (en) | 2009-06-16 | 2010-06-16 | Counter and timer constraints |
SG2011082948A SG176555A1 (en) | 2009-06-16 | 2010-06-16 | Counter and timer constraints |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US18757909P | 2009-06-16 | 2009-06-16 | |
US61/187,579 | 2009-06-16 | ||
US12/816,322 US10768611B2 (en) | 2009-06-16 | 2010-06-15 | Counter and timer constraints |
US12/816,322 | 2010-06-15 |
Publications (2)
Publication Number | Publication Date |
---|---|
WO2010148139A2 true WO2010148139A2 (en) | 2010-12-23 |
WO2010148139A3 WO2010148139A3 (en) | 2011-03-31 |
Family
ID=43357036
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2010/038891 WO2010148139A2 (en) | 2009-06-16 | 2010-06-16 | Counter and timer constraints |
Country Status (4)
Country | Link |
---|---|
US (1) | US10768611B2 (en) |
KR (1) | KR101752807B1 (en) |
SG (1) | SG176555A1 (en) |
WO (1) | WO2010148139A2 (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2014151048A1 (en) | 2013-03-15 | 2014-09-25 | Facebook, Inc. | Defer heavy operations while scrolling |
CN104714838A (en) * | 2013-12-12 | 2015-06-17 | 中国移动通信集团四川有限公司 | Task scheduling method and device |
CN104808636A (en) * | 2015-04-28 | 2015-07-29 | 广东工业大学 | Flexible flow shop energy consumption optimization scheduling method |
CN111766785A (en) * | 2020-07-10 | 2020-10-13 | 北京理工大学 | Multi-machine scheduling method for minimizing expected early and late expenses |
Families Citing this family (50)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9852383B2 (en) * | 2010-10-29 | 2017-12-26 | Kaseya Limited | Method and apparatus of tracking time worked in a multi-tasking environment |
US8694998B2 (en) * | 2011-08-29 | 2014-04-08 | Microsoft Corporation | Cancellable command application programming interface (API) framework |
US9665668B2 (en) * | 2012-02-29 | 2017-05-30 | Applied Materials, Inc. | Configuring a dispatching rule for execution in a simulation |
US9830193B1 (en) | 2014-09-30 | 2017-11-28 | Amazon Technologies, Inc. | Automatic management of low latency computational capacity |
US10048974B1 (en) | 2014-09-30 | 2018-08-14 | Amazon Technologies, Inc. | Message-based computation request scheduling |
US9678773B1 (en) | 2014-09-30 | 2017-06-13 | Amazon Technologies, Inc. | Low latency computational capacity provisioning |
US9600312B2 (en) | 2014-09-30 | 2017-03-21 | Amazon Technologies, Inc. | Threading as a service |
US9323556B2 (en) | 2014-09-30 | 2016-04-26 | Amazon Technologies, Inc. | Programmatic event detection and message generation for requests to execute program code |
US9146764B1 (en) | 2014-09-30 | 2015-09-29 | Amazon Technologies, Inc. | Processing event messages for user requests to execute program code |
US9537788B2 (en) | 2014-12-05 | 2017-01-03 | Amazon Technologies, Inc. | Automatic determination of resource sizing |
US20160171364A1 (en) | 2014-12-15 | 2016-06-16 | Invensys Systems, Inc. | Optimistic data retrieval in a process control environment |
US9588790B1 (en) | 2015-02-04 | 2017-03-07 | Amazon Technologies, Inc. | Stateful virtual compute system |
US9733967B2 (en) | 2015-02-04 | 2017-08-15 | Amazon Technologies, Inc. | Security protocols for low latency execution of program code |
US9910713B2 (en) | 2015-12-21 | 2018-03-06 | Amazon Technologies, Inc. | Code execution request routing |
US10067801B1 (en) | 2015-12-21 | 2018-09-04 | Amazon Technologies, Inc. | Acquisition and maintenance of compute capacity |
US11132213B1 (en) | 2016-03-30 | 2021-09-28 | Amazon Technologies, Inc. | Dependency-based process of pre-existing data sets at an on demand code execution environment |
US10102040B2 (en) | 2016-06-29 | 2018-10-16 | Amazon Technologies, Inc | Adjusting variable limit on concurrent code executions |
US10152566B1 (en) * | 2016-09-27 | 2018-12-11 | Altera Corporation | Constraint based bit-stream compression in hardware for programmable devices |
US10725826B1 (en) * | 2017-06-21 | 2020-07-28 | Amazon Technologies, Inc. | Serializing duration-limited task executions in an on demand code execution system |
US10445140B1 (en) * | 2017-06-21 | 2019-10-15 | Amazon Technologies, Inc. | Serializing duration-limited task executions in an on demand code execution system |
US10831898B1 (en) | 2018-02-05 | 2020-11-10 | Amazon Technologies, Inc. | Detecting privilege escalations in code including cross-service calls |
US10725752B1 (en) | 2018-02-13 | 2020-07-28 | Amazon Technologies, Inc. | Dependency handling in an on-demand network code execution system |
US10853115B2 (en) | 2018-06-25 | 2020-12-01 | Amazon Technologies, Inc. | Execution of auxiliary functions in an on-demand network code execution system |
US10649749B1 (en) | 2018-06-26 | 2020-05-12 | Amazon Technologies, Inc. | Cross-environment application of tracing information for improved code execution |
US11146569B1 (en) | 2018-06-28 | 2021-10-12 | Amazon Technologies, Inc. | Escalation-resistant secure network services using request-scoped authentication information |
US10949237B2 (en) | 2018-06-29 | 2021-03-16 | Amazon Technologies, Inc. | Operating system customization in an on-demand network code execution system |
KR102031853B1 (en) * | 2018-07-18 | 2019-10-15 | 국방과학연구소 | Method of Switching Task-level Criticality-mode for Mixed-Criticality Systems |
US11099870B1 (en) | 2018-07-25 | 2021-08-24 | Amazon Technologies, Inc. | Reducing execution times in an on-demand network code execution system using saved machine states |
US11205159B2 (en) * | 2018-08-28 | 2021-12-21 | Oracle International Corporation | Using constraint programming to obtain a machine maintenance schedule for maintaining machines |
US11099917B2 (en) | 2018-09-27 | 2021-08-24 | Amazon Technologies, Inc. | Efficient state maintenance for execution environments in an on-demand code execution system |
US11243953B2 (en) | 2018-09-27 | 2022-02-08 | Amazon Technologies, Inc. | Mapreduce implementation in an on-demand network code execution system and stream data processing system |
US11943093B1 (en) | 2018-11-20 | 2024-03-26 | Amazon Technologies, Inc. | Network connection recovery after virtual machine transition in an on-demand network code execution system |
US10884812B2 (en) | 2018-12-13 | 2021-01-05 | Amazon Technologies, Inc. | Performance-based hardware emulation in an on-demand network code execution system |
US11010188B1 (en) | 2019-02-05 | 2021-05-18 | Amazon Technologies, Inc. | Simulated data object storage using on-demand computation of data objects |
US11861386B1 (en) | 2019-03-22 | 2024-01-02 | Amazon Technologies, Inc. | Application gateways in an on-demand network code execution system |
US11119809B1 (en) | 2019-06-20 | 2021-09-14 | Amazon Technologies, Inc. | Virtualization-based transaction handling in an on-demand network code execution system |
US11159528B2 (en) | 2019-06-28 | 2021-10-26 | Amazon Technologies, Inc. | Authentication to network-services using hosted authentication information |
US11190609B2 (en) | 2019-06-28 | 2021-11-30 | Amazon Technologies, Inc. | Connection pooling for scalable network services |
US11115404B2 (en) | 2019-06-28 | 2021-09-07 | Amazon Technologies, Inc. | Facilitating service connections in serverless code executions |
US11119826B2 (en) | 2019-11-27 | 2021-09-14 | Amazon Technologies, Inc. | Serverless call distribution to implement spillover while avoiding cold starts |
US11714682B1 (en) | 2020-03-03 | 2023-08-01 | Amazon Technologies, Inc. | Reclaiming computing resources in an on-demand code execution system |
US11188391B1 (en) | 2020-03-11 | 2021-11-30 | Amazon Technologies, Inc. | Allocating resources to on-demand code executions under scarcity conditions |
US11775640B1 (en) | 2020-03-30 | 2023-10-03 | Amazon Technologies, Inc. | Resource utilization-based malicious task detection in an on-demand code execution system |
US11797951B2 (en) | 2020-07-24 | 2023-10-24 | Oracle International Corporation | Using constraint programming to obtain a machine maintenance schedule for maintenance tasks |
US11550713B1 (en) | 2020-11-25 | 2023-01-10 | Amazon Technologies, Inc. | Garbage collection in distributed systems using life cycled storage roots |
US11593270B1 (en) | 2020-11-25 | 2023-02-28 | Amazon Technologies, Inc. | Fast distributed caching using erasure coded object parts |
US11388210B1 (en) | 2021-06-30 | 2022-07-12 | Amazon Technologies, Inc. | Streaming analytics using a serverless compute system |
US11968280B1 (en) | 2021-11-24 | 2024-04-23 | Amazon Technologies, Inc. | Controlling ingestion of streaming data to serverless function executions |
US12015603B2 (en) | 2021-12-10 | 2024-06-18 | Amazon Technologies, Inc. | Multi-tenant mode for serverless code execution |
CN114296415B (en) * | 2021-12-29 | 2024-08-30 | 赛美特信息集团股份有限公司 | Product quantity counting method and product quantity counting device in production process |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040158831A1 (en) * | 2003-01-07 | 2004-08-12 | Katsushige Amano | Process scheduling appratus, process scheduling method, program for process scheduling, and storage medium recording a program for process scheduling |
US20050097012A1 (en) * | 2003-10-31 | 2005-05-05 | Tomohiko Maeda | Production planning method and apparatus |
US20090150891A1 (en) * | 2007-12-06 | 2009-06-11 | International Business Machines Corporation | Responsive task scheduling in cooperative multi-tasking environments |
US20090183162A1 (en) * | 2008-01-15 | 2009-07-16 | Microsoft Corporation | Priority Based Scheduling System for Server |
Family Cites Families (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5341302A (en) * | 1992-04-23 | 1994-08-23 | International Business Machines Corporation | Job configuration for semiconductor manufacturing |
US5819232A (en) * | 1996-03-22 | 1998-10-06 | E. I. Du Pont De Nemours And Company | Method and apparatus for inventory control of a manufacturing or distribution process |
JP3382805B2 (en) * | 1997-02-10 | 2003-03-04 | 日本電気株式会社 | Production control method and production control method |
US5983195A (en) * | 1997-06-06 | 1999-11-09 | Electronic Data Systems Corporation | Method and system for scheduling product orders in a manufacturing facility |
US6182049B1 (en) * | 1998-02-06 | 2001-01-30 | International Business Machines Corporation | Method and apparatus for controlling product routing in a manufacturing line |
US6427090B1 (en) * | 1999-08-18 | 2002-07-30 | International Business Machines Corporation | Requalification controller for durables |
US6519498B1 (en) * | 2000-03-10 | 2003-02-11 | Applied Materials, Inc. | Method and apparatus for managing scheduling in a multiple cluster tool |
US6950196B2 (en) * | 2000-09-20 | 2005-09-27 | Kla-Tencor Technologies Corp. | Methods and systems for determining a thickness of a structure on a specimen and at least one additional property of the specimen |
US20050015504A1 (en) * | 2001-09-13 | 2005-01-20 | Dorne Raphael Jh | Resource management method and apparatus |
US7054702B1 (en) * | 2001-10-23 | 2006-05-30 | Advanced Micro Devices, Inc. | Lot start agent that determines delta virtual WIP time for each bottleneck station in a multi-product and multi-bottleneck manufacturing environment |
US7043318B1 (en) * | 2001-10-23 | 2006-05-09 | Advanced Micro Devices, Inc. | Lot start agent that determines quantity and timing for lot starts |
US6766278B2 (en) * | 2001-12-26 | 2004-07-20 | Hon Hai Precision Ind. Co., Ltd | System and method for collecting information and monitoring production |
US6732006B2 (en) * | 2002-02-06 | 2004-05-04 | Asm International Nv | Method and system to process semiconductor wafers |
JP2004070579A (en) * | 2002-08-05 | 2004-03-04 | Denso Corp | Task scheduling device, task scheduling method and program |
US7027885B1 (en) * | 2002-12-30 | 2006-04-11 | Advanced Micro Devices, Inc. | Determining batch start versus delay |
JP2004234643A (en) | 2003-01-07 | 2004-08-19 | Matsushita Electric Ind Co Ltd | Process scheduling device, process scheduling method, program for process scheduling, and storage medium recorded with program for process scheduling |
US8127248B2 (en) | 2003-06-20 | 2012-02-28 | Apple Inc. | Computer interface having a virtual single-layer mode for viewing overlapping objects |
US7174232B2 (en) * | 2003-10-30 | 2007-02-06 | Agency For Science, Technology And Research | Job release with multiple constraints |
US7904192B2 (en) * | 2004-01-14 | 2011-03-08 | Agency For Science, Technology And Research | Finite capacity scheduling using job prioritization and machine selection |
US7206652B2 (en) * | 2004-08-20 | 2007-04-17 | International Business Machines Corporation | Method and system for intelligent automated reticle management |
US7477960B2 (en) * | 2005-02-16 | 2009-01-13 | Tokyo Electron Limited | Fault detection and classification (FDC) using a run-to-run controller |
US7486391B2 (en) * | 2006-09-13 | 2009-02-03 | Samsung Austin Semiconductor, L.P. | System and method for haze control in semiconductor processes |
JP2008269597A (en) * | 2008-04-09 | 2008-11-06 | Net Kuriasu Systems Kk | Task processor |
-
2010
- 2010-06-15 US US12/816,322 patent/US10768611B2/en active Active
- 2010-06-16 SG SG2011082948A patent/SG176555A1/en unknown
- 2010-06-16 KR KR1020127001223A patent/KR101752807B1/en active IP Right Grant
- 2010-06-16 WO PCT/US2010/038891 patent/WO2010148139A2/en active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040158831A1 (en) * | 2003-01-07 | 2004-08-12 | Katsushige Amano | Process scheduling appratus, process scheduling method, program for process scheduling, and storage medium recording a program for process scheduling |
US20050097012A1 (en) * | 2003-10-31 | 2005-05-05 | Tomohiko Maeda | Production planning method and apparatus |
US20090150891A1 (en) * | 2007-12-06 | 2009-06-11 | International Business Machines Corporation | Responsive task scheduling in cooperative multi-tasking environments |
US20090183162A1 (en) * | 2008-01-15 | 2009-07-16 | Microsoft Corporation | Priority Based Scheduling System for Server |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2014151048A1 (en) | 2013-03-15 | 2014-09-25 | Facebook, Inc. | Defer heavy operations while scrolling |
EP2972722A4 (en) * | 2013-03-15 | 2016-12-21 | Facebook Inc | Defer heavy operations while scrolling |
US10592278B2 (en) | 2013-03-15 | 2020-03-17 | Facebook, Inc. | Defer heavy operations while scrolling |
CN104714838A (en) * | 2013-12-12 | 2015-06-17 | 中国移动通信集团四川有限公司 | Task scheduling method and device |
CN104808636A (en) * | 2015-04-28 | 2015-07-29 | 广东工业大学 | Flexible flow shop energy consumption optimization scheduling method |
CN111766785A (en) * | 2020-07-10 | 2020-10-13 | 北京理工大学 | Multi-machine scheduling method for minimizing expected early and late expenses |
Also Published As
Publication number | Publication date |
---|---|
KR20120031068A (en) | 2012-03-29 |
SG176555A1 (en) | 2012-01-30 |
US20110029984A1 (en) | 2011-02-03 |
WO2010148139A3 (en) | 2011-03-31 |
US10768611B2 (en) | 2020-09-08 |
KR101752807B1 (en) | 2017-06-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10768611B2 (en) | Counter and timer constraints | |
Song et al. | An agent-based simulation system for multi-project scheduling under uncertainty | |
US10088836B2 (en) | Methods, systems, and apparatus for resource allocation in a manufacturing environment | |
US20130067182A1 (en) | Data processing method and system | |
AU2018271267B2 (en) | Robotic regression testing for smart devices | |
JP7179086B6 (en) | Method for scheduling a semiconductor back end fab | |
US20140123114A1 (en) | Framework for integration and execution standardization (fiesta) | |
Aguirre et al. | A novel optimization method to automated wet-etch station scheduling in semiconductor manufacturing systems | |
Snyman et al. | Real-time scheduling in a sensorised factory using cloud-based simulation with mobile device access | |
US9671779B2 (en) | Method and system for filtering lot schedules using a previous schedule | |
Xia et al. | Dependability prediction of WS-BPEL service compositions using petri net and time series models | |
McKee et al. | Enabling decision support for the delivery of real-time services | |
Patel et al. | Evaluating a development framework for engineering internet of things applications | |
Meyer et al. | On the effectiveness of communication-centric modelling of complex embedded systems | |
US8978045B2 (en) | Per-station start time constraint | |
Snyman et al. | A real-time scheduling system in a sensorised job shop | |
Alemão et al. | Production scheduling requirements to smart manufacturing | |
US20240160494A1 (en) | Job schedule quality prediction and job scheduling | |
Dushutina | The Design Framework for Multi-Agent Real-Time Control Systems | |
JP2023536862A (en) | Time constraint management in manufacturing system | |
US20200285213A1 (en) | APPARATUS AND METHOD FOR AUTONOMOUSLY ADDING AND REMOVING OF FUNCTIONALITY IN PROGRAMMABLE LOGIC CONTROLLERS (PLCs) | |
CN118709982A (en) | Production scheduling method, apparatus, storage medium, system and computer program product | |
CN115687037A (en) | Host fault detection for CI/CD system | |
Budnik et al. | Dynamic analysis of enterprise business scenarios | |
WO2019075568A1 (en) | System and method for bi-directional transformation between project domain and process domain |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 10790152 Country of ref document: EP Kind code of ref document: A2 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
ENP | Entry into the national phase |
Ref document number: 20127001223 Country of ref document: KR Kind code of ref document: A |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 10790152 Country of ref document: EP Kind code of ref document: A2 |