# 行政院國家科學委員會補助專題研究計畫 ■期中進度報告

# 半導體產業大型廠房之設施規劃

| 計畫類別:■ 個別型計畫 □ 整合型計畫<br>計畫編號:NSC 96-2628-E-009-026-MY3<br>執行期間:2007年08月01日至2010年07月31日           |
|--------------------------------------------------------------------------------------------------|
| 計畫主持人:巫木誠<br>共同主持人:<br>計畫參與人員:施昌甫、陳振富                                                            |
| 成果報告類型(依經費核定清單規定繳交):■精簡報告 □完整報告                                                                  |
| 本成果報告包括以下應繳交之附件:  □赴國外出差或研習心得報告一份  □赴大陸地區出差或研習心得報告一份  □出席國際學術會議心得報告及發表之論文各一份  □國際合作研究計畫國外研究報告書一份 |
| 處理方式:除產學合作研究計畫、提升產業技術及人才培育研究計畫、<br>列管計畫及下列情形者外,得立即公開查詢<br>□涉及專利或其他智慧財產權,□一年□二年後可公開查詢             |
| 執行單位:國立交通大學工業工程與管理學系                                                                             |

中華民

國

2009年 05月 30日

#### 半導體產業大型廠房之設施規劃

國科會計畫編號:NSC 96-2628-E-009-026-MY3

主持人: 巫木誠 交大工業工程與管理系

# 中文摘要

本研究提供有效的方法解決晶圓廠跨廠區生產的途程規劃問題。半導體廠通常會採用雙廠區的策略,所謂雙廠區生產策略為:將兩座晶圓廠蓋在隔壁,每個晶圓廠的產能可透過跨廠的方式分享產能,所謂跨廠生產的方式為一種產品的至程可以分成可以分成兩部份,一部分在原來廠房生產,另一部分在另一個廠房生產。由於有兩個廠房可供選擇,所以會產生途程規劃的問題。在目標為最大化產出及特定的生產週期時間限制下,必須作兩項決策;第一個決策是決定每種產品可跨廠生產的切割點,第二個決策是決定每種產品在每一途程的生產比例。先前的研究有探討到跨廠生產途程規劃問題,但只適用於小規模生產,當規模擴大時,會產生解空間過大而造成運算時間過長的問題。為了克服此項缺點,本研究提出了三種改良方式,實驗結果證明本研究所提出的方法可以有效的降低計算的複雜度,從原先需花13小時才能求得最佳解改良成只需要 0.5 小時即可求出近似最佳解,在求解時間方面有顯著的改善績效。

關鍵詞:雙廠區、跨廠途程、途程規劃、產能支援、基因演算法、線性規劃

#### Abstract

This paper proposes an efficient approach to solve a cross-fab route planning problem for semiconductor wafer manufacturing. A semiconductor company usually adopts a *dual-fab* strategy. Two fab sites are built neighbor to each other to facilitate capacity-sharing. A product thus may be produced by a *cross-fab route*; that is, some operations of a product are manufactured in one fab and the other operations in the other fab. This leads to a cross-fab routing planning problem, which involves two decisions—determining the cutoff point of the cross-fab route and the route ratio for each product—in order to maximize the throughput subject a cycle time constraint. A prior study has proposed a method to solve the cross-fab route planning problem; yet it is computationally extensive in solving large scale cases. To alleviate this deficiency, we proposed three enhanced methods. Experiment results show that the best enhanced method could significantly reduce the computational efforts from about 13 hours to 0.5 hour, while obtaining a satisfactory solution.

Keywords: dual-fab, cross-fab route, route planning, capacity sharing, genetic algorithm, linear programming

#### 1. Introduction

Recently, some semiconductor companies tend to adopt a *dual-fab* strategy. The strategy advocates that building two fabs at a time, which are next door to each other. One reason why this strategy arises is due to that semiconductor equipment, compared with fab space, is much more expensive and shorter in lead time of acquisition. In practice, more than 80% expenditure of an advanced wafer fab is spent on equipment. The acquisition lead time for equipment ranges from 3-9 months, while that for fab space takes about 1-2 years. To quickly respond to volatile market demand, some companies tend to build a large-scale space for two fabs in advance and gradually purchase equipment based on future demand over time.

Not only good in fast capacity expansion, the dual-fab strategy also provides a *capacity-sharing* mechanism due to close proximity of the two fabs. Consider a *single-fab* production policy which requests each wafer job be manufactured in *only* one fab. In a dual-fab configuration, such a policy usually leads to underutilization of equipment because idle equipment capacity in one fab cannot be used by the other. To utilize the idle capacity, we may have to adopt a *cross-fab* production policy. That is, the manufacturing of a wafer job could be partly done in one fab and partly in the other.

However, under the cross-fab production policy, we would be confronted with a *route-planning* problem—how to appropriately assign the operations of a wafer job to each of the two fabs. Prior studies on such a route-planning problem are relatively few. With each job route being cut into several segments, Toba et al. (2005) studied the route-planning problem in a *real-time* manner. That is, whenever a segment is completed, a decision—which fab to manufacture the next segment—must be immediately made. Wu and Chang (2006) examined a route-planning problem in a *weekly* horizon. Assuming the two fabs plan capacity exchange weekly, they attempted to find an optimal capacity-trading portfolio in order to maximize the total throughput of the two fabs.

Aside from the track of short-term route planning, Wu at al. (2007) addressed the problem from a *relatively long-term* perspective. Given a product mix to produce, say in a *quarter*, they attempted to determine how to cut the route of each product into two segments; and determine the production ratio of each segment that should be assigned to each fab. Their objective function is

to maximize the total throughput of the two fabs subject that a target cycle time must be met.

Numeric experiments indicated that the method proposed by Wu et al. (2007) could effectively increase equipment utilization and total throughput for a dual-fab scenario. However, their method may become computationally extensive in dealing with large scale cases.

In order to *efficiently* solve the route-planning problem, this paper presents an enhanced approach based on Wu et al. (2007). Numeric experiments indicated that solutions obtained by the enhanced approach are almost as good as that obtained by Wu et al. (2008) yet requires much less computational efforts.

The remainder of this paper is organized as follows. Section 2 reviews relevant literature. Section 3 explains the route planning problem. Section 4 outlines the LP-GA solution framework proposed by Wu et al (2008). Section 5 presents the LP (linear program) and our enhancements to reduce computational time. Section 6 presents the GA (genetic algorithm) and our enhancements to reduce computational time. Numerical experiments are in Section 7 and concluding remarks are in the last section.

#### 2. Relevant Literature

In a company with multiple manufacturing sites, planners would face a capacity allocation decision—how to allocate a given demand to each manufacturing site. Literature on the capacity allocation problem could be grouped in two categories:

product-level and operation-level.

In the product-level category, most literature assumed a single-site production policy—each product should be completely manufactured with a single site. A literature survey has been published by Wu et al. (2005), and some recent studies can be referred to (Manmohan 2005; Lee et al. 2006; Chiang et al. 2007). Most of these prior studies used the linear programming (LP) technique to solve the capacity allocation problems.

In the operation-level category, most literature assumed a cross-site production policy manufacturing operations for a product could be distributed among different sites. The need of studying the cross-site-route-planning problems thus arises. Such route planning problems were mostly addressed in the context of group technology (GT). Example literature includes (Kim et al.

2005; Vin et al. 2005; Dimopoulos 2006; Mahdavi 2006; Nsakanda et al. 2006; Spiliopoulos & Sofianopoulou 2007).

In GT, each site is a manufacturing cell and multiple cells from a factory. A GT cell is designed for manufacturing a particular group of products, and by nature is functionally limited. A cell thus may need to outsourcing decision of each cell.

By contrast, in the route-planning problem we address, each of the two fabs is assumed to be functionally comprehensive. Each product can be completely manufactured in either one of the two fabs. The purpose of cross-fab route planning is to maximize the aggregate throughput through optimum capacity sharing.

#### 3. Problem Statement

The *dual-fab route-planning* problem is explained in more detail, where the two fabs are called *Fab\_1* and *Fab\_2*. We first present the assumptions, and proceed to the decision variables, objective function and constraints.

Assumption 1: Each fab is functionally comprehensive. Both fabs are so comprehensively equipped that each fab can individually complete the production of each product—not requiring support of the other fab.

Assumption 2: The transportation path between any two workstations/buffers is unique, rather than multiple. In practice, there exist multiple paths in transporting a wafer job from a workstation/buffer to another. However, to reduce the problem complexity, we assume that a fixed path is predefined for such a transport.

Assumption 3: Each product has only four possible routes. The process route of each product is cut into two segments, where a route's break point is called a *cut-off point*. A product has four possible manufacturing routes:  $1 \rightarrow 2$ ,  $2 \rightarrow 2$ ,  $1 \rightarrow 2$ , and  $2 \rightarrow 1$ , where notation  $i \rightarrow j$  denotes the first segment is manufactured at  $Fab_{-}i$  while the second is manufactured at  $Fab_{-}j$ .

Define  $r_i = [a_i, b_i, c_i, d_i]$  as the percentage of the four possible routes of product *i*. Each element of  $r_i$  in sequence represents the route percentage of  $1 \rightarrow 1, 2 \rightarrow 2, 1 \rightarrow 2, \text{ and } 2 \rightarrow 1.$  Define  $\pi_i$  as the cutoff point for the route of product *i*, which is the identification code (an

integer) of the operation for separating a route into two segments. The range of  $\pi_i$  is  $1 \le \pi_i \le o_i - 1$  where  $o_i$  is the total number of operation of product i. We set  $\pi_i = 0$  while we determine not to manufacture product i by using any cross-fab routes.

Consider a dual-fab company that has n products to manufacture, Represent a solution of the route planning problem by  $(\Pi, R)$ , where  $\Pi = [\pi_1, ..., \pi_n]$  and  $R = [r_1, ..., r_n]$ . The objective is to find an optimal solution  $(\Pi^*, R^*)$  in order to maximize the total throughput of the two fabs, subject to the constraint of meeting a target cycle time.

# 4. Solution Framework

To solve the dual-fab route planning problem, we adopted the solution framework proposed by Wu et al (2008), and developed several enhancements to their solution method in order to reduce computational efforts. As shown in Fig. 1, the solution framework involves two modules.

In Module 1, each path is assumed to be equipped with *infinite transportation capacity*; and the transportation time between any two workstations/buffers is thus zero. The problems so simplified are solved by an iterative use of a linear program (LP) model. This module is intended to find an optimum solution  $(\Pi_L^*, R_L^*)$ , in terms of minimizing the total number of inter-fab transportations. In the prior study (Wu et al 2008), this module is very computationally extensive because the number of LP iterations is quite huge for large scale cases. We proposed three heuristic methods to enhance the prior study by significantly reducing the number of LP iterations.

Let  $(\Pi_L^*, R_L^*)$  represent the solution obtained in Module 1. In Module 2—by taking  $\Pi_L^*$  as given parameters, we deal only with decision variable R by considering each path as a tool with limited transportation capacity. The transportation time for a path depends upon the traffic flow intensity. The higher the traffic intensity, the longer is the cycle time. The performance of a particular  $(\Pi_L^*, R)$  could be evaluated by applying a queueing network model (Connors et al. 1996). In the prior study (Wu et al. 2008), they developed a GA to find a near-optimal solution from the space  $\{(\Pi_L^*, R)\}$ , which is also computationally extensive while dealing with large

scale cases. We enhanced the prior study by reducing the size of the GA chromosomes. In the

enhanced GA, many elements in R are considered to be constant and only a few need to searched

The essences of these two modules are compared below. Module 1 essentially deals with a

static capacity allocation problem which does not consider job flow time. In contrast, Module 2

deals with a time-phased capacity allocation problem, in which job flow time is addressed and

computed by a queueing network model.

#### 5. Module 1-LP Model and Enhancements

Obtaining the solution for Module 1 is through an *iterative* use of an LP model. We first describe the LP model, and then present the architecture of the iterative process. Finally, we describe the three methods designed to reduce the number of LP iterations.

#### 5.1 LP Model

Indices

*i*: index of product

g: index of workstation in Fab\_1

h: index of workstation in Fab\_2

#### **Parameters**

n: total number of products

 $\pi_i$ : cutoff point for defining the cross-fab routes of product i

 $\Pi$ :  $\Pi = [\pi_i]$ ,  $1 \le i \le n$ , the cut-off points of all products

V: estimated total throughput of the two fabs, input by user.

 $z_i$ : percentage of product i in the given product mix,  $\sum_{i=1}^n z_i = 1$ ,  $0 \le z_i \le 1$ .

 $C_g$ : available machine hours of workstation g in  $Fab\_1$ 

 $C_h$ : available machine hours of workstation h in  $Fab\_2$ 

 $m_1$ : total number of workstations in Fab 1

 $m_2$ : total number of workstations in Fab\_2

- $W_{ig}^{a}$ : total processing time per lot required on workstation g in  $Fab\_1$ , while product i is manufactured by route  $1 \rightarrow 1$ .
- $W_{ig}^c$  total processing time per lot required on workstation g in  $Fab\_1$ , while product i is manufactured by route  $1 \rightarrow 2$
- $W_{ig}^{d}$ : total processing time per lot required on workstation g in  $Fab\_1$ , while product i is manufactured by route  $2 \rightarrow 1$
- $W_{ih}^b$ : total processing time per lot required on workstation h in  $Fab\_2$ , while product i is manufactured by route  $2 \rightarrow 2$
- $W_{ih}^c$ : total processing time per lot required on workstation h in  $Fab\_2$ , while product i is manufactured by route  $1 \rightarrow 2$
- $W_{ih}^{d}$  total processing time per lot required on workstation h in  $Fab\_2$ , while product i is manufactured by route  $2 \rightarrow 1$

**Decision Variables** 

$$R: R = [\bar{r}_1, ..., \bar{r}_n], \text{ where } \bar{r}_i = [a_i, b_i, c_i, d_i]$$

 $a_i$ : percentage of using route  $1 \rightarrow 1$  in producing product i

 $b_i$ : percentage of using route  $2 \rightarrow 2$  in producing product i

 $c_i$ : percentage of using route  $1 \rightarrow 2$  in producing product i

 $d_i$ : percentage of using route  $2 \rightarrow 1$  in producing product i

The LP model is to compute an optimum R for a given pair of  $(V, \Pi)$ , in terms of minimizing the number of cross-fab transportation. Define the objective function by  $Z(V, \Pi)$ . The LP model is formulated below.

$$Min Z(V,\Pi) = \sum_{i=1}^{n} V \cdot z_i \cdot (c_i + d_i)$$

s. t.

$$a_i + b_i + c_i + d_i \neq \qquad 1 \le i \le n \tag{1}$$

$$\sum_{i=1}^{n} V \cdot z_{i} \cdot (a_{i} \cdot W_{ig}^{a} + d_{i} \cdot W_{ig}^{d} + c_{i} \cdot W_{ig}^{c}) \le C_{g} \qquad 1 \le g \le m_{1}$$
 (2)

$$\sum_{i=1}^{n} V \cdot z_{i} \cdot (b_{i} \cdot W_{ih}^{b} + d_{i} \cdot W_{ih}^{d} + c_{i} \cdot W_{ih}^{c}) \le C_{h} \quad 1 \le h \le m_{2}$$
 (3)

The objective function is to minimize the number of cross-fab production lots. The rationale for defining this objective is that cross-fab production requires longer transportation time than within-fab production. Subject to a target cycle time, an attempt to minimize cross-fab production lots tends to increase total throughput. Constraint (1) describes the dependent relationship among the route ratios. Constraints (2) and (3) ensure that the capacity used in each workstation, in  $Fab_1$  and  $Fab_2$ , should be lower than its available supply. Notice that V is the estimated throughput; the LP may yield no solution while V is too large.

In the above LP model, each of the n products is eligible for cross-fab production. To reduce computational complexity, we propose to divide the products into two sets:  $Q_c$  and  $Q_s$ . Products in  $Q_c$  are eligible for cross-fab production, and those in  $Q_s$  are only allowed for single-fab production. To deal with such a general scenario  $(Q_c, Q_s)$ , the above LP should be modified by including the following constraints.

$$c_k = 0$$
 and  $d_k = 0$  for each product  $k$  in  $Q_s$  (4)

A procedure  $LP\_Module(V,\Pi,Q_c,Q_s)$  is defined below to facilitate explaining the iterative procedures for calling the modified LP.

# **Procedure LP\_Module** $(V, \Pi, Q_c, Q_s)$

Step 1: Compute  $LP(V, \Pi, Q_c, Q_s)$ 

Step2:

If (LP has no solution) then Pass Check = "Fail", **Return** 

If (LP has solution) then Pass\_Check = "Pass",

**Return**  $Z(V,\Pi)$ ,  $R(V,\Pi)$ , Pass\_Check

In Step 1 of the above procedure, LP( $V,\Pi,Q_c,Q_s$ ) denotes the modified LP. In Step 2, Pass\_Check is a flag in which "Fail" denotes the value of V is too large. Moreover,  $R(V,\Pi)$  denotes the obtained route ratio and  $Z(V,\Pi)$  denotes the obtained value in objective function.

#### **5.2 Iterative Process of LP**

To solve the route planning problem, we need to iteratively run  $LP\_Module(V,\Pi,Q_c,Q_s)$ . The architecture of the iterative process is shown in Fig. 2. The architecture involves four procedures, which are organized in a hierarchical manner. The bottom level of the hierarchy is the  $LP\_Module(V,\Pi,Q_c,Q_s)$ . Details of the other three procedures are presented in Appendices 1-3.

Of the three top level procedures,  $Route\_Planning$  is intended to ask users input  $(Q_c,Q_s)$  and (L,U) which is the range of V. Given a scenario  $(L,U,Q_c,Q_s)$ ,  $Route\_Planning\_for\_Given\_Throughput$  is intended to find an optimal  $V \in (L,U)$ , where the algorithm for identifying V is based on a binary-search method (Fig. 3)  $Performance\_Evaluation$  is intended to find  $(\Pi^*,R^*)$  for a given scenario  $(V,Q_c,Q_s)$ , based on a binary-search algorithm over multiple intervals and each interval is a product route.

Assume set  $Q_c$  has  $n_c$  products; that is, there are  $n_c$  product routes to search for their optimal cut-off points. The computational complexity of the iterative process is  $O(2^{n_c k_1})$  where  $k_l$  is a constant which denotes the maximum number of search required to carry out on each product route. It might be very much computationally extensive while  $n_c = n$  (ie., all products are eligible for cross-fab production). One way to efficiently solve the route planning problem is to find an appropriate  $Q_c$ , which has small value of  $n_c$  and can yield a good quality solution.

# **5.3 Reduction of Iteration Number**

To find such an appropriate  $Q_c$ , we developed a procedure *Product\_Sorting* to categorize all products into three groups. Taking each group as a particular selection of  $Q_c$ , we would have

three different versions of  $Q_c$ . The procedure is presented below.

#### Procedure Product\_Sorting

Step 1: Identify the bottleneck workstation (say, *B*) of the two fabs.

Step 2: Compute the workload of each product on *B* 

Step 3: Sort all the *n* products according to their workload on *B*.

Step 4: Categorize products into three groups, based on the sorted results.

With three different versions of  $Q_c$ , we could have three solution methods in Module 1. The method, using the product group with the highest bottleneck workload, is called  $LP_1$ . The one with middle-level bottleneck workload is called  $LP_2$ , and the remaining one is called  $LP_3$ . The method proposed by Wu et al (2008) is called  $LP_0$ .

The rationale for taking bottleneck workload as the criterion for grouping products is two fold. First, the utilization of bottleneck workstation dominates the two fabs' throughput. Thus, in cross-fab route planning decisions, the capacity allocation of bottleneck workstation would be most critical. Second, we attempt to justify which product group is most critical in the cross-fab route planning—the heavily load group, the middle-level load group, or the lightly loaded group.

#### 6. Module 2—GA

Define the solution of Module 1 as  $(\Pi_L^*, R_L^*)$ , which is obtained under the assumption of *infinite transportation capacity*. In Module 2, with  $(\Pi_L^*, R_L^*)$  being available, we developed a GA in order to find a better solution  $(\Pi_G^*, R_G^*)$  under the assumption of *finite transportation capacity*.

The GA is an enhanced version of the one proposed by Wu et al. (2008). Like Wu et al. (2008), we first set  $\Pi_G^* = \Pi_L^*$  and attempt to find  $R_G^*$ . But in the search of  $R_G^*$ , we make an enhancement by setting  $c_k = d_k = 0$  for each product k in  $Q_S$  (i.e., the single-fab production policy presumed in Module 1 is preserved).

The enhancement could simplify the representation of a solution. Consider a chromosome (a

possible solution) represented by a vector  $R = [\overline{r_1}, ... \overline{r_n}]$  where  $\overline{r_i} = (a_i, b_i, c_i, d_i)$ . We call  $\overline{r_i}$  a gene-segment, and each element in  $\overline{r_i}$  a gene. Since  $a_i + b_i + c_i + d_i = 1$ , we have three free genes for each product in  $Q_c$  and one free gene for each product in  $Q_s$ . Here, a free gene is one whose value is changeable in the search process, while a gene whose value is not changeable is called a static gene. With this enhancement, a chromosome has only  $3n_c + (n - n_c)$  free genes, rather than 3n ones as in Wu et al. (2008). The GA proposed by Wu et al. (2008) is called  $GA_I$ .

The performance (also called fitness) of each chromosome is computed by a queueing network model (Wu et al. 2008), which is adapted from the one developed by Connors et al. (1996). For a given chromosome (i.e., a route plan), the queueing network can be used to compute the aggregate throughput of the two fabs subject to meeting a target cycle time.

The GA is an iterative algorithm which can be briefly described as follows.

#### **Procedure GA**

Step 1: Initialization

- t = 0, Status = 'Not-terminate'
- Randomly generate  $N_p$  chromosomes to form a population  $P_0$

Step 2: Genetic Evolution

While (Status = 'Not-Terminate') do

- Use a *cross-over* operator to create  $N_c$  new chromosomes
- Use a *mutation* operator to create  $N_m$  new chromosomes
- Form a pool by taking the union of  $P_t$  and the set of newly created chromosomes
- t = t + 1, and select the best  $N_p$  chromosomes from the pool to form  $P_t$
- Check if *termination condition* is met; if yes, set Status = "Terminate"

Endwhile

Step 3: Set the best chromosome in  $P_t$  as  $R_G^*$ . Output  $R_G^*$ .

The crossover operation is to create two new chromosomes (say,  $R_3$  and  $R_4$ ) from two existing ones (say,  $R_1$  and  $R_2$ ). Let each *gene-segment* i in  $R_1$  and  $R_2$  be respectively represented

by  $\overline{r_{i1}}$  and  $\overline{r_{i2}}$ . We proposed a one-point crossover operation (Binh & Lan 2007) on gene-segments  $\overline{r_{i1}}$  and  $\overline{r_{i2}}$  to create two new ones  $\overline{r_{i3}}$  and  $\overline{r_{i4}}$ , which in turn could yield two new chromosomes:  $R_3 = [\overline{r_{i3}}], R_4 = [\overline{r_{i4}}], 1 \le i \le n$ .

The one-point crossover operation on a gene-segment is briefly introduced. For two gene-segments (i.e.,  $\overline{r_{i1}}$  and  $\overline{r_{i2}}$ ), we randomly choose a *free* gene, swap their gene values, and modify another gene values in order to ensure meeting the constraint  $a_i + b_i + c_i + d_i = 1$ . Consider an example where the  $2^{\rm nd}$  gene (a free one) is chosen as the cross-over point for mixing  $\overline{r_{i1}} = (a_{i1}, b_{i1}, c_{i1}, d_{i1})$  and  $\overline{r_{i2}} = (a_{i2}, b_{i2}, c_{i2}, d_{i2})$ . By the swap and modification operations, we would obtain  $\overline{r_{i3}} = (a_{i1}, b_{i2}, c_{i1}, 1 - a_{i1} - b_{i2} - c_{i1})$  and  $\overline{r_{i4}} = (a_{i2}, b_{i1}, c_{i2}, 1 - a_{i2} - b_{i1} - c_{i2})$ .

In the mutation operation, a new chromosome (say,  $R_2$ ) is created by an existing one (say,  $R_1$ ). The mutation algorithm creates  $R_2$  by modifying a particular gene-segment in  $R_1$ . The modified gene-segment is randomly chosen. While being selected, two of its free genes are randomly chosen and their gene values are swapped. For example, if gene-segment  $i^*$  is chosen for modification; and the  $2^{\rm nd}$  and  $4^{\rm th}$  genes are chosen to swap for  $\overline{r_{i^*1}} = (a_{i1}, b_{i1}, c_{i1}, d_{i1})$ , then  $\overline{r_{i^*2}} = (a_{i1}, d_{i1}, c_{i1}, b_{i1})$ , which in turn yield a new chromosome  $R_2 = [\overline{r_{i1}}, ...\overline{r_{i^*2}}, ...\overline{r_{n1}}]$  from  $R_1 = [\overline{r_{i1}}, ...\overline{r_{i^*1}}, ...\overline{r_{n1}}]$ . Notice that only products in  $Q_c$  are eligible for applying the mutation operation.

Two termination conditions are defined for the GA. First, the best solution in  $P_t$  has not been changed for over a certain period (say,  $T_b$  iterations). Second, population  $P_t$  has evolved over a certain number of iterations; that is, t has reached its predefined upper bound ( $T_u$ ).

#### 7. Experiments

Numeric experiments are carried out to compare the performance of our three proposed methods against the one proposed by Wu et al. (2008). The one proposed by Wu et al. (2008) is called  $LP_0$ - $GA_0$ . The three we proposed are respectively called  $LP_1$ - $GA_1$ ,  $LP_2$ - $GA_1$ , and  $LP_3$ - $GA_1$ . A personal computer equipped with Pentium (R) Dual CPU 3.4GHz and 1G RAM is used in the

experiments.

In the experiments, the data for machines, product routes and operation times are adapted from a data set provided by a semiconductor company. Each of the two fabs involves 60 workstations. Fab\_1 involves 292 machines and Fab\_2 involves 352 machines. The MTBF (mean time between failure) and MTTR (mean time to repair) of each machine is available, exponentially distributed.

Three scenarios are considered in the experiments. Scenario 1 involves three products (Table 1); Scenario 2 involves six products (Table 2); and Scenario 3 involves nine products (Table 3). In the genetic algorithms, we set  $T_b = 10000$ ,  $T_u = 500$ ,  $P_0 = 1000$ ,  $P_{cr} = 0.9$ , and  $P_m = 0.1$ . The target cycle time is  $CT_0 = 40,000$  min. or 27.7 days.

<<Insert Table 1 about here>>

<<Insert Table 2 about here>>

<<Insert Table 3 about here>>

Table 4 compares the four methods in terms of the two fabs' aggregate throughput. Of the three proposed methods,  $LP_I$ - $GA_2$  appears to be the best one, in particular in Scenario 3—only 2.48% less than  $LP_0$ - $GA_0$  in throughput. However, the computation time required by  $LP_2$ - $GA_1$  is greatly reduced. From Table 5, in dealing with Scenario 3,  $LP_0$ - $GA_0$  requires 46,578 sec. (about 13 hours), while  $LP_2$ - $GA_1$  requires only 2,112 sec. (about 35 min.). In practice, taking half a day in computation is generally not acceptable to practitioners. Therefore,  $LP_2$ - $GA_1$  appears to be a useful decision aid in solving cross-fab route planning problems.

<<Insert Table 4 about here>>

<<Insert Table 5 about here>>

Table 6 shows the two components of computation times required in Scenario 3. The table indicates that the reduction in computation time is substantially due to the enhancement in LP. In the LP module,  $LP_0$ - $GA_0$  takes 42,900 sec. (about 12 hours) while  $LP_2$ - $GA_1$  requires only 110 sec. (about 2 min.).

<<Insert Table 6 about here>>

The reasons why  $LP_2$ - $GA_1$  outperforms the other two proposed methods, in terms of solution quality, are analyzed below. In  $LP_1$ - $GA_1$ , products in  $Q_c$  are high-level in terms of bottleneck

workload. This implies that these products are higher in product mix ratios. This leads to a higher eligible range for each route ratio in  $Q_c$ . In turn, the GA solution space of route ratios would become much larger. Under the same GA terminating conditions, the solution obtained by  $LP_1$ - $GA_1$  may not be as good as that obtained by  $LP_2$ - $GA_1$ .

By contrast, in  $LP_3$ - $GA_1$ , products in  $Q_c$  are low-level in terms of bottleneck workload; that is, products are generally lower in product mix ratios. This leads to a lower eligible range for each route ratio in  $Q_c$ . In turn, the space for improving the solution quality is also reduced. Therefore,  $LP_2$ - $GA_1$  would outperform  $LP_3$ - $GA_1$ .

#### 8. Conclusion

This paper presents an efficient approach to solve cross-fab route planning problems for semiconductor wafer manufacturing. In the problem, each product has four possible production routes, which are defined by a cutoff point. We need to determine the cutoff point and the route ratio for each product in order to maximize the throughput subject a cycle time constraint.

A prior study has proposed a method (called  $LP_0$ - $GA_0$ ) to solve the problem, yet it is computationally extensive in dealing with large scale cases. In this paper, we enhanced the prior method and proposed three efficient methods (called  $LP_1$ - $GA_1$ ,  $LP_2$ - $GA_1$ , and  $LP_3$ - $GA_1$ ). Numerical experiments indicate that the three enhanced methods can significantly reduce the required computation time. Of the three enhanced methods,  $LP_2$ - $GA_1$  outperforms the other two in terms of solution quality, in dealing with large scale cases.

Some extensions of this research are being considered. The first extension is the route planning for a multiple-fab production system—for example, three or more fabs share the capacity in production. The second extension is the route planning for a scenario with higher flexibility in production routes—for example, each product could have two or more cutoff points and in turn have more than four routes.

#### References

- Binh Q.D. & Lan P. N. (2007). Application of a genetic algorithm to the fuel reload optimization for a research reactor. Applied Mathematics and Computation, 187, 977-988.
- Chiang D., Guo R.S., Chen A., Cheng M.T. & Chen C.B.(2007). Optimal supply chain configurations in semiconductor manufacturing. International Journal of Production Research, 45(3), 631–651.
- Connors D.P., Feigin G.E., & Yao D.D. (1996). A Queueing network model for semiconductor manufacturing. IEEE Transactions on Semiconductor Manufacturing, 9(3), 412-427.
- Dimopoulos C. (2006). Multi-objective optimization of manufacturing cell design.

  International Journal of Production Research, 44(22), 4855-4875.
- Kim C.O., Beak J.G., & Jun J. (2005). A machine cell formation algorithm for simultaneously minimizing machine workload imbalances and inter-cell part movements. Int. J. Adv Manufacture Technology, 26, 268-275.
- Lee Y.H., Chung S., Lee B., & Kang K.H. (2006). Supply chain model for the semiconductor industry in consideration of manufacturing characteristics. Production Planning & Control, 17(5), 518-533.
- Mahdavi I., Rezaeian J., Shanker K. & Amiri Z. R. (2006). A set partitioning based heuristic procedure for incremental cell formation with routing flexibility. International Journal of Production Research, 44(24), 5343-5361.
- ManMohan S.S. (2005). Managing demand risk in tactical supply chain planning for a global consumer electronics company. Production and Operations Management, 14(1), 69-79.
- Nsakanda A.L., Diaby M., & Price W.L. (2006). Hybrid genetic approach for solving large-scale capacitated cell formation problems with multiple routings. European Journal of Operational Research, 171, 1051-1070.
- Spiliopoulos K. & Sofianopoulou S. (2007). Manufacturing cell design with alternative routings in generalized group technology: reducing the complexity of the solution space. International Journal of Production Research, 45(6), 1355-1367.
- Toba H., Izumi H., Hatada H., & Chikushima T. (2005). Dynamic load balancing among multiple

- fabrication lines through estimation of minimum inter-operation time. IEEE Transactions on Semiconductor Manufacturing, 18(1), 202-213.
- Vin E., Lit P.D., & Delchambre A. (2005). A multiple-objective grouping genetic algorithm for the cell formation problem with alternative routings. Journal of Intelligent Manufacturing, 16, 189-209.
- Wu M.C., & Chang, W.J. (2007). A short-term capacity trading method for semiconductor fabs with partnership. Expert systems with application, 33(2), 476-483.
- Wu S.D., Erkoc M., Karabuk S.(2005). Managing capacity in the high-tech industry: a review of literature. The Engineering Economist, 50, 125-158.
- Wu M.C., Chen, C.F., & Shih, C.F. (2008). Route Planning for Two Wafer Fabs with Capacity-Sharing Mechanisms. International Journal of Production Research, (Accept for publication)

# Appendix 1

# Procedure Route\_Planning

```
Step 1:

Input (L, U)

Input (Q_c, Q_s)

Step 2:

Call Route\_Planning\_for\_Given\_Throughput (L, U, Q_c, Q_s)

Step 3:

Output Z^*, \Pi_L^*, R_L^*
```

#### Appendix 2

## Procedure Route\_Planning\_for\_Given\_Throughput $(L, U, Q_c, Q_s)$

**Initialization** /\* set initial range of throughput\*/

i = 1, /\* *i* is iteration number\*/

$$L_i = L$$
,  $U_i = U$ 

$$I_i = [L_i, U_i]$$

**While** {(  $i = 1 \text{ or } \frac{V_2 - V_1}{V_1} \ge \varepsilon$  ) } /\*  $\varepsilon$  is a small value, e.g., 0.2% \*/

Step 1: Determine the two test points for the throughput interval  $I_i$ 

$$V_{l} = \left\lfloor (U_{i} + L_{i})/4 \right\rfloor$$

$$V_2 = |3(U_i + L_i)/4|$$

Step 2: Evaluate and record the performance of the two test points

# Call Performance\_Evaluation $(V_I, Q_c, Q_s)$

 $P_1 = Pass\_Check(V_1)$  /\* Check if  $V_1$  is too large\*/

 $\Pi_1 = Optimal \_Cutoff(V_1)$ 

 $R_1 = Optimal \_Route \_Ratio(V_1, \Pi_1)$ 

 $Z_1 = Optimal \_Objective \_Value(V_1, \Pi_1)$ 

## Call Performance\_Evaluation $(V_2, Q_c, Q_s)$

 $P_2 = Pass \_Check (V_2)$  /\* Check if  $V_2$  is too large\*/

$$\Pi_2 = Optimal \_Cutoff(V_2)$$

 $R_2 = Optimal \_Route \_Ratio(V_2, \Pi_2)$ 

 $Z_2 = Optimal \_Objective \_Value(V_2, \Pi_2)$ 

# Step 3: Update the throughput interval for search

If 
$$(P_2 = \text{``Pass''})$$
 then  $L_{i+1} = |(U_i + L_i)/2|$ ,  $U_{i+1} = U_i$ ,  $k = 2$ 

If 
$$(P_1 = \text{``Pass''} \text{ and } P_2 = \text{``Fail''})$$
 then  $L_{i+1} = L_i$ ,  $U_{i+1} = \left| (U_i + L_i)/2 \right|$ ,  $k = 1$ 

If 
$$(P_I$$
= "Fail" and  $P_2$ = "Fail") then  $L_{i+I} = L_i$ ,  $U_{i+I} = \lfloor (U_i + L_i)/4 \rfloor$ ,  $k = 0$ 

$$i = i+1$$

#### **Endwhile**

If k = 0, Stop. /\*User warning: the input value of L is too large\*/

Else 
$$Z^* = Z_{\iota}$$
,  $\Pi_{\iota}^* = \Pi_{\iota}$ ,  $R_{\iota}^* = R_{\iota}$ 

**Return**  $Z^*$ ,  $\Pi_L^*$ ,  $R_L^*$ 

# Appendix 3

## Procedure Performance\_Evaluation $(V, Q_c, Q_s)$

**Assumption:**  $Q_c$  has n products, and the number of operations for product k is  $O_k$  Initialization

j = 1, /\*iteration number\*/

For each product *k*, set its initial interval for search.

$$L_{jk} = 0, \ U_{jk} = O_k, \ 1 \le k \le n$$
  
 $I_{jk} = [L_{jk}, \ U_{jk}], \ 1 \le k \le n$ 

Identify the longest route /\* for terminating the following While loop\*/

$$h = Arg Max O_k$$

**While**  $\{j = 1 \text{ or } (m_{2h} - m_{1h}) \le 1\}$ 

Step 1: Determine the two cut-off points for each segment  $I_{jk}$ 

$$m_{1k} = \lfloor (U_{jk} + L_{jk})/4 \rfloor, \quad 1 \le k \le n$$
  

$$m_{2k} = \lfloor 3(U_{jk} + L_{jk})/4 \rfloor, \quad 1 \le k \le n$$

Step 2: Generate all possible combinations of cut-off points

$$S_i = \{\Pi \mid \Pi = (\pi_1, ..., \pi_n), \text{ where } \pi_k = m_{1k} \text{ or } \pi_k = m_{2k}\}$$

Step 3: Identify the best combination of cut-off points from  $S_i$ 

Set 
$$H_1 = \phi$$
,  $H_2 = \phi$ 

For each  $\Pi \in S_i$ ,

Call LP\_Module  $(V, \Pi, Q_c, Q_s)$ 

If (Pass\_Check = "Pass"), put  $Z(V,\Pi)$  in  $H_1$  and  $R(V,\Pi)$  in  $H_2$  Endfor

Step 4: Check if there exist a solution in  $S_i$ 

If 
$$(H_1 \neq \phi)$$
, then  $\Pi^* = \underset{\Pi \in H_1}{\operatorname{ArgMin}} Z(V, \Pi)$  and  $R^* = R(V, \Pi^*)$ 

If 
$$(H_1 = \phi)$$
, then Pass\_Check = "Fail", **Return**

Step 5: Update the interval for each product *k* 

If 
$$(\pi_k^* = m_{1k})$$
 then  $L_{j+1,k} = L_{j,k}$ ,  $U_{j+1,k} = \lfloor (U_{jk} + L_{jk})/2 \rfloor$ ,  $1 \le k \le n$   
If  $(\pi_k^* = m_{2k})$  then  $L_{j+1,k} = \lfloor (U_{jk} + L_{jk})/2 \rfloor$ ,  $U_{j+1,k} = U_{j,k}$ ,  $1 \le k \le n$   
 $j = j+1$ 

#### **Endwhile**

Optimal\_Cutoff 
$$(V) = \Pi^*$$

Optimal Route Ratio 
$$(V) = R^*$$

Optimal\_Objective\_value 
$$(V) = Z(V, \Pi^*)$$

Pass Check 
$$(V)$$
 = Pass Check

#### Return

Table 1: Scenario 1 which involves 3 products in the route planning

| Product              | P1  | P2  | Р3  |
|----------------------|-----|-----|-----|
| Number of Operations | 338 | 338 | 338 |
| Product Mix          | 0.5 | 0.3 | 0.2 |

Table 2: Scenario 2 which involves 6 products in the route planning

| Product              | P1   | P2   | P3   | P4   | P5  | P6  |
|----------------------|------|------|------|------|-----|-----|
| Number of Operations | 338  | 338  | 338  | 300  | 300 | 300 |
| Product Mix          | 0.25 | 0.25 | 0.15 | 0.15 | 0.1 | 0.1 |

Table 3: Scenario 3 which involves 9 products in the route planning

| Product              | P1   | P2   | Р3   | P4  | P5  | P6  | P7   | P8   | P9   |
|----------------------|------|------|------|-----|-----|-----|------|------|------|
| Number of Operations | 338  | 338  | 338  | 300 | 300 | 300 | 250  | 250  | 250  |
| Product Mix          | 0.17 | 0.17 | 0.16 | 0.1 | 0.1 | 0.1 | 0.07 | 0.07 | 0.06 |

Table 4: Throughput comparison for various solution methods

|                 | Scena    | ario 1  | Scenario 2 |         | Scenario 3 |         |
|-----------------|----------|---------|------------|---------|------------|---------|
| Scenario        | TH (Lot) | Gap (%) | TH (Lot)   | Gap (%) | TH (Lot)   | Gap (%) |
| $LP_0$ - $GA_0$ | 652      | 0       | 725        | 0       | 846        | 0       |
| $LP_1$ - $GA_1$ | 650      | 0.31%   | 724        | 0.14%   | 795        | 6.03%   |
| $LP_2$ - $GA_1$ | 651      | 0.15%   | 723        | 0.28%   | 825        | 2.48%   |
| $LP_3$ - $GA_1$ | 650      | 0.31%   | 697        | 3.86%   | 790        | 6.62%   |

Table 5 : Computation time comparison for various solution methods

| Scenario        | Scena       | ario 1  | Scena       | ario 2  | Scena       | ario 3  |
|-----------------|-------------|---------|-------------|---------|-------------|---------|
| Scenario        | Time (sec.) | Gap (%) | Time (sec.) | Gap (%) | Time (sec.) | Gap (%) |
| $LP_0$ - $GA_0$ | 892         | 0%      | 3111        | 0%      | 46587       | 0%      |
| $LP_1$ - $GA_1$ | 437         | 48.99%  | 1497        | 48.12%  | 2197        | 4.72%   |
| $LP_2$ - $GA_1$ | 532         | 59.64%  | 1478        | 47.51%  | 2112        | 4.53%   |
| $LP_3$ - $GA_1$ | 539         | 60.43%  | 1590        | 51.11%  | 2940        | 6.31%   |

Table 6 : Computation Time Analysis for  $LP_0$ - $GA_0$  and  $LP_2$ - $GA_1$ 

| Scenario 3      |                |         |                      |         |                   |         |  |  |  |
|-----------------|----------------|---------|----------------------|---------|-------------------|---------|--|--|--|
| Algorithm       | LP Time (sec.) | Gap (%) | GA + Queueing (sec.) | Gap (%) | Total Time (sec.) | Gap (%) |  |  |  |
| $LP_0$ - $GA_0$ | 42900          | 0%      | 3687                 | 0%      | 46587             | 0%      |  |  |  |
| $LP_2$ - $GA_1$ | 110            | 0.26%   | 2002                 | 54.3%   | 2112              | 4.53%   |  |  |  |



Fig.1 Solution Framework



Fig. 2: Logic flow of the LP iterative procedures



Fig 3. Binary Search algorithm