This patent application is based on and claims priority to Japanese Patent Application No. 2019-165662 filed on Sep. 11, 2019, the entire contents of which are incorporated herein by reference.
The present disclosure relates to a model generating method, a model generating apparatus, and a program.
Genetic programming (GP) has been known. In genetic programming, by providing a combination of input data and output data as training data, a model (e.g., a function) that fits the training data can be obtained as an output result. Meanwhile, because genetic programming is an algorithm that uses random numbers, a resulting model may significantly differ from those previously modelled, even if the same training data is given. Thus, in a case in which input data is given to a model obtained at a current time, its output may differ significantly from an output obtained from a model that was previously modelled. Thus, in genetic programming, reproducibility of a modelling result is low, and genetic programming may not be practical.
Patent Document 1 describes a technique in which a calculation time of an optimization process using genetic programming until an optimum solution is obtained can be shortened.
[Patent Document 1] Japanese Laid-open Patent Application Publication No. 2017-162069
The present disclosure provides a model generating method, a model generating apparatus, and a program having high reproducibility of model generation, in the modeling using genetic programming.
In one aspect of the present disclosure, a model generating method performed by a computer is provided. First, multiple models are generated by repeatedly executing genetic programming that receives a training data set as an input, and for each of the multiple models, a fitness value that represents a degree of conformity between a corresponding model of the multiple models and the training data set is generated. Next, an indicator is calculated for each of the multiple models, and the multiple models are classified into clusters, by using the indicator calculated for each of the multiple models. Next, a cluster to which the largest number of the models belong is selected from the clusters. Finally, from among models belonging to the selected cluster, a model with the greatest fitness value is selected.
Hereinafter, embodiments will be described with reference to the drawings. For substantially the same components in the present specification and drawings, overlapping descriptions are omitted by giving the same reference numerals.
As noted above, in genetic programming, by providing training data, a model that fits the training data can be obtained as an output. However, in genetic programming, resulting models generally differ for each execution of genetic programming. Further, for example, differences between models cannot be evaluated as errors, and these models may be evaluated as completely different models. Thus, genetic programming may be less reproducible for modeling.
Accordingly, in the present embodiment, a model generating apparatus 10 capable of generating models with high reproducibility, by using genetic programming, will be described. Accordingly, by using the model generating apparatus 10 to be described in the present embodiment, models can be stably obtained with high reproducibility. In the present embodiment, a model is a program (or a program module) or data for predicting output data from input data, and a model is represented by, for example, a mathematical expression such as a function or a formula. Thus, the model generating apparatus 10 according to the present embodiment is applicable to generation of a model that is a solution of a regression problem or the like.
<Overall Configuration of Model Generating Apparatus 10>
First, the overall configuration of the model generating apparatus 10 will be described.
As illustrated in
The storage unit 107 stores various data necessary for generating a model (for example, a set of training data used for inputs of genetic programming, or the like). Hereinafter, a set of training data used for inputs of genetic programming may also be referred to as a “training data set”.
The model candidate generating unit 101 performs genetic programming multiple times by using the training data set stored in the storage unit 107 as an input, to obtain multiple models as the outputs of genetic programming. Hereinafter, the models obtained by the model candidate generating unit 101 may also be referred to as “model candidates”. Each of the model candidates is stored in the storage unit 107 in association with fitness, for example.
The fitness (may also be referred to as a fitness value) is a value used to select a model (e.g., a mathematical expression such as a function or a formula) in genetic programming, which represents a degree of conformity between a model and a training data set. In genetic programming, an ultimately selected model is output as a result. In the present embodiment, a model that is output as an output result of the genetic programming is referred to as the model candidate.
As indicator for evaluating similarity among model candidates stored in the storage unit 107, the indicator calculating unit 102 calculates sensitivity of each of the model candidates. Here, the sensitivity is an example of the indicator, and the sensitivity represents magnitude of variation in output data of a model candidate with respect to variation in input data. The sensitivity may be expressed by a scalar, or may be expressed by a vector. Regarding model candidates being of close sensitivity, variation in output data with respect to variation in input data tends to be similar. Thus, these model candidates can be said to be similar to each other. Sensitivity calculated by the indicator calculating unit 102 is stored in the storage unit 107 in association with a model candidate used for calculating the sensitivity, for example.
The clustering unit 103 divides (classifies) model candidates into multiple clusters by using sensitivity of each of the model candidates that is calculated by the indicator calculating unit 102. When classifying model candidates, the clustering unit 103 classifies the model candidates into multiple clusters so as to maximize a distance between the clusters. This results in similar model candidates (and identical model candidates) belonging to the same cluster. Hereinafter, in model candidates that are similar to each other, identical model candidates may be included.
The cluster selecting unit 104 selects a cluster having the largest number of elements (e.g., model candidates) from among the clusters classified by the clustering unit 103. That is, the cluster selecting unit 104 selects the cluster to which the largest number of model candidates belong. Here, because the number of elements in a cluster corresponds to the number of model candidates similar to each other, the larger the number of elements in a cluster, the more likely it is for identical or similar model candidates to be generated when generating model candidates by genetic programming. That is, the greater number of elements in a cluster, the more reproducible the model candidate belonging to the cluster.
The model selecting unit 105 selects a model candidate having the maximum fitness in genetic programming, from among the cluster selected by the cluster selecting unit 104 (hereafter, a cluster selected by the cluster selecting unit 104 may also be referred to as the “largest cluster”).
The output unit 106 outputs the model candidate selected by the model selecting unit 105 as an ultimately generated model. This provides a highly reproducible model in genetic programming.
An output destination of the output unit 106 may be any destination. For example, the output unit 106 may output (store) a model to the storage unit 107, output (transmit) a model to other devices connected via a communication network, or output (display) a model to a display device or the like.
Next, the hardware configuration of the model generating apparatus 10 will be described.
As illustrated in
The input device 201 may be, for example, a keyboard, a mouse, a touch panel, various operation buttons, or the like. The display device 202 may be, for example, a display or the like. The model generating apparatus 10 may not include at least either the input device 201 or the display device 202.
The external I/F 203 is an interface with an external device such as a recording medium 203a. Examples of the recording medium 203a include a floppy disk, a compact disc (CD), a digital versatile disc (DVD), an SD memory card, and a USB memory (or USB flash drive).
The communication I/F 204 is an interface for connecting the model generating apparatus 10 to the communication network.
The memory device 205 may be of various types of storage device, such as a random access memory (RAM), a read only memory (ROM), a flash memory, a hard disk drive (HDD), and a solid state drive (SSD). For example, the storage unit 107 may be implemented by using the memory device 205.
The processor 206 may be of various types of processing device, such as a central processing unit (CPU). The model candidate generating unit 101, the indicator calculating unit 102, the clustering unit 103, the cluster selecting unit 104, the model selecting unit 105, and the output unit 106 are realized, for example, by one or more computer programs stored in the memory device 205 being executed by the processor 206. The whole or a part of the one or more programs realizing the model candidate generating unit 101, the indicator calculating unit 102, the clustering unit 103, the cluster selecting unit 104, the model selecting unit 105, and the output unit 106 may be acquired (downloaded) from, for example, a server device connected via the communication I/F 204, or may be acquired (read) from the recording medium 203a via the external I/F 203.
The model generating apparatus 10 has the hardware configuration illustrated in
Next, a model generating process for generating models based on genetic programming with high reproducibility, which is performed by the model generating apparatus 10, will be described.
Let the training data set stored in the storage unit 107 be D, and D is expressed by the following expression (1).
D={d
(i):=(y(i),x1(i), . . . ,xn(i));i=1, . . . ,m} (1)
where d(i) is i-th training data, and m is the number of training data included in the training data set D. Hereinafter, y(i) included in training data d(i) may also be referred to as “correct answer output data”, and x1(i), . . . , xn(i) may also be referred to as “input data for training”.
First, in step S101, the model candidate generating unit 101 executes known genetic programming multiple times, by using the training data set D stored in the storage unit 107 as an input, to acquire multiple model candidates. The multiple model candidates are stored in the storage unit 107 in association with, for example, respective fitness of the model candidates. Thus, for example, if genetic programming is performed N times using the training data set D as the input, N model candidates and respective fitness of these N model candidates can be obtained. The number of times performing genetic programming may be designated by a user or the like, or may be predetermined.
In step S102, following step S101, for each of the model candidates stored in the storage unit 107, the indicator calculating unit 102 calculates the sensitivity. The sensitivity calculated for each of the model candidates is stored in the storage unit 107 in association with, for example, a corresponding model candidate used for calculating the sensitivity.
Here, the sensitivity of a model candidate (function f) can be calculated based on partial regression coefficients (or standardized partial regression coefficients) of the multiple regression equation y=f(x1, . . . , xn), where x1, . . . , and xn are explanatory variables and y is a target variable. For example, a change amount of the target variable y when the explanatory variable xj (j=1, . . . , n) varies by Δxj, is denoted by sj. The sensitivity may be calculated as a sum of sj (e.g., s1+s2 . . . +sn), or may be calculated by normalizing the sum of sj. The indicator calculating unit 102 may compute the sj (that is, a scalar quantity), as described above. Alternatively, as the sensitivity, the indicator calculating unit 102 may compute a vector having s1 to sn as elements (=(s1, s2, . . . , sn)).
The above-noted Δxj may be determined without constraint. For example, in a case in which sensitivity is calculated based on standardized partial regression coefficients, a standard deviation of the explanatory variable xj in the training data set may be used as Δxj. In this case, sj can be said to be a change amount of the target variable y when the explanatory variable xj varies by the standard deviation.
In step S103, following step S102, the clustering unit 103 classifies the model candidates into multiple clusters, by using the sensitivity calculated by the indicator calculating unit 102. At this time, the clustering unit 103 classifies the model candidates so as to maximize a distance between clusters.
Note that in the following description, a method for classifying the model candidates into clusters may also be referred to as a clustering method. As the clustering method, any type of method may be used. In the present embodiment, as an example of the clustering method, a hierarchical clustering using Ward's method will be described. The clustering unit 103 can classify the model candidates into multiple clusters, by performing hierarchical clustering using Ward's method according to the following steps 2-1 to 2-4.
(Step 2-1) First, the clustering unit 103 defines an initial state, in which each model candidate belongs to a different cluster. That is, for example, if there are L model candidates, the clustering unit 103 defines, as the initial state, a state in which there are L clusters each including only one model candidate different from those belonging to other clusters. Hereinafter, a cluster is denoted by Ck. “k” is an index (suffix) of the cluster, and in the initial state, k=1, . . . , L. In the initial state, L clusters (C1, C2, . . . , CL) are defined.
(Step 2-2) Next, the clustering unit 103 combines (two) clusters closest to each other to form a new cluster. In Ward's method, a distance between clusters (may also be referred to as an “inter-cluster distance”) between the cluster Ck and the cluster Ck′ is calculated by the following equation:
d
c(Ck,Ck′)=E(CkUCk′)−E(Ck)−E(Ck′)
where dc is the distance between clusters.
Note that E(Ck) is the sum of squares of the distance between the centroid of the cluster Ck(i.e., the average of sensitivity for all model candidates belonging to the cluster Ck) and the sensitivity corresponding to each model candidate belonging to the cluster Ck (this distance is also referred to as an “inter-sample distance”). Similarly, E(CkUCk′) is the sum of the inter-sample distances between the centroid of the cluster CkUCk′, which is the union of the cluster Ck and the cluster Ck′, and the sensitivity corresponding to each of the model candidates belonging to the cluster Ck or the cluster Ck′. In calculating the inter-sample distance, any type of distance can be used as the inter-sample distance. For example, Euclidean distance, Mahalanobis distance, Manhattan distance, Chebyshev distance, distance based on Cosine similarity, distance based on Tanimoto coefficient, and the like can be used as the inter-sample distance.
(Step 2-3) Next, the clustering unit 103 determines whether the number of clusters is one (i.e., only one cluster is present). If it is determined that the number of clusters is not one (that is, the number of clusters is two or more), the process of the clustering unit 103 returns to the above-described step 2-2. Accordingly, the above-described step 2-2 is executed repeatedly until the number of clusters becomes one. Meanwhile, if it is determined that only one cluster is present, the process of the clustering unit 103 proceeds to subsequent step 2-4.
When the number of clusters becomes one, the relationship between each of the model candidates and the clusters can be represented as a tree diagram called a dendrogram.
(Step 2-4) The clustering unit 103 adopts a clustering result in which the maximum inter-cluster distance dc is obtained in step 2-2 as the final clustering result. At this time, the clustering unit 103 determines a threshold value Th for selecting the final clustering result, in order to obtain the final clustering result having the maximum inter-cluster distance dc (i.e., the clustering arrangement selected from among all clustering arrangements, in which a pair of clusters having the greatest inter-cluster distance is present).
For example, suppose a case in which the dendrogram illustrated in
dst1: inter-cluster distance between a cluster including the model candidate M3 and a cluster including the model candidate M6
dst2: inter-cluster distance between a cluster including the model candidate M0 and a cluster including the model candidates M3 and M6
dst3: inter-cluster distance between a cluster including the model candidate M9 and a cluster including the model candidates M0, M3, and M6
dst4: inter-cluster distance between a cluster including the model candidate M4 and a cluster including the model candidates M0, M3, M6, and M9
dst5: inter-cluster distance between a cluster including the model candidate M1 and a cluster including the model candidates M0, M3, M4, M6, and M4
dst6: inter-cluster distance between a cluster including the model candidate M1 and a cluster including the model candidate M7
dst7: inter-cluster distance between a cluster including the model candidate M2 and a cluster including the model candidates M1 and M7
dst8: inter-cluster distance between a cluster including the model candidates M1, M2, and M7 and a cluster including the model candidates M0, M3, M4, M5, M6, and M9
dst9: inter-cluster distance between a cluster including the model candidate M8 and a cluster including the model candidates M0, M1, M2, M3, M4, M5, M6, M7, and M9
Also, suppose a case of dst3<dst1<dst2<dst4<dst5<dst6<dst7<dst9<dst8. In this case, the clustering unit 103 may determine a threshold value Th, for example, such that dst9<Th<dst8, and may perform clustering based on an inter-cluster distance exceeding this threshold value Th. Specifically, in the example illustrated in
By classifying the model candidates into clusters so as to maximize the inter-cluster distance dc (i.e., such that the largest inter-cluster distance can be obtained) as described above, even if the sensitivity is expressed as a vector for example, it is possible to obtain a stable clustering result against variations in the dimension of the vector.
In the present embodiment, the inter-cluster distance is calculated in accordance with Ward's method, but a calculation method of the inter-cluster distance is not limited thereto. For example, an inter-cluster distance may be calculated in accordance with a group average method, a shortest distance method, a longest distance method, or the like. Also, in the present embodiment, model candidates are classified into clusters by using the hierarchical clustering, but a clustering method is not limited thereto. Model candidates may be classified by using any clustering method (e.g., k-means clustering and the like). However, when the k-means clustering or the like is used, various parameters such as the above-described threshold value Th and the number of clusters k are determined by the user.
Following step S103, in step S104, the cluster selecting unit 104 selects the largest cluster (i.e., the cluster having the largest number of model candidates) from among the clusters obtained by the clustering unit 103.
Here, as illustrated in
Following step S104, in step S105, the model selecting unit 105 selects the model candidate having the largest fitness from the largest cluster selected by the cluster selecting unit 104.
Finally, in step S106, the output unit 106 outputs the model candidate selected by the model selecting unit 105 as an ultimately generated model. According to the above-described method in the present embodiment, a model can be obtained with high reproductivity in genetic programming. Because a model obtained in the present embodiment is highly reproducible and has high fitness as described above, it is expected that predicting ability (that is, generalization performance) with respect to unknown input data is high.
Next, examples of application of the above-described model generating apparatus 10 will be described. In the second embodiment, a case in which the above-described model generating apparatus 10 is applied to semiconductor manufacturing processing will be described.
The semiconductor manufacturing system illustrated in
The semiconductor manufacturing apparatus 301 is, for example, an etching apparatus that etches semiconductor substrates (may also be referred to as “wafers”). However, the semiconductor manufacturing apparatus 301 is not limited to an etching apparatus.
When etching a substrate, the substrate is loaded into a chamber of the semiconductor manufacturing apparatus 301, and an etching process is applied to the substrate in the chamber, under a certain process condition set by the controller 302.
The controller 302 is connected to the semiconductor manufacturing apparatus 301. The controller 302 controls each component of the semiconductor manufacturing apparatus 301. For example, the controller 302 may be configured by a general-purpose computer. When an etching process is applied to a substrate in the semiconductor manufacturing apparatus 301, the controller 302 controls the components of the semiconductor manufacturing apparatus 301 in order to control process conditions in the chamber. Examples of the process conditions include, but not limited to, a temperature in the chamber, a flow rate of a process gas supplied to the chamber during etching, an etching time (a period of time for etching a substrate in the chamber), and the like.
The controller 302 is also connected to the model generating apparatus 10 via a network N such as a local area network (LAN). In the example illustrated in
Similar to the first embodiment, the model generated by the model generating apparatus 10 (model generating process) according to the second embodiment is a function f expressed by y=f(x1, . . . , xn), where x1, . . . , xn are the input data, and y is the output data. In the following, the model obtained by the model generating apparatus 10 according to the second embodiment is referred to as a “wafer process model”. The input data (x1, . . . , xn) of the wafer process model is process conditions, such as a temperature in the chamber and a flow rate of a process gas supplied to the chamber during etching. Also, the output data (y) of the wafer process model is the CD value of a hole to be formed on a wafer by etching.
Similar to the first embodiment, the model generating apparatus 10 according to the second embodiment executes the model generating process (
Details of the semiconductor manufacturing apparatus controlling process will be described with reference to
The semiconductor manufacturing apparatus controlling process is executed by the processor 206 in the model generating apparatus 10. First, the processor 206 obtains the wafer process model generated by the model generating process (step S201). The processor 206 may obtain the wafer process model by reading out the wafer process model from the storage unit 107, after the model generating process (output unit 106) outputs (stores) the wafer process model into the storage unit 107.
Next, by using the input device 201, an operator of the model generating apparatus 10 (hereinafter referred to as a “user”) inputs the CD value of a hole that the user desires to form on a wafer by etching, and the processor 206 receives the CD value entered by the user (step S202). As described above, the CD value corresponds to the output data of the wafer process model. That is, the process of step S202 is equivalent to a process of receiving the output data of the wafer process model. In the following, the output data (CD value) received from the user is denoted by y′.
Next, in step S203, the processor 206 calculates the input data corresponding to the output data (y′) received in step S203, by using the wafer process model (function f). Specifically, the processor 206 calculates (searches for) the input data (x1, . . . , xn) that satisfies “f(x1, . . . , xn)−y′=0”. Alternatively, the processor 206 may calculate (search for) the input data (x1, . . . , xn) that minimizes (f(x1, . . . , xn)−y′)2. In order to search for the input data (x1, . . . , xn) satisfying “f(x1, . . . , xn)−y′=0” (or minimizing (f(x1, . . . , xn)−y′)2), conventional methods for solving an optimization problem may be used. For example, a gradient method, such as Newton's method or quasi-Newton method, may be used. In a case in which a gradient method is used, initial values of the input data is required. As the initial values of the input data, arbitrary value may be used. Alternatively, the initial values of the input data may be selected from the training data set used by the model generating process.
As described above, the input data (x1, . . . , xn) is the process conditions, such as a temperature in the chamber and a flow rate of a process gas supplied to the chamber. Thus, by performing step S203, the process conditions (x1, . . . , xn), which are required for forming a hole having the CD value y′ on the wafer by etching, can be obtained.
After the input data (x1, . . . , xn) is calculated in step S203, the processor 206 outputs (sends) the input data (process conditions) to the controller 302 to control the semiconductor manufacturing apparatus 301 (step S204). By outputting the input data (process conditions) to the controller 302, the controller 302 adjusts the process conditions (e.g., temperature, flow rate of process gas) in the semiconductor manufacturing apparatus 301 based on the input data.
As described above, when the model generating apparatus 10 according to the second embodiment receives the output data (CD value) y′ from the user, the model generating apparatus 10 outputs the process conditions (input data x1, . . . , xn) that satisfies f(x1, . . . , xn)−y′=0 (or outputs the input data (x1, . . . , xn) that minimizes (f(x1, . . . , xn)−y′)2). In other words, when the user desires to form a hole on a wafer by etching, by only inputting the CD value (output data y′) of the hole that the user desires to form on the wafer, the model generating apparatus 10 can output the process conditions that are required for forming the hole having the CD value y′, by using the wafer process model, and the model generating apparatus 10 can control the semiconductor manufacturing apparatus 301 based on the output process conditions. Therefore, in the semiconductor manufacturing system according to the second embodiment, the user can process the wafer at a desired etching profile without requiring extensive experience in wafer processing.
In another embodiment, the model generating apparatus 10 (semiconductor manufacturing apparatus controlling process) may obtain process conditions (input data) using multiple wafer process models. An example will be described below.
In this case, the model generating process of the model generating apparatus 10 generates multiple models (wafer process models). For example, when a wafer on which multiple layers of films are formed is to be etched and when the user desires to predict CD values of the first to s-th (s is an integer greater than 1) layers of the films, the user may cause the model generating apparatus 10 (model generating process) to generate the wafer process models that calculate CD values of the respective layers (CD value of the first layer, CD value of the second layer, . . . , and CD value of the s-th layer). In the following description, the CD value of the first layer, the CD value of the second layer, . . . , and the CD value of the s-th layer may be referred to as y1, y2, . . . , and ys, respectively. Also, the wafer process models that calculates y1, y2, . . . , and yn are denoted by f1(x1, . . . , xn), f2(x1, . . . , xn), . . . , and fn(x1, . . . , xn), respectively. Note that the input data (x1, . . . , xn) is the process conditions.
The flow of the semiconductor manufacturing apparatus controlling process in this case will be described with reference to
Next, in step S203, the processor 206 calculates the input data corresponding to the CD values (output data (y1′, . . . , ys′)) received in step S203, by using the wafer process models (f1, f2, . . . , fs). For example, the processor 206 may calculate (search for) the input data (x1, . . . , xn) that minimizes a sum of squares of differences between yk′ (k=1, 2, . . . , s) and fk(x1, . . . , xn). That is, the processor 206 may search for the input data (x1, . . . , xn) that minimizes the following expression:
After the input data (x1, . . . , xn) is calculated in step S203, step S204 is executed. The process performed in step S204 is similar to that described in the second embodiment.
Note that the method of calculating the input data performed in step S203 is not limited to the method of searching for the input data (x1, . . . , xn) that minimizes the sum of squares of the differences between yk′ and fk(x1, . . . , xn). For example, input data that minimizes a sum of absolute values of the differences between yx′ and fk(x1, . . . , xn) (i.e., Σ|fk(x1, x2, . . . , xn)−yk′|) may be calculated. In other words, in order to obtain process conditions (input data (x1, . . . , xn)) in step S203, the semiconductor manufacturing apparatus controlling process (processor 206) may use any mathematical function that evaluates the dissimilarity between the vector (f1(x1, . . . , xn), f2(x1, . . . , xn), . . . , fn(x1, . . . , xn)) and the vector (y1′, y2′, . . . , ys′).
Next, the third embodiment will be described. Similar to the second embodiment, the third embodiment describes a case in which the above-described model generating apparatus 10 is applied to semiconductor manufacturing processing performed in a semiconductor manufacturing system. As the configuration of the semiconductor manufacturing system in the third embodiment is the same as that in the second embodiment, description of the semiconductor manufacturing system will be omitted.
Similar to the second embodiment, the model generating apparatus 10 according to the third embodiment performs the model generating process described in the first or second embodiment to generate (output) a model, and calculates the process conditions by using the model. However, in the third embodiment, the model generating apparatus 10 generates a model in which the input data is information about an etching profile of a hole and the like that is to be formed in a substrate (wafer), and in which the output data is the process condition such as a temperature in the chamber or a flow rate of a process gas supplied to the chamber. In the third embodiment, the model generated by the model generating apparatus 10 is denoted by y=g(x1, . . . , xn), where g is a name of a function, x1, . . . , xn are input data of the model, and y is output data of the model. As described above, the input data is information about an etching profile of a hole and the like that is to be formed in a wafer. In the following description, information about an etching profile may also be referred to as “etching profile information”. Examples of the etching profile information include a depth of a hole and the like formed by etching, and a CD value of an opening of the hole and the like. Also, the output data is a process condition during etching of a wafer, such as a temperature in the chamber or an etching time. Thus, the training data set that is used in the example is a set of combinations of etching profile information and a process condition.
In addition to the above-described model generating process, the model generating apparatus 10 according to the third embodiment also performs a process of calculating the output data (i.e., process condition) from the input data (i.e. etching profile information) by using the model (function g) that is obtained by performing the model generating process. In the following description, the process of calculating the output data (i.e., process condition) from the input data (i.e. etching profile information) by using the model (function g) is referred to as a “process condition calculating process”. The process condition calculating process is implemented by software (program). The program implementing the process condition calculating process is referred to as a “calculation program”. The calculation program may be stored in the storage unit 107, or may be downloaded from other computers via the network N.
Details of the process condition calculating process will be described. The process condition calculating process is executed after the model (function g) is obtained by executing the model generating process.
First, the processor 206 obtains the model. This step is similar to step S201 in the second embodiment. After the processor 206 obtains the model, the user inputs the input data (etching profile information) by using the input device 201. When the processor 206 receives the input data (etching profile information) from the user, the processor 206 calculates the output data y (process condition) by using the model. Specifically, the processor 206 substitutes the input data to the function g to calculate the output data.
After the output data (process condition) is calculated, the model generating apparatus 10 outputs the output data (process condition) to the controller 302. For example, if a flow rate of a process gas is calculated as the process condition, the model generating apparatus 10 generates an instruction including the calculated flow rate, and send the instruction to the controller 302 to control the flow rate of the process gas to be at the calculated flow rate. When the controller 302 receives the instruction from the model generating apparatus 10, the controller 302 controls the semiconductor manufacturing apparatus 301 based on the instruction.
As described above, the model generating apparatus 10 according to the third embodiment can obtain (calculate) the process condition by using the model generated by the model generating process, similar to the second embodiment. The model generating apparatus 10 according to the third embodiment differs from the second embodiment in that the model generating apparatus 10 according to the third embodiment generates a model in which the input data is the etching profile information and the output data is the process condition. Thus, in the third embodiment, the process condition can be calculated quickly by substituting the input data (etching profile information) to the model (function g).
The semiconductor manufacturing system described in the second or third embodiment is a mere example, and may take other configurations. For example, the model generating apparatus 10 and the controller 302 may be implemented by a single computer.
It should be noted that the present invention is not limited to the above-described embodiments specifically disclosed. Variations and modifications of the structure described in the above-described embodiments, combinations with other components, and the like may be made without departing from the spirit of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2019-165662 | Sep 2019 | JP | national |