Shop Scheduling Problem

Slides:



Advertisements
Similar presentations
On the Complexity of Scheduling
Advertisements

Finite-state Recognizers
FLOW SHOPS: F2||Cmax. FLOW SHOPS: JOHNSON'S RULE2 FLOW SHOP SCHEDULING (n JOBS, m MACHINES) n JOBS BANK OF m MACHINES (SERIES) n M1 M2Mm.
Parallel Scheduling of Complex DAGs under Uncertainty Grzegorz Malewicz.
Representing Relations Using Matrices
Complexity 16-1 Complexity Andrei Bulatov Non-Approximability.
1 More On Dynamic programming Algorithms Shortest path with edge constraint: Let G=(V, E) be a directed graph with weighted edges. Let s and v be two vertices.
1 IOE/MFG 543 Chapter 6: Flow shops Sections 6.1 and 6.2 (skip section 6.3)
1 Set # 3 Dr. LEE Heung Wing Joseph Phone: Office : HJ639.
1 Set # 4 Dr. LEE Heung Wing Joseph Phone: Office : HJ639.
Steiner trees Algorithms and Networks. Steiner Trees2 Today Steiner trees: what and why? NP-completeness Approximation algorithms Preprocessing.
1 IOE/MFG 543 Chapter 7: Job shops Sections 7.1 and 7.2 (skip section 7.3)
Approximation Algorithms
TECH Computer Science Graph Optimization Problems and Greedy Algorithms Greedy Algorithms  // Make the best choice now! Optimization Problems  Minimizing.
The greedy method Suppose that a problem can be solved by a sequence of decisions. The greedy method has that each decision is locally optimal. These.
Job-shop Scheduling n jobs m machines No recirculation – Jobs do not revisit the same machine (i, j) is referred to as an operation in which job j is processed.
Incidentor coloring: methods and results A.V. Pyatkin "Graph Theory and Interactions" Durham, 2013.
 Rooted tree and binary tree  Theorem 5.19: A full binary tree with t leaves contains i=t-1 internal vertices.
Outline Introduction Minimizing the makespan Minimizing total flowtime
Maximum Flow Problem (Thanks to Jim Orlin & MIT OCW)
Dvir Shabtay Moshe Kaspi The Department of IE&M Ben-Gurion University of the Negev, Israel.
15.082J and 6.855J March 4, 2003 Introduction to Maximum Flows.
Chapter 8 Maximum Flows: Additional Topics All-Pairs Minimum Value Cut Problem  Given an undirected network G, find minimum value cut for all.
Problems in Combinatorial Optimization. Linear Programming.
12. Lecture WS 2012/13Bioinformatics III1 V12 Menger’s theorem Borrowing terminology from operations research consider certain primal-dual pairs of optimization.
Product A Product B Product C A1A1 A2A2 A3A3 B1B1 B2B2 B3B3 B4B4 C1C1 C3C3 C4C4 Turret lathes Vertical mills Center lathes Drills From “Fundamentals of.
Approximation Algorithms based on linear programming.
5.6 Prefix codes and optimal tree Definition 31: Codes with this property which the bit string for a letter never occurs as the first part of the bit string.
1 Job Shop Scheduling. 2 Job shop environment: m machines, n jobs objective function Each job follows a predetermined route Routes are not necessarily.
Lecture 20. Graphs and network models 1. Recap Binary search tree is a special binary tree which is designed to make the search of elements or keys in.
Single Machine Scheduling Problem Lesson 5. Maximum Lateness and Related Criteria Problem 1|r j |L max is NP-hard.
Approximation Algorithms for Scheduling Lecture 11.
CHAPTER SIX T HE P ROBABILISTIC M ETHOD M1 Zhang Cong 2011/Nov/28.
Scheduling Overview Conjunctive Graph; Potentials, properties and existence conditions; Methods for scheduling; Potential task method Pert method;
Capabilities, Minimization, and Transformation of Sequential Machines
Representing Relations Using Digraphs
Classification of Scheduling Problems
Approximation Algorithms for Scheduling
More NP-Complete and NP-hard Problems
Some Topics in OR.
Job Shop Scheduling Contents 1. Problem Statement 2. Disjunctive Graph
Basic Project Scheduling
Assignment Problem, Dynamic Programming
Parallel Machines (Q||ΣCi , Q|pmtn|ΣCi , R||ΣCi , R|pmtn|Cmax, R|pmtn|Lmax) Lesson 8.
V12: Network Flows V12 follows closely chapter 12.1 in
Basic Project Scheduling
Design and Analysis of Algorithm
Bipartite Graphs What is a bipartite graph?
Chapter 5. Optimal Matchings
Computability and Complexity
The basics of scheduling
3.3 Applications of Maximum Flow and Minimum Cut
ICS 353: Design and Analysis of Algorithms
Algorithms (2IL15) – Lecture 2
3.5 Minimum Cuts in Undirected Graphs
Problem Solving 4.
Activity Networks
Activity Networks
Chapter 7: Job shops Sections 7.1 and 7.2 (skip section 7.3)
Bipartite Graph 1. A graph G is bipartite if the node set V can be partitioned into two sets V1 and V2 in such a way that no nodes from the same set are.
Topic 15 Job Shop Scheduling.
NP-Completeness Reference: Computers and Intractability: A Guide to the Theory of NP-Completeness by Garey and Johnson, W.H. Freeman and Company, 1979.
The Full Steiner tree problem Part Two
Advanced LP models column generation.
Algorithm Design Techniques Greedy Approach vs Dynamic Programming
V12 Menger’s theorem Borrowing terminology from operations research
The Greedy Approach Young CS 530 Adv. Algo. Greedy.
Chapter 1. Formulations.
Maximum Flow Problems in 2005.
Vertex Covers and Matchings
Presentation transcript:

Shop Scheduling Problem Lesson 9

General Shop Problem Given: n jobs i = 1,..., n and m machines M1,..., Mm. Each job i consists of a set of operations Oij (j = 1,..., ni) must be processed on a machine μij  {M1,..., Mm}. There may be precedence relations between the operations of all jobs. Each job can be processed only by one machine at a time. The objective is to find a feasible schedule that minimizes some objective function of the finishing times Ci of the jobs i = 1,..., n. The objective functions are assumed to be regular.

Disjunctive Graph Model G = (V, C, D) V is the set of nodes representing the operations of all jobs. In addition, there are two special nodes, a source 0  V, and a sink   V. A weight is associated with each node. The weights of 0 and  are zero, while the weights of the other nodes are the processing times of the corresponding operations. C is the set of directed conjunctive arcs. These arcs reflect the precedence relations between the operations. Additionally, there are conjunctive arcs between the source and all operations without a predecessor, and between all operations without a successor and the sink. D is set of undirected disjunctive arcs. Such an arc exists for each pair of operations belonging to the same job which a not connected by a conjunctive arc and for each pair of operations belonging to the same machine which a not connected by a conjunctive arc

Figure 9.1  s M1 M4 O11 O12 O13 M2 M3 O22 O21 M1 M3 M2 O33 O31 O32 M1

Selection The basic scheduling decision is to define an ordering between the operations connected by disjunctive arcs. This can be done by turning the undirected disjunctive arcs into directed ones. A selection S is a set of directed disjunctive arcs. Disjunctive arcs which have been directed are called fixed.

Complete Selection A selection is a complete selection if each disjunctive arc has been fixed, and the resulting graph G(S) = (V, C∪S) is acyclic.

Figure 9.1  s M1 M4 O11 O12 O13 M2 O22 M3 O21 M1 M3 M2 O33 O31 O32 M1

Figure 9.1 O11 O12 O13 O22 O21  s O33 O31 O32 O41 O42

Selection  Schedule Given a complete selection S, we may construct a corresponding nonpreemptive (semi-active) schedule x = (xi) defined by the starting times of all operations i. For each path p from vertex i to vertex j in G(S), define the length of p to be the sum of all labels of nodes in p, j included. For each operation i, let l(i) be the length of a longest path from 0 to the vertex representing i. If we define xi = l(i) for all operations i, then we get the feasible schedule x associated with S.

Schedule  Selection On the other hand, an arbitrary feasible schedule x defines an order of operations for each job and each machine. This induces a complete selection S and, given a regular objective function, the corresponding schedule x’ is not worse than x. Thus, a complete selection always exists which represents an optimal schedule.

Open Shop Problems An open shop problem is a special case of the general shop in which each job i consists of m operations Oij (j = 1,..., m) where Oij must be processed on machine Mj, there are no precedence relations between the operations. Thus, the problem is to find job orders and machine orders.

O2||Cmax Let A and B be the two machines and denote by ai and bi the processing times of job i (i = 1,..., n) on machines A and B, respectevely. Define I = {i | ai  bi ; i = 1,..., n} and J = {i | ai > bi ; i = 1,..., n}. We determine job with the largest small operation.

Case 1 ar = max{ max{ai| i  I}, max{bi| i  J}} An optimal schedule is constructed by scheduling first all jobs in I \{r} in an arbitrary order on machine A, then all jobs in J in an arbitrary order, and, finally, job r, first job r on machine B, then all jobs in I \{r} in the same order as jobs in I \{r} are scheduled on A, and finally, all jobs in J in the same order as on machine A.

Case 1 ar = max{ max{ai| i  I}, max{bi| i  J}} I = {i | ai  bi ; i = 1,..., n} J = {i | ai > bi ; i = 1,..., n}. ar = max{ max{ai| i  I}, max{bi| i  J}} A I \ {r} J r B r I \ {r} J

Case 2 br = max{ max{ai| i  I}, max{bi| i  J}} I = {i | ai  bi ; i = 1,..., n} J = {i | ai > bi ; i = 1,..., n}. br = max{ max{ai| i  I}, max{bi| i  J}} A r J\ {r} I B J\ {r} I r

Correctness (case 1)  1) 0 → ai (i  I \ {r}) → ai (i  J ) → ar →  G(S) I \ {r} J r  r 1) 0 → ai (i  I \ {r}) → ai (i  J ) → ar →  2) 0 → br → bi (i  I \ {r}) → bi (i  J ) →  3) 0 → br → ar → 

Correctness (case 1) r = n  G(S) I \ {r} = {1,..., |I| – 1} J = {|I| ,..., n – 1} r = n r  r 0 → a1 →...→ ai → bi → bn –1 →  (i = 1,..., n – 1)

Case 1, i  I ai  max{aj | j  I} = an  bn. an = max{max{ai| i  I}, max{bi| i  J}} I = {i | ai  bi ; i = 1,..., n} ai  max{aj | j  I} = an  bn.

Case 1, i  J an = max{max{ai| i  I}, max{bi| i  J}} J = {i | ai > bi ; i = 1,..., n} bi  max{bj | j  J}   max{max{ai| i  I}, max{bi| i  J}} = an

Flow Shop Problems An flow shop problem is a general shop problem in which each job i consists of m operations Oij with processing time pij (j = 1,..., m) where Oij must be processed on machine Mj, there are precedence relations of the form Oij → Oij+1 (i = 1,..., m – 1) for each i = 1,..., n, i.e. each job is first processed on machine 1, then on machine 2, then on machine 3, etc. Thus, the problem is to find a job order πj for each machine Mj.

Job Sequence Lemma 9.2 For problem Fm||Cmax an optimal schedule exists with the following properties: The job sequence on the first two machines is the same. The job sequence on the last two machines is the same.

Proof of Lemma 9.2 Consider an optimal schedule in which the processing order on both machines is identical for the first k scheduled jobs, where k < n is maximal. Let i be the k-th job and let j be the job scheduled on machine 2 after the second operation of job i. M1 ● ● ● i l ● ● ● h j M2 ● ● ● i j t If on machine 1 we shift job j to the position immediately after job i and move the jobs scheduled previously between job i and job j by p1j time units to the right, we get another optimal schedule. This contradict the maximality of k.

Permutation Flow Shop A flow shop is called a permutation flow shop if solution are restricted to job sequences: π1,..., πm with π1 = π2 =...= πm. Lemma 6.8 shows that for two and three machines the optimal solution of the flow problem is not better than that of the corresponding permutation flow shop.

4 machines M1 M2 M3 M4 J1 1 3 J2 O11 O21 O12 O22 O23 O13 O24 O14 O11

F2||Cmax For solving two-machine flow shop problem we have to find a permutation L: L(1),..., L(n) of all jobs are scheduled in this order on both machines, then the makespan is minimized. An optimal order is constructed by calculating a left list T: L(1),..., L(t) and a right list R: L(t + 1),..., L(n) and then concatenating them to obtain L = T ○ R = L(1),..., L(n). The lists T and R are constructed step by step.

Johnson’s Rule At each step we consider an operation Oi*j* with the smallest pi*j* -value. If j*=1, then we put job i* at the end of list T, i.e. we replace T by T ○ i*. Otherwise we put i* at the beginning of list R, i.e. we replace R by i*○ R. Job i* and processing times pi*1 and pi*2 are then deleted from consideration.

Example 9.3 pi1 pi2 Job 1 4 8 Job 2 3 Job 3 Job 4 1 Job 5 7 T : 4, 3, 1 R : 5, 2 M1 4 3 1 5 2 M2 4 3 1 5 2 t 27

Lemma 9.4 Lemma 9.4 Let L: L(1),..., L(n) be a list constructed by Johnson’s rule. Then min{pi1, pj2}< min{pj1, pi2} implies that job i precedes job j in L.

Proof of Lemma 9.4 (i → j) pi1 < min{ pj1, pi2 } pi1 < pi2 i  T j  R i → j j  T pi1 < pj1 L = T○R T →T ○ i* j appears after i in T i → j

Lemma 9.5 Lemma 9.5 Consider a schedule in which job j is scheduled immediately after job i. Then min{pj1, pi2}  min{pi1, pj2} (6.10) implies that i and j can be swapped without increasing the Cmax-value.

Three Cases wij = pi1 + pj1 + pj2 M1 i j M2 i j wij = pi1 + pi2 + pj2 ● ● ● i j ● ● ● M2 ● ● ● i j ● ● ● wij = pi1 + pi2 + pj2 M1 ● ● ● i j ● ● ● M2 ● ● ● i j ● ● ● x wij = x + pi2 + pj2 M1 ● ● ● i j ● ● ● M2 ● ● ● i j ● ● ●

Proof of Lemma 9.5 wji  wij + = wij = max{ pi1 + pj1 + pj2 , pi1 + pi2 + pj2 , x + pi2 + pj2 } = max{ pi1 + pj2 + max{ pj1 , pi2}, x + pj1 + pj2 } wji = max{ pj1 + pi2 + max{ pi1 , pj2}, x + pj1 + pj2 } L9.4: min{pj1, pi2}  min{pi1, pj2} wji  wij max{–pi1, –pj2}  max{–pj1, –pi2} + pi1 + pi2 + pj1 + pj2 = pj1 + pi2 + max{ pi1 , pj2}  pi1 + pj2 + max{ pj1 , pi2}

Correctness Theorem 9.6 The sequence L: L(1),..., L(n) constructed by Jonson’s rule is optimal.

Proof of Theorem 9.6 Let Λ be the set of all optimal sequences and assume that L  Λ. Then we consider a sequence R  Λ with L(ν) = R(ν) for ν = 1,..., s – 1and i = L(s) ≠ R(s) = j where s is maximal.

Proof Job i is a (not necessarily immediate) successor j in R. Let k be a job scheduled between job j and job i or k = j in R. In L, job k is scheduled after job i. Thus, by Lemma 9.4 we must have min{pk1, pi2} ≥ min{pi1, pk2}, otherwise job i would follow by job k in L.

Proof min{pk1, pi2} ≥ min{pi1, pk2} holds for each such job k. Applying Lemma 9.5 to R, we may swap each immediate predecessor k of job i without increasing the objective value. We finally get a sequence R#  Λ with L(ν) = R#(ν) for ν = 1,..., s. Contradiction with maximality s.

Job Shop Problems The job shop problem is a special case of general shop problem which generalize the flow shop problem. Each job i consists of ni operations Oi1, Oi2,..., Oini, which must be processed on this order. We have precedence relations of the form Oij → Oij+1 (i = 1,..., ni – 1). There is a machine μij{M1,..., Mm} and a processing time pij associated with each operation Oij. Oij must be processed for pij time units on machine μij. The problem is to find a feasible schedule which minimizes some objective function depending on the finishing time Ci of the last operation Oini of the jobs. We assume that μij ≠ μij+1 for i = 1,..., ni – 1.

J2|ni  2 |Cmax This two machine job shop problem with at most two operations per job can be solved by a reduction to the two-machine flow shop problem.

Set of Jobs To describe this reduction, it is convenient to divide the set of jobs into the following subsets: I1: jobs which are processed only on machine 1 I2: jobs which are processed only on machine 2 I1,2: jobs which are processed first on machine 1 and then on machine 2 I2,1: jobs which are processed first on machine 2 and then on machine 1

Reduction To construct an optimal solution for problem J2|ni  2|Cmax we have to apply the following steps. Calculate an optimal sequence R1,2 for the flow shop problem with job set I1,2. Calculate an optimal sequence R2,1 for the flow shop problem with job set I2,1. On machine 1 first schedule I1,2 according R1,2, then all jobs in I1 in an arbitrary order, and finally, I2,1 according to R2,1. On machine 2 first schedule I2,1 according R2,1, then all jobs in I2 in an arbitrary order, and finally, I1,2 according to R1,2.

Structure of Schedule We may assume that the schedule constructed in this way is active. Then at least one machine processes the jobs without idle time. More specifically, if then there is no idle time on machine 1. Otherwise there is no idle time on machine 2.

Optimality No idle time M1 I12 I1 I21 M2 I21 I2 I12 No idle time M1 t = OPT(I12)