Abstract

For facility layout problem with continuous block and unequal area, it is key to generate feasible solution of facility layout with arbitrary space form in order to find the optimal arrangement scheme under a given goal. According to the given slicing position and slicing mode, the plane for arrangement was divided into many block areas by use of plane segmentation, which was consistent with the facilities in number. The precise coordinates of the lower-left corner and the top-right corner of each facility were calculated in light of its area, width, and length. The corresponding algorithm was designed in the form of pseudocode. The procedure proposed can provide a feasible facility layout solution. The running results of facilities layout instance containing 14 facilities show that the scheme can output facilities plane layout scheme quickly and provide decision support for the facilities planning.

1. Introduction

Layout design is an important content of facilities planning and design, mainly to deal with the relative position and area of various kinds of functional facilities (i.e., production or service units) as well as their relevant auxiliary facilities in order to make work flow (customers or materials) and information flow unblocked [1]. The concrete content includes the following two aspects: determination of relative position of all facilities and area of each facility. The former refers to the location relationship between different facilities and the latter refers to the size of each facility. Facilities layout solves the space allocation problem in production and operation and its purpose is to make effective combination of all facilities and obtain the maximum economic benefit. If the facility layout is unreasonable, that is, there are many invalid handling or moving or complex working sites and workshop channels, long distance and high cost handling, long time waiting, and poor production balance, the overall operating efficiency of the production system can be affected greatly [2].

Suppose all facilities’ area is equal and only consider the location of the relationship between facilities; facilities layout problem (FLP) is ascribed to quadratic assignment problem (QAP) [3, 4]. By doing so, FLP is simplified to allocate facilities to discrete points without considering the location coordinates for multirow and multicolumn FLP. But this supposition is hard to meet in real production system and the application of this method is limited. A lot of FLPs are for multiple continuous blocks with unequal area as pointed out in [2]. As a special case, single row FLP considers one-dimensional linear array arrangement of rectangular facilities. In this case, all facilities are arranged in the same line in spite of the consideration of different area of every facility, so the generation of feasible solution and the implementation of algorithm are relatively easy [511].

Double row layout is widely adapted in flexible manufacturing system [1217] to facilitate automatic guided vehicles conveying material. The complexity on feasible solution generation was also greatly reduced by limiting the facilities to double line.

Taking facility layout objective function as criterion, the optimal facility layout approach can be found by selecting the arrangement form freely rather than by limiting its form as single, double, or multiline artificially [18]. But that will greatly expand the feasible solution space of facilities layout. So the key to search the optimal layout approach combined with heuristic intelligent algorithm is to generate the feasible solution quickly.

This paper is organized as follows. Section 2 introduces the principle of plane segmentation method for facility layout. Section 3 describes the layout step of plane segmentation method and the pseudocode of the realizing algorithm. Section 4 describes an application case containing 14 facilities, verification test in Matlab environment, and some of the evaluation results of this method. Finally, Section 5 concludes with a discussion of the paper.

2. The Principle of Plane Segmentation Method for Facility Layout

Suppose vector is a collection of facilities waiting for layout; vector is a collection of splitting positions for each plane splitting operation; vector is a collection of splitting modes, where denotes the facility number and or 1 ().

In each plane splitting operation, the relationship between vectors , , and is shown in Figure 1.

In actual splitting operation, the element in vectors , and can be any permutation within their respective values that an element may take. For a vector with given element order, there is a splitting position between every two adjacent elements. From left to right, the splitting position randomly ranges from 1 to (), respectively, and forms the splitting position vector . For a vector with given element order, there is a splitting mode for every element. From left to right, the splitting mode takes the value 1 or 0, respectively, and forms the splitting position vector . According to the splitting position value of each element in , vector is partitioned into two parts, left and right. The value in vector corresponding to the splitting position value determines the plane splitting mode, and 0 and 1 denote splitting vertically and horizontally, respectively.

Taking a FLP with 6 facilities as an example, the above approach can be described in Figures 2 and 3. Here, , , and .

3. The Realization of Plane Partition Method of Facility Layout

3.1. Determination of Left Set and Right Set for Each Partitioning Operation

Step 1. Find the maximum of existing splitting position .

Step 2. Find the minimum of existing splitting position .

Step 3. In accordance with the relationship between the current splitting position , , and , new left set and right set are determined as follows:(i)If , in this case, the current splitting position lies in existing where was found before. This operation partitions this into two parts, that is, new and .(ii)If , the current splitting position lies in the existing where was found before. This operation partitions this into two parts, that is, new and .(iii)If , here, denotes the maximum of existing splitting position less than and denotes the minimum of existing splitting position greater than . The completion order of splitting operation corresponding to the splitting positions and affects the object of this partition. If splitting was carried out later than , that is, , the right set resulting from splitting was going to be partitioned. Similarly, if splitting was carried out earlier than , that is, , the left set resulting from splitting was going to be partitioned.

This paper defines two structures to record the information of splitting position and its results, sets and ; that is, = struct(“splitting position”, , “left set”, ) and = struct(“splitting position”, , “right set”, ).

The process to determine the sets and of every splitting operation is shown in Algorithm 1.

Procedure    ( is the cardinality of facility set F, cso is position set that have been split)
()    (“splitting position”, 0, “left set”, ); % Initialize the first left set with empty set
()    (“splitting position”, 0, “right set”, ); % Initialize the first right set with set
()    for To
()      ;
()      ;
()      ;
()      ;
()      if
()       (“splitting position”, , “left set”, setR(_max).right set(1: -));
()    (“splitting position”, , “right set”, setR(_max).right set((-): end));
()   elseif
()    (“splitting position”, , “left set”, setL(_min).left set(1: ));
()    (“splitting position”, , “right set”, setL(_min).left set(( + 1): end));
()   elseif
()    if
()     (“splitting position”, , “left set”, setR(temp1).right set(1: ()-cso(temp1)));
()     (“splitting position”, , “left set”,  setR(temp1).right set((-cso(temp1) + 1): end));
()    elseif
()     ((temp2).left set);
()     (“splitting position”, , “left set”, setL(temp2).left set(1: -cso(temp2) + ));
()     (“splitting position”, , “right set”, setL(temp2).left set((-cso(temp2) + + 1): end));
()    end if
()   end if
()  end for

The partition task in Figure 2 was completed using the above approach and the results are shown in Table 1. After repeating the operation 5 times, the facility set was partitioned into 5 sets, each of which contained only one element. At the same time, the plane was also partitioned into 5 blocks, each of which was for arranging a facility.

3.2. Coordinates Determination of the First Splitting Line

Before the first splitting operation, the layout area was empty and no facility was arranged. The coordinates of the lower-left corner and upper-right corner of the layout plane were denoted by and , where and were the horizontal width and the vertical height of facility , respectively. The coordinates of the upper-right corner were the extreme value when all the facilities were arranged side by side horizontally or vertically. The plane was firstly split according to the value of . The splitting line was denoted by , where the first subscript shows the splitting position and the second subscript taking value of 1 or 2 means the start point or end point of splitting line. The line direction is from left to right for horizontal line and from bottom to top for vertical line.

(i) . In this case, the first line is a horizontal one partitioning the layout area into two parts, upper and lower. The facilities of vector on the left of splitting point , that is, leftset, were included in the lower part. The facilities of vector on the right of , that is, rightset, were included in the upper part. The first line was denoted by , .

(ii) . When , the first line is vertical and can be determined by , .

As shown in Algorithm 2, the first line can be drawn by connecting the point (lin_start(1), lin_y(1)) and point (lin_end(1), lin_(1)). As a result, the layout area was partitioned into two parts.

Procedure   (, , , , , )
()    .elements and their index in F;
()    if
()     ; %  -coordinate of horizontal line start point
()     ; %  -coordinate of horizontal line end point
()     ; %  -coordinate of horizontal line
()    elseif
()     ;
()     vlin_end();
()     lin_(((index)));;
() end if
() Connect point (lin_start(), lin_()) and (lin_end(), lin_())
3.3. Coordinates Determination of the Second and Subsequent Splitting Line

From the second splitting operation, inclusion relations between the left set obtained in current operation and the left set and right set obtained before were determined. For the set including the current left set, its maximum of the structure attribute SO is recorded. Let be the index of maximum SO in left set and let be the index of maximum SO in right set.

(I) If the current splitting mode is horizontal, that is, , the splitting line of current operation has the following cases according to the value of and .

(i) Consider , . In this case, the left set obtained in current operation was included by only one existing left set. The determination of splitting line according to the value of was as shown in Figure 4.

As shown in Figure 4(a), when , the corresponding existing splitting line was a horizontal line , below which the current line was drawn horizontally, where , ; Figure 4(b) shows the other case of . The corresponding existing splitting line was vertical, on the left side of which the current line was drawn, where , .

(ii) Consider , . In this case, the left set obtained in current operation was included by only one existing right set. The determination of splitting line according to the value of was as shown in Figure 5.

As shown in Figure 5(a), when , the corresponding existing splitting line was a horizontal line , above which the current line was drawn, where , ; Figure 5(b) shows the other case of . The corresponding existing splitting line was vertical, on the right side of which the current line was drawn, where , .

(iii) Consider , . In this case, the left set obtained in current operation belonged to both some existing right set and some existing left set. The determination of splitting line according to the value of and was as shown in Figure 6.

As shown in Figure 6(a), when and , the corresponding two existing splitting lines were and , and they were horizontal. The current line was drawn above the line and below the line , where , ; in Figure 6(b), when   and , was drawn above the existing horizontal line and on the left side of existing vertical line , where , ; in Figure 6(c), when  and , was drawn below the existing horizontal line and on the right side of existing vertical line , where , ; in Figure 6(d), when   and , was drawn between the left side of the existing vertical line and the right side of existing vertical line , where , .

The above approach to determine the line coordinates and to draw the line was shown as the pseudocode in Algorithm 3.

Procedure    (, , , , , )
()    for TO
()     ; ;
()     for TO
()      if .left .left set  &  
()       
()      elseif .left  .right set  &  
()       
()      end if
()     end for
()  .elements and their index in ;
()  if
()   if
()    ; ;
()    (((index)));
()   elseif
()    ; ;
()    (((index)));
()   end if
()  elseif
()   if
()    lin_startlin_start(); lin_endlin_end(); lin_lin_ + sum(((index)));
()   elseif
()    lin_startlin_; lin_end(); lin_lin_start() + sum(((index)));
()   end if
()  elseif   &  
()   if   &  
()    lin_startlin_start(); lin_endlin_end(); lin_lin_ + sum(((index)));
()   elseif () = 1  &  () = 0
()    lin_startlin_start(); lin_endlin_end(); lin_lin_ + sum(((index)));
()   elseif () = 0  &  () = 1
()    lin_startlin_(); lin_endlin_end(); lin_lin_start() + sum(((index)));
()   elseif () = 1  &  () = 1
()    lin_startlin_(); lin_endlin_; lin_lin_start() + sum(((index)));
()   end if
()  end if
()  Connect point (lin_start(), lin_()) and point (lin_end(), lin_())
() end for

(II) If the current splitting mode is horizontal, that is, , the splitting line of current operation has the following cases according to the value of and .

(i) Consider , . In this case, the left set obtained in current operation belonged to only one existing left set. The determination of splitting line according to the value of was as shown in Figure 7.

As shown in Figure 7(a), when , the corresponding existing splitting line was a horizontal line , below which the current line was drawn vertically, where , ; Figure 7(b) showed the other case of . The corresponding existing splitting line was vertical, on the left side of which the current line was drawn, where ,     .

(ii) Consider . In this case, the left set obtained in current operation belonged to only one existing right set. The determination of splitting line according to the value of was as shown in Figure 8.

As shown in Figure 8(a), when , the corresponding existing splitting line was a horizontal line , above which the current line was drawn vertically, where , ; Figure 8(b) showed the other case of . The corresponding existing splitting line was vertical, on the left side of which the current line was drawn, where , .

(iii) Consider , . In this case, the left set obtained in current operation belonged to both one existing right set and one existing left set. The determination of splitting line according to the value of and was as shown in Figure 9.

As shown in Figure 9(a), when and , the corresponding two existing splitting lines were and , and they were horizontal. The current line was drawn between line and line , where , ; in Figure 9(b), when  and , was drawn above the existing horizontal line and on the left side of existing vertical line , where , ; in Figure 9(c),  when  and , was drawn below the existing horizontal line and on the right side of existing vertical line , where , ; in Figure 9(d), when   and , was drawn between the left side of the existing vertical line and the right side of existing vertical line , where , .

For the case of , the pseudocode to realize the above approach can be achieved by replacing lin_start, lin_end, and lin_ in Figure 5 with lin_start, lin_end, and lin_, respectively. The coordinate values of each splitting line can be determined according to Figures 7~9.

Plane segmentation process is to determine facilities relative position in the layout area. For the aforementioned FLP with 6 facilities (as shown in Figure 3), the process of plane splitting and splitting line coordinate determining can be described as follows.

The initial layout area was a plane determined by the lower-left corner and top-right corner . For the first splitting operation, the vertical splitting line , , , divided the initial layout area into two parts, left and right side. The left was for facilities 1, 2, and 3, and the right was for facilities 4, 5, and 6. The second splitting line , , , was horizontal and partitioned the left side of the first time into two parts, lower and upper part. The lower area was for facilities 1 and 2, and the upper part was for facility 3. The third splitting line , , , was horizontal and partitioned the right side of the first time into two parts, lower and upper. The upper area was for facilities 5 and 6, and the lower part was for facility 4. The fourth vertical splitting line , , , divided the lower part of the second time into two sides, left and right. The left was for facility 1 and the right was for facility 2. The fifth horizontal splitting line , , , divided the upper part of the third time into two sides, upper and lower. The upper one was for facility 6 and the lower one was for facility 5. So far, the plane was divided into blocks whose amount was equal to the facility number. Each block was for a special facility. The position of the above 6 facilities can be located by a point pair of the lower-left corner and the upper-right corner of the 6 blocks as follows: , , , , , and . So a feasible facility layout solution was obtained.

4. Case Study

4.1. Basic Information of Facilities

This paper took the FLP of a toolkit manufacturer as a case to validate the approach mentioned above. The area and aspect ratio of every facility were shown in Table 2.

4.2. Run Settings of Plane Segmentation Algorithm and the Results

According to the layout approach of plane splitting proposed in Section 3, the input information for this case is as follows: , ,  and  , and size matrix of facility is as follows:

In , the data in the first and second row denoted the length and width of each facility, respectively. By running the algorithm in Matlab, a feasible layout approach was obtained as in Figure 10. The Arabic numerals labeled in Figure 10 denoted the facility number, and the block that was labeled with a numeral was the layout area of the corresponding facility. Each block was located by the coordinates of lower-left corner and upper-right corner. The red point in each block denoted the centroid position of each facility.

From the layout scheme of Figure 10, it can be seen that facility 1 was in the lower-left corner of the plane, and, for facilities adjacent to facility 1, the facility with smaller number was located in the left and lower side and the facility with larger number was located in the right and upper side. This result was related to the order given by the input set. By changing the element order of , , and , different feasible layout approaches can be obtained and then be further combined with heuristic intelligent algorithms to search the optimum. Figure 11 showed the different schemes of different , , and .

4.3. Analysis on the Influence of Facilities Quantity on the Algorithm

In order to analyze the sensitivity of the proposed solutions to the quantity of the facilities, this paper selected 40 kinds of data with every 5th number from 5 to 200 to test. The machine parameters to run the algorithm were as follows: Intel Celeron CPU E3300, dual core, 2.5 GHz, 2 GB memory. The test results were displayed in Figure 12.

Figure 12 showed the running time and memory usage of algorithm to generate a feasible layout scheme under different facility quantity. It can be seen that facility quantity has a great influence on the algorithm performance, and the facility quantity was nearly linear with the running time and memory usage. When facility quantity was 20 and 100, the running time was 0.0506 s and 0.7871 s and the memory usage was 74.419 Kb and 118.035 Kb, respectively. Supposing that this method was combined with genetic algorithm (GA) for iterative optimization, the population size of genetic algorithm was 50 and the iteration number was 100, the running time of GA was  s and  s, and the memory usage was and for the above two cases. So the proposed approach is suitable for the FLP of limited facility quantity.

5. Conclusions and Prospects

According to the characteristics of FLP with continuous block and unequal area facilities, this paper proposed plane splitting method to divide the layout area into the same number of blocks with the facility quantity and also developed the algorithm pseudocode to realize the method. The splitting process and the corresponding results were recorded in a data structure. Based on this and the splitting mode of each operation, the splitting line coordinates were determined. The results of case study show the effectiveness and the reliability of the proposed method.

The following conclusions are drawn from the above study:(i)It is reasonable and effective to solve FLP with continuous block and unequal area facilities by use of plane segmentation method, which can divide the layout area into the same number of blocks with the facility quantity and so generate feasible layout scheme.(ii)The proposed plane segmentation algorithm can provide support to CAFP (computer aided facilities planning), generate feasible solution fast, and search the optimal layout approach combined with intelligent optimization algorithm.(iii)The encapsulated parameters of the proposed algorithm make it easy to solve different FLPs. When the FLP changed, the values of , , and can be passed to the algorithm as parameters without changing the algorithm itself.

For particular facility layout goals, the combination of the proposed method with different heuristic intelligent optimization algorithm and the best combination scheme should be studied further. The proposed approach only considered the dimensions of facilities and did not analyze the impact of existing constraints within the layout area, which is common for FLP in renovated or expanded engineering. So it is worthy of further research.

Competing Interests

The authors declare that they have no competing interests.

Acknowledgments

This paper is supported by MOE (Ministry of Education in China) Project of Humanities and Social Sciences (Grant no. 13YJC630049), China, and the Natural Science Foundation of Shanxi Province (Grant no. 2013021021-2), China.