Int. J. of Computers, Communications & Control, ISSN 1841-9836, E-ISSN 1841-9844 Vol. III (2008), No. 3, pp. 270-280 Disassembly Line Scheduling with Genetic Algorithms Luminiţa Duţă, Florin Gheorghe Filip, Jean-Michel Henrioud, Ciprian Popescu Abstract: Disassembly is part of the demanufacturing and it is meant to obtain com- ponents and materials from end-of-life products. An essential performance objective of a disassembly process is the benefits it brings, that is the revenue brought by the retrieved parts and material, diminished by the cost of their retrieval operations. A decision must be taken to balance an automatic disassembly line. A well balanced line will decrease the cost of disassembly operations. An evolutionary (genetic) algo- rithm is used to deal with the multi-criteria optimization problem of the disassembly scheduling. Keywords: control, scheduling algorithms, evolutionary programming, genetic al- gorithms 1 Introduction In the second half of the 20th century, the people and governments started to become aware that the "take - make - waste" system, which resulted from the industrial revolution, is not sustainable. The assumptions on infinite material "sources" of raw materials and "sinks" to absorbe industrial and domestic wastes could not hold any longer because of the exponential growth of world population and accelerated widespreding of industry and consumption. In their inspiring book on system engineering, Blanchard and Fabrycky [1, p.555] state that "Green manufacturing should be an objective adopted by producers to reduce the environmental impact of their products and production operation continuously. Real environmental improvement requires a system life-cycle approach to guide design decisions and operational policies". Several driving factors such as: a) competitive differentiation, b) customer consciousness, c) legal regulations, and d) fight for improving profitability have led to this new way of thinking and even to new standards such as ISO 14,000 series. A new science of sustainability called "Industrial Ecology" was born [2,Frasch ], [3, Graedel, Al- lenby]. Within it, research directions such as "design for environment" (with a proactive character), and "environmental management" (a reactive, remedial aproach) compose a new design trend called "envi- ronmentally conscious design and manufacturing" [1, Blanchard and Fabrycky, p. 558]. At present, both designers and manufacturers show an increasing tendency to consider product and system entire life-cycle starting with perceiving customers needs, and continuing with design and devel- opment, manufacturing, product utilization, maintenance, phase-out, and disposal. In this context, the term "remanufacturing" includes the set of planning and processing activities (such as checking in, dis- assembling, cleaning, inspection and sorting, reconditioning, reassembling, testing and packaging) for recycling obsolete products. The first steps of remanufacturing process can be grouped under the name "demanufacturing". A new industry for demanufacturing has shown up to provide with new usage of expensive modules, components and materials and, at the same time, to prevent excessive wastes. Also industrial producers tend to add their demanufacturing departments to existing manufacturing facilities. Sometimes, chains of firms show up to implement new paradigms such as "extended", "networked", and "virtual" enterprise [3, Filip, Bărbat]. This paper aims at proposing the usage of genetic algorithms for optimal scheduling of disassembly lines. The remaining part of this paper is organised as it follows. First, the main concepts and research directions in modelling, optimization and control in disassembly processes are reviewed. Then, the opti- mal scheduling problem of a disassembly line is formulated. A short description of genetic algorithms is given next. Experimental results on solving the optimal disassembly problem by a genetic algorithm are given before presenting the paper conclusions. Copyright © 2006-2008 by CCC Publications Disassembly Line Scheduling with Genetic Algorithms 271 2 Disassembly- A Main Stage in Recycling Several types of recycling of end-of-life manufactured goods are possible such as : a) reusing of components and modules of high value, b) refurbishing and partial reconstruction of a good returned from the market, c) recovery of the raw material or energy by incineration and melting. Disposal, which is the last solution to resort to, is done only if the other alternatives are not possible. The choice between these different types determines the recycling process and allow for defining the end-of-life destinations for components of manufactured goods. Different recycling loops are different approaches of the process. The simplest approach is that of dismantling a product. By applying dismantling operations, a discarded good can be broken down faster and with small costs. In this case more pure fractions can be obtained with less efforts. This simple approach exploits only the value of the raw material. It does not take into account the functional value of the product or of its components. The regain of the functional values needs a recycling process that minimizes the destroying effects on the product. This means to reuse, refurbish and capitalize the components of the used product in order to remanufacture a new one. Remanufacturing is a superior form of reusing, since its objective is to max- imize the value of repaired parts and to minimize the disposal quantity. Central to remanufacturing is the disassembly process that decomposes a product into parts and/or subassemblies. Disassembling is a non- destructive technique and implies the extraction of the desired components and/or materials. If the parts are not reusable after reconditioning, partial or total destructive operations are to be applied: drilling, cutting, wrenching, and shearing. These techniques are used in view of the material or energetically recovery. There are several research directions in relation with disassembly processes such as: modeling, plan- ning, and control. The chapter 16 on "design for produceability and disposability" of the book on system engineering of Blanchard and Fabrycky [1] contains an excellent introduction to product and system design to facilitate remanufacturing. Since disassembly processes can be viewed as discrete, event - driven systems [5, Cassandras, Lafor- tune], Petri nets can be a natural solution. There are lots of reported results. For example, Moore, Gungor and Gupta [6] propose Disassembly Petri nets to take into account operation precedence constraints in planning aplications. Penev and Ron [7] proposed Disassembly graphs. Kuo, Zhang and Huang [8] de- scribe Disassembly trees which associate for each branch the direction of the disassembly operation by adapting the Assembly trees proposed by Henrioud [9]. The usage of object oriented Petri nets proposed by Lakos [10], to model disassembly processes is analysed by Duta, Filip and Henrioud [11]. For balancing the operation of the disassembly line, Duta, Filip and Henrioud [12] utilize the method of equal piles approach proposed Rekiek [13]. To model products associated with incomplete, imprecise, and, sometimes, wrong information, Fuzzy reasoning Petri nets are proposed by Gao and Zhou [14] to make real-time disassembly scheduling decisions possible. A review of state-of-art implementations of control structures for disassembly line is given by Duta and Filip [15]. 3 Problem formulation Disassembly of manufactured products induces both disassembly costs and revenues from the parts saved by the process. Thus, at the planning stage a good trade-off has to be found that depends, both on the "depth" of the disassembly, and on the sequence of operations. The optimization of the ratio between gain and cost can be accomplished by using an appropriate distribution of the disassembly tasks on workstations, an assignment that provides a maximal value for the total profit. The optimization problem depends upon the structure of the disassembly system: if it is made up of a single workstation, the costs depend mainly upon the process duration. If the system is a line, the costs depend mainly 272 Luminiţa Duţă, Florin Gheorghe Filip, Jean-Michel Henrioud, Ciprian Popescu upon the line balancing, all the more if it is highly manual. Another problem that occurs during a disassembly process is how deep the disassembly sequence must go so as to maximize the outcome of this process. In [11, Duta, Filip and Henrioud], [16, Duta, Henrioud and Caciula] it was shown that an incomplete disassembly sequence can be more profitable than a complete one. Destructive and dismantling operations have to be taken into consideration, as well. Hence, we have to deal with a multi-criteria optimization problem of a disassembly process: max- imizing the benefit it brings deciding how deep the disassembly sequence can go and minimizing the costs using an optimal scheduling along the line. A decision in a scheduling problem upon many crite- ria is a NP-hard to solve problem [17, Filip]. Stochastic algorithms have already been used to fulfill a multi-criteria optimization problem in [18, Minzu and Henrioud]. In this paper we consider that the line structure was given and propose an algorithm which will allow finding a disassembly sequence and its assignment on workstations that optimizes a very simple function which integrates the income from the parts and the cycle time of the disassembly line. In this paper we address the case of disassembly lines where the cycle-time is not merely the sum of all operative and logistic times but it also depends strongly upon the line balancing. The objective is to find the most profitable disassembly sequence taking into account, on one hand - the end-of-life options for each part or subassembly of a given product, and on the other hand - the operational times for a given assignment of the tasks on the disassembly workstations. A cost function which combines both disassembly costs and revenues was proposed in [19, Duta, Filip and Henrioud]. f = r tcy (1) where r is revenue associated to each disassembled part and tcy is the cycle time. The global revenue is the sum of partial revenues obtained according to the end-of-life destinations of the disassembled parts. These partial revenues are established by experts after repeated disassembly processes. r = ∑ k rk, k = 1..nc (2) where nc is the number of final components or the number of subassemblies obtained after the dis- assembly process. The cycle time can be defined like the operational time of the slowest workstation on the line tcy = max Wi ∑ j∈(tasks on Wi) t j (3) where Wi is the workstation i, and j is one disassembly operation and t j the operational times. We make the following assumptions: • The disassembly line is linear (flow-shop type); • End-of-life revenues of the subassemblies are known; • Operational costs are included in the final incomes; • The criterion of maximizing the outcome depending of the success rate of disassembly operations has been taken into consideration; • The failure of the disassembly process is an event that can also occur since certain parts of the product could be deformed and impossible to separate without destroying; Disassembly Line Scheduling with Genetic Algorithms 273 • The disassembly line is not starving; it works in a continuous flow. Evaluating the function from equation (1) reveals the profit on a time unit, which is an important indicator for the productivity of the disassembly system. This function also takes into account the value of the cycle time obtained for a well-balanced line. The optimization can be made both for the manual and automatic disassembly lines. 4 Genetic algorithms Genetic algorithms are optimization solvers used in many areas due to their capacity to reduce the combinatorial complexity of NP-complete problems. They do not give the global optimal solution, but a local optimal one by exploiting a defined search space. A genetic algorithm starts with a set of ran- domly generated possible solutions called initial population. Each member of a population is encoded as a chromosome. Chromosomes are represented by a combination of numbers or characters which con- tain information about the solution. A score named fitness coefficient is assigned to each chromosome based on the viability of the solution. Chromosomes with high scores are chosen as parents to create a new population. The objective is to obtain children with better scores. To avoid the uniformity of the population and to increase the space of research, at each step of creation, two processes may occur namely: crossover and mutation. Crossover combines the features of two or more parents into one child chromosome. Mutation generates a child similar with his parent with one or more genes altered. These operations ensure the diversity of the new generated population [ 20, Goldenberg]. Once established the initial population and defined the three types of operations (reproduction, crossover, mutation), a genetic algorithm provides new members of population until a stop condition is fulfilled. Usually, this criterion is given by a maximal/minimal value of the objective function obtained after a number of iterations of the genetic algorithm. 5 Example To test the genetic algorithm, consider the example of the disassembly of a Motorola radio set de- scribed by Salomonski and Zussman, [21]. The corresponding Disassembly Petri Net is given in the figure 1. The disassembly process is represented four distinct possible sequences of transitions: {t1 → t3 → t5 → t7}, {t1 → t3 → t6 → t8}, {t2 → t4 → t5 → t7} and {t2 → t4 → t6 → t8}. To take into account additional destructive disassembly methods, in the correspondent Petri Net there are three alternative tasks represented by transitions {t1,1,t4,1,t6,1}. For the present study we considered that there are three workstations on the line. An alternative de- structive task is done only on a station that can perform both destructive and non-destructive operations. We say that this kind of workstation is a "mixed" one. Thus, workstations 2 and 3 are considered mixed. In other words, when a task is moved from one station to another, the type of the operation is changed together with its operational time. We supposed that the tasks t1 and t4 can be performed in a non-destructive way on the first workstation and in a destructive way on the second one. For the task t6 a destructive disassembly is done on the third station and a non-destructive disassembly is performed on the second workstation. According to the Petri Net given in figure 1 the correspondent operational times on the initial partition of the tasks on the workstations are: Ti = {0.92, 0.07, 0.07, 0.12, 0.95, 0.75, 0.75, 0.95} Taking into consideration the times for the alternative destructive operations the set above becomes: 274 Luminiţa Duţă, Florin Gheorghe Filip, Jean-Michel Henrioud, Ciprian Popescu Figure 1: Disassembly Petri Net of a radio set Tf = {0.95, 0.07, 0.07, 0.15, 0.95, 0.90, 0.75, 0.95} The final revenues are calculated with the method proposed in [11, Duta, Filip and Henrioud] by using the data from the Petri Net given in the figure 1. The corresponding sets of revenue values are: Ri = {−1.36, 0.27, 0.54, 0.54, 0.62, 0.67, 2.75, 2.75} R f = {−1.32, 0.27, 0.54, 0.50, 0.62, 0.60, 2.75, 2.75} The objective is to maximize the value of the function from the equation (1) by finding the sequence that maximize the final revenue and in the same time ensuring a well-balance of the disassembly line (e.g. minimizing the cycle time). In our problem, a chromosome is represented by the possible tasks assignment matrix S which ele- ments are: si j = { 1 i f the task j can be assigned to the workstation i 0 i f the task j can′t be assigned to the workstation i i = 1..n and j = 1..m (n is the number of workstations and m - the number of disassembly operations). One S matrix can be the solution of our optimization problem only if it satisfies the following con- straints: 1. The non-divisibility constraint that does not allow a task to be assigned to more than one station. si j ∈ {0, 1} (4) Disassembly Line Scheduling with Genetic Algorithms 275 2. The assignment constraint that it requires that each task be assigned to exactly one station. ∑ i si j = 1 (5) 3. The precedence constraint that invokes technological order so that if task i is to be done before task j (i