PME I J https://ojs.upv.es/index.php/IJPME International Journal of Production Management and Engineering doi:10.4995/ijpme.2016.5780 Received 2016-05-15 Accepted: 2016-06-09 Hybrid genetic algorithms: solutions in realistic dynamic and setup dependent job-shop scheduling problems Rogério M. Brancoa*, Antônio S. Coelhob1, Sérgio F. Mayerleb2 a Instituto Federal do Rio Grande do Sul – IFRS Campus Rio Grande, Rua Alfredo Huch, 475, Centro, CEP 96201-460, Rio Grande, RS, Brasil. b Universidade Federal de Santa Catarina, Caixa Postal 476, Campus Universitário UFSC - Trindade, CEP 88040-900, Florianópolis, SC, Brasil. a rogerio.branco@gmail.com b1 a.s.coelho@ufsc.br b2 sergio.mayerle@ufsc.br Abstract: This paper discusses the application of heuristic-based evolutionary technique in search for solutions concerning the dynamic job-shop scheduling problems with dependent setup times and alternate routes. With a combinatorial nature, these problems belong to an NP-hard class, with an aggravated condition when in realistic, dynamic and therefore, more complex cases than the traditional static ones. The proposed genetic algorithm executes two important functions: choose the routes using dispatching rules when forming each individual from a defined set of available machines and, also make the scheduling for each of these individuals created. The chromosome codifies a route, or the selected machines, and also an order to process the operations. In essence , each individual needs to be decoded by the scheduler to evaluate its time of completion, so the fitness function of the genetic algorithm, applying the modified Giffler and Thomson’s algorithm, obtains a scheduling of the selected routes in a given planning horizon. The scheduler considers the preparation time between operations on the machines and can manage operations exchange respecting the route and the order given by the chromosome. The best results in the evolutionary process are individuals with routes and processing orders optimized for this type of problem. Key words: Genetic algorithms, Dispatching rules, Realistic job-shop scheduling. 1. Introduction The growing competition from companies , arising from the globalized market, reinforces their attention to quality and productivity, focusing in the relationships in the supply chain and flexibility, increasing the efficiency of manufacturing. In this context, the Flexible Manufacturing System (FMS) combines high flexibility, productivity and low levels of stock: characteristics that accept the alternative routes of production and make it more agile and robust in face of failures. So, if a machine breaks during a task, a reschedule to find an alternate route is done to finish this job, respecting due dates already planned (Porter et al., 1999; Chan, 2003). In respect to manufacturing systems directly involved with cells and FMS, Porter et al. (1999) and Matsuzaki (2004) point to the job-shop class in the production of small volumes and more variety of concurrent processes. In general, the job-shops are process- oriented production systems and obey a pre-defined sequence of processing. The scheduling problems are widely studied because they assume difficult conditions to solve in polynomial time (NP-hard), due to their combinatorial nature (allocating machines to Int. J. Prod. Manag. Eng. (2016) 4(2), 75-85Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International 75 http://dx.doi.org/10.4995/ijpme.2016.5780 mailto:rogerio.branco@gmail.com mailto:a.s.coelho@ufsc.br mailto:sergio.mayerle@ufsc.br http://creativecommons.org/licenses/by-nc-nd/4.0/ produce parts). Also, the flexibility of alternate routes increases the combinations of resources to compose sequences and therefore, the problem complexity. The literature presents researches involving the SDST-JSSP - Sequence Dependent Setup Times Job- Shop Problems, which are classic JSSP extensions and in which a setup time between two consecutive operations is required. These extensions make the classic cases closer to realistic situations but more complex. In dynamic cases, another extension commonly seen is the NDD-JSSP - Non Deterministic Dynamic Job Shop Problems, which differs from classical because the process does not start at time 0, with random characteristics over starting times and thus, close to realistic cases. Regarding this perspective, this paper propounds combined heuristics techniques and genetic algorithms to solve the combination of these two kind of problems, called NDD-SDST-JSSP. The scheduling algorithm contemplates the goals of shorter processing time and delivery due dates, late start times, variations in processing times of tasks and dependent setup times. Also, there’s another one that forms routes and their internal sequencing, integrated in the GA’s evaluation function. 2. The JSSP problem The scheduling problems belong to the NP-hard problems and exact methods are applied only for relatively small examples of the problem (Araújo, 2006). Furthermore, real problems have additional details which involve more combinations than the classics (Herrmann et al., 1995). The classical JSSP is a group of n jobs to be processed into a set of m machines. Each task has a number of operations and a technological sequence of process. These operations require an uninterrupted processing time over a designed machine. Therefore, it is a time- completion problem that satisfies the constraints: the goal is the minor total completion time - makespan (Vazquez and Whitley, 2000). In the SDST-JSSP, there is a setup time between consecutive operations in the same machine. Thus, once the operation Ojv leaves the machine Mv, before the Okv process starts, a setup time Soiv,okv is added (Gonzales et al., 2005). 3. Methods to solve JSSPs In the literature, there is a great diversity of methods applied to solve the JSSPs. Jain and Meeran (1998) cite Johnson (1954) as one of the firsts significant works in the theory of scheduling, which aimed to minimize the makespan. Several other studies have followed him, where the variety of techniques involved and the forms to modelling these problems greatly increased over these nearly six decades. Following, some methods applied to solve the JSSP can be viewed, without the intention to terminate the discussion about the subject, but only listing the most expressive techniques quite evident in the literature which belong to this state of the art. 3.1. Exact and aproximative methods Several strategies are presented in the literature to solve the classic JSSP. In decision problems as these ones, the Critical Path Method - CPM is one of the most mentioned. Also, formulations involving Linear Programming (LP), Integer Linear Programming (ILP) or Mixed Integer Programming (MIP) are used. Furthermore, the enumerative methods such as Branch and Bound (BB) are strong highlights and the dynamic programming is evidenced in the optimal solution of the classic JSSPs. In general, many simplifications are required to problems in order to find solutions, and they still are little adaptable to variations in size, where applications are restricted to a few small problems (Wall, 1996). It is not difficult to imagine that for real JSSPs, more complex than the classic ones, these implementation strategies will be aggravated. So, a non exact method is now treated, due to its potential in solving JSSPs: the metaheuristics. They are able to search solutions, consisting in the application, at each step, of a subordinate heuristic, which has to be modeled for each specific problem. For them, the principle adopted to explore the solution in the space search can be local or populational. In the first case the operation is performed by means of movement applied to each step on the current solution, generating another promising approach in Int. J. Prod. Manag. Eng. (2016) 4(2), 75-85 Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International Branco, R. M., Coelho, A. S., Mayerle, S. F. 76 http://creativecommons.org/licenses/by-nc-nd/4.0/ its vicinity, like the Tabu Search or the Simulated Annealing techniques. Already, the methods based on population search, are to maintain a set of good solutions and combine them in order to try to produce even better solutions. Classic examples are the Genetic and also, the Memetic Algorithms. The following will be arranged some more detailed operating information of these metaheuristics, focusing on the problem dealt with in this work. 3.2. Tabu search This metaheuristic is considered an iterative global optimization technique. Having originated from the search for integer programming problem solving, it was later extended to almost all combinatorial problems (Goldbarg and Luna, 2000). In general, the Tabu Search (Tabu Search - TS) is a procedure that restricts the search and tries to find optimal solutions, storing the search history in memory. It prohibits (tabu) movements in the neighbourhood with certain attributes, in order to guide the search process as well as solutions (based on available information) have double or are similar to previously stored solutions / obtained. The work of Jain and Meeran (1998) takes the TS as one of the most efficient search for good solutions in classical job-shop systems. They note that methods like branch and bound, if combined, show improvements in search, yet with greater computational cost. Like most local search strategies, TS requires many parameters that must be carefully adjusted. Considering the imminent application of differences in actual cases studied, this may be a difficult barrier to be overcome. 3.3. Simulated Annealing Belonging to the random-guided search techniques, Simulated Annealing - SA presents random components, but also employ current status information to guide the search of the solution of the problem studied. It is a local search method that accepts worsening movements to escape from local optima. It is based on an analogy with thermodynamics, simulating the cooling of a heated set of atoms. For the use of SA should be defined a priori, a method for generating an initial solution s, a method for generating the surrounding solutions S (neighborhood structure) and an objective function f(s) to be optimized (Mauri and Lorena, 2006). Some contributions to neighborhood functions for JSSP were showed by Jain and Meeran (1998). Basically they consist of the reversal of processing orders from a pair of adjacent critical operations for the same machine. This method of SA proposed appears to be quite robust to the JSSP, but Jain and Meeran (1998) mentioned that the results are, also, poor. Only when incorporated into other techniques (eg .: genetic algorithm) is that the quality of the results is improved. The authors also mention the excessive consumption of computational time for good solutions can be found, and the high dependence of the parameters to the algorithm’s nature. It adds that slow colds also potentiate the best results, but also generate a considerable computational time consumption. 3.4. Evolutionary algorithms The Evolutionary Algorithms (EAs) are heuristic search techniques based on natural selection mechanisms, computationally simulating the environments which use the principles of evolution and heredity. They operate with a population of solutions (chromosomes, or individuals), applying selection techniques guided by the ability of each one and subsequently genetic operators such as reproduction and mutation act on them, generating new individuals, new solutions. According to Linden (2008), there are several proposed computational models based on the concept of simulation of evolution through selection and breeding and mutation operators, all dependent on each individual’s fitness in their species and the environment in which it’s inserted. Barboza (2005) cite some of these methods, as the Evolutionary Strategies (EE), Genetic Programming (PG), Classifier Systems (CS) and Transgenetic Computational (CT), among others, saying that the most widespread and researched is the Genetic Algorithm (GA), given their flexibility and effectiveness in performing global search in different environments. 4. Applied methods In general, the solution method proposed for NDD- SDST-JSSP is a combination of dispatching rules, Int. J. Prod. Manag. Eng. (2016) 4(2), 75-85Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International Hybrid genetic algorithms: solutions in realistic dynamic and setup dependent job-shop scheduling problems 77 http://creativecommons.org/licenses/by-nc-nd/4.0/ the genetic and the modified GT algorithms (Giffler and Thompson, 1960). Thus, several considerations were made, starting from the chromosome coding, application of genetic operators and evaluation of individuals. 4.1. The priority dispatching rules The most popular heuristic techniques applied to scheduling problems, the Priority Dispatching Rules (PDR´s), have demonstrated their importance in several works and even today, are still widely used in combined methods. Some examples are the work of Singh, Mehta and Jain (2006), El-Bouri and Shah (2006), Branco (2010), among others. Such importance lies in the easy implementation and low computational cost required. In general, the procedure is to choose a set of operations, not scheduled yet. According to a criterion of choice, a set formed by operations that can be processed in a specific machine will have one of them selected by this adopted criterion, which will be inserted into the scheduling. According to the tests, are used the following know rules from the literature: - RND (random): Rule based in random uniformly distributed variable; - SPT (shortest process time): gives greater priority to the task that presents smaller processing time. - S/RPT (slack per remaining processing time): gives priority to operations based on the composite index by the ratio of the delivery date, subtracts the task completion and remaining processing time. There are several other rules, such as SRPT, LTWK and SPT/TWK, commented by Chiang and Fu (2006). Extensions of SPT incorporate, under combined conditions, other goals, also with good efficiency and late operations. Jain and Meeran (1998) apud Chang et al. (1996) show a study evaluating 42 PDRs applied in an integer linear programming model, where the SPT rule showed the best performance. Regarding work interests, it is important to consider the due time when implementing processes, given the characteristics of demand oriented to orders/ requests that the processes are subject to, but without forgetting the relevant conditions concerning flow time in processes, that leads to combined rules. Thus, the aim is to combine some simpler rules to promote better results in low computational time. Therefore, SPTq (less time needed to complete a process) is selected in Equation 1 and S/RPT, in Equation 2, motivated by the success of the first, in a wide variety of jobs and, for the latter, considering the time needed to complete the ongoing processes. mi q q j iSPT piq = = ∑ (1) mi i q j i q mi q q j d t piq d t iSPT iSPRT iSPTpiq = = − − − − = = ∑ ∑ (2) where: di = jobi due date; pij = processing time of the operation j in job i; t = current time; mi = number of operations remaining to finish jobi; mi q j piq = ∑ = iSPTq = process time remaining (jobi); Both indexes are inversely proportional to the priority value, i.e., higher priority to lower value and lower priority to higher values, so the algorithm is built to prioritize operations with lower rates. The iCHR is given by the equations below: . . i qq q q d t iSPT iCHR iSPT iSPRT iSPT iSPT − − = = (3) i qiCHR d t iSPT= − − (4) 4.2. The genetic algorithm Solving a wide variety of problems in class NP - complete, Evolutionary Algorithms (EAs) make heuristic search techniques based on natural mechanisms of selection, simulating computational environments based on these principles of evolution and heredity (Goldberg, 1989). Int. J. Prod. Manag. Eng. (2016) 4(2), 75-85 Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International Branco, R. M., Coelho, A. S., Mayerle, S. F. 78 http://creativecommons.org/licenses/by-nc-nd/4.0/ The proposed structure to chromosome has two known parts: head and body. The “head” contains the information of the route and the “body” will act in the operation sequence, both with the same dimensions and, for each operation, the locus contains a machine index. The Figure 1 shows the relationship between the operations and machines available to process them and the structure of the “head” of the chromosome.   Figure 1. Example of relation between the original table of operations and the chromossome structure – phenotype×genotype (source: own). Also, the “body” contains whole alleles, not repeated, in the interval ai=[0,total operations-1] and, in the scheduling, it indexes the order of operations, as the Figure 2 shows.   Figure 2. Example of scheduling process from a given chromosome – phenotype×genotype (source: own). 4.3. Creating the initial population Since the “head” must be built first, this is made us- ing random numbers in the range of [0,nmij-1], where nmij is the number of available machines to process operation j of the process i. The Figure 1 above shows this construction part, where resource alloca- tion starts building the “body”, an ordered 0 to nmij-1 array. 4.4. Evaluation of the population The function corresponding to the evaluation of the population, individual by individual, is the fitness function. Each of these values are the quantification of its adaptations. In other words, it means to apply the modified GT algorithm to make the active scheduling for each chromosome. The time completion can be the objective function of the search. Where: n = number of tasks; oik = operation k of job i; tik = time able to start operation k of job i; pik = processing time of the operation k belonging to the job i. As follows, the modified GT algorithm schedulings: Modified GT Algorithm: Step 1: Place the first schedulable operation of each task (of the active planning horizon) in the set of candidate operations C={oi1|1 ≤ i ≤ n}; Step 2: Choose an operation o’ of C, with earliest completion time; Step 3: Determine the machine M’, in which o’ must be processed and thus build the set G (the conflict set of M’), consisting of all operations of C to be executed in M’; Step 4: Remove operations that do not start before o’ finish, G = {oik ∈ G | tik