WO2001033277A1 - Strategic method for process control - Google Patents

Strategic method for process control Download PDF

Info

Publication number
WO2001033277A1
WO2001033277A1 PCT/US2000/028318 US0028318W WO0133277A1 WO 2001033277 A1 WO2001033277 A1 WO 2001033277A1 US 0028318 W US0028318 W US 0028318W WO 0133277 A1 WO0133277 A1 WO 0133277A1
Authority
WO
WIPO (PCT)
Prior art keywords
data
output
process control
input
interconnection cell
Prior art date
Application number
PCT/US2000/028318
Other languages
French (fr)
Inventor
Arnold J. Goldman
Joseph Fisher
Jehuda Hartman
Shlomo Sarel
Original Assignee
Insyst Ltd.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from IL13266399A external-priority patent/IL132663A/en
Priority claimed from US09/633,824 external-priority patent/US7461040B1/en
Application filed by Insyst Ltd. filed Critical Insyst Ltd.
Priority to EP00975247A priority Critical patent/EP1234204A1/en
Priority to AU13326/01A priority patent/AU1332601A/en
Publication of WO2001033277A1 publication Critical patent/WO2001033277A1/en

Links

Classifications

    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B15/00Systems controlled by a computer
    • G05B15/02Systems controlled by a computer electric
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/32Operator till task planning
    • G05B2219/32345Of interconnection of cells, subsystems, distributed simulation
    • YGENERAL 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
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/02Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]

Definitions

  • the present invention generally relates to a method for controlling a manufacturing-type or like process, and to search-space organizational validation of inputs, outputs, and related factors therein.
  • the present invention relates to synergistically combining disparate resolution data sets, such as by actual or simulated integrating of lower resolution expert-experience based model-like templates to higher resolution empirical data-capture dense quantitative search-spaces, and to establishing a process control strategy therewith.
  • the present invention may also be understood to relate to embodiments where this synergetic combining is beneficially accomplished, such as in control systems, command control systems, command control communications systems, computational apparatus associated with the aforesaid, and to quantitative measuring tools used therewith. Equivalently, the present invention may be understood to relate to domains in which this synergetic combining is applied, such as fabrication of semiconductors or of integrated circuits, medical treatment modalities, social engineering models, corporate management enterprise systems, transactional modifications for financial business practices, or substantially any other organized modality of practice or information, technological, bio-physical, mercantile, social, etc
  • Process control has historic origins in improving the yield and efficiency of manufacturing enterprises Numerous methods for process control are used in countless domains of instantiation Inclusive of their variations and combinations, process control techniques are presently finding application in improving the yield and efficiency of logical and physical processes, including technological, bio-physical, mercantile, and social enterprises These diverse types of enterprises, along with classical manufacturing type enterprises are presently evolving into hyper-complex data management and optimization tasks
  • Gintic is a national research institute proactively involved in collaborative applied R & D projects with the industry and contract research Funded by the National Science and Technology Board, Gintic's mission is to enhance the competitiveness of the Singapore industries through the generation and application of advanced manufacturing technology
  • the present invention provides a process control methodology that is easy to reverse engineer with existing process control systems, including existing data capture systems, process management systems, and operational alert and alarm initiation systems More specifically, the present invention provides a process control methodology wherein, on the one hand, professionals (e g process engineers, experts, consultants, managers, and even machine operators) may participate in providing a preliminary definition of factors worthy of consideration when implementing process control for a particular process juncture and, on the other hand, empirical data may be applied to objectively provide actual operational weightings between these multi-parametric factors Ultimately, the present invention provides process control, yielding improved productivity and efficiency Furthermore, the present invention provides analytical derivative result, in the form of a discrete empirical model of the process juncture, which is equivalent to or an improvement over that provided by the participating professionals
  • the present invention provides at least an equal improvement in process control performance as existing systems, with an added value of being able to be further integrated into larger units of process control It is however likely that for most application the method of the present invention will also provide an improved process control performance to known general-purpose process control methods NOTICES
  • the present invention in whole or in part, may be used independently of the Knowledge-Engineering Protocol-Suite or may be used as a part of the preferred integral embodiment of the Knowledge-Engineering Protocol-Suite GENERAL OVERVIEW OF THE INVENTION
  • the present invention relates to a strategic method for process control wherein said method includes the steps of' for a predetermined process juncture defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell, using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters.
  • Various embodiment of the present invention relate to aspects of the step of defining an interconnection cell.
  • defining an interconnection cell includes representing the interconnection cell as corresponding to a single stage in a process map.
  • defining an interconnection cell includes representing the interconnection cell as corresponding to a group of contiguous stages in a process map. According to a further embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to a group of discontiguous stages in a process map
  • defining an interconnection cell includes representing the interconnection cell as corresponding to a group of cells in a process map, which includes therein substantially every stage in the process map
  • defining an interconnection cell includes representing the interconnection cell as corresponding to at least two interrelated interconnection cells in a process map
  • defining the interconnection cell includes associating therewith derived data
  • defining the interconnection cell includes associating therewith values generated by a Design-Of-Expe ⁇ ments assessment of the predetermined process juncture, to be used for initialization of a like-process
  • defining the interconnection cell includes associating therewith values computed using at least one predetermined formula
  • defining the interconnection cell includes validating at least one set of the at least one set of input data to the interconnection cell as respectively having a substantially significant correlation with a set of the at least one set of output data Furthermore, according to the preferred embodiment of the present invention, said validating includes calculating a correlation coefficient between a selected set of the at least one set of input data, and the at least one set of output data; for the interconnection cell Likewise, according to the preferred embodiment of the present invention, assigning at least one boundary value includes analyzing data in the respective set wherein the at least one boundary value is to be assigned
  • analyzing data in the respective set includes examining the data according to at least one predetermined criterion
  • examining the data according to at least one predetermined criterion includes electing a criterion selected from any one or more of the following lists: input constraints, process constraints, or output goals
  • Process constraints closest recipe to most recent recipe within a specification limit, within a range of values, below an upper limit, above a lower limit, closest to a mid-range value.
  • Output goals within a specification limit, within a range of values, a predetermined target value, an upper specification limit, a lower specification limit, below an upper limit, above a lower limit, closest to a mid-range value
  • the method of the present invention relates to a step of - for a predetermined process juncture - defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of
  • said at least one input data set includes historical empiric data obtained from a previously performed like-process
  • said at least one input data set includes data currently being obtained from a substantially presently ongoing like-process
  • processing includes summarizing data in each respective corresponding data record cluster
  • processing includes implementing a Run-to-Run process control mode
  • processing includes running a feed back closed control loop
  • processing includes running a feed forward closed control loop
  • running a feed forward closed control loop includes substantial optimization of multiple outputs
  • processing includes transforming each summarized respective corresponding data record cluster into a sub-manifold of a multi-va ⁇ ate data manifold
  • processing includes transforming each summarized respective corresponding data record cluster into a search-space vector
  • transforming each summarized respective corresponding data record cluster into a search-space vector includes arranging at least one search-space vector into a vector look-up table
  • processing includes A for at least one process control parameter of the at least one set of process control parameters, prescribing at least one process control recipe-element for use in the predetermined process juncture, and
  • processing includes using robust optimization
  • said processing includes characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation
  • said using a statistical calculation includes calculating a process capability ratio
  • characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation includes arranging the characterized data into a look-up table
  • arranging the characterized data into a look-up table includes using the look-up table and therewith designating at least one process control recipe for use at the predetermined process juncture
  • arranging the smoothed characterized data into a look-up table includes using the look-up table for designating at least one process control recipe for use at the predetermined process juncture
  • using the look-up table includes using the look-up table for designating at least one process control recipe for use at the predetermined process juncture
  • processing includes-to the predetermined process juncture associated with the interconnection cell-applying at least one of the respective corresponding data record clusters to the process occurring at that juncture
  • predetermined process juncture associated with the interconnection cell-applying at least one of the respective corresponding data record clusters to the process occurring at that juncture
  • N clusters is updated by using a self-correcting adaptive system
  • applying at least one of the respective corresponding data record clusters includes reporting a process status, and that said reporting is initiated according to predetermined conditions
  • processing data from the plurality of respective formed set combinations into respective corresponding data record clusters includes installing at least one data record cluster correspondence as a front end to a neural network wherein the neural network is used for controlling an aspect of the process at the predetermined process juncture
  • the steps of the method are applied for optimizing a Chemical/Mechanical Polishing processing of silicon wafers
  • the present invention also relates to a substantially equivalently defined strategic method for process control wherein said method includes the steps of using a mapped plurality of graph-directed expertise-suggested interconnection cell relationships, defining a map referenced interconnection cell therein having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, and using the map referenced interconnection cell, designating at least one process control recipe
  • defining includes, for the map referenced
  • defining the map referenced interconnection cell includes validating the map referenced interconnection cell by simulating a validity-metric for an n-tuple of directed graph components of the map referenced interconnection cell
  • defining the map referenced interconnection cell includes, for an n-tuple of directed graph components of the mapped interconnection cell, validating the map referenced interconnection cell by measuring if each of the at least one set of input data to the map referenced interconnection cell significantly contributes to that map referenced interconnection cell's output, wherein a predetermined convolution of these measu ⁇ ngs constitutes an acceptable validity-metric
  • designating at least one process control recipe includes choosing another process control recipe whenever a particular obtained output value differs from a predetermined target value, by at least a predetermined value, thereby obtaining a new subsequent offset goal value closer to a predetermined target value
  • obtaining a new offset goal value includes basing the value upon at least one output value from a previous similar process
  • basing a new offset goal value includes analyzing the at least one output value from a previous similar process by running a feed back closed control loop
  • defining a map referenced interconnection cell includes forming at least two search-space vectors
  • the present invention also relates to an article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including first computer readable program code for causing a computer to define an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, tied to the first computer readable program code, second computer readable program code for causing a computer to assign at least one boundary value to at least one set of the sets associated with the defined interconnection cell, and tied to the second computer readable program code, third computer readable program code for causing a computer to form a plurality of discrete respective set combinations, using the assigned at least one boundary value
  • the preferred embodiment of the article of manufacture further includes having computer readable program code embodied therein for causing a computer to arrange the respective corresponding data record clusters into a look-up table, for the interconnection cell
  • the preferred embodiment of the article of manufacture is furthermore including a computer usable medium ⁇ having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including tied to the third computer readable program code, fourth computer readable program code for causing a computer to process data from the plurality of respective formed set combinations into respective corresponding data record clusters, for the interconnection cell
  • the present invention also relates to a program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including for a predetermined process juncture, defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, for the predetermined process juncture, assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell, for the predetermined process juncture, using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and for the predetermined process juncture, for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters
  • the preferred embodiment of the program storage device is further including therein a method step whereby respective corresponding data record clusters are arranged into a look-up table
  • the present invention also relates to a system for performing strategic process control at a predetermined process juncture including
  • a apparatus for delineating an interconnection cell said interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data,
  • B a computer having therein software for assigning at least one boundary value to at least one set of the at least one set of input data or to at least one set of the at least one set of output data, and having attached thereto data storage apparatus for storing the assigned data sets
  • C a compressor for performing multi-dimensional representing, ordering, and combining of a plurality of discrete respective set combinations from the stored assigned data sets, and
  • D a processor for processing data from the plurality of discrete respective set combinations into respective corresponding data record clusters
  • the processor includes attached thereto an applier for applying at least one of the respective corresponding data record clusters
  • the computer includes attached therewith at least one sensor for providing an
  • the computer includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
  • the processor includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
  • the present invention also relates to an article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including:
  • I first computer readable program code for causing a computer to define a map referenced interconnection cell having therein a mapped plurality of graph-directed expertise-suggested interconnection cell relationships and further having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data; II. tied to the first computer readable program code, second computer readable program code for causing a computer to use
  • the present invention relates to a program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including for a predetermined process juncture, using a mapped plurality of graph-directed expertise-suggested interconnection cell relationships, defining a map referenced interconnection cell therein having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, and for the predetermined process juncture, using the map referenced interconnection cell, designating at least one process control recipe
  • Controllable Input - input at a process step whose value is determined directly by the user In the context of the present invention, controllable input is also referred to as a control parameter
  • a Feed Back Closed Control Loop refers to determining values for controllable input at a given process stage that will optimize one or more characteristics of the output at that stage based on values of those output characteristics from one or more previous process runs
  • the Feed Back Closed Control Loop is a form of run-to-run control
  • Loop refers to determining values for controllable input at a given process stage that will optimize process output at that stage based on the values of measurable ⁇ nput(s) at that stage for the current process run.
  • Forward Closed Control Loop is a form of run-to-run control
  • Input -Input at a given process stage is anything that influences output at that process stage
  • Input constraint - a limitation on the possible range of values for a given input
  • MES Manufacturing Execution (alternatively Enterprise) System
  • 5 ⁇ Module - a set of one or more tools that are configured to execute a part of a process
  • Output - the object or objects produced by a process for which the process is being carried out A process divided up into stages can have output at any of its given stages
  • Run - A run refers to one execution of a process with resulting output
  • Process Step - a single stage in a process with measurable and/or controllable input and output
  • a process step is also referred to as a tool
  • Search-Space the conceptualized universe of data structures (including the broad class of data-manifolds) and their respective and collective transformations - such as is appreciated by data-base theorists and artificial-intelligence theorists
  • Boundary value - a value assigned to a continuous range of possible values for a control parameter, monitored parameter, input constant, output constant, or outside influence in order to create discrete values corresponding to that continuous range
  • the boundary value logically divides the range of values into constituent subsets at least one having therein a plurality of discrete values
  • Boundary value range - a section of a continuous range of possible values for a control parameter, monitored parameter, input constant, output constant, or outside influence bounded by one or more boundary values
  • Data array - a set of values recorded for one process run for any combination of control parameters, monitored parameters, input constants, output constants, and outside influences
  • Data vector - A unique combination of boundary value ranges selected for the purposed of process control optimization with embodiments of the present invention
  • the preferred embodiment of the present invention uses data vectors with boundary value ranges for input variables and constants
  • a data vector is often referred to as simply a vector
  • Input set combination The combination of data sets of input constants and data sets of input variables at a given interconnection cell
  • Interconnection Cell - An interconnection cell is an information unit describing the non-quantitative mutual dependency between one output and one or more inputs of a process step
  • Interrelationship An alleged or validated relationship between two process stages such that when a particular control parameter is set at an earlier stage in the process, a certain resulting output is received at a later stage in the process
  • model predicted value is the predicted value for an output constant according to the vector look-up table
  • the model predicted value for an output constant could also be understood as a vector's average value of that output constant
  • Next best optimal vector - The next best optimal vector is used together with the optimal vector by the smoothing algorithm when optimizing an output constant in the Feed Forward Closed Control Loop
  • the next best optimal vector must have boundary value ranges for input constants that include the values of the current run ' s input constants If the optimal vector's model predicted value is greater than the output constant target value, then the next best optimal vector will have the model predicted value is usually closest to but less than the output constant target value, and if the optimal vector's model predicted value is less than the output constant target value, then the next best optimal vector will have the model predicted value that is usually closest to but greater than the output constant target value
  • the optimal vector for that output constant is usually the vector with the closest model predicted value highest Process
  • a preferable vector for an output constant is usually the one vector from amongst the common vectors with the highest Process Capability Ratio (C pk ) model predicted value closest to the target value for that output constant Due to output constraints, a preferable vector is not necessarily an optimal vector, because one output constant s optimal vector may not be a common vector shared by the other one or more output constants
  • a process juncture is any node or edge in a graph-theoretic representation of a flow of information, goods, or services such as the knowledge tree in the parent application or a process map in the present application
  • Recipe - A recipe is a set of values for input constants and/or variables at a given process step for achieving an optimal value or values for one or more output constants at that process step
  • Smoothing algorithm - in the context of optimizing an output constant, smoothing refers to the procedure for finding a process recipe based on the optimal vector and the next best optimal vector
  • the smoothing algorithm uses either piece-wise linearization, or linear regression, or the like to determine recipe values
  • el Vector look-up table stores data vectors
  • a vector look-up table is often referred to as simply a look-up table
  • Weighting algorithm when optimizing multiple output constants and more than one common vector is found, a weighting algorithm is applied to each output constant's preferable vector whereby the vectors are weighted (i e prioritized) and the weighting algorithm uses these weightings to provide a recipe for optimizing the multiple output constants
  • the weighting algorithm is applied to each output constant's optimal vector whereby the vectors are weighted (i e prioritized) and the weighting algorithm uses these weightings to provide a recipe for optimizing the multiple output constants
  • APC - Advanced Process Control (a variation or alternative to SPC)
  • IPC - Intelligent Process Control (a form of APC)
  • control parameter controllable input
  • model predicted value output constant vector's average value
  • step is generally interchangeable Use of two or more of these terms in the context of any example may be for the purpose of expressing parts of a larger unit
  • a stage may be composed of constituent steps
  • a process map may be made of graph directed stages, and each stage may correspond to an interconnection cell dealing with data related to a juncture in an actual manufacturing operation Substantially, there are a number of related representations that borrow from the generally interchangeable nomenclature.
  • the present invention comes to "teach” a strategic method for process control which, for any juncture in a representation of a process (according to diverse topological definitions for the notion "juncture”), considers disparate quality "guesses” (recommendations) about what factors to consider when trying to optimize the juncture, and likewise unifies disparate quality definitions about what constitutes an optimization
  • conceptually useful intermediary representations are developed Probably, the most interesting of these representations is a lookup table, organized according to discrete combinations of "cases” that can occur at the juncture, which either presents the most probable best configuration (recipe) of process control "settings" to use at this time at the juncture or presents two such cases from which a best configuration may be interpolated
  • the invention presents a strategic method for process control for use at a given process juncture, and includes defining an interconnection cell This interconnection cell has on one hand associated with it one or more sets
  • this interconnection cell entails delineating and designating a "block" (arbitrary unit) consisting of data associated with a given process at the given process juncture (sub-step, interconnection cell, group of cells, group of groups of cells groups of groups of cells, or any higher level MES), and stratifying this data into a number of sub-groups These subgroups may represent a particular item, batch, or combination thereof in a process This collection of subgroups allows data analysis to be performed according to respective sub-group-relevant metrics
  • Data collected for a given item or batch in a process is called a data vector
  • Data vectors are sorted and grouped into data vector clusters according to similar input set combinations (The sorting process includes storing the data vectors that represent combmatorials of input and output process control parameters )
  • Data vector clusters may be stored in tabular form
  • the table in which the data vectors are stored is called a vector look-up table
  • the vector chosen, used for process control includes the recipe for the process, because the values of the control parameters in that vector are used as the values for the control parameters for a current process run Processing includes, for a given process control parameter, prescribing at least one process control recipe-element, that is, some portion of the current recipe, for use in a predetermined process juncture Processing may further include summarizing data in each respective corresponding data set cluster Selecting
  • a best available vector for use with the process control recipe preferably includes running a feed forward closed control loop
  • a feed forward closed control loop involves the steps of process control (described below) of analyzing data and vector selection In a feed forward closed control loop, the data evaluation
  • Analyzing data in any given respective data set includes examining or evaluating the data relevant to at least one predetermined criterion selected a predetermined target value, an upper specification limit, a lower specification limit, within a specification limit, within a range of values, below an upper limit above a lower limit, closest to a predetermined target value, closest to a previously used value, closest to a mid-range value, or closest to most recent recipe
  • predetermined criterion selected from the above list include
  • a value may be selected because it is closest to a value of some particular interest. For example, an expert suggested value, or a value used as an "offset" or over-correction technique. This method is used to correct a previously obtained output value that was, for example higher than desired, by selecting a new value that is theoretically lower than desired, on the presumption that the result will fall in the desired middle range.
  • a value may be excluded because of some restriction placed on an item, run, or other collection of data in the data set.
  • values may be selected to reflect a growing refining of "discretization" levels in choosing values. For example, previous runs may have used a High/Low demarcation type sorting process, whereas present considerations may include at least three groupings. In such cases, the groups in the "middle" ranges will be referred to as intermediate values. Previous and subsequent intermediate values may be classified, that is discretized, by a predetermined fractional value interval.
  • derived data are used Derived data are obtained through a number of methods, and can be values chosen for Design of Experiments, values computed by a predetermined formula, values formulated from information that is expert suggested, or values formulated by synthesizing methods
  • derived data are theoretical, and substantially all steps relevant to gathering and analyzing of data are skipped Instead, a simulated function or algorithm is synthesized and used as // " derived data contributing to the formation of this simulated function had been obtained
  • the system uses the simulated algorithm — or the results of functions fabricated by simulation methods — for performing the process control method
  • a boundary value can be a demarcation point That is, a cut-off point for assigning data values to a particular discrete group category
  • a demarcation point That is, a cut-off point for assigning data values to a particular discrete group category
  • the boundary value constitutes two respective discrete categories
  • the system-using the assigned at least one boundary value-forms a number of set combinations are stored in such a manner so as to be discrete separate representations of differing associated input data groups
  • the sets can then be evaluated in relation to the boundary value
  • Analysis may be done strictly from outputs for the purpose of assigning boundary values for a given specific input set
  • the invention is also capable of doing analysis'st ⁇ ctly from inputs and/or control parameters to the outputs
  • the preferred embodiment algorithm initiates validating whether there is a significant correlation between input sets of data and output sets of data at a given stage in a process
  • a validated significant correlation is a precondition to properly carrying out process control with the present invention That is, validating a supposed correlation between two steps in the manufacturing process must first be done, so that the subsequently formulated algorithmic function can better perform improved yield or improved efficiency Automated Process Control
  • the validity of a correlation - between at least one input data set of an interconnection cell and at least one output set of this interconnection cell - is determined by calculating a correlation coefficient between the minimum two respective input and output sets, or a larger group of respective input and
  • IS output sets Calculating this correlation coefficient may include characterizing the data by calculating a process capability ratio
  • the actual process control performance may include reporting a process status, and this reporting may be initiated according to a variety of predetermined conditions or means
  • a mapped plurality of graph-directed expertise-suggested interconnection cell relationships is used to define the interconnection cell Using the map referenced interconnection cell, a process control recipe can then be designated, as heretofore described
  • the validation portion (validity correlation performance) of the process control procedure is carried out upon n-tuples of directed graph components of the interconnection cell Subsequent refining of the definition of the interconnection cell is done by "measuring" to see whether a particular set of input data significantly contributes to that map referenced interconnection cell's output A predetermined convolution of these measunngs constitutes an acceptable validity-metric correlation
  • choosing a different process control recipe sometimes becomes necessary, for example, whenever a particular obtained output value differs from a predetermined
  • 3b target value by at least a certain predetermined value This, in turn facilitates the obtaining a new subsequent offset goal value closer to the predetermined target value
  • the obtaining of a new subsequent offset goal value may be based upon an output value from a previous like-manufacturing process, or, in addition, by analyzing this output value by running a feed back closed control loop
  • optimal correction of offset goal values, at a given stage in a process is achieved through data analysis of the values of output constants at that stage as obtained and/or compared to values obtained from at least one previous performance of the process
  • An additional embodiment of the invention includes processing data by transforming a summarized respective corresponding data record cluster into a sub-manifold of a multi-vanate data manifold
  • a sub-manifold is defined as an n-tuple of data points, organized into a multi-dimensional surface This surface may be described by functionally orthogonal variables, and the data manipulated by ordinary mathematical treatment
  • This treatment may include, but is not limited to, algebraic, calculus, differential equations, n-dimensional polynomials, regression analysis, combinatorial techniques, and/or statistical means
  • a related embodiment of the invention includes a method for representing a multi-dimensional surface by displaying the organized data elements as discrete volumes of an n-dimensional polynomial solid as this solid is intersected by orthogonals of a finite number "n", of input, output, constant, variable or some combination thereof, of process control parameters, in n-dimensional space
  • a further embodiment of the invention includes processing data by transforming a summarized respective corresponding data record cluster into a search-space vector
  • a search-space vector in this context indicates that the invention will transform the summarized respective corresponding data record clusters into loci in a multi-dimensional vector search-space
  • the invention selects the desired vector to move along to a new cluster based upon the properties of the vector For example, when searching for a value stored in a cluster that represents the value 'closest to the most recent used recipe" the invention might focus on the vector having the smallest empirical magnitude
  • the invention includes a method for sorting data which includes organizing a search-space organization, the method steps including a search-space for a first grouping or set of correlated empirical data-sets, by mapping a second grouping or set of interrelated specific locations in the search-space of graph-directed expertise-suggested data-set relationships onto the first grouping or set of correlated empirical data-sets, and wherein data-set resolution of particulars in the first grouping or set is greater than or equal to that of particulars in the second grouping or set, and validating the search-space so organized from a vantage point of a presumption of validity for the first plurality of data-sets, by i simulating a valid variable input parameter for a particular combinatorial of directed graph components in the mapped second plurality, or n measuring if each input to a locus of the particular combinatorial significantly contributes to that location's output, wherein a predetermined convolution of these measu ⁇ ngs constitutes a valid
  • mapping includes defining substantially every locus-i e location-in the second plurality to have either 1 ) at least one
  • the method wherein organizing includes mapping a second set of interrelated specific locations in the search-space of graph-directed expertise-suggested data-set relationships onto the first grouping or set of correlated empirical data-sets, and wherein data-set resolution of particulars in the first grouping or set is greater than or equal to that of particulars in the second grouping or set.
  • validating includes, for at least one weighted directed graph component from those in the directed graph of second plurality components, improving the weighted component using an input or output, proportional, empirical parameter setting, directed graph component weighting
  • validating includes generating a conditional statistical process-control distribution function and convoluting the conditional distribution function with the present weightings.
  • the invention includes a method for sorting data which includes organizing a search-space organization, the method steps including: mapping a second plurality of interrelated nodes of graph-directed expertise-suggested data-set relationships onto the first plurality of transformed empirical data-sets, at least until there is a predetermined measure of inclusion by the second plurality of nodes and relationships of particulars in the first plurality data-sets, wherein the data-set resolution of particulars in the first plurality is greater than or equal to that of particulars in the second plurality; and validating the search-space from a vantage of a presumption of validity for the first plurality of data-sets, by simulating a validity-metric for an n-tuple of directed graph components in the mapped second plurality, or by measuring if each input to a node of the n-tuple significantly contributes to that node's output, wherein a predetermined convolution of these measu ⁇ ngs constitutes a validity-metric for the
  • the invention includes a system for performing strategic process control at a predetermined process juncture
  • This system includes apparatus for delineating an interconnection cell
  • the interconnection cell so delineated has associated with it at least one set of input data or at least one set of process control parameters, and at least one set of output data
  • This system further includes a computer which has therein software for assigning at least one boundary value to at least one set of the at least one set of input data or to at least one set of the at least one set of output data
  • the computer further has attached thereto data storage apparatus for storing the assigned data sets
  • the system further includes a compressor for performing multi-dimensional representing, ordering, and combining of a plurality of discrete respective set combinations from the stored assigned data sets, and a processor for processing data from the plurality of discrete respective set combinations into respective corresponding data record clusters
  • the processor applies at least one of the respective corresponding data record clusters
  • the computer includes attached therewith at least one sensor for providing an input or output datum to the respective set of input or output data
  • the computer further includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters
  • the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
  • the invention includes a system for process control including apparatus for delineating an interconnection cell, the interconnection cell having at least one input set of data or at least one set of process control parameters, and at least one output set of data, a validator for establishing that at least one input set of data respectively as having a substantially significant correlation with an output set of the at least one output sets, software for assigning at least one boundary value to at least one validated set of the at least one input sets or to at least one set of the at least one output sets, data storage apparatus for storing the assigned data sets, and a sorter for performing multi-dimensional ordenngs of stored data sets, and wherein the ordenngs are performed either concurrently, sequentially, heunstically, recursively, in parallel, asynchronously, synchronously, and/or synchronously with an accompanying time delay
  • processing data from the respective formed set combinations into respective corresponding data record clusters may include installing at least one data
  • V record cluster correspondence as a front end to a neural network
  • the neural network is used for controlling an aspect of the process at the predetermined process juncture
  • Figure 1 illustrates a schematic diagram of a portion of a simple process map showing substantially sequential stages
  • Figure 2 illustrates a schematic diagram of a process stage, i e any single stage in a process
  • Figure 2a illustrates a data set table for a given stage in a process
  • Figure 3 illustrates a schematic diagram of the process map from Figure 1 with control parameters and monitored parameters added to each stage in the process
  • Figure 4 illustrates a schematic diagram of interrelationships and outside influences for stages in a process
  • Figure 4a presents two data set tables and for two types of outside influences
  • Figure 5 illustrates a schematic diagram of the process map from Figure 3 with the interrelationship and outside influences map of Figure 4
  • Figure 6 illustrates a schematic diagram of a process stage "Stage X" with all the various process control relationships that "Stage X" participates in,
  • Figure 7 illustrates a schematic diagram of "Stage X" with process control relationships that are relevant to applying process control only at “Stage X”
  • Figure 8 illustrates a schematic diagram of a process control algorithm standard frame of reference for Stage "X" in a process
  • Figure 9 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage X
  • Figure 10 illustrates a simple schematic diagram of the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables
  • Figure 10a illustrates the assignment of boundary values to three inputs represented by diagrams 10a 1 , 10a 2, and 10a 3,
  • Figure 10b illustrates a table of data arrays for a given stage in a process
  • Figure 10c illustrates a sample vector in a vector look-up table
  • Figure 11 illustrates a vector look-up table for an output constant d at a given process stage
  • Figure 12 illustrates a vector look-Up table for output constants Oi and O 2 at a given process stage
  • Figure 13 illustrates a schematic diagram in the Chemical/Mechanical Polishing process of silicon wafers at "Tool 1 "
  • Figure 14 illustrates a vector look-up table for output constant O ⁇ at a given process stage, an Actual Values column which is not part of the vector look-up table, and a Residual Values column which is not part of the vector look-up table
  • Figure 15 illustrates a schematic diagram of a process module of two tools, "Tool 1 " and "Tool 2", and
  • Figure 16 illustrates a schematic diagram of a module of four tools in a non-sequential configuration
  • Figurel illustrates a schematic diagram of a portion 100 of a simple process map showing substantially sequential stages, "Stage 1 " 102, “Stage 2” 104, “Stage 3a” 107, “Stage 3b” 108 and “Stage 4" 111 of a process, and the inputs and outputs that connect them - starting with the initial measured input to the process 101 and sequentially measured output 103 from "Stage 1 " which is measured input to "Stage 2", measured output 105 from “Stage 2” which is measured input to “Stage 3a”, measured output 106 from “Stage 2" which is measured input to “Stage 3b”, measured output from "Stage 3a” 109 which is measured input to "Stage 4", measured output from “Stage 3b” 110 which is measured input to “Stage 4", and measured output 112 from “Stage 4"
  • FIG 1 depicted is an example simple process map
  • the boxes in the diagram represent sequential stages in a portion of a typical process, and the arrows indicate the direction in which
  • Stages 3a and 3b represent parallel stages, which can run simultaneously or in an alternating manner
  • a process would utilize such stages when an operation carried out at Stage 3 is slower in relation to actions carried out at other stages in the process
  • Stage 3 When a stage in a process is slower in relation to the rest of the process, it is advantageous to break down the slower stage into parallel stages as seen in Figure 1 , to speed up process time at the that stage
  • Another example of when parallel stages are used would be for one process that produces two types of output Such a process will elect which of the different operations will be carried out at the 'parallel stage"
  • FIG 2 illustrates a schematic diagram of a process stage 200, i e any single stage in a process (such as those shown in Figure 1 ) represented here as “Stage X" 203
  • Stage X-1 a process stage
  • Stage X+1 a process stage in a process
  • control parameters measured by actuators at "Stage X" 202 and monitored parameters from sensors at "Stage X” 204
  • FIG. 2 depicted is a typical stage of the process represented in Figure 1 , referred to in Figure 2 as Stage X
  • Stage X To the left of Stage X are shown control parameters for actuators in the process conducted in Stage X; to the right of Stage X are shown sensors for monitoring parameters of the input to or output from Stage X, or the process conducted during Stage X Actuators perform actions in the context of a specific process step Sensors perform measurements relevant to the process
  • the data coming from sensors and control parameter data sent to actuators constitute fundamental dynamic aspects that are required for the purposes of process control as Figure 2a illustrates a data set table 300 for a given stage in a process
  • "Arrow A" 306 represents a data set for a process output O 2 at the given stage
  • Arrow B" 307 represents a data set for a control parameter CP C at the
  • control parameters, monitored parameters, input, and output at any given stage in a process are data sets, as illustrated in Figure 2a
  • the control parameters, monitored parameters, input, and output at any given stage represent four families of data sets
  • the input family has a data sets (where a is any integer greater than 0)
  • the output family has b data sets (where b is any integer greater than 1 )
  • the control parameters family has c data sets (where c is any integer greater than 1 )
  • the monitored parameters family has data sets (where d is any whole number greater than 1)
  • a data set for the input or output families consists of quantities or measurements of that given input or output, for a given number of items or batches produced in a process
  • arrow A in Figure 2a represents a data set for O 2 , where O 2 is the length of an item that is output from the given process stage, and this data is recorded for 50 times that the item is produced on a given day, where e is 50
  • a typical data set for the control parameters family consists of data for a given parameter setting for an operation occurring at the given process stage, for a given number of items or batches produced in a process
  • arrow B in Figure 2a represents a data set for CP C where CP C is the pressure setting of an item produced at the given process stage, and this data is recorded for 50 times that the item is produced on a given day, where e is 50
  • a data set for the monitored parameters family consists of data for a given parameter monitored at the given process stage, for a given number of items or batches produced in a process
  • FIG. 3 (generally referenced as) 400 illustrates a schematic diagram of the process map from Figure 1 and now added to each stage in the process are the controh parameters and monitored parameters that were depicted in Stage X of Figure 2 "Stage 1 " 402 has control parameters measured by actuators 401 , monitored parameters from sensors 403, initial measured input to the process 416, and measured output 417 which is measured input to "Stage 2" 405, "Stage 2" 405 has control parameters measured by actuators 404, monitored parameters from sensors 406, and measured output 418 which is measured input to "Stage 3a” 408, “Stage 3a” 408 has control parameters measured by actuators 407, monitored parameters from sensors 409, and measured output 420 which is measured input to "Stage 4" 414, “Stage 3b” 411 has control parameters measured by actuators 410, monitored parameters from sensors 412, measured output 421 which is measured input to "Stage 4", and “Stage 4" 414 has control parameters measured by actuators 413, and monitored parameters from sensors 415,
  • FIG. 4 illustrates a schematic diagram of interrelationships and outside influences for stages in a process 500
  • "Stage 1 " 501 has an interrelationship 506 with “Stage 3a” 503 and an interrelationship 507 with “Stage 3b” 504,
  • “Stage 2" 502 has an interrelationship 508 with “Stage 3b” 504 and an interrelationship 509 with 509 with “Stage 4 " 505
  • FIG 4 depicted is an interrelationship and outside influences map for the stages in the process map of Figure 1
  • An interrelationship between two stages exists when there is alleged or validated information that when a particular control parameter or parameters are set at an earlier Stage X, a certain resulting output is received at a later Stage X+n (where .. is any integer greater than 0)
  • interrelationships exist between Stage 1 and Stages 3a and 3b, between Stage 2 and Stage 3b, and between Stage 2 and Stage 4
  • An outside influence exists when there is alleged or validated information that some factor outside of a process influences output at a given stage in the process.
  • Figure 4a (generally referenced as) 600 presents two data set tables 601 and 604 for two types of outside influences
  • the first data set represented by "arrow A" 607, consists of data for any type of metric or discrete parameter
  • the second data set represented by "arrow B" 608, consists of data for any type of metric or discrete parameter 606 monitored according to another metric scale 605
  • outside influences also have data sets
  • Data sets for outside influences can be one of two types
  • the first type is data for any type of metric or discrete parameter monitored in a time-dependent manner (arrow A), when the metric or discrete parameter is either suggested to affect or confirmed to affect output at a given stage
  • the second type is data for any type of metric or discrete parameter monitored according to another metric scale (arrow B), when the first metric or discrete parameter is either suggested to affect or confirmed to affect output at a given stage
  • FIG. 700 illustrates a schematic diagram of the process map from Figure 3 with the interrelationship and outside influences map of Figure 4 "Stage 1 " 702 has initial measured input to the process 721 , control parameters measured by actuators 701 , monitored parameters from sensors 703, an interrelationship 717 with “Stage 3a” 708, and an interrelationship 718 with “Stage 3b” 712, and measured output 722 which is measured input to "Stage 2" 705, “Stage 2" 705 which has control parameters measured by actuators at “Stage 2” 704, and monitored parameters from sensors at "Stage 2" 706, an interrelationship 719 with "Stage 3b” 712, an interrelationship 720 with "Stage 4" 715, measured output 723 which is measured input to "Stage 3a” 708, and measured output 724 which is measured input to "Stage 3b” 712 , "Stage 3a” 708 which has control parameters measured by actuators at "Stage 3a” 707, monitored parameters
  • Figure 6 (generally referenced as) 800 illustrates a schematic diagram of a process stage "Stage X" 804 with all the various process control relationships that "Stage X" participates in These relationships include measured input from “Stage X-1" 803, measured output to "Stage X+1 " 807, an outside influence 801 , control parameters measured by actuators at "Stage X” 805, monitored parameters from sensors at "Stage X” 806, an interrelationship with a process stage before "X” 802, and an interrelationship with a process stage after "X” 808
  • Stage X depicted is one stage in a given process, Stage X, with all of the various relevant process relationships that have been depicted in Figures 1-5 Stages prior to Stage X are hereinafter referred to as Stages X-1 , X-2, , X-n, etc Stages following Stage X are hereinafter referred to as Stages X+1 , X+2, , X+n etc Stages which may be substantially simultaneous to Stage X can be arbitrarily assigned the nomenclature X-1 or X+1 Figure 6 illustrates various process control relationships in which Stage X participates
  • FIG. 900 illustrates a schematic diagram of "Stage X" 904 with process control relationships that are relevant to applying process control only at "Stage X” These relationships include measured input from “Stage X-1 " 903, measured output to "Stage X+1" 907, an outside influence 901 , control parameters measured by actuators at "Stage X” 905, monitored parameters from sensors at "Stage X” 906, an interrelationship with a process stage before "X” 902, and an interrelationship with a process stage after "X” 908
  • Figure 8 (generally referenced as) 1000 illustrates a schematic diagram of a process control algorithm standard frame of reference for Stage "X" in a process 1000
  • the relevant factors herein are control parameter(s) 1002, input from 'Stage X-1" 1003, ⁇ nterrelat ⁇ onsh ⁇ p(s) with stage(s) before “X” 1004, ⁇ nterrelat ⁇ onsh ⁇ p(s) with stage(s) after "X” 1005, outside ⁇ nfluence(s) 1006, with the resultant output to "Stage X+1 " 1007, and monitored parameters from sensors 1008
  • Figure 7 depicts Stage X with relationships relevant to applying process control only at Stage X
  • Figure 8 takes the relationships depicted in Figure
  • the method of the present invention relates to process control for a juncture in a process wherein there are no a priori notions regarding predominant influences to the process at that juncture
  • process control recipes can be found, calculated or chosen using decision criteria that could not be directly articulated using prior art methods
  • present invention leads to the development of a well-defined search-space or ensemble of process control vectors whereby multiple goal optimizations may be realized
  • Figure 9 (generally referenced as) 2000 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage X 2002
  • These relationships include control parameter(s) 2011 which are "internal” 2014, input from “Stage X-1 " 2010 which is “near” 2013, ⁇ nterrelat ⁇ onsh ⁇ p(s) with stage(s) before “X” 2007, ⁇ nterrelat ⁇ onsh ⁇ p(s) with stage(s) after "X” 2005, and outside ⁇ nfluence(s) 2001 which are all “far” 2012, monitored parameters 2004 which are "internal” 2015, and output to "Stage X+1 " 2008 which is "near” 2016
  • Polygons "A” 2009, "B” 2003, and “C” 2006” depict the standard types of relationships that are examined when applying standard process control at Stage X
  • the polygons "A” 2009, “B” 2003, “C” 2006 show types of relationships between Input from "Stage X-1 ", Control Parameter(s
  • Figure 9 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage
  • Relative importance is classically determined by the proximity of a relationship to Stage X That is, the closer the relationship, the greater
  • Polygons A, B, and C in Figure 9 depict the standard types of relationships that are examined when applying standard process control at Stage X That is, standard process control at Stage X looks for a correlation between the input from Stage X-1 and control parameters at Stage X (polygon A), a correlation between control parameters at Stage X and the monitored parameters at Stage X (polygon B), and a correlation between monitored parameters at Stage X and the output to Stage X+1 (polygon C).
  • Constants relate to measurements that reflect physical aspects measured in a process; such as weight of an object coming into a process juncture, height of an object coming out of a process juncture, etc.
  • constants are constraints that are outside of the scope of control of the process control engineer. Therefore, even though these aspects are called constants, on an item-to-item basis they may contribute to describing a broad distribution of values. For example, each egg that arrives at an egg-sorting machine has a specific size and weight that is constant for that egg. Nevertheless, one can describe a distribution of weights and sizes for eggs arriving at the sorter.
  • Variables relate to aspects of the process at the process
  • S3 juncture that may be elected by command of a process control engineer, or by his proxy in the form of process control software (such as that of the present invention) setting process control parameters at the process juncture
  • Figure 10 (generally referenced as) 3000 illustrates a simple schematic diagram of the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables, which is the way an embodiment of the present invention addresses process control at "Stage X" 3001 An Interconnection Cell (according to an embodiment of the present invention) 3000 at process "Stage X" 3001 , and its constant/variable relationships.
  • These relationships include input constant(s) 3002, input variables 3004, output constants 3005, and monitored parameters 3003, and by calculating a correlation coefficient between it and an Ouput Constant(s) 3005 As well, ideally, there should be no discrepancy between Input Var ⁇ able(s) i.e. Control Parameters 3004 and their output values i e. Monitored Parameter(s) 3003
  • Figure 10 displays the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables, which is the way an embodiment of the present invention addresses process control at Stage X
  • the input constants in Figure 10 consist of interrelationships that Stage X has with other stages (before or after Stage X), outside influences, and input from Stage X-1 .
  • Input variables consist of control parameters at Stage X Constants and variables can further be understood in terms of data sets. That is, each constant or variable is one of the types of data sets described in Figures 2a and 4a.
  • the process stage and constant/variable relationships depicted in Figure 10 are referred to as an interconnection cell
  • the interconnection cell represents a single process stage, l() hereinafter a tool.
  • An interconnection cell can also represent two (or more) contiguous stages in a process, hereinafter a module.
  • an interconnection cell can represent a plurality of discontiguous stages, hereinafter a virtual module, or a plurality of contiguous or discontiguous modules.
  • an algorithm is used to determine validity of input constants by calculating a correlation coefficient between an input constant with an output constant.
  • This algorithm may be any well-known and accepted algorithm for calculating a correlation coefficient between two data sets, or any algorithm that produces a
  • an algorithm is used to determine correlation coefficients for input variables (i e control parameters at Stage X) with monitored parameters at Stage X
  • the correlation coefficient should have a value of 1 0, meaning that there is no discrepancy between control parameters and their monitored output values
  • a deteriorating correlation coefficient for an input variable with its corresponding monitored parameter means that intended values for control parameters are not properly received or implemented at Stage X and that serious correction is needed
  • the many embodiments of the present invention can be used for improving the yield of Stage X according to relationships between input variables and monitored parameters, the immediately following discussion will deal with the issue of process control for Stage X without addressing the issues of discrepancies between input variables and monitored parameters
  • the more convoluted embodiment first considers assigning at least one boundary value to at least one dividing data for data set of output constant data set and thereby forming at least two discrete sub-sets into at least two discrete sub-sets, and then discovering how to assign boundary values to the input set combination at least one input data set by analyzing portions of the input set(s) one or more data sets in the input set combination that contributed to each of the discrete sub-sets or to more than one of the discrete subsets. Once the contributing portions of the input data sets have been discovered, then the more simple straightforward methods, for assignment of boundary values to input constants and variables, may be applied A simple example should suffice to disclose this convolution
  • a data set of an output constant shows a clear bimodal distribution of measured articles being manufactured at that juncture Accordingly, a boundary value is assigned to the minima between the two apparent modes of the distribution
  • a data set for an input constant associated with this same juncture shows a relatively uniform "flat" distribution of variation When the two modes of the output
  • boundary values are assigned to 1 ) input constants only, 2) input constants and monitored parameters together, 3) input constants, input variables, and monitored parameters together 4) input variables only, 5) monitored parameters only, and 6) input variables and monitored parameters together
  • boundary values are assigned to 1 ) output constants and input variables, 2) output constants and monitored parameters, and 3) output constants input variables, and monitored parameters
  • monitored values for some purposes are considered a preliminary output value, for other purposes it is a supplement to input values. However, most often monitored values are used as a corrective feedback to maintain desired input variable values
  • Boundary values can be determined and assigned according to various criteria More specifically, the selection of boundary values may significantly affect the quality of results achieved by using the method of the present invention In some circumstances, selection of a boundary value is done subjectively by a process control engineer according to his judgment and
  • boundary values are selected according to specifications inherent to the actual goals of the process More often, boundary values are set according to measurable characteristics of the population of values in a given data set
  • Fig 10a (generally referenced as) 4000 illustrates the assignment of boundary values to three inputs represented by diagrams 10a 1 (generally referenced as) 4001 , 10a 2 (generally referenced as) 4009, and 10a 3 (generally referenced as) 4014
  • Diagram 10a 2 (generally referenced as) 4009 in Figure 10a (generally referenced as) 4000 illustrates the assignment of one boundary value x 2 4011 to a population of data measurements for an input, where the population of data measurements divides according to a bimodal distribution curve 4010
  • a 2 4012 represents the lower boundary value range for this input and B 2 4013 represents the upper boundary value range for this input
  • a simple example of an input constant with one assigned boundary value is an egg-sorting machine that sort eggs according to egg diameter
  • a boundary value of 2 50 cm is set as the minimum diameter for eggs to be cleaned and boxed for the consumer market
  • An egg with a diameter of less than 2.50 cm will be sent to the frozen egg line to be frozen and used for powdered eggs
  • diagram 10a.2 of Figure 10a The population of data measurements from some process is shown in the figure This population substantially divides according to an obvious bimodal distribution
  • Line x 2 indicates the minimum value between two modes
  • This minimum value is a boundary value for the input constant
  • a 2 represents the range of input values less than the boundary value represented by line x 2
  • a 2 The range of input values represented by A 2 is referred to as a boundary value range
  • B 2 represents the boundary value range of input values greater than or equal to the boundary value represented by line x 2
  • Diagram 10a 1 (generally referenced as) 4001 in Figure 10a (generally referenced as) 4000 illustrates the assignment of two boundary values Xi 4003 and yi 4004 to a population of data measurements for an input, where the population of data measurements divides according to normal distribution curve 4002 The average of this normal distribution is represented by ⁇ 4005 A T 4006 represents the lower boundary value range for this input B ⁇ 4007 represents the in-specification boundary value range for this input, and Ci 4008 represents the upper boundary value range for this input
  • An example of an input variable with two boundary values could be the percentage of salinity in sardines Consumer engineers determine that a range of 7%-9% salinity in sardines is an acceptable range for consumer tastes Thus, 7% and 9% are the assigned boundary values Sardines produced with a salinity percentage that falls within that range are considered acceptable, and percentages below or above that range are respectively unacceptable
  • diagram 10a 1 of Figure 10a The population of data measurements from some process is shown in the figure This population substantially divides according to an obvious normal distribution
  • Line Xi represents a lower boundary value of x - 2 ⁇ and line y ⁇ represents an upper boundary value of x + 2 ⁇
  • Ai represents the boundary value range of input values less than x - 2 ⁇
  • Bi represents the boundary value range of input values between v - 2a and x + 2 ⁇ inclusively
  • Ci represents the boundary value range of input values greater than x + 2 ⁇ Input values within
  • Diagram 10a 3 (generally referenced as) 4014 in Figure 10a (generally referenced as) 4000 illustrates the assignment of three boundary values x 3 4016, y 3 4017, and z 3 4018 to a population of data measurements for an input, where the population of data measurements divides according to a decaying distribution curve 4015
  • a 3 4019 represents the lowest boundary value range for this input
  • B 3 4020 represents the next lowest boundary value range for this input
  • C 3 4021 represents the second highest boundary value range for this input
  • D 3 4022 represents the highest boundary value range for this input
  • Diagram 10a 3 in Figure 10a depicts an input constant or variable with three boundary values
  • the population of data measurements from some process is shown in the figure This population substantially divides according to an obvious decaying distribution
  • the boundary values have been determined according to 25% of the total population in the distribution (x 3 ), 50% of the total population in the distribution (y 3 ), and 75% of the total population in the distribution (z 3 )
  • a 3 represents the boundary value range of the lowest 250 measurements below a boundary value x 3
  • B 3 represents the boundary value range of the next 250 measurements between boundary values x 3 and y 3
  • C 3 represents the boundary value range of the next 250 measurements between boundary values y 3 and z 3
  • C 3 represents the boundary value range of the 250 highest measurements above the boundary value z 3
  • the boundary values in diagram 10a 3 have been determined according to 25% of the total of the possible domains of measurements with equidistant segments in the distribution (x 3 ), 50% of the total of the possible domain
  • the measurement scale is divided into the following boundary value ranges A 3 representing the range from 0-25%, B 3 representing the range from 25-50%, C 3 representing the range from 50-75%, and D 3 representing
  • boundary values and boundary value ranges are used in the context of the present invention as a means to create discrete values for data with values that fall within a continuous range
  • certain types of input constants and variables by their inherent
  • parallel tools in a given process are discrete values and can be considered as input
  • process input flows into any one of the three tools and the same types of input constants and variables exist at each tool
  • process control it has
  • An embodiment of the present invention uses the boundary value ranges assigned to input constants and variables to form data vectors for a given stage in a process
  • Each input constant or variable is a component entry of the vector
  • the following 24 data vectors exist for the output produced by the inputs depicted in Figure 10a ⁇ (A- , A 2 A 3 ), (Ai A 2 B 3 ), (A 1 A 2 C 3 ), (A 1 A 2 D 3 ), (A 1 B 2 A 3 ), (A, B 2 B 3 ), (A, B 2 C 3 ), (A, B 2 D 3 ), (B, A 2 A 3 ), (B, A 2 B 3 ), (B, A 2 C 3 ), (B A 2 D 3 ), (B, B 2 A 3 ), (B 1 B 2 B 3 ), (B !
  • 10a 1 represents an input constant
  • 10a 2 and 10a 3 represent input variables at a given stage in a process
  • x 2 10 00 mm
  • a 2 is the boundary value range for values less than or equal to 10 00 mm
  • B 2 is the boundary value range for
  • Figure 10b illustrates a Data Arrays table of data arrays 5000 for a given stage in a process
  • the table is composed of a column for the number of the process run 5001 , columns for process input 5002, and a column for a given process output constant 5006
  • the inputs at this process stage are input constant 10a 1 5003, input variable 10a 2 5004, and input variable 5005 Values for these inputs corresponding to the data vector (Bi A 2 D 3 ) are received at the second process run 5007, the e' h process run 5008, the e+ 1 th process run, and the f" 1 process run
  • the value for the given output constant for the second process run is O 2 5011
  • the value for the given output constant for the e"' process run is O e 5012
  • the value for the given output constant for the e+ 1 lh process run is O e+ ⁇ 5013
  • the value for the given output constant for the f h process run is O f 5014, also ith In
  • Figure 10c (generally referenced as) 6000 illustrates a sample vector in a vector look-up table
  • the table is composed of columns for the data vector 6001 and columns for the given output constant data 6002
  • the entries of the vector for the sample vector depicted in this table are input constant 10a 1 6003, input variable 10a 2 6004, and input variable 10a 3 6005
  • the types of output constant data recorded in this vector look-up table are Average 6006, Standard Deviation 6007, and Population 6008
  • the sample vector is vector
  • the data arrays are sorted according to the data vectors they correspond to, and various meaningful statistical calculations are performed on the output data
  • data arrays corresponding to the vector (B ⁇ A 2 D 3 ) were received for process runs 2, e e and f
  • Figure 10c the output data for these four process runs is taken and the average and standard deviation of these four output values is calculated
  • the average value O , the standard deviation ⁇ (O), and the population number 4 are then entered in the vector look-up table in Figure 10c by vector (Bi A 2 D 3 )
  • This output data is used by embodiments of the present invention for optimization of the given output constant
  • other types of meaningful statistical calculations are performed on output data by embodiments of the present invention, such as determining the output constant's Process Capability Ratio (C pk ), and the results of these calculations are used for process control optimization of that output
  • C pk Process Capability Ratio
  • PIQ The conventions of assigning boundary values to input data and sorting input data into data vectors enable detection of problematic input combinations and detection of input combinations that were assumed to yield output that is out of process specification standards and actually yield output that is within process specification standards
  • embodiments of the present invention provide appropriate system responses
  • One of these responses is a self-adjusting feature which automatically adjusts process input that is out of process specification standards to within specification standards
  • Other system responses include the sending of automated reports to the process engineer, or in more serious cases the sounding of an alarm or even cessation of process execution altogether
  • Data that is categorized as input constants, output constants, input variables, or monitored parameters can be either empirical or derived Empirical data is defined as data obtained from actual process runs Derived data is data obtained from conjecturing or mathematical calculations An embodiment of the present invention uses either empirical or derived data, or a combination of the two data types, for the purposes of process control optimization
  • a specific type of derived data that is used by an embodiment of the present invention is data derived from Design of Experiment (DOE) DOE data is obtained by first choosing a limited sample population representing the spectrum of possible values for input constants and input variables at a given stage in a process, running the process with all possible combinations of this limited sample population, and monitoring the output at the given stage for each possible combination Based on the results of these process runs, a mathematical formula is derived that allows for interpolating or extrapolating process output for any possible combination of input constant values and input variable values, and with this formula output data is derived for the entire
  • a Run-to-Run control mode relates to a process control system that determines, based on previous runs of the given process, the optimal setting of process input variable value(s) at a given process tool or module in order to obtain or proximate one or more output target values at that tool or module
  • Process control optimization in the Run-to-Run control mode is implemented at the given tool or module by two methods, known as the Feed Forward and Feed Back closed control loops
  • the preferred embodiment of the present invention accesses data from previous process runs and the current process run, and determines optimal settings for input variables on-line (i e while the process is occurring), allowing automated optimization of output for the current process run without significant delays and without halting operation of the given process
  • Figure 11 illustrates a vector look-up table for an output constant "O 7000 at a given process stage
  • the table is 5 composed of columns for data vectors 7001 and columns for the output constant data for O ⁇ 7002
  • the entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 7003, input variable 10a 2 (generally referenced as) 7004 and input variable 10a 3 (generally referenced as) 7005
  • the types of output constant data recorded in this vector look-up l () table are Average 7006, Standard Deviation 7007, and Population 7008
  • Output constant data is recorded in the look-up table for vectors (Ai , A 2 , C 3 ) 7009, (Bi, A 2 , D 3 ) 7010, (C 1 t A 2 , A 3 ) 7011 , (d , A 2 , B 3 ) 7012, (C 1 t A 2 , C 3 ) 7013, (Ci, A 2l D 3 ) 7014,
  • the first step in implementing the Feed Forward closed control loop is to choose an optimal vector from the vector look-up table This optimal vector is chosen by
  • the vector with the output constant average value closest to the output target value or to the midpoint of the output target value range is chosen as the optimal vector For
  • the target value for O is 10 00 mm
  • O ⁇ 10 02 mm for vector (Ci , A 2 , B 3 )
  • O, 10 04 mm, for vector (Ci , A 2 , C 3 ),
  • O, 9 96 mm, for vector
  • vector (Ci , B , C 3 ) satisfies the second criterion for choosing the optimal vector in the first step of the Feed Forward closed control loop, because its average value for 0_ is closest to the output target value
  • the output constant standard deviation and population number are also considered when choosing the an optimal vector
  • a vector with an average value that is only 01 mm from the output target value but with a large standard deviation and low population number may be less preferable than a vector with an average value that is 02 mm from the output target value but with a low standard deviation and high population number
  • the vector with the lower standard deviation but average value farther from the output target value might be chosen as the optimal vector, and by applying an offset factor to this vector, it is possible to obtain an average output value for this vector closer to the
  • Another criterion for choosing the optimal vector is input constraints. That is, there may be certain input variable boundary value ranges that are considered unacceptable and will therefore disqualify certain vectors which otherwise meet the optimal vector criteria For example, assume that an input constraint exists on input variable 10a.3 such that boundary value range A 3 is considered unacceptable This would therefore disqualify vector (C, , A 2 , A 3 ) Reasons for input constraints can be cost or efficiency related, or can be related to the subjective considerations of the given process.
  • Feed Forward closed control loop is to find the next best optimal vector that most closely fits the criteria established for finding the optimal vector. If the output constant average value of the optimal vector is greater than the target value, then the output constant average value of the next best optimal vector must be less than the output target value. Alternatively, if the output constant average value of the optimal vector is less than the output target value, then the output constant average value of the next best optimal vector must be greater than the output target value.
  • a special smoothing algorithm is applied to the two vectors which interpolates the two vectors by means of piece-wise linearization, or linear regression, or the like. The result of this algorithm is a recipe with
  • O ⁇ for vector (d, B 2 , C 3 ) is 10.01 mm, which is a hundredth of a millimeter greater than the output target value of 10.00
  • the average output value of 9.98 mm is closer to the output target value of 10.00 mm than 9 96 mm Therefore, vector (Ci, A 2 , D 3 ) is chosen as the next best optimal vector.
  • the smoothing algorithm is then applied to vectors (Ci , B 2 , C 3 ) and (Ci, A 2 , D 3 ), and returns a resulting recipe for input variables 10a.2 and 10a.3 in order to receive the output target value of 10.00 mm for output constant ⁇ .
  • Part of this smoothing algorithm involves giving greater priority to the optimal vector according to the proximity of the optimal vector's output constant average value to the output target value.
  • the smoothing algorithm returns interpolated recipe values for input variables that are more likely to be within the boundary value ranges of the input variables in the optimal vector than in the boundary value ranges of those input variables in the next best optimal vector For the current example, this means that the recipe value for input variable 10a.2 is more likely to be in the B 2 range than in the A 2 range, and that the recipe value for input variable 10a.3 is more likely to be in the C 3 range than in the D 3 range.
  • Feed Back Closed Control Loop In the Feed Back closed control loop, optimal correction of input variable values at a given stage in a process is achieved through data analysis of the
  • An embodiment of the present invention allows for optimization of multiple outputs in the Feed Forward closed control loop
  • Current methods of standard process control are substantially unable to optimize multiple outputs in the integrated fashion that the embodiment of the present invention for optimizing multiple outputs does
  • the present invention provides a unique and revolutionary approach to process control optimization of multiple outputs
  • Figure 12 (generally referenced as) 8000 illustrates a vector look-Up tables for multiple outputs constants O ⁇ and O 2 at a given process stage 8000
  • the table is composed of columns for data vectors 8001 , columns for the output constant data for O ⁇ 8002, and columns for the output constant data for
  • O 2 8003 The entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 8004, input variable 10a 2 (generally referenced as) 8005, and input variable 10a 3 (generally referenced as) 8006
  • the types of output constant data recorded for output constant Oi are Average 8007 Standard Deviation 8008, and Population 8009
  • the types of output constant data recorded for output constant O 2 are Average 8010, Standard Deviation 8011 , and Population 8012
  • Output constant data is recorded in the look-up table for vectors (Ai , A ?
  • the embodiment of the present invention for optimizing multiple outputs carries out optimization of multiple outputs in two stages
  • the first stage is to try is implemented by first trying to find one or more common vectors for the multiple outputs at the given process stage
  • a common vector is defined as a vector with average values for the multiple output constants such that each constant's average value in the vector is within the target value range for that constant
  • Figure 12 presents a vector look-up table for multiple outputs based on the vector look-up table for output constant Oi from Figure 11
  • O 2 O f and O 2 are both output constants at one given stage in a process and the inputs to this process stage are input constant 10a 1 and input variables 10a 2 and 10a 3
  • the value for the input constant 10a 1 for the current process run is in the Ci boundary value range
  • vector (Ci , B 2 , C 3 ) has an average value closer to the midpoint of the target value range, for the purposes of optimizing multiple outputs with the common vector embodiment of the present invention, all vectors with average values within the target value range are considered
  • Output constant Oi was found to have vectors (Ci , A 2 , D 3 ) and (Ci, B 2 , C 3 ) in its output target value range
  • output constant O 2 was found to have vectors (Ci, A 2 , C 3 ) and (Ci , A 2 , D 3 ) in its output target value range Therefore, it is clearly seen that these two output constants share the common vector (Ci , A 2 , D 3 ) in their respective target value ranges (d, A 2) D 3 ) is the optimal vector for output constants Oi and O 2
  • the recipe for optimizing these multiple outputs is determined by taking the midpoints of the boundary value ranges of input variables 10a 2 and 10a 3, which in this case are the midpoints of boundary value ranges A 2 and D 3
  • the optimal vector for multiple outputs would not necessarily be the optimal vector for each output constant if each output constant is analyzed on its own without regard to the other output constants
  • output constant Oi was found to have vectors (Ci, A 2 , D 3 ) and (Ci, B 2 , C ) in its output target value range, with vector (d, B 2 , C 3 ) having the closest average value to the midpoint of the target value range
  • (Ci , B 2 , C 3 ) would be its optimal vector
  • vector (Ci, B 2 , C 3 ) does not fall within the target value range for output constant O 2
  • vector (Ci , A 2 , D 3 ) does Likewise, in regards to output constant O 2 , vector (Ci , A 2l D 3 ) would not be its optimal vector if O 2 is analyzed on its own, since vector (d, A 2 , C 3 ) has the closest average value to the midpoint of the
  • weighting algorithm is applied to this situation in the same manner as it was applied in the previous example with output constants Oi and O 2 and common vectors (Ci, A 2 , D 3 ) and (d , B 2 , C 3 )
  • weightings must be assigned to the three vectors (C, , A 2 , B 3 ), (Ci , A 2 , D 3 ) and (d B 2 , C 3 )
  • the optimal vector for O 3 (Ci , A 2 , B 3 ) receives the greatest weight of the three vectors
  • vector (Ci , A 2 , D 3 ) receives a greater weighting than vector (CL B 2 , C 3 ) as in the previous example
  • the recipe value for the input variable 10a b will now very likely be close to the midpoint of boundary value A 2 since vector (Ci , A 2 , A 3 ) (with the greatest weighting) and vector (Ci, A 2 , D 3 ) (with the second greatest weighting
  • the schematic diagram in Figure 13 (generally referenced as) 9000 illustrates in a schematic diagram a stage in the Chemical/Mechanical Polishing process of a silicon wafers at Tool “1 " 9001
  • the Inputs constants at "Tool-1” are Th ⁇ ckne.ss-In 9002, and Pad Life 9003, Input variables at “Tool-1” are Time 9004, Pressure 9005, and Speed 9006, output constants at "Tool-1 " are Uniformity 9007 and Imal -Thickness 9008
  • Run-to-Run algorithm mode is applied to this process and calculates the Feed Back and Feed Forward corrections Closed Control Loops are implemented for process run n as follows
  • Model ' pr e (n-j) is the model predicted value of output constant Final-Thickness at run (n-j), which is the average value for output constant Final-Thickness taken from the vector look-up table for process run (n-j)
  • ⁇ ⁇ . j is the standard deviation of output constant Final-Thickness at run (n-j), taken from the vector look-up table for process run (n-j).
  • P is a correction coefficient used to correct discernible deviation trends.
  • n More than one common vector is found - from the common vectors found, determine the preferable vector for Uniformity and the preferable vector for Final-Thickness Assign weightings to Uniformity and Final-Thickness and apply the weighting algorithm to their preferable vectors to obtain the process recipe for input variables Pressure. lime, and Speed
  • the determination of optimal values for input variables is based on both output values from previous runs, and the values of input constants for the current process run That is, the calculation of the average offset for Uniformity and Final-Thickness and their new output target value ranges for run n is a case of using output values from previous runs to determine optimal values of input variables for run n, and the selection of optimal vectors from the vector look-up table is a case of using the values of input constants for the current process run to determine the optimal values of input variables.
  • the Feed Back and Feed Forward closed control loops are implemented together
  • the preferred embodiment of the present invention implements both control loops together.
  • both control loops can be implemented independent of the other.
  • input constant data for the current process run is used to determine the optimal values for input variables without known output data, thus operating only in the Feed Forward closed control loop and not the Feed Back closed control loop.
  • input constant data for the current process run is used to determine the optimal values for input variables without known output data, thus operating only in the Feed Forward closed control loop and not the Feed Back closed control loop.
  • 1 output value data is used to determine the optimal values for input variables without using input constant data, thus operating only in the Feed Back closed control loop and not the Feed Forward closed control loop.
  • An embodiment of the present invention allows for updating the data stored in the vector look-up table. Every time a process run is executed, the data for that run is processed according to the various methods that have been described up to this point, and with that data, the vector look-up table is eventually updated The ability for the look-up table to be updated is of particular significance when data in the look-up table has been generated through Design of Experiment (DOE). Because the data from DOE is almost entirely derived data, output data derived from DOE is inherently less accurate than output data obtained from recording the results of actual process runs. Therefore, the ability to update a look-up table containing DOE data with data from actual process runs is essential.
  • DOE Design of Experiment
  • the embodiment of the present invention for updating the look-up table with recent empirical data is designed so that the process engineer can determine with what frequency the look-up table will automatically be updated. In many process control situations, it is neither efficient nor desirable to update the look-up table after every process run or even after every few process runs, and it is necessary to allow the process engineer to set the frequency for updating the look-up table based on the specific requirements of and constraints on the given process. This frequency can sometimes be even periods of weeks or months. Other embodiments of the present invention allow for analysis of output data in the look-up table and correction of model predicted output values.
  • the actual values of output constants recorded during recent process runs are compared with the model predicted values for that output constant according to the vector look-up table
  • Recent process runs are defined as process runs whose data has not been used to update the vector look-up table
  • the differences, hereinafter residuals, between the actual values and the model predicted values of the output constant are calculated, and the residuals for each vector are examined If, for all the residual values calculated, a common residual value is observed, then this common residual value is used to correct the model predicted output values
  • Figure 14 (generally referenced as) 10,000 illustrates a vector look-up table 10,001 for output constant Oi at a given process stage, an Actual Values column 10,002 which is not part of the vector look-up table, and a Residual Values column 10,003 which is not part of the vector look-up table
  • the vector look-up table 10,001 is composed of columns for data vectors 10,004 and columns for the output constant data for d 10,005
  • the entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 10,006, input variable 10a 2 (generally referenced as) 10,007, and input variable 10a 3 (generally referenced as) 10,008
  • the types of output constant data recorded in this vector look-up table are Average 10,009, Standard Deviation 10,010, and Population 10,011
  • Output constant data is recorded in the look-up table for vectors (Ai, A 2 , C 3 ) 10,012, (Bi, A 2 , D 3 ) 10,013,
  • the Residual Values column 10,003 contains values ⁇ o ⁇ (A ⁇ , A 2 , C 3 ) 10,026, ⁇ 0 ,(B ⁇ , A 2 , D 3 ) 10,027, ⁇ o ⁇ (C, , A 2 , A 3 ) 10,028, ⁇ 0 ⁇ (C ⁇ , A 2 , B 3 ) 10,029, ⁇ 0 ⁇ (C ⁇ , A 2 , C 3 ) 10,030, ⁇ o ⁇ (C, , A 2 , D 3 ) 10,031 , ⁇ 0 ⁇ (C,, B 2 , C 3 ) 10,032
  • the Actual Values 10,002 are compared with the predicted values according to the Vector Look-Up Table for Output Constant "O1" 10,001 and the calculated difference between them is the Residual Value 10,003
  • FIG. 14 depicted is the vector look-up table for output constant d at a given process stage which has been seen previously in Figures 11 and 12, with the noticeable difference that the population numbers for each vector are much greater now than they were in Figures 11 and 12
  • the process is now executed another 70 times with varying input combinations that correspond to the vectors in the look-up table depicted in Figure 14
  • the values for Oi for these 70 process runs are recorded but the look-up table is not updated with these values
  • the column to the right of the look-up table contains the average of the actual values of Oi received during the 70 recent process runs for each vector in the look-up table, and the column on the far right contains the residual values of Oi for each vector in the look-up table That is, assume that during the 70 recent process runs, the process was executed 10 times for each vector in the look-up table
  • the value Act 0 ⁇ (A ⁇ , A 2 , C 3 ) is the average of the 10 values received for Oi the when the process was executed with input combinations corresponding to the boundary value ranges Ai, A 2 , and C 3
  • the value Acto.(Bi , A 2 , D 3 ) is the average of the 10 values received for d when the process was executed with input combinations corresponding to the boundary value ranges Bi, A 2 , and D 3 , and likewise preferably for all the values listed in the Actual Values column
  • the column on the far right contains the residual values of Oi for each vector in the look-up table That is the value ⁇ O1 (A ⁇ ,A 2 ,C 3 ) in the first row of the residual values column is the difference between Oi of vector (Ai, A 2 , C 3 ) and Acto ⁇ (A ⁇ , A 2 , C 3 ), ⁇ o ⁇ (B ⁇ , A 2 , D 3 ) is the difference between ().
  • Another embodiment of the present invention analyzes respective residuals and their corresponding model predicted values for each vector in the output constant's vector look-up table to determine whether a functional
  • FIG. 15 (generally referenced as) 11 ,000 illustrates a process module of two tools
  • a schematic diagram for APC on a Module Level 11 ,000 “Tool “1 " 11 ,001 and “Tool-2” 11 ,002”
  • Tool-1 has input constants T cknes s-m 11 ,003 and Pad Life- 1 11 ,004, has inputs variables "Time -I” 11 ,005, “Pres sure -I” 11 ,006, and “Speed -I " 11 ,007, and input constants (whose values are used in feed forward 11 ,001 to adjust the aforementioned input variable values) "Pad Life 1 " 11 ,003, and Thickness-in 11 ,004, and output constant Thickness-out 11 ,008
  • Tool-2 has input constants Thickness-out 11 ,008 (which is also an output constant from “Tool-1”) and Pad L ⁇ fe-2 11 ,009, input variables T ⁇ me-2 11 ,010, Presswe-2 11 ,
  • Tool-1 and Tool-2 Tool-1 has input variables T ⁇ me-1, Pressure- 1. and Speed-1, input constants Pad Life- 1 and Th ⁇ ckness- ⁇ n, and output constant Thickness-out, which is also an input constant to Tool-2.
  • Tool-2 has input variables T ⁇ me-2, Pressure-2, and Speed-2, input constants PadL ⁇ fe-2 and Thickness-out (the output constant from Tool-1 ), and two output constants Uniformity and Final-Thickness.
  • Embodiments of the present invention can be applied to a process module such as the one depicted in Figure 15 for optimization of the output constants Uniformity and Final-Thickness at Tool-2 by means of the input constants and variables at Tool-1 Assume that a recipe of input values at Tool-2 has been determined for the optimization of the multiple outputs constants Uniformity and Final-Thickness This recipe contains a specific value or value range for the input constant Thickness-out at Tool-2.
  • Thicknes s-out is also an output constant for Tool-1
  • embodiments of the present invention are applied to Tool-1 to determine a recipe for the output target value or target value range of Thickness-out, where the output target value or target value range for Ihickness-out is the input constant value or value range of Thickness-out in the recipe for optimizing multiple outputs Uniformity and Fmal-Thicknes s That is, the recipe value of Thickness-out when optimizing multiple outputs constants I fnal-l uckness and Uniformity serves as the output target value for the recipe at Tool-1
  • embodiments of the present invention can be applied on non-sequential module configurations such as the module depicted in Figure 16 Figure 16 depicts a module of four tools, where Tools 1 a, 1b, 1 c run parallel to each other in either a simultaneous or alternate manner and send output to Tool-2
  • the output constants of Tools 1 a, 1 b, and 1c are input constants to Tool-2
  • an output target value is known for the output constant Final Output at Tool-2
  • a recipe for receiving the target value of Final Output is obtained using embodiments of the present invention
  • the values of the input constants in the recipe for Final Output at Tool-2 then serve as the output constant target values for the recipes at Tools 1a, 1b, and 1c
  • this embodiment of the present invention determines the output target values at each of the parallel tools and then determines the recipe for input variables and constants at each parallel tool

Abstract

A strategic method for process control wherein the method includes, for a predetermined process juncture, the steps of: (A) defining an interconnection cell (3000) having associated therewith (i) at least one set of input data (3002) or at least one set of process control parameters (3004), and (ii) at least one set of output data (3005); (B) assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell (3000); (C) using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and (D) for the interconnection cell (3000), processing data from the plurality of respective formed set combinations into respective corresponding data record clusters.

Description

Strategic Method for Process Control
This is a continuation in part of U.S. Patent Application Number 09/588,681 filed on 07 June 2000, the specification of which is incorporated herein by reference.
FIELD OF THE INVENTION
The present invention generally relates to a method for controlling a manufacturing-type or like process, and to search-space organizational validation of inputs, outputs, and related factors therein.
More specifically, the present invention relates to synergistically combining disparate resolution data sets, such as by actual or simulated integrating of lower resolution expert-experience based model-like templates to higher resolution empirical data-capture dense quantitative search-spaces, and to establishing a process control strategy therewith.
Furthermore, given the inherent interdisciplinary nature of the present invention, from alternative technological vantages, the present invention may also be understood to relate to embodiments where this synergetic combining is beneficially accomplished, such as in control systems, command control systems, command control communications systems, computational apparatus associated with the aforesaid, and to quantitative measuring tools used therewith. Equivalently, the present invention may be understood to relate to domains in which this synergetic combining is applied, such as fabrication of semiconductors or of integrated circuits, medical treatment modalities, social engineering models, corporate management enterprise systems, transactional modifications for financial business practices, or substantially any other organized modality of practice or information, technological, bio-physical, mercantile, social, etc
BACKGROUND OF THE INVENTION
Process control has historic origins in improving the yield and efficiency of manufacturing enterprises Numerous methods for process control are used in countless domains of instantiation Inclusive of their variations and combinations, process control techniques are presently finding application in improving the yield and efficiency of logical and physical processes, including technological, bio-physical, mercantile, and social enterprises These diverse types of enterprises, along with classical manufacturing type enterprises are presently evolving into hyper-complex data management and optimization tasks
Given the seemingly ever-increasing capacity of computer processing to perform tasks (e g data gathering, data storage, data management, and data related modeling), and given that this growth of task performance provides logical facilities for higher complexity modeling activities, there has arisen a pressing need in the art for facile tools that provide accurate strategies for managing process control activities Furthermore, there is a continuously growing need for strategic methods for integrating a plurality of locally optimized processes into some presumptive better global optimization This need has stood as a substantial barrier to the broad application of process control, even in manufacturing enterprises that only have the seemingly straightforward tasks of unifying already process controlled tools into process controlled modules, and then into process controlled manufacturing enterprise systems (MES) Simply stated, there is a need in the art for a strategic process control method that will extend the known benefits of process control to higher order activities There is an especially long felt need for a strategic process control method that is, on the one hand, conceptually facile for varying levels of process control professionals to use, and that is, on the other hand, facile for integration with higher order mathematical modeling theories
There follows five Internet accessible references, which each independently attempts to articulate solutions to substantial sub-sets of the aforesaid outstanding needs It should be appreciated that even if these references were combined into some hybrid system, there would still remain the aforesaid outstanding needs, especially since any such combination would decimate any operational expectation for conceptual simplicity
http //www lac honeywell com/|ournal/feb97/|29739 htm
Open solutions a strategic approach - Paul Peters - Senior Process Control Engineer - Hoechst Celanese Bishop Plant - Bishop, Tx
http //www lac honeywell com/services/networks/about htm
ABOUT INDUSTRIAL-STRENGTH NETWORKS - Overview -
Manufacturers are recognizing the increasing value of integrating specific information embedded within the process control domain into the business information domain and vice versa The availability and accuracy of this information is critical to the success of your enterprise
http //www qintic qov sq/recruιt1 html R&D in Manufacturing Technology - Gintic is a national research institute proactively involved in collaborative applied R & D projects with the industry and contract research Funded by the National Science and Technology Board, Gintic's mission is to enhance the competitiveness of the Singapore industries through the generation and application of advanced manufacturing technology
http //www tu-chemnitz de/wιrtschaft/wι2/loos/wbf95/wbf95 htm
Production Management - Linking Business Applications to Process Control - Peter Loos - Institut fuer Wirtschaftsinformatik -University of Saarland, Saarbr^ cken, Germany - published in World Batch Forum 1995 (Proceedings, Newtown Square, PA, May 22-24, 1995), pp 2 1 -2 16
http //www ece orst edu/~barreta/sme/sme htm
A Software Architecture and Environment for Flexible Manufacturing - Spencer B Barrett - Member of Technical Staff - Intelledex, Incorporated - Corvallis, Oregon, CONFERENCE. Semiconductor Manufacturing - October 30 1990 - Tempe Arizona - This paper describes a process control software system for manufacturing cell and cluster control An object-oriented approach that permits on-line configuration of objects provides a simplistic, flexible and extendible system Automated design tools help create, analyze, document, and maintain the different classes of objects used in the system
Collectively, the preceding five Internet accessible references have numerous common factors All of them are forced into some sort of multi-level approach in order to express the complexity of integrating an ensemble of interrelated process events into a single MES-type view The parent application of the present invention was likewise forced into constructing a multi-layer model in order to express the complexity of integrating an ensemble of interrelated process events into a single MES-type view
However, the resultant integration, implementation, and process control method of the prior art (such as those described in these references) remain excessively cumbersome, and do not lend themselves to any proof of their respective efficacy There remains a need in the art for improvement in process control, especially for a facile integration of any arbitrary plurality of interrelated process events
ADVANTAGES, OBJECTS, AND BENEFITS OF THE INVENTION
Technological Need Issues The present invention provides a process control methodology that is easy to reverse engineer with existing process control systems, including existing data capture systems, process management systems, and operational alert and alarm initiation systems More specifically, the present invention provides a process control methodology wherein, on the one hand, professionals (e g process engineers, experts, consultants, managers, and even machine operators) may participate in providing a preliminary definition of factors worthy of consideration when implementing process control for a particular process juncture and, on the other hand, empirical data may be applied to objectively provide actual operational weightings between these multi-parametric factors Ultimately, the present invention provides process control, yielding improved productivity and efficiency Furthermore, the present invention provides analytical derivative result, in the form of a discrete empirical model of the process juncture, which is equivalent to or an improvement over that provided by the participating professionals
Ergonomic Need Issues In that the present invention is focused on developing a greatly simplified family of discrete combinatorial cases for a process juncture, both expressing concepts of relationships affecting the performance at that juncture and subsequently appreciating the actual performance at that juncture Furthermore, this simplification extends to integrating process junctures into aggregates, such as integrating tools into a module or integrating modules into an MES
Economic Need Issues Notwithstanding the aforesaid technological and ergonomic need issues, the present invention provides at least an equal improvement in process control performance as existing systems, with an added value of being able to be further integrated into larger units of process control It is however likely that for most application the method of the present invention will also provide an improved process control performance to known general-purpose process control methods NOTICES
The present invention will forthwith be described with a certain degree of particularity, however those versed in the art will readily appreciate that various modifications and alterations may be carried out without departing from either the spirit or scope, as hereinafter claimed
By way of reference, it should be noted that many broad aspects of the present application have their antecedent basis in the parent application - Knowledge-Engineering Protocol-Suite, (U S Patent Application Number 09/588,681 filed on 07 June 2000) In order to provide the reader with a coherent transition from the parent application to the present application, the following observations may be useful
The term 'input set combination' in the present application should be understood as substantially equivalent to the term 'n-tuple' from the parent application
The term 'interconnection cell at a predetermined process juncture' in the present application should be understood as a combination of the terms
'first plurality of correlated data sets' and 'second plurality of interrelated nodes of graph-directed expertise-suggested data-set relationships' from the parent application
The term 'validating' in the present application should be understood as a specific embodiment of the term 'simulating a validity-metric' from the parent application The concepts of updating the vector look-up table and the self-correcting feature of the vector look-up table in the present application should be understood as an embodiment of the concept of 'improving the weighted component' in the parent application One of the descriptions for validating' in the parent application is
'generating a conditional statistical process-control distribution function and convoluting the conditional distribution function with the present weightings' The preferred embodiment of validation according to this description is the strategic method of the present invention Due to constraints and goals that affect obtaining a process recipe, it is sometimes beneficial to use a representational search-space that differs from the simple vectors and the vector look-up table described in the present application, such as empirical manifolds or multi-dimensional manifolds as described in the parent application In order for the reader to further appreciate these correspondences between the parent application and present application, the references to and descriptions of Figures 30, 31 a, 31b, 32, and 33 in the parent application are noteworthy
Furthermore, it should generally be appreciated by the man of the art that the present invention, in whole or in part, may be used independently of the Knowledge-Engineering Protocol-Suite or may be used as a part of the preferred integral embodiment of the Knowledge-Engineering Protocol-Suite GENERAL OVERVIEW OF THE INVENTION
The present invention relates to a strategic method for process control wherein said method includes the steps of' for a predetermined process juncture defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell, using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters.
Various embodiment of the present invention relate to aspects of the step of defining an interconnection cell.
According to an embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to a single stage in a process map.
According to another embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to a group of contiguous stages in a process map. According to a further embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to a group of discontiguous stages in a process map
According to a different embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to a group of cells in a process map, which includes therein substantially every stage in the process map
According to yet another embodiment of the present invention, defining an interconnection cell includes representing the interconnection cell as corresponding to at least two interrelated interconnection cells in a process map
According to still a further embodiment of the present invention, defining the interconnection cell includes associating therewith derived data
According to a different embodiment of the present invention, defining the interconnection cell includes associating therewith values generated by a Design-Of-Expeπments assessment of the predetermined process juncture, to be used for initialization of a like-process
According to a similar embodiment of the present invention, defining the interconnection cell includes associating therewith values computed using at least one predetermined formula
According to the preferred embodiment of the present invention, defining the interconnection cell includes validating at least one set of the at least one set of input data to the interconnection cell as respectively having a substantially significant correlation with a set of the at least one set of output data Furthermore, according to the preferred embodiment of the present invention, said validating includes calculating a correlation coefficient between a selected set of the at least one set of input data, and the at least one set of output data; for the interconnection cell Likewise, according to the preferred embodiment of the present invention, assigning at least one boundary value includes analyzing data in the respective set wherein the at least one boundary value is to be assigned
Also, according to the preferred embodiment of the present invention, analyzing data in the respective set includes examining the data according to at least one predetermined criterion
In addition, according to the preferred embodiment of the present invention, examining the data according to at least one predetermined criterion includes electing a criterion selected from any one or more of the following lists: input constraints, process constraints, or output goals Input constraints within a specification limit, within a range of values, below an upper limit, above a lower limit, closest to a mid-range value, closest to a previously used value Process constraints closest recipe to most recent recipe, within a specification limit, within a range of values, below an upper limit, above a lower limit, closest to a mid-range value. Output goals, within a specification limit, within a range of values, a predetermined target value, an upper specification limit, a lower specification limit, below an upper limit, above a lower limit, closest to a mid-range value
In that the method of the present invention relates to a step of - for a predetermined process juncture - defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of
li process control parameters, and secondly at least one set of output data, various embodiments of the present invention relate to sources or origins of the contents of each of these sets, be they containing data or be they containing parameters According to one such variation of the present invention, said at least one input data set includes historical empiric data obtained from a previously performed like-process
According to another such variation of the present invention, said at least one input data set includes data currently being obtained from a substantially presently ongoing like-process
Independently, various embodiment of the present invention relate to aspects of the step of processing data from the plurality of respective formed set combinations into respective corresponding data record clusters According to an embodiment of the present invention, processing includes summarizing data in each respective corresponding data record cluster
According to another embodiment of the present invention, processing includes implementing a Run-to-Run process control mode According to a further embodiment of the present invention, processing includes running a feed back closed control loop
According to yet another embodiment of the present invention, processing includes running a feed forward closed control loop According to the preferred variation of this embodiment, running a feed forward closed control loop includes substantial optimization of multiple outputs
ιa According to a different embodiment of the present invention, processing includes transforming each summarized respective corresponding data record cluster into a sub-manifold of a multi-vaπate data manifold
According to still a further embodiment of the present invention, processing includes transforming each summarized respective corresponding data record cluster into a search-space vector According to the preferred variation of this embodiment, transforming each summarized respective corresponding data record cluster into a search-space vector includes arranging at least one search-space vector into a vector look-up table Furthermore, according to the preferred variation of this embodiment, the at least one search-space vector-having been arranged into a vector look-up table-is updated by using a self-correcting adaptive system
According to still another different embodiment of the present invention, processing includes A for at least one process control parameter of the at least one set of process control parameters, prescribing at least one process control recipe-element for use in the predetermined process juncture, and
B designating the prescribed at least one process control recipe-element for use in the predetermined process juncture According to still another embodiment of the present invention, processing includes using robust optimization
According to still another further embodiment of the present invention, said processing includes characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation According to a variation of this embodiment, said using a statistical calculation includes calculating a process capability ratio According to another variation of this embodiment, characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation includes arranging the characterized data into a look-up table Furthermore, according to the preferred implementation of this variation, arranging the characterized data into a look-up table includes using the look-up table and therewith designating at least one process control recipe for use at the predetermined process juncture In the context of this preferred variation, it is further provided to preferably implement that using the characterized data in the look-up table includes smoothing the data In the context of the immediately preceding variation in its most preferred form, arranging the smoothed characterized data into a look-up table includes using the look-up table for designating at least one process control recipe for use at the predetermined process juncture Furthermore according to a different implementation of this variation, using the look-up table for designating at least one process control recipe for use at the predetermined process juncture includes selecting a best (recipe optimum) available vector and therewith deriving a process control recipe According to another preferred implementation of this mult faceted variation, using the look-up table for designating at least one process control recipe for use at the predetermined process juncture includes updating said look-up table by using a self-correcting adaptive system Furthermore, it is preferred to implement selecting a best available vector for use with the process control recipe by therein including running a feed forward closed control loop
According to another embodiment of the present invention, processing includes-to the predetermined process juncture associated with the interconnection cell-applying at least one of the respective corresponding data record clusters to the process occurring at that juncture In this context, it is preferred that at least one of the respective corresponding data record
N clusters is updated by using a self-correcting adaptive system In this context, it is alternatively preferred that applying at least one of the respective corresponding data record clusters includes reporting a process status, and that said reporting is initiated according to predetermined conditions
Also, according to an embodiment of the present invention, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters includes installing at least one data record cluster correspondence as a front end to a neural network wherein the neural network is used for controlling an aspect of the process at the predetermined process juncture
According to another embodiment of the present invention, the steps of the method are applied for optimizing a Chemical/Mechanical Polishing processing of silicon wafers
The present invention also relates to a substantially equivalently defined strategic method for process control wherein said method includes the steps of using a mapped plurality of graph-directed expertise-suggested interconnection cell relationships, defining a map referenced interconnection cell therein having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, and using the map referenced interconnection cell, designating at least one process control recipe
According to an embodiment of the substantially equivalently defined method of the present invention, defining includes, for the map referenced
'5 interconnection cell, validating at least one of the mapped plurality of graph-directed expertise-suggested interconnection cell relationships
According to another embodiment of the substantially equivalently defined method of the present invention, defining the map referenced interconnection cell includes validating the map referenced interconnection cell by simulating a validity-metric for an n-tuple of directed graph components of the map referenced interconnection cell
According to a further embodiment of the substantially equivalently defined method of the present invention defining the map referenced interconnection cell includes, for an n-tuple of directed graph components of the mapped interconnection cell, validating the map referenced interconnection cell by measuring if each of the at least one set of input data to the map referenced interconnection cell significantly contributes to that map referenced interconnection cell's output, wherein a predetermined convolution of these measuπngs constitutes an acceptable validity-metric
According to a different embodiment of the substantially equivalently defined method of the present invention, designating at least one process control recipe includes choosing another process control recipe whenever a particular obtained output value differs from a predetermined target value, by at least a predetermined value, thereby obtaining a new subsequent offset goal value closer to a predetermined target value
Optimally, in the context of this embodiment, obtaining a new offset goal value includes basing the value upon at least one output value from a previous similar process Furthermore, in the context of this embodiment it is preferred that basing a new offset goal value includes analyzing the at least one output value from a previous similar process by running a feed back closed control loop According to yet another embodiment of the substantially equivalently defined method of the present invention, defining a map referenced interconnection cell includes forming at least two search-space vectors
The present invention also relates to an article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including first computer readable program code for causing a computer to define an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, tied to the first computer readable program code, second computer readable program code for causing a computer to assign at least one boundary value to at least one set of the sets associated with the defined interconnection cell, and tied to the second computer readable program code, third computer readable program code for causing a computer to form a plurality of discrete respective set combinations, using the assigned at least one boundary value
The preferred embodiment of the article of manufacture further includes having computer readable program code embodied therein for causing a computer to arrange the respective corresponding data record clusters into a look-up table, for the interconnection cell Also the preferred embodiment of the article of manufacture is furthermore including a computer usable medium π having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including tied to the third computer readable program code, fourth computer readable program code for causing a computer to process data from the plurality of respective formed set combinations into respective corresponding data record clusters, for the interconnection cell
The present invention also relates to a program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including for a predetermined process juncture, defining an interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, for the predetermined process juncture, assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell, for the predetermined process juncture, using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and for the predetermined process juncture, for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters
0 The preferred embodiment of the program storage device is further including therein a method step whereby respective corresponding data record clusters are arranged into a look-up table
The present invention also relates to a system for performing strategic process control at a predetermined process juncture including
A apparatus for delineating an interconnection cell, said interconnection cell having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data,
B a computer having therein software for assigning at least one boundary value to at least one set of the at least one set of input data or to at least one set of the at least one set of output data, and having attached thereto data storage apparatus for storing the assigned data sets, C a compressor for performing multi-dimensional representing, ordering, and combining of a plurality of discrete respective set combinations from the stored assigned data sets, and
D a processor for processing data from the plurality of discrete respective set combinations into respective corresponding data record clusters
According to the preferred embodiment of the system of the present invention, the processor includes attached thereto an applier for applying at least one of the respective corresponding data record clusters Also, according to the preferred embodiment of the system of the present invention, the computer includes attached therewith at least one sensor for providing an
n input or output datum to the respective set of input or output data. Likewise, according to the preferred embodiment of the system of the present invention, the computer includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination In addition, according to the preferred embodiment of the system of the present invention, the processor includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
The present invention also relates to an article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including:
I first computer readable program code for causing a computer to define a map referenced interconnection cell having therein a mapped plurality of graph-directed expertise-suggested interconnection cell relationships and further having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data; II. tied to the first computer readable program code, second computer readable program code for causing a computer to use
■ ? fc the map referenced interconnection cell to designate at least one process control recipe
Furthermore, the present invention relates to a program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including for a predetermined process juncture, using a mapped plurality of graph-directed expertise-suggested interconnection cell relationships, defining a map referenced interconnection cell therein having associated therewith firstly at least one set of input data or at least one set of process control parameters, and secondly at least one set of output data, and for the predetermined process juncture, using the map referenced interconnection cell, designating at least one process control recipe
Summary of Definitions as Gleaned from the Prior Art:
Closed control loop - a process run with process control methods applied to
Controllable Input - input at a process step whose value is determined directly by the user In the context of the present invention, controllable input is also referred to as a control parameter
Control parameter - see controllable input Feed Back Closed Control Loop - A Feed Back Closed Control Loop refers to determining values for controllable input at a given process stage that will optimize one or more characteristics of the output at that stage based on values of those output characteristics from one or more previous process runs The Feed Back Closed Control Loop is a form of run-to-run control
Feed Forward Closed Control Loop - The Feed Forward Closed Control
Loop refers to determining values for controllable input at a given process stage that will optimize process output at that stage based on the values of measurable ιnput(s) at that stage for the current process run The Feed
Forward Closed Control Loop is a form of run-to-run control
Input -Input at a given process stage is anything that influences output at that process stage
Input constraint - a limitation on the possible range of values for a given input
Measurable Input - input at a process step whose value can be measured but cannot be controlled directly by the user
Manufacturing Execution (alternatively Enterprise) System (MES) - In a graph theoretic process map representation, a collection of nodes and edges representing tools and sub-tool process steps, MES is a highest level process control view of integration of tools into modules and modules into meta-modules
5Λ Module - a set of one or more tools that are configured to execute a part of a process
Open loop - a process run without process control methods applied to it
Output - the object or objects produced by a process for which the process is being carried out A process divided up into stages can have output at any of its given stages
Output constraint - when applying process control to optimize more than one output characteristic at a given process step, an output constraint exists when the optimization of one output characteristic inhibits the optimization of at least one other output characteristic at that process step
Robust optimization - optimization of an output characteristic by reducing variability around a target value for that output characteristic
Run - A run refers to one execution of a process with resulting output
Run-to-Run Control - a method of process control where the process is adjusted between runs for the purpose of optimizing one or more output characteristics
Process Step - a single stage in a process with measurable and/or controllable input and output In the context of the present invention, a process step is also referred to as a tool
Search-Space - the conceptualized universe of data structures (including the broad class of data-manifolds) and their respective and collective transformations - such as is appreciated by data-base theorists and artificial-intelligence theorists
Target value- the desired value for an output characteristic for which process control optimization is being applied
Tool - See "Process Step" (above), also a constituent part of a Module
Definitions for Terms Used in the Context of the Present Invention:
Boundary value - a value assigned to a continuous range of possible values for a control parameter, monitored parameter, input constant, output constant, or outside influence in order to create discrete values corresponding to that continuous range Alternatively, in the case where the range of values is discrete, then the boundary value logically divides the range of values into constituent subsets at least one having therein a plurality of discrete values
Boundary value range - a section of a continuous range of possible values for a control parameter, monitored parameter, input constant, output constant, or outside influence bounded by one or more boundary values
Data array - a set of values recorded for one process run for any combination of control parameters, monitored parameters, input constants, output constants, and outside influences
3\ Data set - a set of values for a given control parameter, monitored parameter, input constant, output constant or outside influence recorded over a series of consecutive process runs
Data vector - A unique combination of boundary value ranges selected for the purposed of process control optimization with embodiments of the present invention The preferred embodiment of the present invention uses data vectors with boundary value ranges for input variables and constants In the context of the present invention, a data vector is often referred to as simply a vector
Design of Experiment - a procedure preferably including interpolating and extrapolating output values for any possible combination of input values based on a limited sample population representing the spectrum of possible input values
Input set combination - The combination of data sets of input constants and data sets of input variables at a given interconnection cell
Interconnection Cell - An interconnection cell is an information unit describing the non-quantitative mutual dependency between one output and one or more inputs of a process step
Interrelationship - An alleged or validated relationship between two process stages such that when a particular control parameter is set at an earlier stage in the process, a certain resulting output is received at a later stage in the process
?5 Model Predicted Value - In the preferred embodiment of the present invention, the model predicted value is the predicted value for an output constant according to the vector look-up table The model predicted value for an output constant could also be understood as a vector's average value of that output constant
Next best optimal vector - The next best optimal vector is used together with the optimal vector by the smoothing algorithm when optimizing an output constant in the Feed Forward Closed Control Loop The next best optimal vector must have boundary value ranges for input constants that include the values of the current run's input constants If the optimal vector's model predicted value is greater than the output constant target value, then the next best optimal vector will have the model predicted value is usually closest to but less than the output constant target value, and if the optimal vector's model predicted value is less than the output constant target value, then the next best optimal vector will have the model predicted value that is usually closest to but greater than the output constant target value
Optimal vector - When optimizing an output constant in the Feed Forward Closed Control Loop, the optimal vector for that output constant is usually the vector with the closest model predicted value highest Process
Capability Ratio (Cpk) for that output constant to that output constant's target value and with boundary value ranges for input constants that include the values of the current run's input constants
Output Constant - an output constant is any user-defined characteristic of process output for which optimization is being applied
Λb> Outside Influence - a factor that is not considered input at any stage in a process and that is alleged or validated to influence output at a given stage in the process is an outside influence
Preferable vector - When optimizing multiple output constants and common vectors are found for the multiple output constants, a preferable vector for an output constant is usually the one vector from amongst the common vectors with the highest Process Capability Ratio (Cpk) model predicted value closest to the target value for that output constant Due to output constraints, a preferable vector is not necessarily an optimal vector, because one output constant s optimal vector may not be a common vector shared by the other one or more output constants
Process Juncture - a general nomenclature for designating where the method of the present invention is applied In its simplest and most widely applicable form, a process juncture is any node or edge in a graph-theoretic representation of a flow of information, goods, or services such as the knowledge tree in the parent application or a process map in the present application
Recipe - A recipe is a set of values for input constants and/or variables at a given process step for achieving an optimal value or values for one or more output constants at that process step
Smoothing algorithm - in the context of optimizing an output constant, smoothing refers to the procedure for finding a process recipe based on the optimal vector and the next best optimal vector The smoothing algorithm uses either piece-wise linearization, or linear regression, or the like to determine recipe values
el Vector look-up table - The table (or a like representation) stores data vectors In the context of the present invention, a vector look-up table is often referred to as simply a look-up table
Weighting algorithm - when optimizing multiple output constants and more than one common vector is found, a weighting algorithm is applied to each output constant's preferable vector whereby the vectors are weighted (i e prioritized) and the weighting algorithm uses these weightings to provide a recipe for optimizing the multiple output constants When optimizing multiple output constants and no common vector is found, the weighting algorithm is applied to each output constant's optimal vector whereby the vectors are weighted (i e prioritized) and the weighting algorithm uses these weightings to provide a recipe for optimizing the multiple output constants
Acronyms:
APC - Advanced Process Control (a variation or alternative to SPC)
CMP - Chemical Mechanical Polishing
DOE - Design of Experiment
IPC - Intelligent Process Control (a form of APC)
MES - Manufacturing Execution System (alternately Manufacturing Enterprise System)
R2R - Run-to-Run (a process control resolution metric) SPC - Standard Process Control (also often Statistical Process Control)
Synonyms, in the Context of the Present Invention:
input variable = control parameter = controllable input
measurable input = input constant
process step = tool
data array = data record
model predicted value = output constant vector's average value
Note: The semiotic nomenclature "step", "stage ", "juncture", "cell", and "node" are generally interchangeable Use of two or more of these terms in the context of any example may be for the purpose of expressing parts of a larger unit For example, a stage may be composed of constituent steps
Likewise, use of two or more of these terms in the context of any example may be for expressing a correspondence between different representations For example, a process map may be made of graph directed stages, and each stage may correspond to an interconnection cell dealing with data related to a juncture in an actual manufacturing operation Substantially, there are a number of related representations that borrow from the generally interchangeable nomenclature. For example, there is the referent location where a manufacturing or like-process event is performed, there is a graph theoretic representation of the event in the context of previous, subsequent, and related events, there is a information theoretic representation related to transformations or comparisons between data captured in the performing of the referent process event or the symbolic information structure representation thereof there are then "procedures" that attempt to deal with optimizing the referent process and likewise that attempt to deal with optimizing the information processing Simply stated, it should be apparent to the man of the art, from the context and construction of each example, that the intent of these generally interchangeable terms is to differentiate between at least two different aspects (often corresponding to parallel aspects in the seven layer knowledge-engineering protocol-suite of the parent application)
SUMMARY OF THE INVENTION
Simply stated, the present invention comes to "teach" a strategic method for process control which, for any juncture in a representation of a process (according to diverse topological definitions for the notion "juncture"), considers disparate quality "guesses" (recommendations) about what factors to consider when trying to optimize the juncture, and likewise unifies disparate quality definitions about what constitutes an optimization In the course of performing the steps of the strategic method of the present invention, conceptually useful intermediary representations are developed Probably, the most interesting of these representations is a lookup table, organized according to discrete combinations of "cases" that can occur at the juncture, which either presents the most probable best configuration (recipe) of process control "settings" to use at this time at the juncture or presents two such cases from which a best configuration may be interpolated The invention presents a strategic method for process control for use at a given process juncture, and includes defining an interconnection cell This interconnection cell has on one hand associated with it one or more sets of input data or one or more sets of process control parameters, and on the other hand at least one set of output data
Defining this interconnection cell entails delineating and designating a "block" (arbitrary unit) consisting of data associated with a given process at the given process juncture (sub-step, interconnection cell, group of cells, group of groups of cells groups of groups of cells, or any higher level MES), and stratifying this data into a number of sub-groups These subgroups may represent a particular item, batch, or combination thereof in a process This collection of subgroups allows data analysis to be performed according to respective sub-group-relevant metrics
Data collected for a given item or batch in a process is called a data vector Data vectors are sorted and grouped into data vector clusters according to similar input set combinations (The sorting process includes storing the data vectors that represent combmatorials of input and output process control parameters ) Data vector clusters may be stored in tabular form The table in which the data vectors are stored is called a vector look-up table
The vector chosen, used for process control includes the recipe for the process, because the values of the control parameters in that vector are used as the values for the control parameters for a current process run Processing includes, for a given process control parameter, prescribing at least one process control recipe-element, that is, some portion of the current recipe, for use in a predetermined process juncture Processing may further include summarizing data in each respective corresponding data set cluster Selecting
3\ a best available vector for use with the process control recipe preferably includes running a feed forward closed control loop
According to the preferred embodiment, a feed forward closed control loop involves the steps of process control (described below) of analyzing data and vector selection In a feed forward closed control loop, the data evaluation
(also described below), is usually performed according to the criterion of apparently being substantially closest to a predetermined target value
Analyzing data in any given respective data set includes examining or evaluating the data relevant to at least one predetermined criterion selected
Figure imgf000034_0001
a predetermined target value, an upper specification limit, a lower specification limit, within a specification limit, within a range of values, below an upper limit above a lower limit, closest to a predetermined target value, closest to a previously used value, closest to a mid-range value, or closest to most recent recipe Specific examples of criteria selected from the above list include
*> an average calculated from values collected during a previously performed single manufacturing process run from data relevant to the interconnection cell, a value incremented at least one standard deviation from a single manufacturing process run average value, an average calculated from values collected from at least two previously performed manufacturing process runs regarding data relevant to the interconnection cell, or a value incremented at least one standard deviation from said average value as calculated from values collected from at least two previously performed manufacturing process runs.
Furthermore, a value may be selected because it is closest to a value of some particular interest. For example, an expert suggested value, or a value used as an "offset" or over-correction technique. This method is used to correct a previously obtained output value that was, for example higher than desired, by selecting a new value that is theoretically lower than desired, on the presumption that the result will fall in the desired middle range.
Likewise, a value may be excluded because of some restriction placed on an item, run, or other collection of data in the data set. In addition, values may be selected to reflect a growing refining of "discretization" levels in choosing values. For example, previous runs may have used a High/Low demarcation type sorting process, whereas present considerations may include at least three groupings. In such cases, the groups in the "middle" ranges will be referred to as intermediate values. Previous and subsequent intermediate values may be classified, that is discretized, by a predetermined fractional value interval. It should be emphasized that discretization can be done by making as many arbitrary categories or intervals as needed or desired The only limit being the fact that above a certain level of discretization, further differentiations cease to have meaningful effects on actual output It should be understood that the various criteria will vary depending upon whether the data currently being analyzed are relevant to input constraints, process constraints, or output goals
In certain situations, historical empirical data and/or data obtained from monitoring the input of a currently running performance of a process are either insufficient, or not preferable, for implementing process control with the present invention In these situations, derived data are used Derived data are obtained through a number of methods, and can be values chosen for Design of Experiments, values computed by a predetermined formula, values formulated from information that is expert suggested, or values formulated by synthesizing methods
Further alternate embodiments of the method include utilizing on-line, current, manufacturing data in a dynamic, adaptive manner, and including this data in performing the process control This embodiment therefore includes a "learning" in real-time ability in the method for performing process control The present invention also allows for a simulation process in which the
"derived data" are theoretical, and substantially all steps relevant to gathering and analyzing of data are skipped Instead, a simulated function or algorithm is synthesized and used as //"derived data contributing to the formation of this simulated function had been obtained The system then uses the simulated algorithm — or the results of functions fabricated by simulation methods — for performing the process control method
tf An embodiment algorithm of the present invention makes extensive use of boundary values for input and output when optimizing process control In the simplest case, a boundary value can be a demarcation point That is, a cut-off point for assigning data values to a particular discrete group category For example, above or below the boundary value constitutes two respective discrete categories
The system-using the assigned at least one boundary value-forms a number of set combinations These sets are stored in such a manner so as to be discrete separate representations of differing associated input data groups The sets can then be evaluated in relation to the boundary value
Analysis may be done strictly from outputs for the purpose of assigning boundary values for a given specific input set The invention is also capable of doing analysis'stπctly from inputs and/or control parameters to the outputs
Preferably, before the present invention can implement its unique algorithms for optimizing process control, the preferred embodiment algorithm initiates validating whether there is a significant correlation between input sets of data and output sets of data at a given stage in a process A validated significant correlation is a precondition to properly carrying out process control with the present invention That is, validating a supposed correlation between two steps in the manufacturing process must first be done, so that the subsequently formulated algorithmic function can better perform improved yield or improved efficiency Automated Process Control
The validity of a correlation - between at least one input data set of an interconnection cell and at least one output set of this interconnection cell - is determined by calculating a correlation coefficient between the minimum two respective input and output sets, or a larger group of respective input and
IS output sets Calculating this correlation coefficient may include characterizing the data by calculating a process capability ratio
A further purpose of the present invention is applying the results of the analysis for actual process control This analysis can be done in any given chosen mathematical manner The preferred embodiment of the invention uses piece-wise linearization for refining the value or vector obtained for subsequent process control performance The actual use of the analysis is a further extension of the broad purpose
According to the present invention, the actual process control performance may include reporting a process status, and this reporting may be initiated according to a variety of predetermined conditions or means
In a further alternative embodiment of the invention, a mapped plurality of graph-directed expertise-suggested interconnection cell relationships is used to define the interconnection cell Using the map referenced interconnection cell, a process control recipe can then be designated, as heretofore described
In this embodiment of the invention, the validation portion (validity correlation performance) of the process control procedure is carried out upon n-tuples of directed graph components of the interconnection cell Subsequent refining of the definition of the interconnection cell is done by "measuring" to see whether a particular set of input data significantly contributes to that map referenced interconnection cell's output A predetermined convolution of these measunngs constitutes an acceptable validity-metric correlation
Further, in this embodiment of the invention, choosing a different process control recipe sometimes becomes necessary, for example, whenever a particular obtained output value differs from a predetermined
3b target value by at least a certain predetermined value This, in turn facilitates the obtaining a new subsequent offset goal value closer to the predetermined target value
The obtaining of a new subsequent offset goal value may be based upon an output value from a previous like-manufacturing process, or, in addition, by analyzing this output value by running a feed back closed control loop
In a feed back closed control loop, optimal correction of offset goal values, at a given stage in a process, is achieved through data analysis of the values of output constants at that stage as obtained and/or compared to values obtained from at least one previous performance of the process
An additional embodiment of the invention includes processing data by transforming a summarized respective corresponding data record cluster into a sub-manifold of a multi-vanate data manifold A sub-manifold is defined as an n-tuple of data points, organized into a multi-dimensional surface This surface may be described by functionally orthogonal variables, and the data manipulated by ordinary mathematical treatment This treatment may include, but is not limited to, algebraic, calculus, differential equations, n-dimensional polynomials, regression analysis, combinatorial techniques, and/or statistical means
A related embodiment of the invention includes a method for representing a multi-dimensional surface by displaying the organized data elements as discrete volumes of an n-dimensional polynomial solid as this solid is intersected by orthogonals of a finite number "n", of input, output, constant, variable or some combination thereof, of process control parameters, in n-dimensional space
51 A further embodiment of the invention includes processing data by transforming a summarized respective corresponding data record cluster into a search-space vector
A search-space vector in this context indicates that the invention will transform the summarized respective corresponding data record clusters into loci in a multi-dimensional vector search-space The invention then selects the desired vector to move along to a new cluster based upon the properties of the vector For example, when searching for a value stored in a cluster that represents the value 'closest to the most recent used recipe" the invention might focus on the vector having the smallest empirical magnitude
In a further alternative embodiment, the invention includes a method for sorting data which includes organizing a search-space organization, the method steps including a search-space for a first grouping or set of correlated empirical data-sets, by mapping a second grouping or set of interrelated specific locations in the search-space of graph-directed expertise-suggested data-set relationships onto the first grouping or set of correlated empirical data-sets, and wherein data-set resolution of particulars in the first grouping or set is greater than or equal to that of particulars in the second grouping or set, and validating the search-space so organized from a vantage point of a presumption of validity for the first plurality of data-sets, by i simulating a valid variable input parameter for a particular combinatorial of directed graph components in the mapped second plurality, or n measuring if each input to a locus of the particular combinatorial significantly contributes to that location's output, wherein a predetermined convolution of these measuπngs constitutes a valid ity-metπc for the combinatorial
In this embodiment, mapping includes defining substantially every locus-i e location-in the second plurality to have either 1 ) at least one
? graph-directed input and at least one graph-directed output, or 2) only one graph-directed output.
The method wherein organizing includes mapping a second set of interrelated specific locations in the search-space of graph-directed expertise-suggested data-set relationships onto the first grouping or set of correlated empirical data-sets, and wherein data-set resolution of particulars in the first grouping or set is greater than or equal to that of particulars in the second grouping or set.
Further in this embodiment of the invention validating includes, for at least one weighted directed graph component from those in the directed graph of second plurality components, improving the weighted component using an input or output, proportional, empirical parameter setting, directed graph component weighting
The method wherein validating includes generating a conditional statistical process-control distribution function and convoluting the conditional distribution function with the present weightings.
In a further alternative embodiment, the invention includes a method for sorting data which includes organizing a search-space organization, the method steps including: mapping a second plurality of interrelated nodes of graph-directed expertise-suggested data-set relationships onto the first plurality of transformed empirical data-sets, at least until there is a predetermined measure of inclusion by the second plurality of nodes and relationships of particulars in the first plurality data-sets, wherein the data-set resolution of particulars in the first plurality is greater than or equal to that of particulars in the second plurality; and validating the search-space from a vantage of a presumption of validity for the first plurality of data-sets, by simulating a validity-metric for an n-tuple of directed graph components in the mapped second plurality, or by measuring if each input to a node of the n-tuple significantly contributes to that node's output, wherein a predetermined convolution of these measuπngs constitutes a validity-metric for the n-tuple
In a further alternative embodiment, the invention includes a system for performing strategic process control at a predetermined process juncture This system includes apparatus for delineating an interconnection cell The interconnection cell so delineated has associated with it at least one set of input data or at least one set of process control parameters, and at least one set of output data This system further includes a computer which has therein software for assigning at least one boundary value to at least one set of the at least one set of input data or to at least one set of the at least one set of output data The computer further has attached thereto data storage apparatus for storing the assigned data sets The system further includes a compressor for performing multi-dimensional representing, ordering, and combining of a plurality of discrete respective set combinations from the stored assigned data sets, and a processor for processing data from the plurality of discrete respective set combinations into respective corresponding data record clusters The processor applies at least one of the respective corresponding data record clusters
The computer includes attached therewith at least one sensor for providing an input or output datum to the respective set of input or output data The computer further includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters The provided process control parameter setting is assigned according to a predetermined discrete respective set combination
4fc In a further alternative embodiment, the invention includes a system for process control including apparatus for delineating an interconnection cell, the interconnection cell having at least one input set of data or at least one set of process control parameters, and at least one output set of data, a validator for establishing that at least one input set of data respectively as having a substantially significant correlation with an output set of the at least one output sets, software for assigning at least one boundary value to at least one validated set of the at least one input sets or to at least one set of the at least one output sets, data storage apparatus for storing the assigned data sets, and a sorter for performing multi-dimensional ordenngs of stored data sets, and wherein the ordenngs are performed either concurrently, sequentially, heunstically, recursively, in parallel, asynchronously, synchronously, and/or synchronously with an accompanying time delay
Further aspects of this embodiment of the invention include an article of manufacture, which in turn includes a computer usable medium having computer readable program code embodied therein for performing strategic process control An additional aspect of the invention includes a program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control
In an additional further alternative embodiment of the invention, processing data from the respective formed set combinations into respective corresponding data record clusters may include installing at least one data
V record cluster correspondence as a front end to a neural network In such an instance, the neural network is used for controlling an aspect of the process at the predetermined process juncture
BRIEF DESCRIPTION OF THE FIGURES
In order to understand the invention and to see how it may be carried out in practice embodiments including the preferred embodiment will now be described, by way of non-limiting example only, with reference to the accompanying drawings, in which
Figure 1 illustrates a schematic diagram of a portion of a simple process map showing substantially sequential stages,
Figure 2 illustrates a schematic diagram of a process stage, i e any single stage in a process, Figure 2a illustrates a data set table for a given stage in a process,
Figure 3 illustrates a schematic diagram of the process map from Figure 1 with control parameters and monitored parameters added to each stage in the process,
Figure 4 illustrates a schematic diagram of interrelationships and outside influences for stages in a process,
Figure 4a presents two data set tables and for two types of outside influences,
Figure 5 illustrates a schematic diagram of the process map from Figure 3 with the interrelationship and outside influences map of Figure 4, Figure 6 illustrates a schematic diagram of a process stage "Stage X" with all the various process control relationships that "Stage X" participates in,
Figure 7 illustrates a schematic diagram of "Stage X" with process control relationships that are relevant to applying process control only at "Stage X", Figure 8 illustrates a schematic diagram of a process control algorithm standard frame of reference for Stage "X" in a process,
Figure 9 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage X
Figure 10 illustrates a simple schematic diagram of the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables,
Figure 10a illustrates the assignment of boundary values to three inputs represented by diagrams 10a 1 , 10a 2, and 10a 3,
Figure 10b illustrates a table of data arrays for a given stage in a process, Figure 10c illustrates a sample vector in a vector look-up table,
Figure 11 illustrates a vector look-up table for an output constant d at a given process stage,
Figure 12 illustrates a vector look-Up table for output constants Oi and O2 at a given process stage, Figure 13 illustrates a schematic diagram in the Chemical/Mechanical Polishing process of silicon wafers at "Tool 1 ",
Figure 14 illustrates a vector look-up table for output constant Oι at a given process stage, an Actual Values column which is not part of the vector look-up table, and a Residual Values column which is not part of the vector look-up table, 3 Figure 15 illustrates a schematic diagram of a process module of two tools, "Tool 1 " and "Tool 2", and
Figure 16 illustrates a schematic diagram of a module of four tools in a non-sequential configuration
DETAILED DESCRIPTION OF THE INVENTION
Understanding Process Control
Figurel illustrates a schematic diagram of a portion 100 of a simple process map showing substantially sequential stages, "Stage 1 " 102, "Stage 2" 104, "Stage 3a" 107, "Stage 3b" 108 and "Stage 4" 111 of a process, and the inputs and outputs that connect them - starting with the initial measured input to the process 101 and sequentially measured output 103 from "Stage 1 " which is measured input to "Stage 2", measured output 105 from "Stage 2" which is measured input to "Stage 3a", measured output 106 from "Stage 2" which is measured input to "Stage 3b", measured output from "Stage 3a" 109 which is measured input to "Stage 4", measured output from "Stage 3b" 110 which is measured input to "Stage 4", and measured output 112 from "Stage 4" Referring to Figure 1 , depicted is an example simple process map The boxes in the diagram represent sequential stages in a portion of a typical process, and the arrows indicate the direction in which output from one stage flows as input to the next stage Often, this input or output is measured for purposes of process control Simply stated, process control generally relates to determining the optimal values for control parameters at a stage in a process to improve quality or quantity of yield at that stage in the process. Stages 3a and 3b represent parallel stages, which can run simultaneously or in an alternating manner For example, a process would utilize such stages when an operation carried out at Stage 3 is slower in relation to actions carried out at other stages in the process When a stage in a process is slower in relation to the rest of the process, it is advantageous to break down the slower stage into parallel stages as seen in Figure 1 , to speed up process time at the that stage Another example of when parallel stages are used would be for one process that produces two types of output Such a process will elect which of the different operations will be carried out at the 'parallel stage"
Figure 2 illustrates a schematic diagram of a process stage 200, i e any single stage in a process (such as those shown in Figure 1 ) represented here as "Stage X" 203 There is measured input from "Stage X-1" 201 and measured output to "Stage X+1" 205 Also included in the process are control parameters measured by actuators at "Stage X" 202 and monitored parameters from sensors at "Stage X" 204
Referring to Figure 2, depicted is a typical stage of the process represented in Figure 1 , referred to in Figure 2 as Stage X To the left of Stage X are shown control parameters for actuators in the process conducted in Stage X; to the right of Stage X are shown sensors for monitoring parameters of the input to or output from Stage X, or the process conducted during Stage X Actuators perform actions in the context of a specific process step Sensors perform measurements relevant to the process The data coming from sensors and control parameter data sent to actuators constitute fundamental dynamic aspects that are required for the purposes of process control as Figure 2a illustrates a data set table 300 for a given stage in a process There are four families of data represented for any given number of items or batches 305 produced in the process measured inputs from previous stage 301 , outputs 302, control parameters 303, and monitored parameters 304 "Arrow A" 306 represents a data set for a process output O2 at the given stage and "Arrow B" 307 represents a data set for a control parameter CPC at the given stage
Substantially associated with every set of control parameters, monitored parameters, input, and output at any given stage in a process are data sets, as illustrated in Figure 2a The control parameters, monitored parameters, input, and output at any given stage represent four families of data sets
Within the control parameters, monitored parameters, and output families, there can be from 1 to any number of data sets Within the input family, there can be from 0 to any number of data sets In Figure 2a, the input family has a data sets (where a is any integer greater than 0), the output family has b data sets (where b is any integer greater than 1 ), the control parameters family has c data sets (where c is any integer greater than 1 ), and the monitored parameters family has data sets (where d is any whole number greater than 1)
A data set for the input or output families consists of quantities or measurements of that given input or output, for a given number of items or batches produced in a process For example, arrow A in Figure 2a represents a data set for O2, where O2 is the length of an item that is output from the given process stage, and this data is recorded for 50 times that the item is produced on a given day, where e is 50
M^O A typical data set for the control parameters family consists of data for a given parameter setting for an operation occurring at the given process stage, for a given number of items or batches produced in a process For example, arrow B in Figure 2a represents a data set for CPC where CPC is the pressure setting of an item produced at the given process stage, and this data is recorded for 50 times that the item is produced on a given day, where e is 50 A data set for the monitored parameters family consists of data for a given parameter monitored at the given process stage, for a given number of items or batches produced in a process
Figure 3 (generally referenced as) 400 illustrates a schematic diagram of the process map from Figure 1 and now added to each stage in the process are the controh parameters and monitored parameters that were depicted in Stage X of Figure 2 "Stage 1 " 402 has control parameters measured by actuators 401 , monitored parameters from sensors 403, initial measured input to the process 416, and measured output 417 which is measured input to "Stage 2" 405, "Stage 2" 405 has control parameters measured by actuators 404, monitored parameters from sensors 406, and measured output 418 which is measured input to "Stage 3a" 408, "Stage 3a" 408 has control parameters measured by actuators 407, monitored parameters from sensors 409, and measured output 420 which is measured input to "Stage 4" 414, "Stage 3b" 411 has control parameters measured by actuators 410, monitored parameters from sensors 412, measured output 421 which is measured input to "Stage 4", and "Stage 4" 414 has control parameters measured by actuators 413, and monitored parameters from sensors 415, and measured output 422
^D Referring to Figure 3, depicted is the process map from Figure 1 , and now added to each stage in the process are the control parameters and monitored parameters that were depicted in Stage X of Figure 2
Figure 4 illustrates a schematic diagram of interrelationships and outside influences for stages in a process 500 "Stage 1 " 501 has an interrelationship 506 with "Stage 3a" 503 and an interrelationship 507 with "Stage 3b" 504, "Stage 2" 502 has an interrelationship 508 with "Stage 3b" 504 and an interrelationship 509 with 509 with "Stage 4" 505 There is an outside influence 510 on "Stage 3a" 503
Referring to Figure 4, depicted is an interrelationship and outside influences map for the stages in the process map of Figure 1 An interrelationship between two stages exists when there is alleged or validated information that when a particular control parameter or parameters are set at an earlier Stage X, a certain resulting output is received at a later Stage X+n (where .. is any integer greater than 0) In Figure 4, interrelationships exist between Stage 1 and Stages 3a and 3b, between Stage 2 and Stage 3b, and between Stage 2 and Stage 4 An outside influence exists when there is alleged or validated information that some factor outside of a process influences output at a given stage in the process. In Figure 4, we see an outside influence exists on Stage 3a
Figure 4a (generally referenced as) 600 presents two data set tables 601 and 604 for two types of outside influences The first data set, represented by "arrow A" 607, consists of data for any type of metric or discrete parameter
603 monitored in a time-dependent manner 602 The second data set, represented by "arrow B" 608, consists of data for any type of metric or discrete parameter 606 monitored according to another metric scale 605
Referring to Figure 4a, like the relationships described in Figure 2, outside influences also have data sets Data sets for outside influences can be one of two types The first type is data for any type of metric or discrete parameter monitored in a time-dependent manner (arrow A), when the metric or discrete parameter is either suggested to affect or confirmed to affect output at a given stage The second type is data for any type of metric or discrete parameter monitored according to another metric scale (arrow B), when the first metric or discrete parameter is either suggested to affect or confirmed to affect output at a given stage
Figure 5 (generally referenced as) 700 illustrates a schematic diagram of the process map from Figure 3 with the interrelationship and outside influences map of Figure 4 "Stage 1 " 702 has initial measured input to the process 721 , control parameters measured by actuators 701 , monitored parameters from sensors 703, an interrelationship 717 with "Stage 3a" 708, and an interrelationship 718 with "Stage 3b" 712, and measured output 722 which is measured input to "Stage 2" 705, "Stage 2" 705 which has control parameters measured by actuators at "Stage 2" 704, and monitored parameters from sensors at "Stage 2" 706, an interrelationship 719 with "Stage 3b" 712, an interrelationship 720 with "Stage 4" 715, measured output 723 which is measured input to "Stage 3a" 708, and measured output 724 which is measured input to "Stage 3b" 712 , "Stage 3a" 708 which has control parameters measured by actuators at "Stage 3a" 707, monitored parameters from sensors at "Stage 3a" 709, and an outside influence 710, and measured output 725 which is measured input to "Stage 4" 715 "Stage 3b" 712 which
4 has control parameters measured by actuators at "Stage 3b" 711 , and monitored parameters from sensors at "Stage 3b" 713, measured output 726 which is measured input to "Stage 4" 715, and "Stage 4" 715 with has control parameters measured by actuators at "Stage 4" 714, and monitored parameters from sensors at "Stage 4" 716, and measured output 727
Referring to Figure 5, depicted is the process map of Figure 3 merged with the interrelationship and outside influences map of Figure 4 The different relationships between and at stages in Figure 5 illustrate various factors that may be involved in process control
Figure 6 (generally referenced as) 800 illustrates a schematic diagram of a process stage "Stage X" 804 with all the various process control relationships that "Stage X" participates in These relationships include measured input from "Stage X-1" 803, measured output to "Stage X+1 " 807, an outside influence 801 , control parameters measured by actuators at "Stage X" 805, monitored parameters from sensors at "Stage X" 806, an interrelationship with a process stage before "X" 802, and an interrelationship with a process stage after "X" 808
Referring to Figure 6, depicted is one stage in a given process, Stage X, with all of the various relevant process relationships that have been depicted in Figures 1-5 Stages prior to Stage X are hereinafter referred to as Stages X-1 , X-2, , X-n, etc Stages following Stage X are hereinafter referred to as Stages X+1 , X+2, , X+n etc Stages which may be substantially simultaneous to Stage X can be arbitrarily assigned the nomenclature X-1 or X+1 Figure 6 illustrates various process control relationships in which Stage X participates
,5b Figure 7 (generally referenced as) 900 illustrates a schematic diagram of "Stage X" 904 with process control relationships that are relevant to applying process control only at "Stage X" These relationships include measured input from "Stage X-1 " 903, measured output to "Stage X+1" 907, an outside influence 901 , control parameters measured by actuators at "Stage X" 905, monitored parameters from sensors at "Stage X" 906, an interrelationship with a process stage before "X" 902, and an interrelationship with a process stage after "X" 908
Figure 8 (generally referenced as) 1000 illustrates a schematic diagram of a process control algorithm standard frame of reference for Stage "X" in a process 1000 The relevant factors herein are control parameter(s) 1002, input from 'Stage X-1" 1003, ιnterrelatιonshιp(s) with stage(s) before "X" 1004, ιnterrelatιonshιp(s) with stage(s) after "X" 1005, outside ιnfluence(s) 1006, with the resultant output to "Stage X+1 " 1007, and monitored parameters from sensors 1008
Referring to Figure 7, Figure 7 depicts Stage X with relationships relevant to applying process control only at Stage X Referring to Figure 8, Figure 8 takes the relationships depicted in Figure
7 and presents them from the perspective of how to implement an algorithm for standard process control at Stage X, and what factors must be considered when implementing that algorithm
The following figures more specifically relate to benefits of the present invention above those that can be achieved from the vantage of the prior art
For example, it will be appreciated, from the forthcoming figures and
5\ description, that the method of the present invention relates to process control for a juncture in a process wherein there are no a priori notions regarding predominant influences to the process at that juncture Furthermore, that process control recipes can be found, calculated or chosen using decision criteria that could not be directly articulated using prior art methods More specifically, the present invention leads to the development of a well-defined search-space or ensemble of process control vectors whereby multiple goal optimizations may be realized
Figure 9 (generally referenced as) 2000 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage X 2002 These relationships include control parameter(s) 2011 which are "internal" 2014, input from "Stage X-1 " 2010 which is "near" 2013, ιnterrelatιonshιp(s) with stage(s) before "X" 2007, ιnterrelatιonshιp(s) with stage(s) after "X" 2005, and outside ιnfluence(s) 2001 which are all "far" 2012, monitored parameters 2004 which are "internal" 2015, and output to "Stage X+1 " 2008 which is "near" 2016 Polygons "A" 2009, "B" 2003, and "C" 2006" depict the standard types of relationships that are examined when applying standard process control at Stage X The polygons "A" 2009, "B" 2003, "C" 2006 show types of relationships between Input from "Stage X-1 ", Control Parameter(s), Monitored Parameters from sensors 2004 (of Internal 2015) and the Output to "Stage X+1 " 2008 (of Near 2016) which are examined when applying process control at "Stage X"
Figure 9 illustrates the relative importance according to classical thinking, per se, of relationships relevant to applying process control at Stage
X Relative importance is classically determined by the proximity of a relationship to Stage X That is, the closer the relationship, the greater
$ significance is attributed to it when implementing process control at Stage X Relationships labeled INTERNAL (control parameters) have the greatest significance, relationships labeled NEAR (input from Stage X-1 ) have the next greatest significance, and relationships labeled FAR (interrelationships with stages before X, interrelationships with stages after X, and outside influences) have the least significance. Within the FAR relationships, interrelationships with stages before X have the greatest significance, interrelationships with stages after X have the next greatest significance, and outside influences have the least significance Polygons A, B, and C in Figure 9 depict the standard types of relationships that are examined when applying standard process control at Stage X That is, standard process control at Stage X looks for a correlation between the input from Stage X-1 and control parameters at Stage X (polygon A), a correlation between control parameters at Stage X and the monitored parameters at Stage X (polygon B), and a correlation between monitored parameters at Stage X and the output to Stage X+1 (polygon C).
At this juncture, some additional notes about nomenclature are appropriate. Constants relate to measurements that reflect physical aspects measured in a process; such as weight of an object coming into a process juncture, height of an object coming out of a process juncture, etc. In this sense, constants are constraints that are outside of the scope of control of the process control engineer. Therefore, even though these aspects are called constants, on an item-to-item basis they may contribute to describing a broad distribution of values. For example, each egg that arrives at an egg-sorting machine has a specific size and weight that is constant for that egg. Nevertheless, one can describe a distribution of weights and sizes for eggs arriving at the sorter. Variables relate to aspects of the process at the process
S3 juncture that may be elected by command of a process control engineer, or by his proxy in the form of process control software (such as that of the present invention) setting process control parameters at the process juncture
Figure 10 (generally referenced as) 3000 illustrates a simple schematic diagram of the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables, which is the way an embodiment of the present invention addresses process control at "Stage X" 3001 An Interconnection Cell (according to an embodiment of the present invention) 3000 at process "Stage X" 3001 , and its constant/variable relationships. These relationships include input constant(s) 3002, input variables 3004, output constants 3005, and monitored parameters 3003, and by calculating a correlation coefficient between it and an Ouput Constant(s) 3005 As well, ideally, there should be no discrepancy between Input Varιable(s) i.e. Control Parameters 3004 and their output values i e. Monitored Parameter(s) 3003
Referring to Figure 10, Figure 10 displays the various process control input and output relationships of Figures 8 and 9 in terms of constants and variables, which is the way an embodiment of the present invention addresses process control at Stage X In the present invention, there are no a priori notions regarding predominant influences at Stage X The input constants in Figure 10 consist of interrelationships that Stage X has with other stages (before or after Stage X), outside influences, and input from Stage X-1 . Input variables consist of control parameters at Stage X Constants and variables can further be understood in terms of data sets. That is, each constant or variable is one of the types of data sets described in Figures 2a and 4a. The influences on Stage X numbered 2-5 in Figure 9 are depicted in Figure 10 as having equal potential significance until empirical weighting proves otherwise. It should be noted that this facilitates a significant departure from the normal means of standard process control, where relative importance is classically determined by the proximity of a relationship to Stage X as depicted in Figure
5 9
In the context of the present invention, the process stage and constant/variable relationships depicted in Figure 10 are referred to as an interconnection cell At the highest level of resolution and in the preferred conception, the interconnection cell represents a single process stage, l() hereinafter a tool. An interconnection cell can also represent two (or more) contiguous stages in a process, hereinafter a module. Further, an interconnection cell can represent a plurality of discontiguous stages, hereinafter a virtual module, or a plurality of contiguous or discontiguous modules.
15 According to an embodiment of the present invention, an algorithm is used to determine validity of input constants by calculating a correlation coefficient between an input constant with an output constant. This algorithm may be any well-known and accepted algorithm for calculating a correlation coefficient between two data sets, or any algorithm that produces a
20 substantially equivalent result. We will use the convention that a high correlation coefficient (i.e. a number with an absolute value close to 1 on the scale of 0 to 1) means that the input constant has a relatively valid relationship with an output constant at Stage X and should be considered when implementing process control at Stage X for that output constant. Likewise,
25 we will use the convention that a low correlation coefficient means that there is relatively no valid relationship between the input constant and the output constant at Stage X It is often desirable in process control to consider the most valid relationships to process stages The choice of how many relationships and which relationships is partially determined by computational capacity and partially determined by data availability
Those input constants that were found to have high correlation coefficients with output constants at Stage X, together with the input variables at Stage X, serve as an input set combination for carrying out process control optimization at Stage X with preferred embodiments of the present invention This input set combination is the basis for carrying out process control optimization at Stage X with the preferred embodiments of the present invention
In addition, according to an embodiment of the present invention, an algorithm is used to determine correlation coefficients for input variables (i e control parameters at Stage X) with monitored parameters at Stage X Ideally, the correlation coefficient should have a value of 1 0, meaning that there is no discrepancy between control parameters and their monitored output values A deteriorating correlation coefficient for an input variable with its corresponding monitored parameter means that intended values for control parameters are not properly received or implemented at Stage X and that serious correction is needed While the many embodiments of the present invention can be used for improving the yield of Stage X according to relationships between input variables and monitored parameters, the immediately following discussion will deal with the issue of process control for Stage X without addressing the issues of discrepancies between input variables and monitored parameters
5 b Boundary Values
It is an object of Stage X to achieve a maximum measurable output yield In order to do this, embodiments of the method of the present invention can be implemented in one of two general manners The more straightforward embodiment focuses on assigning boundary values to the input constants and variables of the input set combination at Stage X to optimize yield for a given output constant at Stage X yield Another more convoluted embodiment first assigns boundary values to output constants then uses an analysis according to output boundary values in order to assign boundary values to the input set combination at Stage X constants
The more convoluted embodiment first considers assigning at least one boundary value to at least one dividing data for data set of output constant data set and thereby forming at least two discrete sub-sets into at least two discrete sub-sets, and then discovering how to assign boundary values to the input set combination at least one input data set by analyzing portions of the input set(s) one or more data sets in the input set combination that contributed to each of the discrete sub-sets or to more than one of the discrete subsets Once the contributing portions of the input data sets have been discovered, then the more simple straightforward methods, for assignment of boundary values to input constants and variables, may be applied A simple example should suffice to disclose this convolution A data set of an output constant (for a process juncture) shows a clear bimodal distribution of measured articles being manufactured at that juncture Accordingly, a boundary value is assigned to the minima between the two apparent modes of the distribution A data set for an input constant associated with this same juncture shows a relatively uniform "flat" distribution of variation When the two modes of the output set are "reverse projected" back from this input set, one discloses three discrete regions A first region that resulted in the first output mode, a second region that resulted in the second output mode, and a third region that resulted from elements contributed from both modes Accordingly, one resultant idea for assigning boundary values to this input set combination would be according to these three disclosed regions
The following discussion will deal with the more simple straightforward methods for assignment of boundary values to input constants and variables in the input set combination, and with uses thereof There are also variations of the more straightforward embodiment for optimizing output yield, wherein boundary values are assigned to 1 ) input constants only, 2) input constants and monitored parameters together, 3) input constants, input variables, and monitored parameters together 4) input variables only, 5) monitored parameters only, and 6) input variables and monitored parameters together Likewise, there are variations of the more convoluted embodiment, wherein boundary values are assigned to 1 ) output constants and input variables, 2) output constants and monitored parameters, and 3) output constants input variables, and monitored parameters Furthermore, monitored values for some purposes are considered a preliminary output value, for other purposes it is a supplement to input values. However, most often monitored values are used as a corrective feedback to maintain desired input variable values
Boundary values can be determined and assigned according to various criteria More specifically, the selection of boundary values may significantly affect the quality of results achieved by using the method of the present invention In some circumstances, selection of a boundary value is done subjectively by a process control engineer according to his judgment and
S experience Other times, boundary values are selected according to specifications inherent to the actual goals of the process More often, boundary values are set according to measurable characteristics of the population of values in a given data set
Fig 10a (generally referenced as) 4000 illustrates the assignment of boundary values to three inputs represented by diagrams 10a 1 (generally referenced as) 4001 , 10a 2 (generally referenced as) 4009, and 10a 3 (generally referenced as) 4014 Diagram 10a 2 (generally referenced as) 4009 in Figure 10a (generally referenced as) 4000 illustrates the assignment of one boundary value x2 4011 to a population of data measurements for an input, where the population of data measurements divides according to a bimodal distribution curve 4010 A2 4012 represents the lower boundary value range for this input and B2 4013 represents the upper boundary value range for this input
A simple example of an input constant with one assigned boundary value is an egg-sorting machine that sort eggs according to egg diameter In such a case, a boundary value of 2 50 cm is set as the minimum diameter for eggs to be cleaned and boxed for the consumer market An egg with a diameter of less than 2.50 cm will be sent to the frozen egg line to be frozen and used for powdered eggs Another example of an input constant or variable with one boundary value is illustrated in diagram 10a.2 of Figure 10a The population of data measurements from some process is shown in the figure This population substantially divides according to an obvious bimodal distribution Line x2 indicates the minimum value between two modes This minimum value is a boundary value for the input constant, and A2 represents the range of input values less than the boundary value represented by line x2
7 The range of input values represented by A2 is referred to as a boundary value range Similarly, B2 represents the boundary value range of input values greater than or equal to the boundary value represented by line x2
Diagram 10a 1 (generally referenced as) 4001 in Figure 10a (generally referenced as) 4000 illustrates the assignment of two boundary values Xi 4003 and yi 4004 to a population of data measurements for an input, where the population of data measurements divides according to normal distribution curve 4002 The average of this normal distribution is represented by \ 4005 AT 4006 represents the lower boundary value range for this input B^ 4007 represents the in-specification boundary value range for this input, and Ci 4008 represents the upper boundary value range for this input
An example of an input variable with two boundary values could be the percentage of salinity in sardines Consumer engineers determine that a range of 7%-9% salinity in sardines is an acceptable range for consumer tastes Thus, 7% and 9% are the assigned boundary values Sardines produced with a salinity percentage that falls within that range are considered acceptable, and percentages below or above that range are respectively unacceptable Another example of an input constant or variable with two boundary values is illustrated in diagram 10a 1 of Figure 10a The population of data measurements from some process is shown in the figure This population substantially divides according to an obvious normal distribution
Line Xi represents a lower boundary value of x - 2σ and line y^ represents an upper boundary value of x + 2σ Ai represents the boundary value range of input values less than x - 2σ, Bi represents the boundary value range of input values between v - 2a and x + 2σ inclusively, and Ci represents the boundary value range of input values greater than x + 2σ Input values within
bb the Bi range are considered within a specification range, input values within the Ai range are considered below the specification range, and input values within C i range are considered above the specification range
Diagram 10a 3 (generally referenced as) 4014 in Figure 10a (generally referenced as) 4000 illustrates the assignment of three boundary values x3 4016, y3 4017, and z3 4018 to a population of data measurements for an input, where the population of data measurements divides according to a decaying distribution curve 4015 A3 4019 represents the lowest boundary value range for this input B3 4020 represents the next lowest boundary value range for this input, C3 4021 represents the second highest boundary value range for this input, and D3 4022 represents the highest boundary value range for this input
Diagram 10a 3 in Figure 10a depicts an input constant or variable with three boundary values The population of data measurements from some process is shown in the figure This population substantially divides according to an obvious decaying distribution According to one judgment, the boundary values have been determined according to 25% of the total population in the distribution (x3), 50% of the total population in the distribution (y3), and 75% of the total population in the distribution (z3) For example, if 1 ,000 measurements are represented in diagram 10a 3, then A3 represents the boundary value range of the lowest 250 measurements below a boundary value x3, B3 represents the boundary value range of the next 250 measurements between boundary values x3 and y3 C3 represents the boundary value range of the next 250 measurements between boundary values y3 and z3 and C3 represents the boundary value range of the 250 highest measurements above the boundary value z3 According to another judgment, the boundary values in diagram 10a 3 have been determined according to 25% of the total of the possible domains of measurements with equidistant segments in the distribution (x3), 50% of the total of the possible domains of measurements with equidistant segments in
5 the distribution (y3), and 75% of the total of the possible domains of measurements with equidistant segments in the distribution (z3) For example, the domain allows measurements between 0% and 100% mixtures of two materials Therefore, the measurements can never have a value less than 0% or greater than 100% While it is understood that this value has a significant l() effect on the process there is no a priori understanding of what the preferred range for this value should be in order to optimize the yield from the process Therefore, the measurement scale is divided into the following boundary value ranges A3 representing the range from 0-25%, B3 representing the range from 25-50%, C3 representing the range from 50-75%, and D3 representing
15 the range from 75-100%
It should be clear that the use of boundary values and boundary value ranges are used in the context of the present invention as a means to create discrete values for data with values that fall within a continuous range However, certain types of input constants and variables by their inherent
20 nature have values that fall within a discrete range For example, parallel tools in a given process are discrete values and can be considered as input Assume that a given process has three parallel tools, where process input flows into any one of the three tools and the same types of input constants and variables exist at each tool For the purposes of process control, it has
25 been decided to monitor into which tool process input flows and that the tool location at this parallel stage is to be considered as an input to the process The three parallel tools are therefore categorized by the discrete values A, B,
< and C For the purposes of the present invention, these discrete values are applied in the same manner as boundary value ranges
In the event that there are large numbers of values in a discrete range, then the equivalent of boundary values can be applied, thereby forming discrete groups
It should be noted that the ability for this embodiment of the present invention to use input data whose values fall into either continuous or discrete ranges is a versatile feature, as methods of standard process control today are primarily designed to handle input data whose values fall only within a continuous range, while methods for handling input data whose values fall only within a discrete range are less common However, methods of process control for dealing with both input values in a continuous range and input values in a discrete range such as this embodiment of the present invention are potentially of great use in countless diverse applications
Data Vectors and the Vector Look-Up Table
An embodiment of the present invention uses the boundary value ranges assigned to input constants and variables to form data vectors for a given stage in a process Each input constant or variable is a component entry of the vector Given the inputs depicted in the three diagrams in Figure 10a and their respective boundary values, it is seen that the following 24 data vectors exist for the output produced by the inputs depicted in Figure 10a { (A-, A2 A3), (Ai A2 B3), (A1 A2 C3), (A1 A2 D3), (A1 B2 A3), (A, B2 B3), (A, B2 C3), (A, B2 D3), (B, A2 A3), (B, A2 B3), (B, A2 C3), (B A2 D3), (B, B2 A3), (B1 B2 B3), (B! B2 C3), (Bi B2 D3), (d A2 A3), (d A2 B3), (d A2 C3), (d A2 D3), (d B2 A3), (d B2 B3), (Ci B2 C3), (d B2 D3) } Referring again to Figure 10a, for the sake of example, assume that 10a 1 represents an input constant, and that 10a 2 and 10a 3 represent input variables at a given stage in a process The boundary values for 10a 1 are Xi = 24 98 mm and yi = 25 02 mm, where Bi is the preferred boundary value range for values between 24 98-25 02 mm inclusively, Ai is the boundary value range for values less than 24 98 mm, and d is the boundary value range for values greater than 25 02 mm For 10a 2, there is one boundary value x2 = 10 00 mm A2 is the boundary value range for values less than or equal to 10 00 mm, and B2 is the boundary value range for values greater than 10 00 mm For 10a 3, there are three possible boundary values, denoted x3 y3 and z3 A3, B3, C3, and D represent four possible boundary value ranges for the height of an item The possible range of the height of the item varies from 0 00 mm to 10 00 mm A is the boundary value range for values greater than 0 00 mm and up to and including 2 50 mm, B3 is the boundary value range for values greater than 2 50 mm and up to and including 5 00 mm, C3 is the boundary value range for values greater than 5 00 mm and up to and including 7 50 mm, and D3 is the boundary value range for values greater than 7 50 mm and up to and including 10 00 mm
Figure 10b illustrates a Data Arrays table of data arrays 5000 for a given stage in a process The table is composed of a column for the number of the process run 5001 , columns for process input 5002, and a column for a given process output constant 5006 The inputs at this process stage are input constant 10a 1 5003, input variable 10a 2 5004, and input variable 5005 Values for these inputs corresponding to the data vector (Bi A2 D3) are received at the second process run 5007, the e'h process run 5008, the e+ 1th process run, and the f"1 process run The value for the given output constant for the second process run is O2 5011 , the value for the given output constant for the e"' process run is Oe 5012, the value for the given output constant for the e+ 1lh process run is Oe+ι 5013, and the value for the given output constant for the fh process run is Of 5014, also ith Inputs 5002 input constant "10a 1 " 5003, input variables "10a 2" 5004 and "10a 3" 5005 and their respective Output values 5006 make up a data array for any given Process Run(s) 5001
If we received values of 25 01 mm for 10a 1 , 9 98 mm for 10a 2, and 8 00 mm for 10a 3 this data corresponds to the vector (Bi A2 D3), according to the assigned boundary values Referring to Figure 10b, assume that the process is executed n times, and that after assigning boundary values to the data received for 10a 1 , 10a 2, and 10a 3 values corresponding to the vector (B, A2 D3) are received for process runs 2, e e+J and /, where e is an integer whole number greater than 3 and f is an whole number integer greater than e+ l and less than or equal to n The values O2, Oe, Oe+ ., and Of represent the output values received for a given output constant for process runs 2, e e+l, and / respectively at the given stage in the process The data received for any given process run, such as the value for input constant 10a 1 at run 2, the values for input variables 10a 2 and 10a 3 at run 2, and the value 02 for the output at run 2, are referred to as a data array
Figure 10c (generally referenced as) 6000 illustrates a sample vector in a vector look-up table The table is composed of columns for the data vector 6001 and columns for the given output constant data 6002 The entries of the vector for the sample vector depicted in this table are input constant 10a 1 6003, input variable 10a 2 6004, and input variable 10a 3 6005 The types of output constant data recorded in this vector look-up table are Average 6006, Standard Deviation 6007, and Population 6008 The sample vector is vector
(£>5 (Bi A2 D3) 6009 The average value for this vector for the given output constant is () 6010, the standard deviation is σ(O) 6011 and the population number is 4 6012
After a number of runs deemed sufficient by statistical criteria have been executed, the data arrays are sorted according to the data vectors they correspond to, and various meaningful statistical calculations are performed on the output data For example, in Figure 10b, data arrays corresponding to the vector (B^ A2 D3) were received for process runs 2, e e and f In Figure 10c the output data for these four process runs is taken and the average and standard deviation of these four output values is calculated The average value O , the standard deviation σ(O), and the population number 4 are then entered in the vector look-up table in Figure 10c by vector (Bi A2 D3) This output data is used by embodiments of the present invention for optimization of the given output constant In addition to average, standard deviation, and population number, other types of meaningful statistical calculations are performed on output data by embodiments of the present invention, such as determining the output constant's Process Capability Ratio (Cpk), and the results of these calculations are used for process control optimization of that output However, for the purposes of illustration, the examples that follow here refer to calculation and use of only standard deviation, average, and population number of output constant data
In many process control situations, it is understood that not all possible combinations of boundary value ranges for input constants and variables represent actual valid process input Therefore, for those vector input combinations that represent invalid input combinations for which the given process cannot be carried out, there will be no corresponding output data in the vector lookup table
PIQ The conventions of assigning boundary values to input data and sorting input data into data vectors enable detection of problematic input combinations and detection of input combinations that were assumed to yield output that is out of process specification standards and actually yield output that is within process specification standards When problematic or unusual input combinations are detected, embodiments of the present invention provide appropriate system responses One of these responses is a self-adjusting feature which automatically adjusts process input that is out of process specification standards to within specification standards Other system responses include the sending of automated reports to the process engineer, or in more serious cases the sounding of an alarm or even cessation of process execution altogether
For example, it is understood that in certain process control situations, certain vector input combinations will represent input combinations for which the current process can be carried out, however it has been determined from previous history of the given process that the a given input combination is known to yield output which is out of process specification standards, or that the a given input combination contains one or more inputs outside of process specification standards, or that this specific combination of inputs is unacceptable for reasons related to the given process An embodiment of the present invention allows the process engineer to program the system carrying out the given process so that if input combinations or output that are considered unacceptable for either of these reasons are received during process execution, the machinery and/or mechanisms carrying out the process automatically correct the input to within process specification standards For more serious cases of this nature, this embodiment of the present invention allows the process engineer to program the system carrying
L>1 out the given process to automatically sound an alarm instead of or in addition to automatic correction, or to even automatically halt process execution altogether, or to report an unacceptable input combination or output to the process engineer, or in more serious cases an alarm is sounded or process execution is halted altogether
Likewise, in certain process control situations, examination of data in the vector look-up table shows that certain combinations of boundary value ranges for input constants and/or variables which were assumed to yield output that is out of process specification standards do in fact yield output that is within process specification standards Or, certain combinations of boundary value ranges for input constants and/or variables where one or more of the boundary value ranges are considered out of the specification standard for that input do in fact yield output that is within process specification standards For example, referring again to input constant 10a 1 and input variables
10a 2 and 10a 3, assume that for 10a.1 the boundary value range Ai is considered out of process specification standards, that for 10a.2 the boundary value range B2 is considered out of process specification standards, and that for 10a.3 the boundary value range A3 is considered out of process specification standards. However, after applying boundary values to the input data and sorting the input data into data vectors according to the embodiments of the present invention, the resulting output is found to be within process specification standards. Despite this output, which is within specification standards, such a situation still warrants attention, as the given input combination is still considered to be out of process specification standards. In such a case, an embodiment of the present invention allows the process engineer to program the system carrying out the given process to
(_# report input combinations that are out of process specification standards and yet yield output within process specification standards The input combination can then be analyzed to determine whether the combination constitutes a new and valid set of input or whether the combination constitutes an invalid set of input despite its output yield within process specification standards The ability of embodiments of the present invention to determine input combinations of this nature with resulting output within process specification standards is a unique feature of the present invention that is unknown in standard methods of process control
Design of Experiment (DOE)
Data that is categorized as input constants, output constants, input variables, or monitored parameters can be either empirical or derived Empirical data is defined as data obtained from actual process runs Derived data is data obtained from conjecturing or mathematical calculations An embodiment of the present invention uses either empirical or derived data, or a combination of the two data types, for the purposes of process control optimization A specific type of derived data that is used by an embodiment of the present invention is data derived from Design of Experiment (DOE) DOE data is obtained by first choosing a limited sample population representing the spectrum of possible values for input constants and input variables at a given stage in a process, running the process with all possible combinations of this limited sample population, and monitoring the output at the given stage for each possible combination Based on the results of these process runs, a mathematical formula is derived that allows for interpolating or extrapolating process output for any possible combination of input constant values and input variable values, and with this formula output data is derived for the entire
fe9 range of possible input constant values and input variable values Boundary values are assigned to this data, and with the boundary value ranges the data is arranged into data vectors These data vectors are entered into the vector look-up table in exactly the same manner as data vectors for empirical data However, because there is no actual sample population for the derived data, no standard deviation or average value can be calculated Instead, the output value received from the DOE formula is entered in the vector look-up table as the average output value by the appropriate vector, and a default standard deviation value is likewise entered in the vector look-up table by the appropriate vector
Run-to-Run Process Control Mode
The preferred embodiment of the present invention is implemented in a Run-to-Run control mode In this context, a Run-to-Run control mode relates to a process control system that determines, based on previous runs of the given process, the optimal setting of process input variable value(s) at a given process tool or module in order to obtain or proximate one or more output target values at that tool or module Process control optimization in the Run-to-Run control mode is implemented at the given tool or module by two methods, known as the Feed Forward and Feed Back closed control loops When implemented in the Run-to-Run control mode, the preferred embodiment of the present invention accesses data from previous process runs and the current process run, and determines optimal settings for input variables on-line (i e while the process is occurring), allowing automated optimization of output for the current process run without significant delays and without halting operation of the given process
lt> Feed Forward Closed Control Loop
Figure 11 (generally referenced as) 7000 illustrates a vector look-up table for an output constant "O 7000 at a given process stage The table is 5 composed of columns for data vectors 7001 and columns for the output constant data for O^ 7002 The entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 7003, input variable 10a 2 (generally referenced as) 7004 and input variable 10a 3 (generally referenced as) 7005 The types of output constant data recorded in this vector look-up l () table are Average 7006, Standard Deviation 7007, and Population 7008 Output constant data is recorded in the look-up table for vectors (Ai , A2, C3) 7009, (Bi, A2, D3) 7010, (C1 t A2, A3) 7011 , (d , A2, B3) 7012, (C1 t A2, C3) 7013, (Ci, A2l D3) 7014, and (d, B2, C ) 7015
In the context of the present invention, the Feed Forward closed control
15 loop relates to optimal correction of input variable values at a given stage in a process determined by the values of that stage's input constants for the current process run and an output target value or target value range The first step in implementing the Feed Forward closed control loop is to choose an optimal vector from the vector look-up table This optimal vector is chosen by
20 first selecting vectors from the vector look-up table that have boundary value ranges for input constants that include the values of the current run's input constants Then, from among those selected vectors, the vector with the output constant average value closest to the output target value or to the midpoint of the output target value range is chosen as the optimal vector For
25 example, assuming the input constants and variables from Figure 10a and their boundary values, in Figure 11 a vector look-up table is presented for output constant d with vectors (Ai , A2, C3), (Bi, A2, D3), (Ci, A2, A3), (d, A2,
It B3), (Ci, A2, C3), (Ci , A2, D3), and (Ci , B2, C3) In the current process run, the value for input constant 10a 1 is 25 03 mm which is in boundary value range d It is clearly seen that vectors (Ci, A2, A3), (Ci , A2, B3), (Ci , A2, C3), (d, A2, D3), and (Ci , B2, C3) satisfy the first criterion for choosing a vector in the first step of the Feed Forward closed control loop, because the value of input constant 10a 1 in the current process run is in boundary value range Ci
Next, it must be determined which of these five vectors has the closest average value for output constant Oι to the output target value The target value for O, is 10 00 mm For vector (C t , A2, A3), Oι = 10 02 mm for vector (Ci , A2, B3), O, = 10 04 mm, for vector (Ci , A2, C3), O, = 9 96 mm, for vector
(Ci , A2, D3), O, = 9 98, and for vector (C, , B2, C3), Oι = 10 01 mm It is clearly seen that vector (Ci , B , C3) satisfies the second criterion for choosing the optimal vector in the first step of the Feed Forward closed control loop, because its average value for 0_ is closest to the output target value In addition to the vector's output constant average value, the output constant standard deviation and population number are also considered when choosing the an optimal vector For example, a vector with an average value that is only 01 mm from the output target value but with a large standard deviation and low population number may be less preferable than a vector with an average value that is 02 mm from the output target value but with a low standard deviation and high population number In such a case, the vector with the lower standard deviation but average value farther from the output target value might be chosen as the optimal vector, and by applying an offset factor to this vector, it is possible to obtain an average output value for this vector closer to the target value Those versed in the art will appreciate that rather than examining a vector's average and standard deviation, the easiest and most facile way of selecting an optimal vector is to choose the available vector with the highest Process Capability Ratio (Cpk) However, for the purposes of illustration, the examples presented here refer only to calculation and use of standard deviation, average, and population number of output constant data
It should also be appreciated that there will be situations where choosing an optimal vector also depends on recently used process recipes For example, it is possible that the vector with the highest Cpk contains input variable boundary value ranges that significantly differ from recently used input variables values, and that due to system constraints using this vector will cause delays in reconfiguring a given process In such a situation, a vector with a lower Cpk but with an input combination close to or matching recently used input variables values proves to be the optimal vector since implementation of that vector avoid delays in reconfiguring the given process
Robust Optimization
The ability to choose an optimal vector based on both average value and standard deviation Cpk is an example demonstrates of using of robust optimization for purposes of process control, where robust optimization is defined as the ability to reduce data variance while also attempting to obtain or come as close as possible to approximating a target value Current methods of standard process control are unable to utilize robust optimization, and the ability to utilize robust optimization with embodiments of the present invention is one of the present invention's unique features that other methods of process control do not offer
13 Input Constraints
Another criterion for choosing the optimal vector is input constraints. That is, there may be certain input variable boundary value ranges that are considered unacceptable and will therefore disqualify certain vectors which otherwise meet the optimal vector criteria For example, assume that an input constraint exists on input variable 10a.3 such that boundary value range A3 is considered unacceptable This would therefore disqualify vector (C, , A2, A3) Reasons for input constraints can be cost or efficiency related, or can be related to the subjective considerations of the given process.
Vector Smoothing and Process Recipe
(Ci, B2, C3) is found to be the optimal vector However, the average value Oι for vector (Ci , B2, C3) is 10.01 , and is not exactly equal to the output target value of 10.00 mm Therefore, the second step in implementing the
Feed Forward closed control loop is to find the next best optimal vector that most closely fits the criteria established for finding the optimal vector. If the output constant average value of the optimal vector is greater than the target value, then the output constant average value of the next best optimal vector must be less than the output target value. Alternatively, if the output constant average value of the optimal vector is less than the output target value, then the output constant average value of the next best optimal vector must be greater than the output target value. After choosing the next best optimal second vector, a special smoothing algorithm is applied to the two vectors which interpolates the two vectors by means of piece-wise linearization, or linear regression, or the like. The result of this algorithm is a recipe with
7T optimal values for input variables at the given process stage that will yield the output target value
For example, Oι for vector (d, B2, C3) is 10.01 mm, which is a hundredth of a millimeter greater than the output target value of 10.00 The vector with the closest average value for d that is less than the output target value must be found We saw previously that for vector (Ci, A2, D3),
Figure imgf000077_0001
=
9.98, and for vector (Ci, A2l C3), Oι = 9.96 mm The average output value of 9.98 mm is closer to the output target value of 10.00 mm than 9 96 mm Therefore, vector (Ci, A2, D3) is chosen as the next best optimal vector. The smoothing algorithm is then applied to vectors (Ci , B2, C3) and (Ci, A2, D3), and returns a resulting recipe for input variables 10a.2 and 10a.3 in order to receive the output target value of 10.00 mm for output constant Οι. Part of this smoothing algorithm involves giving greater priority to the optimal vector according to the proximity of the optimal vector's output constant average value to the output target value. The smoothing algorithm returns interpolated recipe values for input variables that are more likely to be within the boundary value ranges of the input variables in the optimal vector than in the boundary value ranges of those input variables in the next best optimal vector For the current example, this means that the recipe value for input variable 10a.2 is more likely to be in the B2 range than in the A2 range, and that the recipe value for input variable 10a.3 is more likely to be in the C3 range than in the D3 range.
Feed Back Closed Control Loop In the Feed Back closed control loop, optimal correction of input variable values at a given stage in a process is achieved through data analysis of the
15 values of output constants at that stage from previous runs of the process For example, in the present invention, if an output target value for an output constant is known and actual values of that output constant are known from previous process runs, the actual output values can be used to calculate an average offset of that output constant for the current process run With this average offset, a new output target value is obtained, and with this new target value embodiments of the present invention automatically implement the Feed Forward closed control loop
Multiple Outputs
An embodiment of the present invention allows for optimization of multiple outputs in the Feed Forward closed control loop In such a case, there are two or more output constants at a given process stage, with output target value ranges for each output constant Current methods of standard process control are substantially unable to optimize multiple outputs in the integrated fashion that the embodiment of the present invention for optimizing multiple outputs does In this context, the present invention provides a unique and revolutionary approach to process control optimization of multiple outputs
Figure 12 (generally referenced as) 8000 illustrates a vector look-Up tables for multiple outputs constants Oι and O2 at a given process stage 8000
The table is composed of columns for data vectors 8001 , columns for the output constant data for Oι 8002, and columns for the output constant data for
O2 8003 The entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 8004, input variable 10a 2 (generally referenced as) 8005, and input variable 10a 3 (generally referenced as) 8006 The types of output constant data recorded for output constant Oi are Average 8007 Standard Deviation 8008, and Population 8009 The types of output constant data recorded for output constant O2 are Average 8010, Standard Deviation 8011 , and Population 8012 Output constant data is recorded in the look-up table for vectors (Ai , A?, C3) 8013, (Bi, A2, D3) 8014, (Ci , A2, A3) 8015 (d, A2 B3) 8016, (Ci, A2. C ) 8017, (C1 t A2, D3) 8018, and (Ci , B2l C3) 8019 The first table is for Output Constant "O1 " 8001 and the second table is for Output Constant "O2" 8002
The embodiment of the present invention for optimizing multiple outputs carries out optimization of multiple outputs in two stages The first stage is to try is implemented by first trying to find one or more common vectors for the multiple outputs at the given process stage A common vector is defined as a vector with average values for the multiple output constants such that each constant's average value in the vector is within the target value range for that constant For example, Figure 12 presents a vector look-up table for multiple outputs based on the vector look-up table for output constant Oi from Figure 11 In Figure 12, in addition to all the output data for output constant Oi that was in the vector look-up table in Figure 11 , there is output data for an output constant O2, and a vector look-up table for an output constant referred to as O2 Of and O2 are both output constants at one given stage in a process and the inputs to this process stage are input constant 10a 1 and input variables 10a 2 and 10a 3 As in the previous example, assume that the value for the input constant 10a 1 for the current process run is in the Ci boundary value range, and that there is an input constraint on input constant 10a 3 such that such that boundary values range A3 is considered unacceptable Therefore, the possible vectors to choose from are (d , A2, B3), (Ci , A2, C3), (Ci, A2, D3),
Figure imgf000079_0001
T7 Previously, an output target value of 10 00 mm was assumed for output constant O, A target value range of 9 97-10 03 mm is now assumed Assuming the same output constant average values for vectors (Ci , A2, B3), (Ci , A , d), (Ci , A2, D3), and (Ci , B2, C3) that were mentioned previously, it is clearly seen that vectors (Ci, A2, D3) and (Ci , B2, C3) fall within the target value range, since for vector (Ci , A2, D3), ()\ = 9 98, and for vector (d , B2,
C3), ()\ - 10 01 mm Although vector (Ci , B2, C3) has an average value closer to the midpoint of the target value range, for the purposes of optimizing multiple outputs with the common vector embodiment of the present invention, all vectors with average values within the target value range are considered
Assume that the output constant 02 measures the density of the item produced by inputs 10a 1 , 10a 2, and 10a 3 at the given process, and that output constant 02 has an output target value range of 999 50-1000 50 grams/cm3 For vector (Ci, A2, C3), O2 = 999 87 grams/cm3, for vector (Ci , A2, D3), Oι = 1000 22 grams/cm3, and for vector (Ci, B2, C3), ϊ), = 999 46 grams/cm3 It is clearly seen that vectors (d , A2, C3) and (Ci, A2, D3) fall within the range 999 50-1000 50 grams/cm3 for output constant Ο2, and that vector (Ci, B2, C3) does not
Output constant Oi was found to have vectors (Ci , A2, D3) and (Ci, B2, C3) in its output target value range, and output constant O2 was found to have vectors (Ci, A2, C3) and (Ci , A2, D3) in its output target value range Therefore, it is clearly seen that these two output constants share the common vector (Ci , A2, D3) in their respective target value ranges (d, A2) D3) is the optimal vector for output constants Oi and O2, and the recipe for optimizing these multiple outputs is determined by taking the midpoints of the boundary value ranges of input variables 10a 2 and 10a 3, which in this case are the midpoints of boundary value ranges A2 and D3 Although this example
IS" illustrates implementation of the embodiment of the present invention for optimization of multiple outputs on only two outputs, the methods presented here can be applied to any number of outputs
Output Constraints
It is important to note that the optimal vector for multiple outputs would not necessarily be the optimal vector for each output constant if each output constant is analyzed on its own without regard to the other output constants For example, output constant Oi was found to have vectors (Ci, A2, D3) and (Ci, B2, C ) in its output target value range, with vector (d, B2, C3) having the closest average value to the midpoint of the target value range If O1 were analyzed on its own, (Ci , B2, C3) would be its optimal vector However, vector (Ci, B2, C3) does not fall within the target value range for output constant O2, whereas vector (Ci , A2, D3) does Likewise, in regards to output constant O2, vector (Ci , A2l D3) would not be its optimal vector if O2 is analyzed on its own, since vector (d, A2, C3) has the closest average value to the midpoint of the target value range However, vector (Ci, A2, C3) does not fall within the target value range for output constant Oi , whereas vector (Ci , A2, D3) does Therefore, since vector (Ci, A2, D3) is the only vector to fall within the target value ranges for output constants Oi and O2, (Ci, A2, D3) becomes the optimal vector when both output constants are analyzed together This situation can be understood in terms of output constraints That is, each output presents a constraint on other outputs, such that a vector which would be considered an optimal vector for a given output when that output is analyzed independent of other outputs cannot be used because it is outside of the output target value range(s) of the other output(s), and a common vector which may not be the optimal vector for some or all of the given output
7? constants is selected because it is within the output target value ranges for all outputs and best optimizes multiple outputs when all the various output constraints are taken into consideration
When applying the embodiment of the present invention for optimization of multiple outputs, it is also possible that more than one common vector is shared by the multiple outputs For example, in the previous example, an output target value range of 999 50-1000.50 grams/cm3 was assumed for output constant O2, with vectors (Ci , A2, C3) and (Ci , A2l D3) falling within that target value range Assume now that the target value range is expanded to 999 45-1000 50 grams/cm3 The vector (Ci , B2, C3), with an average value of 999 46 grams/cm3 for O2, now falls within the target value range O2 Further, in the previous example the output constant Oi had an output target value range of 9 97-10.03 mm and the vector (Ci , B2, C3), with an average value of 10.01 mm for d , also fell within the target value range for Oi Therefore, there are now two vectors, (Ci , A , D3) and (Ci , B2, C3), which fall in the output target value ranges for output constants Oi and O2 If from amongst the two or more common vectors there is one vector with average values for all of the output constants closer to the midpoint of each output target value range for the respective output constants than any of the other vectors, then that vector is clearly the optimal vector for optimizing the given multiple outputs. However, if from among the two or more common vectors there is no one vector with average values for all of the output constants closer to the midpoint of each output target value range for the respective output constants than any of the other vectors, then there is a need to determine which of the two or more common vectors will best optimize the multiple outputs The present example illustrates this latter possibility. It was determined that both vectors (Ci, A2, D3) and (Ci , B2, C3) fall within the output target value ranges
%D for output constants Oi and 02 Regarding output constant Oi , (Ci, B2, C3) with ()\ = 10 01 mm is clearly preferable over vector (Ci , A2? D3) with Oi = 9 98 mm However, regarding output constant 02, (Ci , A2, D3) with () - 1000 22 grams/cm3 is clearly preferable over (Ci, B2, C3) with () > = 999 46 grams/cm3 With the present invention, optimization of multiple outputs in such a situation is done by means of a special weighting algorithm that is part of the embodiment for optimization of multiple outputs When using this weighting algorithm, the process engineer assigns weightings to (i e prioritizes) the multiple outputs The weighting assigned to each given output is then applied to the most preferable vector for that given output constant from amongst the common vectors, and the weighting algorithm derives a recipe for optimization of the multiple outputs based on each output's preferable vector and its corresponding weighting In most cases, the recipe values for input variables will be within the input variable boundary value ranges of the vector with the greatest weight The assignment of these weightings can also be understood in terms of output constraints That is, the more weight (or greater priority) that is assigned to one output will place greater constraints on the optimization of the other outputs
In our current example with common vectors (Ci, A2, D3) and (Ci, B2, C3), assume that output constant O2 receives a greater weighting than Oi Therefore, the greater weighting is applied to vector (Ci, A2, D3), which is O2's more preferable vector from amongst the two common vectors Oi receives the lesser weighting, and this lesser weighting is applied to vector (d, B2, C3), which is Oi's more preferable vector from amongst the two common vectors The two vectors have input variables 10a 2 and 10a.3 Since vector (Ci, A2, D3) receives the higher priority, the recipe value for 10a 2 will be in the A2 boundary value range and the recipe value for 10a 3 will be in the D3 boundary value range The extent to which the vector (Ci , A2, D3) received a greater weighting will determine to what extent the recipe values for input variables are closer to the midpoint of the boundary value ranges of the input variables In our current example, if (Ci, A2, D3) received a much greater weight than (Ci, B2, C3), then the recipe values for 10a 2 will be close to the midpoint of boundary value range A2, whereas if (Ci , A2, D3) received only a slightly greater weighting than (Ci , B2, C3), then the recipe value for 10a 2 will still be within boundary value range A2 but will be closer to the end of range A2 that borders boundary value range B2 In certain situations, it is not always possible to find one or more common vectors within the output target value ranges of the multiple outputs Optimization of any one given output at a given stage in a process presents a constraint on .optimizing all other outputs constants at that given process stage, and as the number of output constants and constraints increase, so does the difficulty in finding one common vector within the output target value ranges for all the multiple outputs In the above example, common vectors (Ci , A , D3) and (Ci , B2, C3) were found within the two output target value ranges If another third output constant were taken into consideration, it is possible that vectors (Ci, A2, D3) and (d , B2, C3) would not fall within the target value range of that third output constant, and no common vector would be found that falls within the output target value ranges for all three output constants In such a situation, the weighting algorithm is also be applied to optimize multiple outputs
For example, assume that in addition to the output constants Oi and O2 from the previous example, there is a third output constant O3 at the given process stage and that the vectors (d, A2, D3) and (Ci, B2, C3), which were determined to fall within the output target value ranges of Oi and O2, do not fall within the output target value range of O3 Further, assume that O3 has an optimal vector (Ci, A2, B3), and that vector (Ci , A2, B3) does not fall within either of the output target value ranges for output constants Oi and O2 Therefore, there is no common vector that falls within the output target value ranges for the three output constants
The weighting algorithm is applied to this situation in the same manner as it was applied in the previous example with output constants Oi and O2 and common vectors (Ci, A2, D3) and (d , B2, C3) Now, weightings must be assigned to the three vectors (C, , A2, B3), (Ci , A2, D3) and (d B2, C3) Assume now that the optimal vector for O3, (Ci , A2, B3), receives the greatest weight of the three vectors, and that vector (Ci , A2, D3) receives a greater weighting than vector (CL B2, C3) as in the previous example The recipe value for the input variable 10a b will now very likely be close to the midpoint of boundary value A2 since vector (Ci , A2, A3) (with the greatest weighting) and vector (Ci, A2, D3) (with the second greatest weighting) both have boundary value range A2 for input variable 10a 2 The recipe value for input variable 10a 3 in this case will greatly depend on the degree to which vector (Ci , A2, B3) is weighted over vector (Ci, A2, D3) and the degree to which vector (Ci, A2, D3) is weighted over vector (Ci , B2, C3) If vector (Ci , A2, B3) has a much greater weight than vector (Ci , A2, D3), then the recipe value is likely to be somewhere in the B3 range, whereas if the weighting for (Ci, A2, B3) is only slightly greater than the weighting for vector (Ci, A2l D3) and the weighting for (Ci, A2, D3) is much greater than the weighting for vector (Ci, B2, C3), the recipe value for 10a 3 is likely to be somewhere in the C3 range
S3 CMP Example
The schematic diagram in Figure 13 (generally referenced as) 9000 illustrates in a schematic diagram a stage in the Chemical/Mechanical Polishing process of a silicon wafers at Tool "1 " 9001 The Inputs constants at "Tool-1" are Thιckne.ss-In 9002, and Pad Life 9003, Input variables at "Tool-1" are Time 9004, Pressure 9005, and Speed 9006, output constants at "Tool-1 " are Uniformity 9007 and Imal -Thickness 9008
The following example illustrates how embodiments of the present invention are applied in the Chemical/Mechanical Polishing (CMP) of silicon Wafers A stage in the CMP process is depicted in Figure 13, with the following inputs
1. Thicknes s— In (Constant)
2. Pad Life (Constant)
3. Pressure (Variable)
4 Time (Variable)
5. Speed (Variable)
and two output constants Fmal-Thickness and UmXormity. It is clearly seen in Figure 13 that these two output constants are dependent on the 5 inputs Embodiments of the present invention are applied in the APC
Run-to-Run algorithm mode is applied to this process and calculates the Feed Back and Feed Forward corrections Closed Control Loops are implemented for process run n as follows
3- Calculate the offset average for the output constant Final- Thickness for run ./ for the last m previous runs, where m is any number from 1 to n- 1 , as follows
Final Thιckne.s.s(All ) -
Figure imgf000087_0001
V m
Where-
Actual(n-j) is the actual measured value of output constant Final-Thickness at run (n-j),
Model ' pre (n-j) is the model predicted value of output constant Final-Thickness at run (n-j), which is the average value for output constant Final-Thickness taken from the vector look-up table for process run (n-j)
σπ.j is the standard deviation of output constant Final-Thickness at run (n-j), taken from the vector look-up table for process run (n-j).
P is a correction coefficient used to correct discernible deviation trends.
2. With Fιnal-Thickness(Δπ), calculate the adjusted output target value range Ad] Targetn for output constant Final-Thickness according to the following formula: Adj. Target,, = Target,, - Fιnal-Thickness(Δn)
Where /_.. _:- t„ is the original output target value range for output constant 1'inal-lhicknes s In the event that the adjusted target value range goes above the UCL (Upper Control Limit) or below the LCL (Lower Control Limit) for output constant Final- Thickness, the system will cease operation
Repeat steps 1 and 2 for the output constant Uniformity , calculating the offset average for Uniformity at run n with the formula from Step 1 that was used to calculate the average offset for / /.._./ Thickness and using the offset average for Unifor mity at run ./ to determine the adjusted output target value range for Umfotmin
With the adjusted output target value ranges for Uniformity and
Final Thickness and the values of input constants Thιckness-ln and Pad Life for the current process run, refer to the vector look-up table for Uniformity and Final-Thickness to find vectors within the respective adjusted output target value ranges
With the two groups of vectors obtained in step 4 look for common vectors in the two groups
At this step, there are three possible results
l One common vector is found - use this vector to determine the process recipe The recipe will be determined by taking the midpoints of the boundary value ranges in the vector for input variables Pressure Time and Speed
n More than one common vector is found - from the common vectors found, determine the preferable vector for Uniformity and the preferable vector for Final-Thickness Assign weightings to Uniformity and Final-Thickness and apply the weighting algorithm to their preferable vectors to obtain the process recipe for input variables Pressure. lime, and Speed
lii. No common vector is found - Determine the optimal vector for Uniformity and the optimal vector for Final-Thickness. Assign weightings to Uniformity and Final-Thickness and apply the weighting algorithm to their optimal vectors to obtain the process recipe for input variables Pressure. Time, and Speed
In the above example, the determination of optimal values for input variables is based on both output values from previous runs, and the values of input constants for the current process run That is, the calculation of the average offset for Uniformity and Final-Thickness and their new output target value ranges for run n is a case of using output values from previous runs to determine optimal values of input variables for run n, and the selection of optimal vectors from the vector look-up table is a case of using the values of input constants for the current process run to determine the optimal values of input variables. Simply stated, the Feed Back and Feed Forward closed control loops are implemented together The preferred embodiment of the present invention implements both control loops together.
However, it should be noted that both control loops can be implemented independent of the other. For example, in an embodiment of the present invention, input constant data for the current process run is used to determine the optimal values for input variables without known output data, thus operating only in the Feed Forward closed control loop and not the Feed Back closed control loop. Likewise, in another embodiment of the present invention,
1 output value data is used to determine the optimal values for input variables without using input constant data, thus operating only in the Feed Back closed control loop and not the Feed Forward closed control loop.
Self-correcting, Adaptive System
An embodiment of the present invention allows for updating the data stored in the vector look-up table. Every time a process run is executed, the data for that run is processed according to the various methods that have been described up to this point, and with that data, the vector look-up table is eventually updated The ability for the look-up table to be updated is of particular significance when data in the look-up table has been generated through Design of Experiment (DOE). Because the data from DOE is almost entirely derived data, output data derived from DOE is inherently less accurate than output data obtained from recording the results of actual process runs. Therefore, the ability to update a look-up table containing DOE data with data from actual process runs is essential. The embodiment of the present invention for updating the look-up table with recent empirical data is designed so that the process engineer can determine with what frequency the look-up table will automatically be updated. In many process control situations, it is neither efficient nor desirable to update the look-up table after every process run or even after every few process runs, and it is necessary to allow the process engineer to set the frequency for updating the look-up table based on the specific requirements of and constraints on the given process. This frequency can sometimes be even periods of weeks or months. Other embodiments of the present invention allow for analysis of output data in the look-up table and correction of model predicted output values.
S According to one of these embodiments, the actual values of output constants recorded during recent process runs are compared with the model predicted values for that output constant according to the vector look-up table Recent process runs are defined as process runs whose data has not been used to update the vector look-up table The differences, hereinafter residuals, between the actual values and the model predicted values of the output constant are calculated, and the residuals for each vector are examined If, for all the residual values calculated, a common residual value is observed, then this common residual value is used to correct the model predicted output values
Figure 14 (generally referenced as) 10,000 illustrates a vector look-up table 10,001 for output constant Oi at a given process stage, an Actual Values column 10,002 which is not part of the vector look-up table, and a Residual Values column 10,003 which is not part of the vector look-up table The vector look-up table 10,001 is composed of columns for data vectors 10,004 and columns for the output constant data for d 10,005 The entries for the vectors in the look-up table are input constant 10a 1 (generally referenced as) 10,006, input variable 10a 2 (generally referenced as) 10,007, and input variable 10a 3 (generally referenced as) 10,008 The types of output constant data recorded in this vector look-up table are Average 10,009, Standard Deviation 10,010, and Population 10,011 Output constant data is recorded in the look-up table for vectors (Ai, A2, C3) 10,012, (Bi, A2, D3) 10,013, (Ci, A2, A3) 10,014, (Ci, A2, B3) 10,015, (d , A2, C3) 10,016, (d, A2, D3) 10,017, and (d , B2, C3) 10,018 The Actual Values column 10,002 contains values Act0ι(Aι, A2, C3) 10,019, Actoι(Bι, A2, D3) 10,020, Actoι(C1 t A2, A3) 10,021 , Act0ι(d, A2, B3) 10,022, Actoι(Cι, A2, C3) 10,023, Actoi(Ci , A2, D3) 10,024, and
Si Actoι(Cι , B2, C3) 10,025 The Residual Values column 10,003 contains values Δoι(Aι , A2, C3) 10,026, Δ0,(Bι , A2, D3) 10,027, Δoι(C, , A2, A3) 10,028, Δ0ι(Cι , A2, B3) 10,029, Δ0ι(Cι , A2, C3) 10,030, Δoι(C, , A2, D3) 10,031 , Δ0ι(C,, B2, C3) 10,032 The Actual Values 10,002 are compared with the predicted values according to the Vector Look-Up Table for Output Constant "O1" 10,001 and the calculated difference between them is the Residual Value 10,003
For example, referring to Figure 14, depicted is the vector look-up table for output constant d at a given process stage which has been seen previously in Figures 11 and 12, with the noticeable difference that the population numbers for each vector are much greater now than they were in Figures 11 and 12 Assume that the process is now executed another 70 times with varying input combinations that correspond to the vectors in the look-up table depicted in Figure 14 The values for Oi for these 70 process runs are recorded but the look-up table is not updated with these values The column to the right of the look-up table contains the average of the actual values of Oi received during the 70 recent process runs for each vector in the look-up table, and the column on the far right contains the residual values of Oi for each vector in the look-up table That is, assume that during the 70 recent process runs, the process was executed 10 times for each vector in the look-up table
Therefore the value Act0ι(Aι , A2, C3) is the average of the 10 values received for Oi the when the process was executed with input combinations corresponding to the boundary value ranges Ai, A2, and C3, the value Acto.(Bi , A2, D3) is the average of the 10 values received for d when the process was executed with input combinations corresponding to the boundary value ranges Bi, A2, and D3, and likewise preferably for all the values listed in the Actual Values column The column on the far right contains the residual values of Oi for each vector in the look-up table That is the value ΔO1 (Aι ,A2,C3) in the first row of the residual values column is the difference between Oi of vector (Ai, A2, C3) and Actoι(Aι , A2, C3), Δoι(Bι , A2, D3) is the difference between (). of vector (Bi , A2, D3) and Act0ι(Bι, A2, D3), etc Assume that for vector (Ai, A2, C3), O, = 9 99 mm, for vector (Bi, A2, D3), Oi = 10 00 mm, for vector for vector (d , A2, A3), Oi = 10 02 mm, for vector (Ci , A2, B3), (), = 10 04 mm, for vector (C1 ? A2, C3), Oi = 9 96 mm for vector (C, , A2, D3), O, = 9 98, and for vector (d ,
B2, C3), Oi = 10 01 mm Further, assume that Actoi(Ai, A2, C3) = 9 97 mm, Actoι(Bι, A2, D3) = 9 98 mm, Act0ι(C, , A2, A3) = 10 00 mm, Act0ι(Cι, A2, B3) = 10 02 mm, Act0ι(Cι , A2, C3) = 9 94 mm, Act0ι(Cι , A2, D3) = 9 96 mm, and Act0ι(Cι , B2, C3) = 9 99 mm It is clearly seen that there is a common residual value for each vector in the look-up table of 0 02 mm Because there is a common residual value, the model predicted output values for Oi are decreased by 0 02 mm, and these adjusted predicted values will be used for the purposes of process control optimization at the given process stage in the future The example here presents a simple case of detecting an exact common residual value for all vectors in the look-up table However, in practice, a significant range for residual values will likely be determined such that even if residual values are not exactly equal, if residual values fall within the significant range, then a common residual value is considered to have been detected and the model predicted output values will be corrected by the average value of those residual values
Another embodiment of the present invention analyzes respective residuals and their corresponding model predicted values for each vector in the output constant's vector look-up table to determine whether a functional
Si relationship exists between the output constant's model predicted values and the corresponding residual value. If a functional relationship is determined, then that functional relationship is used to correct the model predicted output values for all vectors of the given output constant It is also possible that residual values will be analyzed and that no common residual value is detected, nor is any functional relationship determined between model predicted output values and their corresponding residual values This can also be true even when applying a significant range, and not an exact value, to detect common residuals In such a situation, if it is determined that the residual values are significant enough to warrant correction of model predicted output values, then the vector look-up table must be disregarded and a new vector look-up is calculated according to the embodiments of the present invention previously described here
APC - The Present Invention on the Module Level
The description of the embodiments of the present invention, up to this point, has focused on implementation of these embodiments at the process stage, or tool, level. It should be recalled that the tool level is the highest level of resolution in process control, such that process control optimization focuses on optimization of output at only one given stage in a process and no more. However, the embodiments of the present invention described here are also applied to process control optimization on the module level, where a module is defined as two or more contiguous tools in a process. In the simplest case, a module consists of two contiguous tools. In such a case, there is some output from the first tool that is input to the second tool. Process control optimization with embodiments of the present invention in such a case focuses on
< optimizing output at the second tool in the module by means of the input variables and constants of the first tool in the module
The schematic diagram in Figure 15 (generally referenced as) 11 ,000 illustrates a process module of two tools, a schematic diagram for APC on a Module Level 11 ,000 "Tool "1 " 11 ,001 and "Tool-2" 11 ,002 "Tool-1" has input constants T cknes s-m 11 ,003 and Pad Life- 1 11 ,004, has inputs variables "Time -I" 11 ,005, "Pres sure -I" 11 ,006, and "Speed -I " 11 ,007, and input constants (whose values are used in feed forward 11 ,001 to adjust the aforementioned input variable values) "Pad Life 1 " 11 ,003, and Thickness-in 11 ,004, and output constant Thickness-out 11 ,008 "Tool-2" has input constants Thickness-out 11 ,008 (which is also an output constant from "Tool-1") and Pad Lιfe-2 11 ,009, input variables Tιme-2 11 ,010, Presswe-2 11 ,011 , and Speed-2 11 ,012, and output constants Uniformity 11 ,013 and Final-Thickness 11 ,014 For example, Figure 15 presents a process module of two tools, labeled
Tool-1 and Tool-2 Tool-1 has input variables Tιme-1, Pressure- 1. and Speed-1, input constants Pad Life- 1 and Thιckness-ιn, and output constant Thickness-out, which is also an input constant to Tool-2. Tool-2 has input variables Tιme-2, Pressure-2, and Speed-2, input constants PadLιfe-2 and Thickness-out (the output constant from Tool-1 ), and two output constants Uniformity and Final-Thickness. Embodiments of the present invention can be applied to a process module such as the one depicted in Figure 15 for optimization of the output constants Uniformity and Final-Thickness at Tool-2 by means of the input constants and variables at Tool-1 Assume that a recipe of input values at Tool-2 has been determined for the optimization of the multiple outputs constants Uniformity and Final-Thickness This recipe contains a specific value or value range for the input constant Thickness-out at Tool-2. Because Thicknes s-out is also an output constant for Tool-1 , embodiments of the present invention are applied to Tool-1 to determine a recipe for the output target value or target value range of Thickness-out, where the output target value or target value range for Ihickness-out is the input constant value or value range of Thickness-out in the recipe for optimizing multiple outputs Uniformity and Fmal-Thicknes s That is, the recipe value of Thickness-out when optimizing multiple outputs constants I fnal-l uckness and Uniformity serves as the output target value for the recipe at Tool-1
The example illustrated in Figure 15 presents a simple case of applying embodiments of the present invention on the module level However it should be noted that embodiments of the present invention are applied on the module level where the module is any number or configuration of contiguous or non-contiguous tools For example, assume a module of five sequential tools If each tool in the module has one or more output constants that are inputs to the next tool in module, then a recipe for obtaining one or more output target values or target value ranges at the fifth tool in the module will serve as the basis for determining the recipe of input variables at the first tool in the module The embodiments of the present invention are applied at each tool in the module starting from the last tool and working back to the first tool At each tool, starting from the second to last tool in the module, target values or target value ranges for the output constants in the recipe at that tool will be the recipe values or value ranges that those output constants have as input constants in the recipe for the immediately following tool in the module, until a recipe is received for input values at the process engineer the first tool in the module Figure 16 (generally referenced as) 12,000 illustrates a schematic diagram of a module of four tools in a non-sequential configuration "TooMa" 12,001 , "Tool-1 b" 12,002, and "Tool-1 c" 12,003 are parallel tools which run in either a simultaneous or alternate manner and send output to "Tool-2" 12,004 "Tool-1a" has input constants 12,005, input variables 12,006, and output constants 12,007 which are also input constants to "Tool-2" "Tool-1 b" has input constants 12,008, input variables 12,009, and output constants 12,010 which are also input constants to "Tool-2" "Tool-1 c" has input constants 12,011 , input variables 12,012, and output constants 12,013 which are also input constants to "Tool-2" "Tool-2" has input constants 12,007, 12,010, and 12,013, and the output constant f inal Output 12,014
Likewise, embodiments of the present invention can be applied on non-sequential module configurations such as the module depicted in Figure 16 Figure 16 depicts a module of four tools, where Tools 1 a, 1b, 1 c run parallel to each other in either a simultaneous or alternate manner and send output to Tool-2 The output constants of Tools 1 a, 1 b, and 1c are input constants to Tool-2 Assume that an output target value is known for the output constant Final Output at Tool-2 A recipe for receiving the target value of Final Output is obtained using embodiments of the present invention The values of the input constants in the recipe for Final Output at Tool-2 then serve as the output constant target values for the recipes at Tools 1a, 1b, and 1c On the basis of the recipe at Tool-2, this embodiment of the present invention determines the output target values at each of the parallel tools and then determines the recipe for input variables and constants at each parallel tool
5

Claims

1. A strategic method for process control wherein said method includes the steps of: for a predetermined process juncture A. defining an interconnection cell having associated therewith i. at least one set of input data or at least one set of process control parameters, and ii at least one set of output data;
B. assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell;
C. using the assigned at least one boundary value, forming a plurality of discrete respective set combinations, and
D. for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters.
2. The method according to Claim 1 wherein defining an interconnection cell includes representing the interconnection cell as corresponding to a single stage in a process map.
3. The method according to Claim 1 wherein defining an interconnection cell includes representing the interconnection cell as corresponding to a group of contiguous stages in a process map.
% The method according to Claim 1 wherein defining an interconnection cell includes representing the interconnection cell as corresponding to a group of discontiguous stages in a process map
The method according to Claim 1 wherein defining an interconnection cell includes representing the interconnection cell as corresponding to a group of cells in a process map which includes therein substantially every stage in the process map
The method according to Claim 1 wherein defining an interconnection cell includes representing the interconnection cell as corresponding to at least two interrelated interconnection cells in a process map
The method according to Claim 1 wherein said at least one input data set includes historical empiric data obtained from a previously performed like-process
The method according to Claim 1 wherein said at least one input data set includes data currently being obtained from a substantially presently ongoing like-process
The method according to Claim 1 wherein defining the interconnection cell includes associating therewith derived data
</? The method according to Claim 1 wherein defining the interconnection cell includes associating therewith values generated by a Design-Of Experiments assessment of the predetermined process juncture, to be used for initialization of a like-process
The method according to Claim 1 wherein defining the interconnection cell includes associating therewith values computed using at least one predetermined formula
The method according to Claim 1 wherein defining the interconnection cell includes validating at least one set of the at least one set of input data to the interconnection cell as respectively having a substantially significant correlation with a set of the at least one set of output data
The method according to Claim 12, wherein said validating includes calculating a correlation coefficient between a selected set of the at least one set of input data, and the at least one set of output data, for the interconnection cell
The method according to Claim 1 wherein assigning at least one boundary value includes analyzing data in the respective set wherein the at least one boundary value is to be assigned
<?r
15. The method according to Claim 14 wherein analyzing data in the respective set includes examining the data according to at least one predetermined criterion
16. The method according to Claim 15 wherein examining the data according to at least one predetermined criterion includes electing a criterion selected from the list of
A Input constraints - i within a specification limit, n within a range of values, in " below an upper limit, iv above a lower limit, v closest to a mid-range value, vi closest to a previously used value;
B. Process constraints - i closest recipe to most recent recipe, ii. within a specification limit, iii. within a range of values, iv below an upper limit, v above a lower limit, vi. closest to a mid-range value; or
<!<? C Output goals - i within a specification limit, ii within a range of values, in a predetermined target value, iv an upper specification limit, v a lower specification limit, vi below an upper limit, vii above a lower limit,
VIM closest to a mid-range value
The method according to Claim 1 wherein processing includes summarizing data in each respective corresponding data record cluster
The method according to Claim 1 wherein processing includes implementing a Run-to-Run process control mode
The method according to Claim 1 wherein processing includes running a feed back closed control loop
The method according to Claim 1 wherein processing includes running a feed forward closed control loop
ic The method according to Claim 20 wherein running a feed forward closed control loop includes substantial optimization of multiple outputs
The method according to Claim 1 wherein processing includes transforming each summarized respective corresponding data record cluster into a sub-manifold of a multi-vaπate data manifold
The method according to Claim 1 wherein processing includes transforming each summarized respective corresponding data record cluster into a search-space vector
The method according to Claim 23 wherein transforming each summarized respective corresponding data record cluster into a search-space vector includes arranging at least one search-space vector into a vector look-up table
The method according to Claim 24 wherein the at least one search-space vector-having been arranged into a vector look-up table- is updated by using a self-correcting adaptive system
The method according to Claim 1 wherein processing includes
A for at least one process control parameter of the at least one set of process control parameters, prescribing at least one process control recipe-element for use in the predetermined process juncture, and
(Dl B designating the prescribed at least one process control recipe-element for use in the predetermined process juncture
The method according to Claim 1 wherein said processing includes using robust optimization
The method according to Claim 1 wherein said processing includes characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation
The method according to Claim 28 wherein said using a statistical calculation includes calculating a process capability ratio
The method according to Claim 28 wherein characterizing data in substantially each respective corresponding data record cluster by using a statistical calculation includes arranging the characterized data into a look-up table
The method according to Claim 30 wherein arranging the characterized data into a look-up table includes using the look-up table and therewith designating at least one process control recipe for use at the predetermined process juncture
rcΛ
32. The method according to Claim 31 wherein using the characterized data in the look-up table includes smoothing the data
33. The method according to Claims 30, 31 , and 32 wherein arranging the smoothed characterized data into a look-up table includes using the look-up table for designating at least one process control recipe for use at the predetermined process juncture.
34 The method according to Claim 31 wherein using the look-up table for designating at least one process control recipe for use at the predetermined process juncture includes selecting a best available vector and therewith deriving a process control recipe
35. The method according to Claim 33 wherein using the look-up table for designating at least one process control recipe for use at the predetermined process juncture includes updating said look-up table by using a self-correcting adaptive system
36. The method according to Claim 34 wherein selecting a best available vector for use with the process control recipe includes running a feed forward closed control loop.
37. The method according to Claim 1 wherein processing includes-to the predetermined process juncture associated with the interconnection cell-applying at least one of the respective corresponding data record clusters to the process occurring at that juncture
The method according to Claim 37 wherein at least one of the respective corresponding data record clusters is updated by using a self-correcting adaptive system
The method according to Claim 38 wherein applying at least one of the respective corresponding data record clusters includes reporting a process status, and wherein said reporting is initiated according to predetermined conditions
The strategic method for process control according to claim 1 wherein the steps of the method are applied for optimizing a Chemical/Mechanical Polishing processing of silicon wafers
A strategic method for process control wherein said method includes the steps of
A using a mapped plurality of graph-directed expertise-suggested interconnection cell relationships, defining a map referenced interconnection cell therein having associated therewith i at least one set of input data or at least one set of process control parameters, and n at least one set of output data, and
/6 T B using the map referenced interconnection cell, designating at least one process control recipe
The method according to Claim 41 wherein defining includes for the map referenced interconnection cell, validating at least one of the mapped plurality of graph-directed expertise-suggested interconnection cell relationships
The method according to Claim 41 wherein defining the map referenced interconnection cell includes validating the map referenced interconnection cell by simulating a validity-metric for an n-tuple of directed graph components of the map referenced interconnection cell
The method according to Claim 42 wherein defining the map referenced interconnection cell includes for an n-tuple of directed graph components of the mapped interconnection cell validating the map referenced interconnection cell by measuring if each of the at least one set of input data to the map referenced interconnection cell significantly contributes to that map referenced interconnection cell's output, wherein a predetermined convolution of these measuπngs constitutes an acceptable validity-metric
'05 The method according to Claim 41 wherein designating at least one process control recipe includes choosing another process control recipe whenever a particular obtained output value differs from a predetermined target value, by at least a predetermined value, thereby obtaining a new subsequent offset goal value closer to a predetermined target value
The method according to Claim 45 wherein obtaining a new offset goal value includes basing the value upon at least one output value from a previous similar process
The method according to Claim 46 wherein basing a new offset goal value includes analyzing the at least one output value from a previous similar process by running a feed back closed control loop
The method according to Claim 41 wherein defining a map referenced interconnection cell includes forming at least two search-space vectors.
An article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including:
/bio A first computer readable program code for causing a computer to define an interconnection cell having associated therewith i at least one set of input data or at least one set of process control parameters, and ii at least one set of output data,
B tied to the first computer readable program code, second computer readable program code for causing a computer to assign at least one boundary value to at least one set of the sets associated with the defined interconnection cell, and
C tied to the second computer readable program code, third computer readable program code for causing a computer to form a plurality of discrete respective set combinations, using the assigned at least one boundary value.
The article of manufacture according to claim 49 having computer readable program code embodied therein for causing a computer to arrange the respective corresponding data record clusters into a look-up table, for the interconnection cell
A program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including:
A for a predetermined process juncture, defining an interconnection cell having associated therewith
/OI i at least one set of input data or at least one set of process control parameters, and n at least one set of output data,
B for the predetermined process juncture, assigning at least one boundary value to at least one set of the sets associated with the defined interconnection cell,
C for the predetermined process juncture, using the assigned at least one boundary value forming a plurality of discrete respective set combinations and D for the predetermined process juncture, for the interconnection cell, processing data from the plurality of respective formed set combinations into respective corresponding data record clusters
The program storage device according to claim 51 including therein a method step whereby respective corresponding data record clusters are arranged into a look-up table
A system for performing strategic process control at a predetermined process juncture including A apparatus for delineating an interconnection cell, said interconnection cell having associated therewith i at least one set of input data or at least one set of process control parameters, and ii at least one set of output data,
l OZ B a computer having therein software for assigning at least one boundary value to at least one set of the at least one set of input data or to at least one set of the at least one set of output data, and having attached thereto data storage apparatus for storing the assigned data sets,
C a compressor for performing multi-dimensional representing, ordering, and combining of a plurality of discrete respective set combinations from the stored assigned data sets, and
D a processor for processing data from the plurality of discrete respective set combinations into respective corresponding data record clusters
The system according to Claim 53 wherein the processor includes attached thereto an applier for applying at least one of the respective corresponding data record clusters
The system according to Claim 53 wherein the computer includes attached therewith at least one sensor for providing an input or output datum to the respective set of input or output data
The system according to Claim 53 wherein the computer includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
/o9 An article of manufacture including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including
A first computer readable program code for causing a computer to define a map referenced interconnection cell having therein a mapped plurality of graph-directed expertise-suggested interconnection cell relationships and further having associated therewith i at least one set of input data or at least one set of process control parameters, and ii at least one set of output data, B tied to the first computer readable program code, second computer readable program code for causing a computer to use the map referenced interconnection cell to designate at least one process control recipe
A program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for performing strategic process control, said method steps including
A for a predetermined process juncture, using a mapped plurality of graph-directed expertise-suggested interconnection cell
no relationships, defining a map referenced interconnection cell therein having associated therewith i at least one set of input data or at least one set of process control parameters, and ii at least one set of output data, and
B for the predetermined process juncture, using the map referenced interconnection cell, designating at least one process control recipe
he method according to Claim 1 wherein processing data from the plurality of respective formed set combinations into respective corresponding data record clusters includes installing at least one data record cluster correspondence as a front end to a neural network, wherein the neural network is used for controlling an aspect of the process at the predetermined process juncture
The article of manufacture according to claim 49 including a computer usable medium having computer readable program code embodied therein for performing strategic process control at a predetermined process juncture, the computer readable program code in said article of manufacture including tied to the third computer readable program code, fourth computer readable program code for causing a computer to process data from the plurality of respective formed set combinations into respective corresponding data record clusters, for the interconnection cell
///
1. The system according to Claim 53 wherein the processor includes attached therewith at least one actuator for providing a process control parameter setting from the respective set of process control parameters, and the provided process control parameter setting is assigned according to a predetermined discrete respective set combination
PCT/US2000/028318 1999-10-31 2000-10-13 Strategic method for process control WO2001033277A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP00975247A EP1234204A1 (en) 1999-10-31 2000-10-13 Strategic method for process control
AU13326/01A AU1332601A (en) 1999-10-31 2000-10-13 Strategic method for process control

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
IL132663 1999-10-31
IL13266399A IL132663A (en) 1999-10-31 1999-10-31 Knowledge-engineering protocol-suite
US09/588,681 2000-06-07
US09/588,681 US6952688B1 (en) 1999-10-31 2000-06-07 Knowledge-engineering protocol-suite
US09/633,824 2000-08-07
US09/633,824 US7461040B1 (en) 1999-10-31 2000-08-07 Strategic method for process control

Publications (1)

Publication Number Publication Date
WO2001033277A1 true WO2001033277A1 (en) 2001-05-10

Family

ID=27271918

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2000/028318 WO2001033277A1 (en) 1999-10-31 2000-10-13 Strategic method for process control

Country Status (3)

Country Link
EP (1) EP1234204A1 (en)
AU (1) AU1332601A (en)
WO (1) WO2001033277A1 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2003088067A1 (en) 2002-04-10 2003-10-23 Kendro Laboratory Products, Lp Data-centric automation
WO2007023502A2 (en) * 2005-08-26 2007-03-01 Camtek Ltd. Method and system for automatic defect detection of articles in visual inspection machines
US7471991B2 (en) 2004-05-06 2008-12-30 Smp Logic Systems Llc Methods, systems, and software program for validation and monitoring of pharmaceutical manufacturing processes
US7799273B2 (en) 2004-05-06 2010-09-21 Smp Logic Systems Llc Manufacturing execution system for validation, quality and risk assessment and monitoring of pharmaceutical manufacturing processes
US7966087B2 (en) 2002-11-15 2011-06-21 Applied Materials, Inc. Method, system and medium for controlling manufacture process having multivariate input parameters
US8694145B2 (en) 2001-06-19 2014-04-08 Applied Materials, Inc. Feedback control of a chemical mechanical polishing device providing manipulation of removal rate profiles

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6112126A (en) * 1997-02-21 2000-08-29 Baker Hughes Incorporated Adaptive object-oriented optimization software system
US6122555A (en) * 1997-05-05 2000-09-19 Honeywell International Inc. System and methods for globally optimizing a process facility

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6112126A (en) * 1997-02-21 2000-08-29 Baker Hughes Incorporated Adaptive object-oriented optimization software system
US6122555A (en) * 1997-05-05 2000-09-19 Honeywell International Inc. System and methods for globally optimizing a process facility

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8694145B2 (en) 2001-06-19 2014-04-08 Applied Materials, Inc. Feedback control of a chemical mechanical polishing device providing manipulation of removal rate profiles
WO2003088067A1 (en) 2002-04-10 2003-10-23 Kendro Laboratory Products, Lp Data-centric automation
EP1493096A1 (en) * 2002-04-10 2005-01-05 Kendro Laboratory Products, LP Data-centric automation
EP1493096A4 (en) * 2002-04-10 2005-11-30 Kendro Lab Prod Lp Data-centric automation
US7966087B2 (en) 2002-11-15 2011-06-21 Applied Materials, Inc. Method, system and medium for controlling manufacture process having multivariate input parameters
US7471991B2 (en) 2004-05-06 2008-12-30 Smp Logic Systems Llc Methods, systems, and software program for validation and monitoring of pharmaceutical manufacturing processes
US7799273B2 (en) 2004-05-06 2010-09-21 Smp Logic Systems Llc Manufacturing execution system for validation, quality and risk assessment and monitoring of pharmaceutical manufacturing processes
WO2007023502A2 (en) * 2005-08-26 2007-03-01 Camtek Ltd. Method and system for automatic defect detection of articles in visual inspection machines
WO2007023502A3 (en) * 2005-08-26 2007-05-10 Camtek Ltd Method and system for automatic defect detection of articles in visual inspection machines

Also Published As

Publication number Publication date
EP1234204A1 (en) 2002-08-28
AU1332601A (en) 2001-05-14

Similar Documents

Publication Publication Date Title
US7461040B1 (en) Strategic method for process control
US6678668B2 (en) System and method for complex process optimization and control
TWI459169B (en) Method and system foryield prediction feedback for controlling an equipment engineering system, and non-transitory computer readable medium for recording related instructions thereon
US20210116898A1 (en) Matching process controllers for improved matching of process
Lee et al. Cutting-parameter selection for maximizing production rate or minimizing production cost in multistage turning operations
US7123978B2 (en) Method for dynamically targeting a batch process
Arkat et al. Applying simulated annealing to cellular manufacturing system design
CN108369916B (en) Wafer point-to-point analysis and data presentation
WO2001033277A1 (en) Strategic method for process control
Chan et al. Flexibility performance: Taguchi's method study of physical system and operating control parameters of FMS
KR20220160671A (en) Predictive Wafer Scheduling for Multi-Chamber Semiconductor Equipment
Foumani et al. A scalarization-based method for multiple part-type scheduling of two-machine robotic systems with non-destructive testing technologies
Mahootchi et al. A two-stage stochastic model for designing cellular manufacturing systems with simultaneous multiple processing routes and subcontracting
WO2023059740A1 (en) Time constraint management at a manufacturing system
JP2010267947A (en) Process parameter selection apparatus, process parameter selection method, process parameter selection program, program recording medium, and production process management apparatus containing the process parameter selection apparatus
Ng et al. Reference point based evolutionary multi-objective optimization with dynamic resampling for production systems improvement
US20230135102A1 (en) Methods and mechanisms for process recipe optimization
US20230384777A1 (en) Methods and mechanisms for preventing fluctuation in machine-learning model performance
Satori et al. Quantum optimization for location assignment problem in ASSR
Pilát et al. Surrogate model selection for evolutionary multiobjective optimization
US20230359179A1 (en) Methods and mechanisms for adjusting film deposition parameters during substrate manufacturing
US20230195074A1 (en) Diagnostic methods for substrate manufacturing chambers using physics-based models
US20240037442A1 (en) Generating indications of learning of models for semiconductor processing
US20230342016A1 (en) Methods and mechanisms for generating virtual knobs for model performance tuning
US20230306300A1 (en) Methods and mechanisms for measuring patterned substrate properties during substrate manufacturing

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 2000975247

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 2000975247

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWW Wipo information: withdrawn in national office

Ref document number: 2000975247

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: JP