Online Storage Systems and Transportation Problems with Applications
Applied Optimization Volume 91 Series Editors:
P...
13 downloads
487 Views
5MB Size
Report
This content was uploaded by our users and we assume good faith they have the permission to share this book. If you own the copyright to this book and it is wrongfully on our website, we offer a simple DMCA procedure to remove your content from our site. Start by pressing the button below!
Report copyright / DMCA form
Online Storage Systems and Transportation Problems with Applications
Applied Optimization Volume 91 Series Editors:
Panos M. Pardalos University of Florida, U.S.A. Donald W. Hearn University of Florida, U.S.A.
Online Storage Systems and Transportation Problems with Applications Optimization Models and Mathematical Solutions
Julia Kallrath ITWM, Germany
Q - Springer
Library of Congress Cataloging-in-Publication Data A C.I.P. Catalogue record for this book is available from t h e Library of Congress.
ISBN 1-4020-2971-3
e-ISBN 0-387-23485-3
Printed on acid-free paper.
O 2005 Springer Science+Business Media, Inc. All rights reserved. This work may not be translated or copied in whole or in part without the written permission of the publisher (Springer Science+Business Media, Inc., 233 Spring Street, New York NY 10013, USA), except for brief excerpts in connection with reviews or scholarly analysis. Use in connection with any form of information storage and retrieval, electronic adaptation, computer software, or by similar or dissimilar methodology now know or hereaRer developed is forbidden. The use in this publication of trade names, trademarks, service marks and similar terms, even if the are not identified as such, is not to be taken as an expression of opinion as to whether or not they are subjact to proprietary rights.
Printed in the United States of America. 9 8 7 6 5 4 3 2 1
SPIN 11161943
to my parents
Contents
Dedication Preface 1. INTRODUCTION
1.1 Optimization Everywhere 2. BATCH PRESORTING PROBLEMS. I 2.1 Problem Description and Classification 2.2 Formulation of the Batch Presorting Problem 2.2.1 Feasible Permutations 2.2.2 Mathematical Formulation of BPSPl 2.2.3 Mathematical Formulation of BPSP2 and BPSP3 2.2.3.1 An Optimization Version of BPSP2 2.2.3.2 An Optimization Version of BPSP3 2.3 Complexity Results 2.4 Polynomial Subcases 2.4.1 Reformulation of BPSP2 and BPSP3 2.4.2 An Alternative Model Formulation of D-BPSP/ 2.5 The Case of Two Layers 2.5.1 Offline Situations 2.5.2 Online Situations 2.5.3 Algorithms for Online Situations with Lookahead 2.5.3.1 Definition of a Lookahead 2.5.3.2 An Algorithm with a Weak Lookahead, size X = 1 2.5.3.3 Algorithms with a Weak Lookahead, size X > 2 2.5.3.4 An Algorithm with a Strong Lookahead 2.5.4 Competitive Analysis
...
vm
Online Storage Systems and Transportation Problems
Comparison of D z and Online Algorithms with Lookahead 2.6 Extensions 2.7 Summary und Future Research 2.5.5
3. BATCH PRESORTING PROBLEMS. I1 3.1 The Storage System Rotastore 3.1.1 A Brief Description of the Rotastore 3.1.2 Stochastic Measures 3.2 Numerical Tests 3.2.1 Models 3.2.2 Algorithms 3.3 Summary 4. VEHICLE ROUTING PROBLEMS IN HOSPITALS. I 4.1 Problem Formulation and Solution Outline 4.1.1 Problem Description 4.1.2 Discussion of one Particular Model Formulation 4.1.3 Discussion of Existing Solution Approaches 4.1.4 Outline of Proposed Methods 4.2 General Framework 4.2.1 Notation 4.2.2 Characterizing the Quality of Tours 4.3 Exact Solution Approaches 4.3.1 A Mixed Integer Programming Approach 4.3.1.1 Data, Indices and Variables 4.3.1.2 The Objective Function 4.3.1.3 The Constraints 4.3.1.4 Equivalent Mixed Integer Linear Formulations 4.3.1.5 Online Version of the MILP Model 4.3.1.6 Comments on the Size and the Structure of the MILP Problem 4.3.1.7 Tightening the Model Formulation 4.3.1.8 Concluding Remarks on the Model 4.3.2 A Branch-and-Bound Approach for Solving the Intra-Tour Problem 4.3.3 Column Enumeration 4.3.3.1 Motivating a Column Enumeration Approach 4.3.3.2 Comments on Column Generation Techniques
94
Contents
4.3.3.3 Developing a Column Enumeration Approach 4.3.3.4 Summarizing the Column Enumeration Approach 4.3.3.5 Complexity Aspects and Computational Issues 4.3.3.6 Numerical Improvements 4.3.3.7 Column Enumeration Coupled to Heuristics 4.4 Construction and Improvement Heuristics 4.4.1 Construction Heuristics 4.4.1.1 Heuristic CONHI 4.4.1.2 Heuristic CONH2 4.4.1.3 Penalty Criteria 4.4.2 Improvement Heuristics 4.4.2.1 Heuristic I T 1 4.4.2.2 Heuristic IT2 4.4.2.3 Adding an Order to a Tour 4.4.2.4 Termination Criteria 4.4.3 Simulated Annealing and Vehicle Routing 4.4.3.1 Monte Carlo Methods and Simulated Annealing 4.4.3.2 Optimization Problems and Simulated Annealing 4.4.3.3 Improving Tours by Simulated Annealing 4.5 Summary 5. VEHICLE ROUTING PROBLEMS IN HOSPITALS. I1 5.1 OptiTrans 5.2 Numerical Tests 5.2.1 Input data 5.2.2 Offline and Online Versions 5.2.3 MILP Model 5.2.3.1 Intra-Tour Optimization (Single-Vehicle Cases) 5.2.3.2 An Online Case Including Pre-assigned Orders 5.2.4 Column Enumeration Experiments 5.2.5 Construction and Improvement Heuristics 5.2.5.1 Offline Version 5.2.5.2 Online version 5.2.6 Simulated Annealing Examples 5.2.7 Summary of the Numerical Experiments 5.3 Summary
146
x
Online Storage Systems and Transportation Problems
6. SUMMARY Appendices A Rotastore A.l Tabular Results for Different Models A.2 Tabular Results for Different Algorithms B OptiTrans B.l Input Data B.l.l Input Data Common to all Solution Approaches B.1.2 Specific Input Data for the MILP Model and the Column Enumeration Approach B.1.3 Specific Input Data for the Heuristic Methods B.1.3.1 Penalty Criteria B.1.3.2 Control Parameters of the OptiTrans Software B.2 Tabular Results B.2.1 Tabular Results for the MILP Model B.2.2 Tabular Results for the Heuristic Methods B.2.2.1 Input Data for a Whole Day - Offline Analysis B.2.2.2 Results for CIH and SA References Index
149
Preface
This book covers the analysis and development of online algorithms involving exact optimization and heuristic techniques, and their application to solve two real life problems. The first problem is concerned with a complex technical system: a special carousel based high-speed storage system - Rotastore. It is shown that this logistic problem leads to an NP-hard Batch Presorting Problem ( B P S P ) which is not easy to solve optimally in offline situations. We consider a polynomial case and develope an exact algorithm for offline situations. Competitive analysis showed that the proposed online algorithm is 312-competitive. Online algorithms with lookahead improve the online solutions in particular cases. If the capacity constraint on additional storage is neglected the problem has a totally unimodular polyhedron. The second problem originates in the health sector and leads to a vehicle routing problem. We demonstrate that reasonable solutions for the offline case covering a whole day with a few hundred orders can be constructed with a heuristic approach, as well as by simulated annealing. Optimal solutions for typical online instances are computed by an efficient column enumeration approach leading to a set partitioning problem and a set of routing-scheduling subproblems. The latter are solved exactly with a branch-and-bound method which prunes nodes if they are value-dominated by previous found solutions or if they are infeasible with respect to the capacity or temporal constraints. Our branch-and-bound method is suitable to solve any kind of sequencing-scheduling problem involving accumulative objective functions and constraints, which can be evaluated sequentially. The column enumeration approach developed to solve this hospital problem is of general nature and thus can be embedded into any decision-support system involving assigning, sequencing and scheduling.
xii
Online Storage Systems and Transportation Problems
The book is aimed at practioners and scientists in operation research especially those interested in online optimization. The target audience are readers interested in fast solutions of batch presorting and vehicle routing problems or software companies producing decision support systems. Students and graduates in mathematics, physics, operations research, and businesses with interest in modeling and solving real optimization problems will also benefit from this book and can experience how online optimization enters into real world problems.
Structure of this Book This book is organized as follows. Chapter 2 addresses the BPSP, where a formal definition of the BPSP is introduced (Section 2.1) and several modeling approaches are proposed (see Section 2.2). Complexity issues of some formulations are investigated in Section 2.3 and Section 2.4. For one polynomial case of the BPSP several algorithms are presented and compared in Section 2.5. In Chapter 3 we consider a concrete application of the BPSP - carousel based storage system Rotastore. In Section 3.1 we describe the system performance, and in Section 3.2 the numerical results of the experiments are presented. Chapter 4 focuses on the Vehicle Routing problem with Pickup and Delivery and Time Windows (VRPPDTW), adapted for hospital transportation problems. After introducing some notations (Subsection 4.2.1), we suggest several approaches we have developed to solve this problem, including a MILP formulation (Subsection 4.3.1), a branch-and-bound approach (Subsection 4.3.2), a column enumeration approach (Subsection 4.3.3), and heuristic methods (Section 4.4). In Chapter 5 we describe a problem related to a hospital project with the University Hospital in Homburg. Detailed numerical results for our solution approaches related to the VRPPDTW are collected in Section 5.2.
xiii
PREFACE
Conventions and Abbreviations The following table contains in alphabetic order the abbreviations used in this book. Abbreviation B&B B&C BPSP CEA IP LP MCP MILP MINLP RH SA SAT SH s.t. TS VNS VRP VRPPDTW w.r. t.
Meaning Branch-and-Bound Branch-and-Cut Batch Presorting Problem column enumeration approach Integer Programming Linear Programming Mixed Complementarity Problem Mixed Integer Linear Programming Mixed Integer Nonlinear Programming reassignment heuristic simulated annealing satisfiability problem sequencing heuristic subject to tabu search variable neighborhood search Vehicle Routing Problem VRP with Pickup and Delivery and Time Windows with respect to
Acknowledgements First of all I want to thank Prof. Dr. Stefan Nickel (ITWM Kaiserslautern and Universitat Saarbrucken), the head of our department, who was leading the two real world projects; without him the book would not have appeared. Prof. Dr. Christodoulos Floudas (Princeton University) and Prof. Dr. Linus Schrage (University of Chicago) - for their interest in this work and encouraging comments on the vehicle routing problem. Prof. Dr. Susanne Albers (Freiburg Universitat) - for the useful feedback on the topic of online optimization and the competitive analysis for the batch pre-sorting problem. Prof. Dr. Alexander Lavrov (ITWM Kaiserslautern and NTUU Kiev) - for his constant support and help during all my time at the ITWM in Kaiserslautern. Dr. Teresa Melo (ITWM Kaisers1autern)- for fruitful discussions about the vehicle routing problem and for the proof reading. Martin Muller (Siemens AG, Munchen) - for constructive talks and discussions about the batch presorting problem. Prof. Dr. Robert E. Wilson (University of Florida), Steffen Rebennack (Universitat Heidelberg) and Dr. Anna Schreieck (BASF, Ludwigshafen) - for careful reading parts of this book. And last but not least, my husband Josef Kallrath - for his positive spirit encouraging and supporting me never to give up.
xiv
Online Storage Systems and Transportation Problems
JULIAKALLRATH
Chapter 1
INTRODUCTION
What do a logistics manager responsible for an inventory storage system and a vehicle fleet dispatcher in a hospital campus have in common? They both have to consider new objects arriving at short notice and to decide on what to do with them, how to assign them to given resources or how to modify previously made decisions. This means they both need to make decisions based on data suffering from incomplete knowledge about near future events. Online optimization is a discipline in mathematical optimization and operations research which provides the mathematical framework and algorithms for dealing appropriately with such situations.
1.1.
Optimization Everywhere
The need for applying optimization arises in many areas: finance, space industry, biosystems, textile industry, mineral oil, process and metal industry, and airlines to name a few. Mathematical programming is a very natural and powerful way to solve problems appearing in these areas. In particular, see [12], [18], [23], [37] and [83] for application examples. One might argue that low structure systems can probably be handled well without optimization. However, for the analysis and development of real life complex systems (that have many degrees of freedom, underlying numerous restrictions etc.) the application of optimization techniques is unavoidable. It would not be an exaggeration even to say that any decision problem is an optimization problem. Despite their diversity real world optimization problems often share many common features, e.g., they have similar mathematical kernels such as flow, assignment or knapsack structures. One further common feature of many real life decision problems is the online nature aspect, i. e., decision making is based on partial, insufficient
2
Online Storage Systems and Transportation Problems
information or without any knowledge of the future. One approach (not treated in this book) to solve problems with only partial or insufficient information is optimization under uncertainty (cf. [45], [50], or [88]), and especially, stochastic programming (cf. [14], [53], [77], or [78]). In that case, the problem is still solved as an offline problem. However, it is not always appropriate to solve a problem offline. If we cannot make any assumptions on future data, only the currently available data can be used. In such situations online optimization is recommended. We can list a number of problems that were originally formulated as offline problems but which in many practical applications are used in their online versions: the bin packing problem, the list update problem, the k-server problem, the vehicle routing problem, and the pickup and delivery problem to name a few. Special optimization techniques for online applications exploit the online nature of the decision process. Usually, a sequence of online optimization problems is solved when advancing in time and more data become available. Therefore, online optimization can be much faster than offline optimization (which uses the complete input data). To estimate the quality of a sequence of solutions obtained by online optimization one can only compare it with the overall solution produced by an offline algorithm afterwards. A powerful technique to estimate the performance of online algorithms is the competitive analysis (cf. [Ill). A good survey on online optimization and competitive analysis can be found in [4], [ll], [30]. Online optimization and competitive analysis are based on generic principles and can be beneficial in completely different areas such as the storage system and transportation problem considered in this book. At first we consider an example of a complex technical system, namely a special carousel based high-speed storage system - Rotastore [73],which not only allows storing ([56], [57]) but also performs sorting ([49], [70]). Sorting actions and assignment to storing locations are fulfilled in real time, but the information horizon may be rather narrow. The quality of the corresponding decisions strongly influences the performance of the system in general; thus the need to improve the quality of the decisions. Due to the limited information horizon online optimization is a promising approach to solve these problems. In our second case study, the conditions for the decision making process in hospital transportation are similar: the orders often are not known in advance, the transportation network may be changed dynamically. The efficiency of order assignment and scheduling of the transport system can influence the operation of the whole hospital. That assumes, in this case, not only economical aspects, but, at first of all, human health and life issues.
Introduction
3
As will be shown in this book, the mathematical base for the first problem is the Batch Presorting Problem (BPSP), for the second one we naturally can use an online variant of the Vehicle Routing problem with Pickup and Delivery and Time Windows (VRPPDTW). The efficient application of the corresponding solution methods allows to improve the performance of both systems compared to the current real life situation.
Chapter 2
BATCH PRESORTING PROBLEMS. I MODELS AND SOLUTION APPROACHES
This chapter is organized as follows: at first, we describe the problem and give a short classification. In Section 2.2 different formulations of the BPSP are presented. In Subsection 2.2.2 we consider an optimization version of BPSP1. In Subsection 2.2.3 we formulate BPSP2 and BPSP3 as decision problems and additionally introduce optimization models. The complexity status of BPSP2 is investigated in Section 2.3, and in Section 2.4 we show that there is a polynomial version of the BPSP. Also we consider a special subcase of a BPSP with N~ = 2 in offline and online situations and present corresponding algorithms in Section 2.5. Finally, in Section 2.6, some results derived for BPSPs with N~ = 2 are adapted to general BPSP.
2.1.
Problem Description and Classification
We consider the problem of finding a finite sequence of objects of different types, that guarantees an optimal assignment of objects to given physical storage layers with a pre-sorting facility of limited capacity. This problem will be called the Batch Presorting Problem (BPSP), because the objects have to be sorted within one batch before they are assigned to the layers. After sorting, the object with number i will be assigned to layer i . For a more transparent presentation we speak of colors instead of types and thus consider all objects of type k as having the same color k. We present three types of BPSP with different objective functions. The
Online Storage Systems and Transportation Problems
6
objective function, z , of B P S P l minimizes the total number of layers not yet occupied by objects of a certain color k; such objects can be considered as occupying an empty layer (empty w.r.t. to k) at zero cost. Once each layer has an object of a given color, the cost does not change with further additions of that color. If the forgoing is true for all colors, z gives the number of all objects to be distributed minus those already assigned to the layers. In B P S P 2 the objective is to minimize the maximum number of objects of the same color on the same layer. Finally, BPSP3 aims to minimize the sum of the maximum number of objects of the same color over all layers. We use the following example to illustrate the problem:
E X A M P L E2.1 Suppose, there are six objects of two diferent colors i n the input sequence (see Fig. 2.1.1) and three layers. Objects can be sorted within one batch, i.e., the objects I , 2, 3 can be sorted, then they are assigned to the layers. After this the objects 4,5 and 6 can be sorted and assigned t o the layers. Fig. 2.1.1 displays the content of the layers without pre-sorting. For this assignment the objective function value of BPSPl i s 2, because the objects of the first batch occupy the layers at zero cost (layers were empty); the objects 4 and 5 occupy the layers 1 and 2, respectively, each with cost one, and object 6 occupies layer 3 at zero cost. The objective function value of BPSP2 is 2, because the maximal number of objects of any color o n all layers is 2. Finally, the objective function value of BPSP3 is 4 , because the maximal number of objects of the colors 1 and 2 over all layers is 2 for both colors. Clearly, this assignment is not optimal w.r.t. none of the three objective functions. The optimal objective function values for B P S P l , BPSP2, and BPSP3 are 0 , 1, and 2, respectively (see Fig. 2.1.2).
2.2.
Formulation of the Batch Presorting Problem
At first we introduce some notations used in this chapter: w
N o is the number of objects of different colors in a given sequence. These objects are indexed by i or j (for simplicity the positions of the objects are identified by their index values). Sk is the set of objects of color k, and i E Sk means that the object at position i in the sequence (also called "ithobject" or "object in for short) has color k;
w
N K is the number of colors;
w
N~ is the number of layers; N S is the capacity of the pre-sorting facility.
7
Batch Presorting Problems. I
batch 2
batch 1
ma
layer 1
Figure 2.1.1. The input sequence and the content of the storage layers without presorting. On the left part of the figure, the numbers 1, 2, ..., 6 refer to the objects while the numbers 1 and 2 in the squares denote the colors.
batch 2
+
batch 1 layer 1
layer 2
layer 3
Figure 2.1.2. Optimal permutation and content of the storage layers after the assignment
2.2.1
Feasible Permutations
Before we talk about feasible permutations, recall the definition of permutation:
-
D E F I N I T I O 2.2 N A permutation S o n a set of N o objects i s a one-toone mapping of set ( 1 , . . . , N O ) onto itself, i.e., S : { I , .. . , N o ) (1, . . . ,No}. T h u s S ( i ) = j if the object originally positioned at i , i s placed onto position j . In other words, if S is a permutation, S ( i ) denotes the position of object i in the output sequence. In our case, only a subset of all possible permutations can be performed using the pre-sorting facility.' lFor the concrete technical functionality see Chapter 3.
8
Online Storage Systems and Transportation Problems
trays:
layers: Figure 2.2.3.
The set of all possible permutations for N'
=1
THEOREM 2.3 Let N' be the capacity of the pre-sorting facility. A permutation S is realizable, if and only if for each object i , S ( i ) > i - N S . If N o 5 N S then there exist N o ! realizable permutations, otherwise there will be N S ! ( N S + l)"O-"'. Proof. (see, for instance, [39]) Fig. 2.2.3 illustrates the result of Theorem 2.3. Notice, that if N o 5 N' then there exist N o ! realizable permutations and N S ! ( N S l ) N O - N S otherwise. In this work the terms realizable and feasible permutations are equivalent. Now we formally introduce the notion of a feasible permutation.
+
DEFINITION 2.4 A permutation 6 is feasible if for any i = 1, ...,N o
is fulfilled.
2.2.2
Mat hemat ical Formulation of BPSPl
>
As was defined above, only the permutations with S ( i ) i - N' are feasible. Note that only the objects at the permuted positions S ( i ) = j will be placed onto layer I , where 1 = j mod N L , i.e., 1 is a function of j. For example, if N o = 5 , N L = 2, then objects with positions j = 1,3,5 will be placed onto layer 1 = 1, those with positions j = 2,4 onto layer 1 = 2. In addition we introduce the following notations: 1, i f S ( i ) = j 0, otherwise
'
Batch Presorting Problems. I
and
0,
if layer 1, 1 F j modIVL, has already an object of the same color as object i otherwise
(2.2.2) The optimal permutation can be constructed from the solution of the following linear program [39]:
We can interpret the coefficient Cij as the cost of placing object i onto position j (which uniquely identifies layer 1). As (2.2.3) minimizes the total placing cost, it minimizes hence the total number of layers not yet occupied by objects of a certain color k . Such objects can populate an empty layer (empty w.r.t.to k) at zero cost. Infeasible permutations are excluded (depending on NS), a priori by (2.2.6). Obviously, (2.2.6) corresponds to (2.2.1). It is well known that this kind of integer program is totally unimodular (cf. [61]) and, thus, may be solved efficiently by some versions of the Simplex algorithm. Many special matching algorithms solve the problem in polynomial time (cf., [72]). In practical applications (see Chapter 3), the performance very often depends on the number of attempts needed to output completely a set of orders (an order is a set of objects of different types). An attempt is considered successful if there exists at least one object of a given color on each layer (ie., belonging to the requested order). Therefore, for a given set of orders, the number of attempts needed for complete output is the maximum number of objects in these orders found on a single layer. Consider, for instance, the following example: N o = 8, N K = 2 (e.g., blue and yellow), N L = 2, C& = 1 for all i, j (lie., one blue and one yellow object already exist on each layer). Let the first four objects be
10
Online Storage Systems and Transportation Problems
blue and the others yellow. Suppose, BPSPl has two optimal solutions with objective function value 8: 1 Three blue objects are assigned to the first layer and one to the second; one yellow object to the first layer and three to the second.
2 Two objects of each color are assigned to both layers.
+
The numbers of attempts for complete output are 4 4 = 8 in the first case and 3 3 = 6 in the second (see Fig. 2.2.4). In terms of suffi-
+
Figure 2.2.4. layers.
The example of two different assignments of objects to the storage
ciency the second solution is preferable, because it needs fewer attempts for complete output. For practical applications we want to produce a solution with minimal number of attempts. Since BPSPl does not necessarily do so, we developed the following problem formulations. Note that the formulation above does not contain the index k, because the information about the color of objects is hidden in the coefficients Clj. More precise, Clj = Clj(k). Example 2.5 illustrates how the coefficients C'. are constructed. 23
2.2.3
Mat hematical Formulation of BPSP2 and BPSP3
In this section we formulate BPSP2 and BPSP3 as decision problems. Most of the notations used in the previous section will be kept. Analogous to the notation Cij from Section 2.2.2 we use the notation Ckl- the number of objects of color k already present on layer 1. Additionally we define: an integer bound B;
11
Batch Presorting Problems. I
constants 0, otherwise
'
(2.2.8)
1, i f j ~ mod^^ l 0, otherwise.
This allows us to define
Now we can formulate the following decision problems: D-BPSP2: Is there a feasible permutation S such that the maximal cost
does not exceed B? D-BPSP3: Is there a feasible permutation S such that the total cost
does not exceed B? Remark: The term DikjlSij takes the value 1 if an additional object i of color k is placed onto layer 1 by permutation 6. As Ckl denotes the number of objects of color k already present on that layer, the cost C ~ L N_I;:~ Dikjl6ij yields the number of objects after the permuted objects have all been placed in the layers. In other words, D-BPSP2 is the problem of finding a permutation of objects such that the maximal number of objects of the same color on any layer is less than or equal to B for all colors. Thus, for practical applications, the total cost term of D-BPSP2 can be interpreted as a worst-case estimation of the performance and the total cost of D-BPSP3, analogously, represents the average performance over all colors.
+EL:
2.2.3.1 An Optimization Version of BPSP2 Since the objective is to minimize the maximal cost (2.2.11), we now formulate the decision problem as an optimization problem:
12
Online Storage Systems and Transportation Problems
There appears to be no easy way to solve the above problem efficiently. Therefore we transform it to an integer linear programming formulation. The minimax objective function is replaced by an equivalent linear formulation. For this aim new variables are introduced: ur, - the maximal number of objects of color k on any layer, i.e.,
That allows us to define the transformed objective function miny
,
(2.2.14)
subject to additional constraints
Let us make some remarks related to the above constraints: Note that (2.2.14) and (2.2.15) imply the identity y = max {ur,}. k=1,...,NK The inequalities (2.2.16) express that the number of objects of color k already on layer 1 plus a number of objects of color k assigned to this layer cannot be greater than the maximal number ur, of objects of color k on any layer. The assignment constraints (2.2.17)-(2.2.18) determine the permutations of the objects, i.e., each object can take only one position in a new ordering and each new position can be filled only with one object. Depending on N S , certain permutations can be excluded a priori by (2.2.19).
Batch Presorting Problems. I
13
In some situations, when the difference between the number of objects of different orders is very large, it may not be advisable to minimize just the maximum number of objects of this set of orders found on a single layer. Instead, it is more efficient to minimize the total amount of output cycles. We treat this approach in the optimization problem B P S P 3 introduced below. 2.2.3.2 An Optimization Version of BPSP3 The objective function corresponding to (2.2.12) is:
Using the new variables uk (2.2.13), we get: min
C uk
subject to (2.2.16)-(2.2.20). Thus, it can be seen that B P S P 2 and BPSP3 contain B P S P l as a kernel. Unfortunately, the polyhedrons of B P S P 2 and B P S P 3 are not integral and, hence, the complexity issues of these problems are very important. The following section addresses the complexity of B P S P 2 .
E X A M P L E2.5 I n this example we illustrate i n detail the optimization models B P S P l , B P S P 2 , and BPSP3 with possible optimal solutions using the following set of input data: The number of objects, N o , is 6 , the number of colors, N K , is 3. These objects are grouped together in the sets: S1 = {I), S2 = { 2 , 3 , 4 ) , S3 = { 5 , 6 ) . The number of layers, N L , is 3 , and the capacity of the pre-sorting facility is N S = 2. Coeficients reflecting the content of the = 2, C33 = 1, layers have the following values: Cll = 1, Czl = 1, all other Ckl= 0. Fig. 2.2.5 shows the input sequence and the content of the layers before the assignment. B P S P l : For this model the construction of coeficients Ckl is simplified, so we do not need t o calculate the number of objects of color k o n layer 1, but only need to indicate whether layer 1 has a n object of color k (see 2.2.2). Regarding this definition, only the coeficients Cil,Cil,C42,CAI, CA2,Cil, Ci2,Ck3, and C& have value 1.
Online Storage Systems and Transportation Problems
14
Figure 2.2.5. The input sequence and the content of the layers before the assignment
subject t o
64176517652766176627663=0
Sij E { O , l ) ,
I l i , jI 6
7
.
(2.2.24) (2.2.25)
N o w consider BPSP2: (2.2.26)
f2 = min y
subject t o u17u27u3
7
Batch Presorting Problems. I
15
Figure 2.2.6. The input sequence and the content of the layers after the assignment
and (2.2.23)- (2.2.25). BPSP3 : subject to (2.2.23)-(2.2.25) and (2.2.28)-(2.2.30). For all these models, the permutation S = (2,1,3,6,4,5) is optimal. The objective functions f l , f2 and f3 have the values 1, 2 and 4, respectively. Fig. 2.2.6 illustrates this example.
2.3.
Complexity Results
THEOREM 2.6 Problem D-BPSP2 is NP-complete. Proof. It is easy to see that BPSPz E NP, since a nondeterministic algorithm needs only to guess a permutation of the variables and to check in polynomial time whether that permutation satisfies all the given constraints. We proceed by showing that the 3-SAT (3-Satisfiability) problem can be polynomially reduced to BPSP2. Concerning the complexity issues of the 3-SAT problem we refer the reader to [32].Below we give the definition of the Satisfiability problem [64].
DEFINITION 2.7 Let X = { x 1 , x 2 ..., , xn) be a set of n Boolean variables. A literal yi is either a variable xi or its negation Zi. A clause Fj is a disjunction of literals. Let formula F = Fl AF2A... AF, be a conjunction of m clauses. The formula F is satisfiable if and only if there is a truth assignment t : X --t {O,l), which simultaneously satisfies all clauses Fj in F . The Satisfiability problem is the problem to decide for a given instance ( X ,F ) whether there is a truth assignment for X that satisfies F . The 3-SAT problem is a restriction of the Satisfiability problem where each clause contains exactly 3 literals. The 3-SAT problem is still NPcomplete.
Online Storage Systems and Transportation Problems
Figure 2.3.7. The content of the storage before distributing the objects from the sequence seq
For an arbitrary instance (X,F) of the 3-SAT problem we define an instance of the sequencing problem BPSP2, such that there exists a feasible permutation of the objects 6 with
if and only if there is a truth assignment t : X + {0,1) satisfying F. We choose B = 3 and NS = 1 (ie., an object can move forward at most by one position). The number of layers is N L := 2 ( m + 1) the number of objects is No :=2nNL and the number of sets Sk is
Specifically, we have
,
(2.3.1)
Batch Presorting Problems. I
kf , one for each variable xi,
w
2n colors ,k:
w
rn colors
w
the first group of m n auxiliary colors kgF, and
kjF, one for each clause Fj,
the second group of m n auxiliary colors
GF.
The sequence seq consists of 2n subsequent parts seqi of N~ objects each, i.e., seq := (seql, seq2, ..., seq,, seqn+l, seqn+2, ..., seq2,). Each seqi has , qi,zrn+2).NOWwe define the 2(m 1) objects, i. e., seqi := ( q ~q ,i ~..., sets Sk,i.e., the color of each object contained in the sequence seqi : the first and last objects of seqzi-1 and seqzi always have the colors of the variable xi7 ie.,
+
The colors of the 2m objects in between are defined depending on the occurrence of variable xi in the clauses Fj as follows:
The values of the cost function Ckl (which reflects the content of the storage) are defined for any {k, 1) as:
18
Online Storage Systems and Transportation Problems
Fig. 2.3.7 illustrates these coefficients for an example with n = 3 and m = 2. In the remaining part of the proof we show that a feasible permutation of the objects in seq with
exists if and only if F is satisfiable, i.e., there is a truth assignment t : X + {0,1) that satisfies each clause in F. First, we assume that F is satisfiable. We show that there exists a feasible permutation of objects with no more than 3 objects of the same color on any layer. Recall that: for each color kf there are already exactly three objects on each of the layers 2, ...,NL-2, N L , two objects on each of the layers 1,N ~ - 1 , one object in seqai-1 and one object in seq2i; w
for each color k r there is one object on layer 2 j exactly three objects in seq;
-
1 and there are
for each color kGF, k c F there exist at most two objects in seq; for each color k: only two objects exist in seqi. Now consider the first object of subsequence seqzi-1. This object has color k f . It has to be sent to layer N L - 1 or has to remain on the first layer, because all other layers already contain three objects of this color. The layers 1 and N~ - 1 already contain two objects of color k? and can accommodate only one additional object each. Therefore, the second object of color kf - the first object of seq2i - has to be sent to the layer not used by the first object. This will be done by moving the objects to the nearest layer (i.e., move of minimal distance), such that for any j E seqi the following holds: S(j) E seqi. That means we can discuss each subsequence independently. We will use this alternation to map the truth assignments into the permutations set S:
19
Batch Presorting Problems. I
In this way, if t assigns 1 to xi, then from (2.3.12) the first object of seqzi-1 moves to layer N L - 1, and all other objects in seq2i-1 move one layer up (except for the last object which remains on the last layer). All objects of seq2i keep their positions. Otherwise, if t assigns 0 to xi, then it follows from (2.3.13) that all objects from seqzi-1 keep their positions and the first object of seqzi moves to the layer N L - 1. All other objects in seq2i move one layer up (except for the last object which remains on the last layer). Assume there is a layer 1 with four or more objects of the-same color. Let us first discuss the color. It cannot be one of kcF, ,kcF, k t since there are at most two of those and Ckl is zero for them. Without loss of on layer 1. generality we assume that there are four objects of color Since ( S pI = 3, CkF must be 1 and because of (2.3.10) it follows that 1 = 1 3 ' 2 j - 1. Now consider one of the three objects. From (2.3.6) and (2.3.7) it is known that Sky c {q2i,2j,q2i-lj2j}. We distinguish two cases: Case 1:
icf
Case 2:
Therefore, in both cases the truth value of the literal of xi in Fj is false, so Fj contains one false literal. The same reasoning holds for the other two objects. Thus, Fj contains three false literals and is therefore false itself. This is a contradiction to the assumption that t satisfies (X, F ) . For the missing direction of the proof, we assume that (X, F) is unsatisfiable. Our goal is to prove that for any permutation 6 there exists at least one color for which four objects are located on the same layer. Barring trivial cases, that will be color Consider the permutations where 6(q2i,1) = 1 mod N~ with 2 5 1 < N L - 1 or 1 = N L , i.e., when the first object of subsequence 2i is not moved to the first or last-but-one layer. Because of (2.3.9) Ckx,l= 3, layer 1 contains four objects of color k f . Therefore we only need to consider the remaining cases, i.e., when the first object moved to the first or to the next to last layer.
icf.
20
Online Storage Systems and Transportation Problems
With the same reasoning we can assume that S(qzi-l,l) So we only deal with cases where
S(q2i11)E -1 mod N L and S(q2iel,l) = 1mod N L
E f1mod N L .
.
(2.3.19)
-
Let us define a truth assignment t6 by t(xi) =
1 if S(q2i,l)= 1mod N~ 0 if S ( q z i ~ ) -1 mod N L
Furthermore, (2.2.1) tells us that S(j) 2 j - 1 as NS = 1by construction. Since (X,F) is unsatisfiable by assumption, there must be some clause Fj which is not satisfied by ts. Case 1: Fj contains a non-negated literal xi. Then t6(xi) = 0 and from (2.3.20) we know, that S(qzi,~) = -1 mod N L and from (2.3.19) that S(qzi-l,l) E 1mod NL. Because S(q2ill)2 q2i,l 1 OmodNL, SO S(qzi,l) 2 q2i,l N L - 2 since S(k) > k - 2, i e . , the tray qzi,l stays in the additional storage at least until N L - 2 objects k 1 for 2 5 k 5 N L - 1, especially passed. Therefore, S(qzi,k) = ~ i , for k = 2j. From (2.3.6) we know that q2i,2j E SkF,hence there is one
-
+
J
additional object of color kf' in layer 2 j - 1. Case 2: Fj contains a negated literal ?ti. Then ts(xi) = 1 and from (2.3.20) we know that S(q2i,1)E 1mod N L and from (2.3.18) that S(qai-l,l) E -1 mod NL. As in the first case, we conclude that S(qzi-1,l) 2 q2i-l,l+ N L - 2 and, therefore, it follows that S(q2i-1,zj) = q2i-1,2j - 1 2 j - 1mod N L . Since (2.3.7) qzi-l,zj E SkF 3 there is an additional object of color k: on layer 2 j - 1. Hence, for each of the three literals of Fj there is one object of color k$ on layer 2 j - 1 and C z j P l k ~= 1 according to (2.3.10). Therefore, ' 3 layer 2 j - 1 contains four objects of color k r and the proof is complete. To see that this transformation can be performed in polynomial time, it suffices to observe that the number of layers, the number of colors and the number of objects in seq are bounded by a polynomial in 2(m I ) , 4n(m 1) and 2n m 2mn, respectively. Hence the size of the BPSP2 instance is bounded above by a polynomial function of the size of the 3-SAT instance (q.e.d). W We illustrate Theorem 2.6 by the following example.
--
+
+ +
+
EXAMPLE 2.8 Suppose there is the following instance of the 3-SAT problem: F = (XIv x 2 v x 3 )A (?tlV X ~ V Z ~ i)e, . , n = 3 and m = 2. Now define
21
Batch Presorting Problems. I
all data needed for constructing the sequence seq. B y (2.3.1)-(2.3.3) we obtain N~ = 6, No = 36, and the number of sets Sk is N~ = 20, i.e.,
Fig. 2.3.7 shows the content of the storage system w.r.t. formulas (2.3.9) and (2.3.10) before the objects from seq are distributed. Fig. 2.3.8 shows the sequence seq = (seql, seq2, ...,seq6). I n addition, this picture illustrates the assignments, e.g., for X I , described by formulas (2.3.12) and (2.3.13) and the subsequent assignment t o the layers. Similar transformations apply to the sequences seqs, seqd, seqs, seq6 (the first two correspond to x2, the others to 23).
2.4.
Polynomial Subcases
The decision problem D-BPSP2 is shown to be NP-complete (see Section 2.3). What makes this problem difficult? In this section we consider the problem with some additional assumptions. The first assumption is that the numbers of elements in sets S k , i. e., values ISk 1 , are known in advance. The second one is that the capacity of the pre-sorting facility is large enough, i.e., given N' 2 N L - 1, any permutation of objects can be realized. This assumption is only needed for an alternative model formulation provided in Subsection 2.4.2.
2.4.1
Reformulation of BPSP2 and BPSP3
In Section 2.2.3.2 we suggested model formulations with continuous variables u k . We can decrease the number of variables if the values of /Ski,the number of objects of color k in the input sequence, are known in advance. Clearly, the optimal permutation of the objects is one that allows a uniform distribution of objects over all layers. Of course, we need to add to the value ISk I all objects of color k that are already in the layers
c E ~Ckl.It can happen that l=1,rnax ...,
NL
Ckl > [lsk+'~:
we have to calculate values Si = max
(1
. Therefore,
NL
1
~ k l + ~ tc k ~l _ ~
rnax ~ ~ 1 1=1,...,NL Thus, the corresponding objective function value for BPSP3 is N~ u k = ~f=: Si and the equality max ak = rnax Si holds for BPSP2. k 1 , ...,NK k=1,...,NK Then we can modify the optimization models from Section 2.2.3.2 and obtain the transformed model: N~
)
) .
22
Online Storage Systems and Transportation Problems
This is not yet an optimization problem since only a feasible point of (2.4.1)-(2.4.5) need to be found. If the capacity of the pre-sorting facility is not large enough, the feasible set can be empty.
EXAMPLE 2.9 Here we demonstrate the calculation of S$ values o n the data from Example 2.5:
2.4.2
An Alternative Model Formulation of D-BPSP/
In the following we show that D-BPSP~without (2.4.4) is polynomially solvable. At first, we present another mathematical model formulation named D - BPSPI with the following integer variables: xk1 is the number of objects of color k on layer
1
.
Notice that these variables can be derived easily from the Sij variables:
Batch Presorting Problems. I
23
Suppose N O = p ~ L where , p E Z. Then the decision problem D-BPSP' concerns whether an assignment exists for xkl satisfying the constraints:
After that we show the correspondence between D-BPSPI and D-BPSP/ by demonstration that a solution of the first problem implies a solution of the second one and vice versa.
are THEOREM2.10 Problems D-BPSPI (without 2.4.4) and D-BPSPI equivalent. Proof. W e show that if there is a solution of D-BPSPI 6ij E ( 0 , I ) , i, j N O that satisfies (2.4.1)-(2.4.3), then the solution xkl of 1
<
D-BPSPI
<
satisfies (2.4.7)-(2.4.9), and vice versa.
3:-The constraints (2.4.3) and (2.4.9) are the same. Indeed,
Online Storage Systems and Transportation Problems
24
E X A M P L E2.11 Here we illustrate how to convert a solution of D-BPSPI to a solution of D-BPSPI. Consider the input sequence and sets
from Example 2.5. Suppose a solution of D-BPSPI
to be:
W e construct the solution Sij of D-BPSPI as follows: For all k = 1 , ..., N K , 1 = 1 , ...,N L set initially cr, := 1 and il := 0 . T h e n repeat the following steps while xkl 2 1: l e t i * := i,,, := 1
cl~:= ck
+ 1;
+ i l ~ L il, := i l + 1;
H
let j*
w
let Spj* := 1 and xkl := xkl - 1.
Using this procedure for N K = 3 and N L = 3 we obtain the solution: S = ( 2 , 1 , 3 , 6 , 5 , 4 ) . Notice that this permutation yields the same assignment to the layers as in Example 2.5. B u t i t is not feasible there, because the capacity of the pre-sorting facility is not large enough. Let us now show that the problem D-BPSP/ is polynomially solvable. We use the following results from [61].
THEOREM 2.12 ([61], Part III. 1 "Totally unimodular matrices ") Let A be a ( 0 , 1 , -1) matrix with n o more than two nonzero elements in each column. T h e n A is totally unimodular i f l the rows of A can be partitioned into two subsets A' and A2 such that i f a column contains two nonzero elements, the following statements are true: 1 If both nonzero elements have the same sign, then one is i n a row contained in A' and the other is i n a row contained in A2.
2 If the two nonzero elements have opposite sign, then both are in rows contained in the same subset. THEOREM 2.13 ([61], Part III. 1 "Totally unimodular matrices ") If A is totally unimodular, if b, b', d and d'are integral, and if P ( b , b', d , dl) =
25
Batch Presorting Problems. I
{x E Rn : b' 5 Ax 5 b, a n integral polyhedron.
d' 5
x 5 d)
i s not empty, t h e n P ( b , b', d , d') i s
T H E O R E2.14 M The problem D-BPSP' is polynomially solvable. Proof. W e re-write (2.4.7)- (2.4.9) as:
where
and
A t first, notice that the matrix A i s totally unimodular: B y Theorem 2.12, the matrix A i s partitioned into two subsets (2.4.12), and each subset contains exactly one nonzero element of the same sign in each column. Secondly, the polyhedron of (2.4.1 O)-(,$?.4.ll) i s integral by Theorem 2.13: b' = b = S&K+NL, d' = 0 , d = S;KNL are integral, and obviously, the system of linear inequalities (2.4.10)-(2.4.11) always has a solution. And again from [61] it is well known that such problems are polynomially solvable (q.e.d).
.
2.5.
The Case of Two Layers
In this section we analyze the BPSP with N~ = 2. We show that in this case the BPSP is polynomially solvable, and construct corresponding polynomial algorithms.
Online Storage Systems and Transportation Problems
26
2.5.1
Offline Situations
In offline situations we know the arrival sequence of the N O objects in advance. Consequently, the number ISk\ of objects of type k is also known. It is obvious that the best solution is to assign half of objects of each type to layer 1 and the other half to layer 2. If ISk[is even, then there are exactly objects of the type k on each layer, otherwise there can be no more than function value is
191objects. Thus, the optimal objective
where uk represents the maximal number of objects of type k over all layers (we use the objective function for BPSP3). Without loss of generality we assume that N O is even. The assignment of the objects can be realized as follows. We group each pair of two consecutive objects so that the whole sequence is divided into $ pairs. Let C = {PI,P2, ...,P& } L
be a list of these pairs. Obviously, in each pair only two types are presented, kl and k2. Assume that in each pair Pi in C the first object with number (2i - 1) has type kl and the second object with number 2i belongs to type kz. For each type k we define two functions: p[k], that provides us with information about the objects assigned so far. This function takes values depending on the relation between the numbers of objects of type k on the first and second layer (MLl and &IL2,respectively), i. e.,
PP]=
M L (k) ~ = M L (k) ~ 0, M L (k) ~ = M L (k) ~ 1, M L (k) ~ = M L (k) ~
- 1,
+1 +1
,
d [ k ] , that gives the number of objects of type k which are already assigned to the layers. Algorithm Dl generates an assignment with the optimal objective function value for (2.5.1). The decision variables are defined in the following way:
1, if object number i is assigned to position number j 0, otherwise The algorithm starts with the first pair of C and Sij := 0 for all i and j . The objects from this first pair have types kl and k2, respectively.
27
Batch Presorting Problems. I
Let the object of type kl go to the first layer, and the object of type k2 to the second. We save this assignment in p[kl] and p[k2]and delete this pair from C. Then we choose the next pair according to the rule described in Step 4. The next time an object of type kl appears in a pair, we assign it to layer 2, and the other object of this pair to layer 1. We proceed as long as there are elements left over in C. Algorithm Dl Steps of the algorithm: 1 Generate the list of pairs of objects C = {Pi,7'2, ...,P,o -). 2
2 Calculate p[k] for every k; If all p[k] = 0 then goto Step 3, else goto Step 4.
3 Take the first element Pi from C; Determine the types kl and k2 of objects 2i - 1, 2i, respectively; Goto Step 6.
4 Take the first element Pi from C for which the following condition holds: p[kl] # 0 or p[kz] # 0 or both, where kl and k2 are the types of the objects 2i - 1 and 2i, respectively. +1, -1,
0,
then goto Step 6, then goto Step 7, then goto Step 8.
6 Assign S2i-l,2i := S2i,2i-1:= 1, i. e., change the order of objects; Goto Step 9. 7 Assign: S2i-1,2i-1 := S2i,2i:= 1, i. e., keep the order of objects; Goto Step 9. If '[lc2]
=
{
+1, -1,
then goto Step 7, then goto Step 6.
9 Change p[kl] and p[k2] correspondingly to the assignment on Step 6 or Step 7; Delete Pi from C, goto Step 2. Note that the above algorithm does not consider the cases p[kl] = p[k2] = 1 and p[kl] = p[k2]= - 1. As the following lemma shows, these cases do not occur.
Online Storage Systems and Transportation Problems
28
L E M M A2.15 After completing each step of algorithm Dl the following holds: for any n such that E .C and for any type k there exist at most two p [ k ] # 0. If 3 k l , k2 : p [ k l ] # 0 , p[k2] # 0 , t h e n either ~ [ k l=] 1 and p[k2]= -1, o r p [ k l ] = -1 and p[kz] = 1 , and, additionally, for all k # k l , k # k2 : p [ k ]= 0 . Pro0f: NO Proof. We prove by induction over n = 1 , ..., T. n = 1. This means that we start with the objects with number 1 and 2 and p[k] = 0 , k = 1, ...,N ~ . Consider the following cases:
1 Suppose the objects have different types. Let 1 E Sk,, 2 E Sk2 (the case 2 E Sk,, 1 E Sk2is analogous). The first object goes to the first layer, i.e., we assign p [ k l ] := 1 in Step 8 , the second one goes to the second layer, i. e., we assign p[k2] := -1 in Step 8. All other values p [ k ] remain unchanged, i.e., p [ k ] = 0 , k # k l , k2. 2 Suppose both objects have the same type. Let 1 , 2 E Sk, (the case 1 , 2 E Sk2is analogous). After Step 8: p [ k l ] = 0 1 - 1 = 0. All other values p[k] are left unchanged, i.e., p [ k ] = 0 , k # k l . So, we have p [ k ] = 0 for any k .
+
Thus, for n = 1 the statement is true. Now let us consider the induction step. Suppose the assumption is true for n - 1. Let us evaluate p[k] for the case n:
1 The objects have different types k l and k2. Depending on step n - 1 there are the following six possibilities: a
p[kl] = 1; p [ k ] = 0 , k # k l . After Step 8: p [ k l ] = 1 - 1 = 0 ; p[kz] = O f 1 = 1; ~ [ k=] 0 , k
# k2;
p [ k l ] = -1; p[k] = 0 , k # k l . After Step 8: p [ k l ] = -1 1 = 0 ; p[k2] = 0 - 1 = -1; p [ k ] = 0 , k # k2; a p [ k l ] = 1 , p[k2] = -1; p [ k ] = 0 , k # h , k 2 . After Step 8: p [ k l ] = 1 - 1 = 0 ; p[kz] = -1 1 = 0 ; SO, b'k : P [ ~ I = 0; a p [ k l ] = -1, p[k2] = 1; p [ k ] = 0 , k # k i , k 2 . After Step 8: p [ k l ] = -1 1 = 0 ; ~ [ k z=] 1 - 1 = 0 ; p [ k ] = 0 ; SO, b'k : p [ k ] = 0 ;
+
+
+
a p [ k l ] = 1 , 3k3 : p[ks]= -1; p[kz] = 0 ; p[k] = 0 ,
# h , k # k3-
29
Batch Presorting Problems. I
w
After Step 8: p[kl] = 1 - 1 = 0 ; p[k2] = 0+ 1 = 1; p[ks] = -1 +O = -1; p[k]= 0 , k # k2, k # ks; p [ k l ]= - I , 3 k 3 : p [ k s ]= l ; p [ k z ]= O ; p [ k ] = O ,k # h , k # k s . After Step 8: p [ k l ] = -1 1 = 0 ; p[k2] = 0 - 1 = -1; ~ [ k s=] I + O = 1; p[k] = 0 , k # k2, k # k3.
+
These variants are symmetric with respect to kl and k z in the sense that we can replace kl by k2 and vice versa. So, one can see that in any case we have no more then two values k with p[k] # 0. If we have exactly two such k , p [ k l ] and p[k2]have different signs.
2 Both objects have the same type k l . Depending on the previous information during step n there are four possibilities: w
p[kl] = 1; p[k] = 0 , k # k l . After Step 8: p[k1] = 1 - 1 1 = 1; p[k] = 0 , k # k ~ ; p[kl] = -1; p[k]= 0 , k # k l . After Step 8: p [ k l ] = -1 1 - 1 = -1; p[k] = 0 , k # k l ;
+
+
p[kl] = 1, p[k2]= -1; p[k]= 0 , k # k l , k # k2. After Step 8: p [ k l ]= 1 - 1 1 = 1; p[kz]= -1 0 = -1; p[k] = 0 , k # k l , k # k2; p[kl] = -1, p[kz]= 1; p[k]= 0 , k # k l , # k2. After Step 8: p [ k l ]= -1 1 - 1 = -1; p[k2]= 1 +O = 1; ~ [ k=]0 , k # k l , k # k2.
+
+
+
Again, these variants are symmetric with respect to kl and k z . Thus, in any case we have no more then two k : p[k] # 0 . In case we have exactly two k , p[kl] and p[kz]have different signs (q.e.d). The following theorem ensures that the algorithm Dl finds an optimal solution in polynomial time.
T H E O R E2.16 M Algorithm Dl constructs a n optimal solution in polynomial time. Proof. The optimality of the generated assignment follows directly from algorithm Dl and the lemma above, because we always assign the objects in such a way that one half of the objects of type k is assigned to section 1 and the second half to section 2. This is possible as long as we have the pre-sorting facility of capacity one. Let us see how m a n y operations are necessary to construct the optimal solution. All steps of algorithm Dl times, because each time we delete one element are repeated at most
30
Online Storage Systems and Transportation Problems
+
from C. Initially, C contains elements. I n order to check if i E Sk we need n o more than N K operations. Checking if all p[k] = 0 requires also N K operations. And finally, Step 3 can be repeated at most - 3 times, because i has a value at least two before the step. So, in total there are o(NO, N K ) = ~ ( N + KN K + P - 3) = E Y + N O N K - 3NO. 2 4 2 one can see it is polynomial in the number of objects N o as well as in the number of types N K (q.e.d).
2.5.2
Online Situations
In the following we present an online algorithm that is linear in No and N K . It is, therefore, much faster than the offline algorithm D l . The sequence of objects appears in pairs: 'PI, l3,.. . , When we assign layers for the objects from 'Pi, the online algorithm does not have any knowledge of 'Pj, j > i. Only after % has been served, the next pair Pi+l becomes known. In total there are N o objects. Without loss of generality, N o is assumed to be even. We group two consecutively objects into N O pairs. Obviously, in each pair of objects there are no more than two types kl and k z . Let Ckl specify the number of objects of type k already assigned to the layer 1. Algorithm D2 NO For i := 1 to 7 do: 1 Determine types kl and k2 of the objects 2i
2 If ( h = k2) or (Ckll = Ck,z) and else goto Step 3. 3 If (Ckll > C k 1 2 ) Or else goto Step 4.
(Ckll = C k 1 2
-
1, 2i respectively.
( C k 2 1 = C k 2 2 ) , then
and
Ck22
goto Step 4 ,
> C k 2 1 ) , then goto Step 5,
4 Assign Szi-1,2i-1 := Szi,2i := 1, i. e., keep the order of objects unchanged; Goto Step 6. 5 Assign S2i-l,2i := S2i,2i-1 := 1, i.e., change the order of objects; Goto Step 6.
6 Change C k l l ,Cklz,CkZ1and Ckz2with respect to the assignment. End For.
THEOREM 2.17 The algorithm D2 finds the best online solution in polynomial time.
Batch Presorting Problems. I N Proof. W e prove the theorem by induction over n = 1, ...,p. n = 1 , i.e, C i = O , k = l , ..., N ~ . NK
C U ; = C rnax{CEl + C
+
NK
Jil; Ci2 C 6i2) k=l k=l iEsk iEsk Consider the following cases: 1. Both objects have the same type: {1,2) C_ Ski.
f 1(u) =
NK
fl(U) =
C u;=
k=l
NK
+ i€Sk C Sil; Ci2 + C 6i2)
C max{Cil k=l = max{cjll =
i€Sk
+ &Sk, C fiil;CE12 + C
fii2)
iESkl
+max{Ci21+
C
6i1;Ciz2+ C-622)
iESlcZ
iESkZ
+ 611 + 621; Cil2 + 612 + 622) + r n a ~ { CC222) ~~~; + 621; 612 + 622) = 1,
= max{Cgll
= max{611
Therefore, the objective function value is 1, independent of how we permute the objects. Only one and exactly one element of the sums 611 621 and 612 622 has to be equal t o 1. Consequently, Sll S12 = 621 622 = 1. 2. The case {1,2) S k , is analogous t o Case 1. 3. The objects have diflerent types: (1) C_ Ski, (2) C Sk2(kl # k2).
+ +
+
+
NK
f1(4 =
C u;
k=l
NK
+ C 6i1; Ci2 + && C 6i2) + i GCk 1fiil;Ci12+ C 6i2)
C max{Ci1 k=l = max{CjI1 =
2€Sk
iESkl
+
= rnax{~:~,
+
+
+
+
611; Ci12 612) max{Ci21 621; CiZ2 622) 612) rnax{&l; 622) = 1 1 = 2. Therefore, the objective function value is 2, independent of how we permute the objects. Only one and exactly one element of the pairs (611; 612) has to be equal 1. Consequently, and ISzl; = max{Sll;
4.
+
+
The case (2) E Ski, (1) C Skzis symmetric to Case 3.
32
Online Storage Systems and Transportation Problems
Thus, for n = 1 we get the minimal objective function value. Now consider the induction step. Suppose, the assumption is true for n - 1. Let us now analyze the case n. Again, we have t o consider several cases: 1. Both objects are of the same type: { 2 n - 1, 2 n ) C Ski. NK
f n ( 4 = k=l C
= fn-I(.)
.;
+ 1.
The objective function value increases by 1, independent of the permutation of the objects. Cf. Case 1 in the initial step of the induction. 2. The case ( 2 n - 1 , 2 n ) Sk2 is analogous t o Case 1. 3. The objects have diflerent types: ( 2 n - 1 ) S Ski, { 2 n ) 2 S k , .
c
Batch Presorting Problems. I
33
I n this case the objective function value depends o n the permutation of the objects. Consider all possible combinations and calculate the objective function value after changing the order of the objects, o r if the order of objects was kept:
1
Changing the order implies 62n-1,2n := S2n,zn-1 := 1; Note that algorithm Dz assigns the values to the decision variables in such a way that the objective function i s minimized, i.e., the value for fn(u) is minimal as long as fn-'(u) i s minimal (assumption of the induction step). 4. The case ( 2 n ) Sk,, ( 2 n - 1) Sk, i s symmetric t o Case 3. Thus, instead of keeping we need to change the order of the objects. This is what algorithm D2 does. Let u s now see how m a n y operations are necessary to construct the optimal solution. For checking if i E Sk we need no more than N" operations, since in the worst case the set Skcan contain all input objects. times. Thus, in total we have o(N') = Steps I to 6 are repeated $ N K . A s one can see, it i s polynomial with respect t o the number of objects N O as well as to the number of types N K (q.e.d). W
c
2.5.3
Algorithms for Online Situations with Lookahead
2.5.3.1 Definition of a Lookahead Very often the knowledge of future requests would help to improve the objective function value and to construct more efficient algorithms. Such situations will be referred as situations with lookahead. In recent years, a lot of problems with lookahead have been studied (paging problems, bin packing problems, graph problems and so on). It was expected that knowing a lookahead will improve the solution for the BPSP as well. The reason is the following: suppose we have the input sequence described in Example 2.23. Obviously, in this case, if we knew the third pair while
Online Storage Systems and Transportation Problems
34
serving the second - we will obtain a better solution. So, in this section we describe algorithms with lookahead for the BPSP with N~ = 2 (later we make a brief comparative analysis of algorithms with lookahead and without). Formal definitions of lookahead can be found in [3], [38]. In this book we use the simplified definitions given in [29]:
DEFINITION 2.18 Weak lookahead with respect to the number of requests ( W L N R ) The online algorithm sees the present request at time t and the next X - 1 succeeding requests. Request t X i s not seen by the algorithm at time t . However, once the request S ( t ) is processed, a new request, i.e., S ( t + A), becomes known.
+
DEFINITION 2.19 Strong lookahead with respect to the number of requests ( S L N R ) T h e online algorithm sees X present requests at time t , and before all these are processed n o new request becomes known. In our case, we consider a lookahead containing not simple requests (objects), but pairs of objects, i.e., we say that the size of the lookahead is X = n if the algorithm sees the present pair at time t and sees and considers n succeeding pairs. 2.5.3.2 An Algorithm with a Weak Lookahead, size X = 1 The idea of this algorithm is quite simple: the sequence of objects is represented in pairs as was described above (for algorithm Dz). At the time we have to serve the current pair Pi, also objects from pair Pi+lare known. It means there are four objects (two in each pair) and there are four possibilities to permute the objects: to keep the order of objects in both pairs, to change the order in both pairs and to keep the order of objects in one pair, changing the order in the second one. Then, depending on the values of the evaluated objective function z = Ckl,we realize the most efficient (tis minimal) permutation on objects from the current pair Pi. Next we consider the following pair of objects, Pi+l,and produce the same calculations. For the last pair, PNo, - we take the decision based on the previous assignment.
c:=:E E ~ 2
Algorithm WL1 Initialize i := 1.
1 Determine the types kl and k2 of the objects 2i - 1, 24 respectively. 2 If i
< $, then goto Step 3, else goto Step 5 .
3 Determine the types l1 and l 2 of the objects 2if1, 2i+2, respectively;
Batch Presorting Problems. I
Goto Step 4.
4 If kl
# L1, 12
and k2 # 11, 12, then goto Step 5 , else goto Step 6.
5 For the current i, kl and k2 apply Steps 2-6 of algorithm D2;
If i = $, then STOP, otherwise Goto 15. 6 Assign temporarily S2i-l,2i-l := S2i,2i := 1, S2i+1,2i+l := S2i+2,2i+2 := 1, i.e., keep the order of both: the first pair of objects and the second pair of objects.
7 Calculate the value of S; = C C C M . k
1
8 Assign temporarily S2i-1,2i-1 := S2i,2i := 1, S2i+1,2i+2 := S2i+2,2i+l := 1, i.e., keep the order of objects for the first pair and change the order of objects for the second pair. 9 Calculate the value of
SE = C C CkI. k
1
10 Assign temporarily S2i-l,2i := S2i,2i-1 := 1, S2i+1,2i+l := S2i+2,2i+2 := 1, i.e., keep the order of objects for the second pair and change the order of objects for the first pair. 11 Calculate the value of
sg = C C Ckl. k
1
12 Assign temporarily S2i-1,2i := S2i,2i-1 := 1, S2i+1,2i+2 := S2i+2,2i+l := 1 , i e . , to change the order of both: the first pair of objects and the second pair of objects. 1 3 Calculate the value of
s~C = C C ~ I . k 1
14 Compare the values of s$,S& S$, s g . If SE or S$ has the minimal value, then finally assign S2i-l,2i-l := Szi,2i := 1, otherwise assign S 2 i - l J i := S2i,2i-1 := 1. 15 i := i
+ 1;
Goto Step 1.
>
2.5.3.3 2 Algorithms with a Weak Lookahead, size X If we have a lookahead of size X 1 2 there are two different strategies to handle the rest of the input sequence with number of pairs in lookahead less or equal than A. The first possibility: when we consider pair 7+,, such that X = - i to run the offline algorithm Dl for the rest of the sequence (algorithm W L ~ ) the ; second possibility: to serve each
36
Online Storage Systems and Transportation Problems
individual pair separately irrespective of how many pairs are left in the lookahead (algorithm W L ~. ) Algorithm W L ~ 1 For i := 1 to
NO
do:
2 If X = -i then apply the offline algorithm D l to the input sequence Pi, ...,Pi+x and STOP, else goto the next step. 3 Call algorithm D l with Pi+l,
...,Pi+xas input sequence.
4 Assign temporarily S2i-l,2i-l objects in Pi unchanged.
:=
S2i12i:= 1, ie., keep the order of
5 Calculate the value of SK = C C Ckl. k
1
6 Assign temporarily S2i-l12i := S2i12i-1 := 1, i.e., change the order of objects in Pi.
7 Calculate the value of Sc = C C Ckl. k
I
8 If SK < SC then assign constantly S2i-l,2i-l := S2i,2i := 1, else assign constantly S2i-1,2i := S2i,2i-1 := 1. End For. Algorithm W L ~ For i := 1 to If X
< ($
NO
- i),
do: then goto Step 2, else goto Step 3.
Apply algorithm D l to the input sequence Pi+l, ...,Pi+x and goto Step 6. If
-
i = 0, then goto Step 4, else goto Step 5.
Apply algorithm D 2 to the last pair Pi and STOP. Apply algorithm D l to the input sequence F'i+l, ...,P,o - and goto 2
Step 6. Assign temporarily S2i-l,2i-l := S2i,2i := 1, i. e., keep the order of objects in Pi unchanged. Calculate the value of SK = C C Ckl. k
1
37
Batch Presorting Problems. I
8 Assign temporary S2i-l,2i := S2i,2i-1 := 1, i.e., change the order of objects in Pi. 9 Calculate the value of Sc = C C Ckl. k
I
10 If SK < Sc then finally assign S2i-l,2i-l := S z i p := 1, else assign S2i-1,2i := S2i,2i-1 := 1. End For.
An Algorithm with a Strong Lookahead In the following we present an online algorithm with strong lookahead of size A. It means that at the beginning pairs P I , ...,f i are known, after serving them pairs PA+l, ...,P2x become known, and so on. Therefore, we divide the input sequence into q := N O groups and operate with each group individually. Algorithm SLA For i := 1 to q do: ...,Pix. Apply the offline algorithm Dl to the input sequence P(i-l)x+l, End For. 2.5.3.4
[-);-I
2.5.4
Competitive Analysis
The efficiency of online algorithms can be evaluated using competitive analysis, where online algorithms are compared with an optimal offline algorithm. First we collect some definitions and terms used throughout this chapter. One basic concept used for estimating the performance of online algorithms is the competitive ratio. The competitive ratio of an online algorithm can be defined with respect to an optimal offline algorithm, which knows an input sequence in advance and produces an optimal solution with minimal cost. Let A be an online algorithm, S is an input sequence of requests and f A ( S ) is the cost achieved by A on the input sequence 6. Denote by f o P T ( S ) the cost achieved by an optimal offline algorithm OPT on the same input. Now we can give the definition of the competitive ratio of the online algorithm A.
DEFINITION 2.20 ( [ l l ] ) A n online algorithm A is c-competitive if there is a constant a such that for all finite input sequences 6,
W h e n for the additive constant a 5 0 holds, we m a y say for emphasis that A is strictly c- competitive.
Online Storage Systems and Transportation Problems
38
In the following the competitiveness of the algorithms from Section 2.5 is analyzed. We will show that algorithm D 2 is strictly $ - competitive. To do this we have to prove the following two lemmas.
LEMMA2.21 A n y online algorithm which solves the given sequencing problem is strictly N L - competitive, where N L is the number of layers. Proof. T h e objective function has the largest value if all objects of the same type are assigned to the same layer. Thus, the m a x i m u m number, u k , of objects of type k in any layer i s I S k I . Evaluate the objective function value: f ( u )=
NK
NK
k=l
k=l
C ur, = C
ISk[.Clearly, the corresponding optimal NK
NK
o f l i n e objective function value i s fDl ( u )= that for all k :
=0
C ur, = C 1 5 1. Suppose,
rNL] k=l
mod N L , t h e n !id I
such that lSkl 1 ( 1 , . . . ,N L
-
I
1 ) mod N L , then
k=l
-
NL.
If there exists k
1 9 1> 9and
This implies that the competitive ratio i s N L (q.e.d).
.
Consider a situation with only two layers, i. e., N L = 2. Then the following lemma holds.
LEMMA2.22 If a n algorithm A i s a c-competitive online algorithm, then $ 5 c 5 2. Proof. From Lemma 2.21 with N L = 2 we conclude that the upper bound for c i s 2. W e show that c cannot be less than $. For any positive = 2 for all integer number G we define K := 4 G , N := 8 G and k = 1,.. . ,N K , i.e., we only have two objects of each type. Consider the following input sequence S = S1S2... SG, where Sg ( g = 1 , . . . ,G ) consists of eight elements. Sg = ( 8 g - 7, . . . ,8g - 4,8g - 3 , . . . ,891. Let 8g - 7 E S4g-3;8g - 6 E S d g - 2 ; 8g - 5 E S4g-l; 8g - 4 E S4g. Define the types for the next four objects ( 8 9 - 3 , . . . , 8 g ) depending o n how algorithm A operates. A n y online algorithm (with the same number of known objects) gets the input sequence of objects in pairs. T h e algorithm has to decide whether to keep the order of objects or to change it. If the algorithm keeps the order, the first object goes to the first layer, the second one to the second. Otherwise, the first object is sent t o the second
Batch Presorting Problems. I
39
layer, and the second one t o the first layer. Hence, after serving the first two pairs (89 - 7,89 - 6) and (89 - 5,8g - 4) we can get four cases (see Table 2.1) and depending o n the decision we can construct the next two pairs of objects: (89 - 3,8g - 2) and (89 - 1,89) for Sg (see Table 2.2): Table 2.1: Results sequences after running the algorithm A
T h e n an algorithm has to serve the next 2 pairs: (89 - 3,8g - 21, ( 8 9 1 7 8g>. Table 2.2: Recommended sequences for the next objects: (89 - 3, . . . ,891
Let us determine the objective function value after serving these pairs. Regardless of the algorithm's decision, the maximum number, u k , of objects in any layer has the following values. Consider case 1: If an algorithm changes the order of (49 - 3,4g - I), then u q g - 3 = 1, ~ 4 ~ -=1 2; otherwise ~ 4 ~ - -=3 2, u q g - l = 1. If an algorithm changes the order of (49 - 2,491, then u q g - ~= 1, u q g = 2; otherwise u q g - 3 = 2, = 1. Thus, f o r S g we have f ~ , J u )= ~ 4 ~ - 3 + ~ 4 ~ - 1 + ~ 4 ~ = - 2 3 3 = 6. W e get the same result for the remaining cases. Since objects from different Sg have different types, we obtain
+
A t the same time the optimal objective function value is
This means c =
(q. e.d). H
Let us illustrate Lemma 2.22 by the following example.
+ ~ 4 ~
Online Storage Systems and Transportation Problems
If G = 1 N K = 4, N O = 8; ISkl= 2 for k = 1,...,4, we have to construct the input sequence S = Sl where S1 consists of eight objects. The first four objects have types 1,2,3,4, respectively. After executing the algorithm we get one of the following cases: w
the algorithm kept the order of objects for both pairs. Therefore, we get the output sequence: 1,2,3,4. In this case the next four objects (from 5 to 8) must have types 1,3,2,4, respectively; the algorithm changed the order of the first pair and kept the order of the second. We get: 2,1,3,4. In this case the next four objects (from 5 to 8) must have types 2,3,1,4; the algorithm kept the order of the first pair and changed the order of the second. We get: 1,2,4,3. In this case the next four objects (from 5 to 8) must have types 1,4,2,3;
w
the algorithm changed the order of both pairs. We have: 3,1,4,2. In this case the next four objects (from 5 to 8) must have types 3,4,1,3.
For the first case, independently of the actions of the algorithm on the objects 5,6,7,8, after these actions the following statements hold: Both objects of the same type, either 1 or 3 are on the same layer; Both objects of the same type, either 2 or 4 are on the same layer. An equivalent argumentation holds for all other cases. Therefore, the best value of the objective function for the online case is
At the same time we get the optimal value of the objective function for the o f l i n e case:
Using the Lemmas 4 and 5 we can now prove the following theorem.
THEOREM 2.24 The algorithm Da is strictly 3-competitiue. Proof. The algorithm Dzoperates as follows. At first, the sequence of all incoming objects is grouped into a list of pairs of objects. These pairs
41
Batch Presorting Problems. I
q.
are numbered from 1 through From each pair of objects with types kl and k z , the object of type kl is assigned to section L1 and the object of type k2 is assigned to section L z . Thus, the next time a n object of type kl appears i n a pair, it is assigned to section La and the other object of the current pair to section L1. A problem could only occur if both objects of the current pair should be assigned t o the same section, but this is not possible. This case was already considered in the proof of Lemma 2.22. Therefore the competitive ratio of algorithm D2 is (q.e.d).
.
2.5.5
Comparison of D 2and Online Algorithms with Lookahead
Here we show that additional knowledge of input data improves the objective function value. Consider the worst case for the algorithm D2, i.e., the following input sequence (1,2,3,4,1,3,2,4) (the construction rule was described in Lemma 2.22 and Example 2.23). In Table 2.3, the objective function values, f (i),for offline and online algorithms are presented, as well as the resulting permutations S(i). Table 2.3: Comparison of offline and online algorithms
Thus, with only one pair of objects in the lookahead algorithms WL1,
W L produce ~ an optimal permutation. Algorithms W L and ~ SLArequire the knowledge of two and three pairs, respectively, to get an optimal permutation.
2.6.
Extensions
In this section we consider a specific case of the sequencing problem, in which the number of layers is a power of 2, i.e., 2P. Accordingly, without loss of generality, the number of known objects, N O , is divided by 2P.
42
Online Storage Systems and Transportation Problems
We show that for this problem there exists a polynomial algorithm if the capacity NS of the pre-sorting facility is sufficiently large. In this case we can use the algorithm D2 consequently 2P-1 times. In the following, we refer to this modification as algorithm D;. Algorithm D; Apply the algorithm D z to H
the whole sequence of N o objects. Output: two subsequences of each of two subsequences of
objects;
q objects.
Output: four subsequences of
H
each of 2P-1 subsequences of Output: 2P subsequences of
$ objects; NO
objects.
$ objects.
g
THEOREM2.25 The algorithm described above is strictly ( z ) P - c o m p e titive. Proof. Follows directly from Theorem 2.24 and the description of D2 (q.e.d). THEOREM2.26 The algorithm time.
g
constructs a solution i n polynomial
Proof. By Theorem 2.17 the complexity of D2 is 0 ( N 0 , N K ) = q N K . Now we calculate the complexity of D;. The first step of D; costs q N K operations, the second - 2 % ~ " . Then we run D g four times for the $ objects, and thus the number of operations is 4% N K and so on. In total the complexity is:
As soon as a polynomial algorithm for three layers will be constructed, it is possible to develop an algorithm similar to D: for the problems with number of layers 3P, and 2p13P2.
Batch Presorting Problems. I
2.7.
43
Summary und Future Research
In this chapter we developed mathematical formulations and integer programming models for the Batch Presorting Problems (BPSP). The main result is the proof of NP-completeness. So far it is still open whether BPSP3 is polynomial or NP-complete. However, we expect that BPSP3 is NP-complete as well. As the complexity proof for BPSP2 involved the SAT problem, it is useful to adapt some existing efficient algorithms that have been developed to solve the SAT problem to the BPSPz problem. In addition, we have investigated what makes this problem difficult. We constructed an alternative formulation and showed that it has an integer polyhedron and is equivalent to a restricted variant of BPSP2 and BPSP3; thus, this restricted version is also polynomially solvable. In addition we considered a polynomial subcase of the original formulation - the case of two layers. For this special case, we constructed one exact offline algorithm and several online algorithms with and without lookahead. We compared them using competitive analysis. One of those algorithm was adapted for a more general case of 2P layers. For further research, we suggest to construct a similiar polynomial algorithm for the case of three layers, and then to modify it for the problem with 2p13P2layers in online case. For a better estimation of the efficiency of such algorithms it would be helpful to get a non-trivial (different from a constant) lower bound for a general BPSP. Another possible research direction is to construct a transformation from the problem with two layerslmany colors to the problem with many layers/two colors.
Online Storage Systems and Transportation Problems
seq,
seq,
seq4 seq,
Figure 2.3.8.
seq2
seq1
Changes in the sequence after assigning a value to
XI
Chapter 3
BATCH PRESORTING PROBLEMS. I1 APPLICATIONS IN INVENTORY LOGISTICS
In this chapter we consider a concrete application of BPSP to the storage system Rotastore, which is introduced in Section 3.1. Numerical results obtained when we applied our BPSP algorithms and models to the Rotastore system, are summarized in Section 3.2.
3.1.
The Storage System Rotastore
In the following we describe the storage system Rotastore, developed and produced by psb GmbH, Pirmasens, Germany [73].
3.1.1
A Brief Description of the Rotastore
This system overcomes the poor performance of stacker crane systems by implementing a modular multi-carousel principle. This principle allows parallel loading and unloading by means of elevators interfacing the vertically staked carousel layers. As shown in Fig. 3.1.1, a typical configuration consists of two elevators and a stack of carousels each with identical numbers of slots. Identically sized objects are transported to and from the lifts by conveyors. Each carousel and each elevator may move independently. As indicated by the arrows, two combs of punches push objects simultaneously on all layers in or out of the carousel stack. The whole assembly is controlled by a sophisticated high-level programmable computer system which keeps track of operations and inventory.
Online Storage Systems and Transportation Problems
The system normally operates in an output-driven mode, i e . , an input/output-cycle (110-cycle) starts with accepting a set of orders with one ordered object on each layer. The carousels then place, by rotation, the ordered objects in front of the output elevator ("seeking"). Next, the punches push out all ordered objects onto the output elevator which immediately starts unloading them onto the leaving conveyer ("stepping"). The carousels move the now empty slots in front of the input elevator and the punch push in the waiting objects. While the elevators load and unload, the next 110-cycle starts with seeking the next set of orders. The expected performance of a Rotastore with m slots on each of n layers was investigated by Hamacher et al. [39]. In Subsection 3.1.2 most important results from their work are reviewed.
3.1.2
Stochastic Measures
For the performance of the system, the number of 110-cycles per time unit is of course critical, therefore in [39] the expected duration of an 110-cycle under uniform assumptions was computed. For the following analysis it is assumed that the outgoing conveyor is fast enough, never blocked and there are always objects waiting for input. These assumptions can be met by installing sufficient buffer space before and after the elevators.
Batch Presorting Problems. 11
47
THEOREM 3.1 ([39])Let the orders be independently uniformly distributed. Then the expected duration of a n 1/0 cycle of a Rotastore with n layers
where
is the maximal time needed to seek a n object o n one layer, the time the elevators need for stepping, tkle, = t,le, - t p s h - t s h i f t is the part of the stepping time which happens in parallel to seeking, t p s h and t s h i f t are the times for pushing and shifting, and finally, b := min mseek I) is the ratio between stepping and seeking time. tmSeek
tele, is
(+?
The same result has been derived for a combined input/output elevator (paternoster) by Kartnig [51]and Klinger [54]. The ratio b then simplifies to b := since the elevator starts stepping only after the second push of tKePYcle. The next result, derived by Hamacher et al. is related to the expected number of the occupied layers. It is assumed that the Rotastore accepts more than n orders which are fulfilled at a time. The assumption of one independent order, uniformly distributed over the layers is generalized to n~ independent uniformly distributed orders anywhere in the Rotastore, where nT may be larger than n .
e,
THEOREM 3.2 ([39])Let there be a set of nT independent uniformly distributed orders. T h e n the expected number of occupied layers is
Direct computation of En,,, shows, that for practically relevant cases one can expect between 50% and 80% of the layers to be occupied by orders. Practical experience shows that additional measures have to be taken into account to distribute the objects eventually with respect to the layers in order to realize the parallelizing speedup of the Rotastore. We will consider the case of a distribution center of a mayor German department store company. In this case, the objects are already partitioned into sets of orders when input into the Rotastore and the Rotastore may output a complete set of orders as soon as all objects of the set of orders are present. To improve the performance, the incoming objects are pre-sorted such that each batch spreads over as many layers as possible. Conveyors transport the objects throughout the system. Reordering is done online by stacker frames. A stacker frame is a small robotic device that lifts one object from the conveyor to let an arbitrary number of
Online Storage Systems and Transportation Problems
Figure 3.1.2. Three stacker frames
objects pass. As Fig. 3.1.2 illustrates, usually several stacker frames are placed in a row along the conveyer so an object may overtake several preceding objects easily. The assembly is usually located above the input accumulating conveyor (e.g., roller conveyer) directly in front of the Rot astore.
3.2.
Numerical Tests
Because we can formulate the problem of minimizing the number of I/O cycles of the Rotastore as the BPSP, we can apply all solution approaches developed in Chapter 2. First, we check which model is more efficient, i e . , gives the best performance of the Rotastore. Second, we compare offline and online algorithms for the polynomial case when the Rotastore has only two layers, i e . , N~ = 2.
3.2.1
Models
As was already mentioned, all proposed BPSP model formulations can be used to model the Rotastore. Thus, in this section we test the models BPSPl to BPSP3. Computational experiments were carried out with randomly generated examples of the sets Sk using ILOG's OPL-studio [47]. Input data were chosen using real-world data knowledge: the usual number of objects in the input sequence is about 900, the Rotastore has eight layers of 113 slots each. We do not take in consideration the number of slots, because the layers are occupied only about 50% - 80% as mentioned above. The input of Rotastore could be rearranged by two stacker frames. Since the average size of the sets of objects is ten, the number of different orders is about 90. Thus, using the notations
Batch Presorting Problems. II
introduced in Section 2.2 we set:
N= = NK = NL= N ' = NO
900 60 90 8
2
(the total number of objects); (the number of known objects); (the number of colors); (the number of layers); (the number of stacker frames).
In order to distribute all objects among the layers of the Rotastore (each time only N o objects are available, the next N o objects become known only after distribution of the first NO objects) it is necessary to solve the model [N/N0l times. The input sequence is generated as N K sets Sk.For example, if N K = 4, NO = 7, then the generated sets could be:
We want to observe the number, NOC, of output cycles for the Rotastore using the solutions of the models BPSPl and BPSP2. Obviously, BPSP3 gives a minimal value for NOC, because the objective function of BPSP3 (2.2.21) minimizes this directly. As in BPSP3, the variables uk are related to the output cycles in BPSP2, therefore NOC = uk. In BPSPl we do not have those variables, but they can be calculated indirectly as follows: ur, = max Rkl, where Rkl is a number of objects of color k
cF=:
k 1 ,...,N L
on layer 1 after assigning of all objects to the layers of the Rotastore. For instance, for the input sequence in Example 2.5, R1l = 1, R12 = 1, R13 = 0, R21 = 2, R22 = 2, R23 = 2, R31 = 1, R32 = 1, R33 = 1 (see Fig. 2.2.6). Thus ul = 1, u2 = 2, us = 1 and NO^ = 4. We summarize the results of the experiments for BPSPl and BPSP2 in tables such as Table 3.1 and Table 3.2, respectively (further result tables are collected in Appendix A.A.l). Values in column "opt NOC" are calculated by BPSP3 and A is the optimality gap, which measures how far a solution is away from the optimum for the current cycle :
Online Storage Systems and Transportation Problems Table 3.1: Results for BPSPl cycle
1
NS
11 2
I 1
I
I
cpu, sec. NUC opt N~~ 2.45 1 45 1 44
1
A,%
I
A, %
1 2.27
Table 3.2: Results for BPSPz
I
I
I
cycle N" cpu, sec. 11 2 1 10.82 1
NO^
I
44 1
opt
NO^ 44
1 0.00
For each value N', ten runs were made (each one starting with an empty Rotastore, ie., at the beginning all Ckl = 0) with different inputs. Figures 3.2.3 and 3.2.4 show the average values of CPU time (in seconds) and the number of output cycles, respectively. It was observed that BPSPl and BPSPz produce solutions which are on average worse by 54% and 7% than those obtained by BPSP3, respectively. The CPU time for BPSPl is usually about 2 seconds and for BPSPz is 7 seconds. Similar results were obtained for different values of N' = [I,...,N ~ ] For . BPSP3 the CPU time varies between 8 seconds
Batch Presorting Problems. I1
51
(NS = [3, ...,N L ] ) , 10-15 seconds (N' = I), and above 200,000 seconds ( N =~ 2).
Figure 3.2.3. The average CPU time versus the number of stacker frames
Figure 3.2.4. Average number of 110 cycles versus the number of stacker frames
The CPU time seems to depend on the degree of filling of the Rotastore (see, for instance, Fig. 3.2.5). On average, one observes that
52
Online Storage Systems and Transportation Problems
1
2
3
4
5
6
7
8
9 1 0 1 1 1 2 1 3 1 4 1 5
Cycle
Figure 3.2.5. CPU time for BPSP3 with N ' =2
the CPU time decreases when the Rotastore contains more objects (Ckl becomes larger). This is explained by the fact that the feasible region becomes smaller, and therefore, there are less possible combinations of the binary variables Sij. As a consequence of this, the number of active nodes in the branch-and-bound algorithm becomes smaller, that in turn decreases the running time. So, we recommend to use BPSP3 when the Rotastore is not empty. However, in practical situations this happens very seldom. In some rare cases, when the Rotastore is empty, we can fill it using BPSP2, and continue with BPSP3. In this case, the computed solution is near-optimal (A = 1 - 2%) and the CPU time is drastically decreased. Sometimes the combination of BPSP2 and BPSP3 (for the first cycle to run BPSP2 and for the cycles 2-14 to run BPSP3) can produce better solutions than applying BPSP3 repeatedly 15 times. Consider, for instance, the data in Table 3.3. For cycle 6, both BPSP2 and BPSP3, produced solutions with the same objective function value 92, but the solutions differ w.r.t.the assignment of the objects to the layers. Thus, before cycle 7 starts, these models have different initial data and, therefore, the combination of the models produced, after 15 cycles, solutions with better results in shorter time (compare the CPU time displayed on Fig. 3.2.5 with CPU time displayed on Table 3.3) than applying BPSP3 15 times.
Batch Presorting Problems. II
Table 3.3: Results using the combination of BPSPz and BPSP3
I
I
cycle Ns cpu, sec. 1 1 2 1 10.82
I 1
No" 44
I 1
opt NU" 44
I
A,%
1
0.00
In addition, we observe that it is not useful to have more than four stacker frames because this does not lead to a smaller number of output cycles. This fact was also confirmed for different input sequences.
3.2.2
Algorithms
In this section we present computational results for the algorithms described in Section 2.5.3.1. In order to compare the efficiency of those algorithms we implemented them using the programming language C++. At first, we want to estimate the quality of the solutions produced by the online algorithm Dz. Secondly, we check the influence of the lookahead on those solutions. The size of the lookahead, A, ie., the number of pairs known in advance, varies between one and five pairs. Finally, we investigate how often the competitive ratio of is reached on randomly generated example. For N o = 900, N K = 90 the result of the comparative analysis of all algorithms compared to the exact offline algorithm Dl is given in Table 3.4; NO^ is the number of output cycles needed for complete output; A is the optimality gap defined in Section 3.2.1. More results of the experiments are presented in Appendix A.A.2; note that the CPU time is not reported there, because it always was smaller than 6 seconds.
Online Storage Systems and Transportation Problems Table 3.4: Comparative analysis of all algorithms
I I
alg. X ( A, % DI I I472 I
I
cpu, sec. 0
Table 3.4 shows that algorithm D2 is very efficient and produces nearoptimal objective function values, i e . , the competitive ratio c = 1.5 is reached only on a worst case example. Using the algorithms D2, WL1, W L ~W , L the ~ optimality gap A usually does not exceed 2% and 20% for SLx. The knowledge of the lookahead of different sizes does not improve the solution produced by the online algorithms without lookahead. For instance, if D2 produces the solution with A = 1.91%, then WL1 decreases this value till l.67%, W L till ~ 1.48%, W L till ~ 1.06%. The observation also shows that increasing the lookahead does not improve the value of A, ie., the number of output cycles (see Fig. 3.2.6) in most cases. This is to be expected. If the Rotastore has only two layers, not more than two objects at the same time can be distributed, therefore the knowledge of more objects ( i e . , X 2 2) has no advantages.
3.3.
Summary
In this chapter we considered one real life application of BPSP: the storage system Rotastore. We demonstrated that BPSPl produced solutions quickly but very far from the optimal solution (integrality gap of almost 50%). BPSP2 gives near optimal results in short time (integrality gap less than 10%). Finally, BPSP3 produces optimal solutions, but the running time can become sometimes very long. Therefore, we suggest to use a combination of BPSP2 and BPSP3 to get solutions with integrality gaps of less than 1%in short time. For the polynomial
Batch Presorting Problems. 11
k
WLNl
-
Figure 3.2.6. Solutions of the online algorithms with lower bound 472 versus size of the lookahead
case we compared all algorithms described in Section 2.5 and showed that a lookahead brings almost no further improvement, ie., the online algorithm without lookahead is already good by itself (it produces nearoptimal solutions). For this reason, this online algorithm was extended to the case of 2P layers.
Chapter 4
VEHICLE ROUTING PROBLEMS IN HOSPITAL TRANSPORTATION. I MODELS AND SOLUTION APPROACHES
In this chapter we focus on the VRPPDTW, adapted for hospital transportation problems. After a description of the problem (Subsection 4.1 . l ) and introducing some notations (Subsection 4.2. I), we suggest several approaches for solving this problem, including a mixed integer linear programming (MILP) formulation (Subsection 4.3.1), a branchand-bound approach (Subsection 4.3.2), a column enumeration approach (Subsection 4.3.3), and heuristics methods (Section 4.4).
4.1. 4.1.1
Problem Formulation and Solution Outline Problem Description
In this subsection we give a formulation of the vehicle routing problem with pickup and delivery and time window constraints (VRPPDTW). Solutions of the problem are needed for managing the transport of patients and goods in a hospital campus by a dispatcher responsible for coordinating vehicles. The setup for the hospital-oriented VRPPDTW problem differs from the standard VRPPDTW in the following aspects:
loads may include not only independent single items (patients or materials), but also groups of people (patients with accompanying personnel) ;
Online Storage Systems and Transportation Problems
58
target times for pickup and delivery have to be met instead of strict time windows, or the delay w.r.t. target times should be minimized, respectively; passengers should not spend more than, say, 30 minutes in a vehicle, i.e., the time between pickup and delivery is limited; some items may require special transport equipment (e.g., wheelchair, bed, or special vehicle); certain items cannot be transported simultaneously (e.g., infectious patients) ; a dispatcher receives new requests or orders and needs to assign them to free vehicles or to add them to existing tours, i e . , an online version of the VRPPDTW is required. The problem is characterized as follows. Data: rn
a heterogeneous fleet of vehicles;
rn
a set of requests or orders;
rn
source and destination depots for each vehicle v, s, and d,, respectively;
rn
distances between all locations, i.e., between all possible locations, including vehicle depots. Orders : type of an order, i.e., description of transported goods or type of transported patient to be picked up and delivered. A patient may be transported while sitting in the vehicle, lying in a bed, or sitting in a wheelchair;
rn
H
service time associated with an order at the pickup and/or at the delivery location (for instance, to load a patient lying in bed); target time associated with an order at pickup and/or delivery location. Vehicles:
H
time intervals during which the vehicles are available; type of a vehicle (i. e., which type of goods/patients it can transport);
Vehicle Routing Problems i n Hospitals. I
59
capacity of a vehicle with respect to its type (how many goods/patients of a certain type it can transport simultaneously). Objectives: to minimize the total travel time of the goods/patients (possibly some goods have to be transported very fast, e.g., blood); to minimize the total duration of transportation for each vehicle (better exploitation of the vehicle fleet); to minimize possible delays at pickup and delivery locations (increase the satisfaction of patients). Each order needs to be carried out on time (or if that is not possible, its delay should be minimized) and served by only one vehicle. Each vehicle must start from its origin depot and return to its destination depot at the end of its period of service. In this book, driven by the real world hospital case, we concentrate mostly on experiments using the third objective function. However, the other objective functions, and also combinations of them, can be considered as well. The problem involves assigning the requests or orders to the available vehicles. The requests occur at the nodes of a transportation network and the routes are characterized by the sequence of the nodes to be visited consecutively by each vehicle. If the assignment of nodes to a vehicle has been done, both the sequence of the nodes in the routes and the arrival and departure times have to be determined. Thus, we have to solve a combined assignment, routing (sequencing) and scheduling problem: assignment routing scheduling
assigning orders to vehicles putting the nodes in a route in sequence computing arrival and departure times, as well as considering temporal constraints
Let us comment on the temporal restrictions of the real world problem we will analyze in Chapter 5 . Usually, and this also applies to the Desaulniers et al. formulation [25] (briefly listed and discussed in subsection 4.1.2), the temporal constraints are exact time window constraints such as (4.1.3): if the vehicle visits a node of its tour, it must arrive within a time window [a,b]. Should it arrive earlier than time a , the vehicle is allowed to wait. As was mentioned above our problem is different: 1 Instead of time windows only target times are to be observed, i.e., desired pickup and delivery times.
Online Storage Systems and Transportation Problems
60
2 For most orders or requests only one target time is specified and valid for either the pickup or the delivery node. As passengers should not spend more than AT minutes in a vehicle, we define the target time not specified as a function of the specified one and AT. 3 The target times are allowed to be met late but lateness is penalized in the objective function, i. e., they are relaxable temporal constraints.
4 For pickup nodes, the vehicle must wait if it arrives earlier than the target time. In this case, the target time is to be interpreted as an earliest pickup time. Earliness, or the equivalent waiting time, is also penalized in the objective function. Despite these features we keep calling our model a VRPPDTW (time window) model, because we do not wish to coin or add a new term to this research field. Formally, one could classify our problem as a multicommodity, capacitated vehicle routing problem with pickup and delivery and relaxable time window constraints, in which for pickup nodes the upper time limit, b, is set to f m , and for delivery nodes the lower time limit, a , is set to -m.
4.1.2
Discussion of one Particular Model Formulation
In this subsection we briefly review the model presented by Desaulniers et al. [25],and comment on it. The model presented is, for general objective functions, a routing-scheduling model assuming that the assignment decisions have been fixed previously. Only for special objective functions, their model can solve the vehicle assignment problem as well. We adapt the notation used in [25] to that used in this book: Identify request (we use the term order, synonymously) i by two nodes, i and N f i , corresponding, respectively, to the pickup and delivery stops of the request. It is possible that different nodes may represent the same geographical locations. Next, denote the set of pickup nodes by P = (1, ..., N o ) and the set of delivery nodes by D = { N 1,...,2N0). Further, define N = P U 27. If request i consists of transporting Di units from i to N i, let Li = Di and Ln+i = -Di. Let V be a set of N V vehicles. Because not all vehicles can service all requests, each vehicle v may have a specific set Nu = P, U D, associated with it, where Nu N, Pv P, and D, D are appropriate subsets of N, P and D, respectively. This subset may have been constructed within a pre-solving phase. Note that at this level nothing is said about whether the same request i is contained in several subsets. However, if the subsets N,, P,, and D, have been constructed by an assignment
+
+
c
c
61
Vehicle Routing Problems in Hospitals. I
heuristic, or by a column generation approach based on a set partitioning model, then each request i is only contained in one vehicle subset. For each vehicle v, define now the network Gv = (K,, A,). Set K, = N, U { ~ ( v )d(v)) , as the sets of nodes inclusive of the origin, o(v), and destination, d(v), depots for vehicle v, respectively. The subsets A, of K, x K, contain all feasible arcs. The subsets, A,, may have been constructed by eliminating infeasible arcs from the full set of all arcs. The capacity of vehicle v is given by C,, and its travel time and cost between distinct nodes i, j E G, by T,$, and C ,,: respectively. Vehicle v is assumed to leave unloaded from its origin depot at time a,(,) = bo(,). Each admissible pickup and delivery route for t,his vehicle corresponds to a feasible path from o(v) to d(v) in network Gv, visiting each node at most once. If the vehicle visits node n E N, it must do so within time window [a,, b,] when the service time T: must begin. Should it arrive too early, the vehicle is allowed to wait. The formulation involves three types of variables: binary variables Sijv, is equal to 1, if arc (i,j ) E A, is used by vehicle v, and 0 otherwise; time variables t,, specifying when vehicle v starts the service at node n E Vk; and variables p,, giving the load of vehicle v after the service at node n E K, has been completed. The Desaulniers et al. formulation is as follows:
subject to
i~N,~{o(v))
C
i~N,~{d(v)}
=O
,
'dv E V, j E N v ,
Online Storage Systems and Transportation Problems
Sijv E { O , 1 )
,
'dv E V, (i,j) E Av.
(4.1.5)
Note that the objective function includes only the arc variables Sijv, but no other variables. This has some important consequences for the optimal solution of the model (4.1.1) to (4.1.5).
1 It suffices to compute the compound load variables, p,k, and beginservice time variables, tnk, to obtain feasible solutions. Compound means that they depend on both node, n, and vehicle, v. 2 The assignment decision, i.e., the assignment of requests to vehicles, can be derived from the arc variables, &jv. Once the assignments are known and represented by v,, the real begin-service times, t,, and load information, p,, are given by t, = t,,, E {t,, : v E V) and Pn = Pnv E {pnv : u E V). If the objective function depends explicitly on t, (or p,), the variables t, (or p,), and Sijv need to be connected. Of course, if each request is already assigned to a specific vehicle, then the variable t,, (or p,,), for each node n, exists for only one vehicle v. Note also, that due to nonlinear relations (4.1.2) and (4.1.4) the model leads to a mixed integer nonlinear programming (MINLP) problem.
Vehicle Routing Problems i n Hospitals. I
4.1.3
63
Discussion of Existing Solution Approaches
The vehicle routing problem (VRP) is one of the basic optimization problems known to be NP-hard [86]. Variants of the VRP, such as the vehicle routing problem with time windows (VRPTW), and the vehicle routing problem with pickup and delivery (VRPPDP), the capacitated vehicle routing problem (CVRP) were thoroughly investigated during recent years. All of them are NP-hard, and thus many researchers looked for efficient solution methods solving at least instances of modest size. Early surveys on the literature of vehicle routing with time window constraints are given in [81] and [82]. Several approaches can be found in the literature:
1 Exact approaches based on Dynamic Programming, B&B, B&C, and Column Generation algorithms. These methods are mostly applied to the capacitated VRP. They include dynamic programming [60], branch-and-bound (B&B) algorithms ([31], [55]), branch-and-cut (B&C) algorithms ([5], [6], [8], [63], [69], [lg]), and column generation algorithms ([26], [9], [48]). If time windows are included as in [26], the time window constraints are treated deterministically and are not subject to relaxation. In the early 1990's the best B&P solvers were able to solve multi-vehicles problems with up to 100 orders [26]. 2 Route construction and improvement heuristics. The construction part of such heuristics includes sequential insertion heuristics in which further nodes are inserted into existing routes (see [67], [80]). The improvement part includes exchange heuristics 1681, such as 2-opt*, %opt, Or-opt or CROSS-exchange with 2-opt* and Or-opt as special cases ([21], [46], [58], [81], [84], [85]),see for instance, Figures 4.1.1 and 4.1.2 for 2-opt and %opt, respectively.
Figure 4.1.1.
The exchange heuristic 2-opt
64
Online Storage Systems and Transportation Problems
Figure 4.1.2.
The exchange heuristic 3-opt
3 Metaheuristics. Unlike mathematical optimization approaches, metaheuristics are based on simulating a given system or a problem and evaluating a function of merit (analogous to the objective function in exact optimization) [35]. Metaheuristics are not problem specific (for applications to the vehicle routing problem see, for instance, 1621, [lo], [16], [17], [13], [36], or [44]), and are based on generic principles and schemes that can be used to construct problem-specific heuristics: genetic algorithms (GA), simulated annealing (SA), tabu search (TS), and variable neighborhood search (VNS). All metaheuristics usually lack a proof of convergence and a proof of optimality. However they improve a given solution by performing a local search ([74], [75]),coupled with exchange mechanisms based on appropriate neighborhood relations. SA links the probability of accepting a solution that is inferior to the reference solution to a temperature-like parameter that describes the cooling of metals (see, for instance, [1], [2], [28] or [Xi!]). TS ([20], [35], [66], [79], [84]) is a metastrategy for guiding known heuristics past the traps of local optimality. It exploits knowledge from previous solutions and thus uses a kind of memory. GA ([7], [42], [43], [65]) use a population of solutions subject to survival of the fittest criteria as well as mutation and recombination of positive properties in solutions. VNS ([40], [71]) explores increasingly distant neighborhoods of the current solutions and moves to a new solution only if there is an improvement.
4.1.4
Outline of Proposed Methods
In this subsection several solution approaches we developed are briefly described and implemented to solve the VRPPDTW problem of Section
Vehicle Routing Problems i n Hospitals. I
65
4.1.1. Notice that the problem has some specific features: vehicles may have partial availability over the day, i e . , very often the vehicles are available during different time intervals; vehicles have different capacities, i.e., not all vehicles can carry patients that are lying down or are sitting in wheelchairs. As a consequence, orders can only be exchanged between certain vehicles fulfilling those constraints. If route improvement heuristics and VNS methods do not incorporate these features, many infeasible tours need to be evaluated. In addition we should keep in mind the overall motivation. We wish to develop algorithms to be integrated in a software supporting the daily work of a dispatcher in a hospital, which requires solving online instances of the problem. A typical example involves, for instance, 26 orders, 16 of them already assigned to individual vehicles, and 10 of them subject to assignment, routing and scheduling to the fleet of vehicles. Thus, the algorithms should be suitable to solve small instances of the problem in short time. In order to compare the quality of the online solutions to the overall offline optimal solution over a given period, we would like to be able to solve offline problems as well. But this is not the main focus of this book, and therefore it is not necessary to solve large problems to optimality. We consider specific features of VRPPDTW discussed in Section 4.1.1 and suggest several solution methods that include exact optimization approaches, namely mixed integer programming (Section 4.3.1), and branch-and-bound approach (Section 4.3.2), column enumeration (Section 4.3.3), and heuristic approaches (Section 4.4). The heuristics are necessary to solve VRPPDTWs whose size exceeds those that exact methods can solve. Below we give an outline of the methods we have developed and implemented:
Exact optimization approaches
1 solving a MILP model describing the intra-tour planning problem: routing and scheduling of orders within one vehicle (single-vehicle problem); 2 solving a MILP model describing the inter-tour planning problem: assigning orders to vehicles, and routing and scheduling them (multi-vehicles problem); 3 a branch-and-bound approach to solve the intra-tour planning problem; and 4 a special variant of a column generation method based on complete column enumeration to solve the inter-tour planning problem.
66
Online Storage Systems and Transportation Problems
We have adjusted all approaches to solve both online and offline scenarios.
w
Heuristic approaches
1 construction of initial tour sets
2 improvement of tour sets
(a) intra-tour improvements using a sequencing heuristic i complete enumeration ii heuristic approaches, including simulated annealing (SA) iii solving the subproblems to optimally using the MILP model within the heuristic approach (this will only be suggested, but not implemented) (b) inter-tour improvements using a reassignment heuristic i cross-over1 heuristics to move one order from one vehicle to another ii SA (c) combined "SH-RH-SH" tour procedure with both the sequencing and reassignment improvement strategies
The combined "sequencing-reassignment-sequencing" tour heuristic works effectively for all data we have tested. It produces a schedule for an individual vehicle or a whole fleet in reasonable time. It exploits the sequencing and reassignment improvement heuristics. For small instances the results of the heuristics are compared to the optimal solutions.
l ~ h term e cross-over used in this book should not be confused with its usage in the genetic algorithms community.
Vehicle Routing Problems in Hospitals. 1
General Framework Notation
4.2. 4.2.1
Prior to presenting the mathematical model and the heuristics, we introduce the required notation: the total number of orders the total number of vehicles the set of all vehicles, IVI = N" the set of all orders, 1 01= N O : the set of pickup nodes, l'P/ = N O : the set of delivery nodes, ID1 = N o : the set of all pickup and delivery nodes; N = P ' UD : the set of pickup and delivery nodes extended by the depots {s,, dv) for vehicle v; M , := N U {s,, d,) : the set of all possible arcs, (nl, nn), vehicle can drive along : the set of orders served by vehicle v : : : :
NO
NV V
0 'P D
N M, A 0,
To address the various objects in those sets, the following indices are used (especially, in the MILP model): orders or pickup nodes of orders
i
:
j n
: delivery nodes :
nodes (unspecified whether pickup or delivery node)
Nodes are usually addressed by the index n. However, if it is known that a certain node is a pickup node, then the index i is used; a similar convention applies to the use of delivery nodes j. If we need to indicate that j is a delivery node corresponding to pickup node i, then the index ji is used. Orders and pickup nodes are used synonymously as each order uniquely induces one pickup node. Thus, the index i is used for both pickup nodes and orders. Additionally, in the MILP model the following data are used: D
: cost for vehicle v to drive from node nl to node nz
C,,,,, CLA
:
cLB c," c," c," c:: C,";'
CZ D? D:
DY
:
: : : : : : :
penalty cost for arriving too early at node i penalty cost for arriving too late at node i capacity of a vehicle for lying patients capacity of a vehicle for sitting patients capacity of a vehicle for wheelchairs cost per lying patient in vehicle v at node n cost per sitting patient in vehicle v at node n cost per wheelchair in vehicle v at node n
demand (sitting persons) associated with order i
: demand (lying persons) associated with order i :
demand (persons in wheelchairs) associated with order i
Online Storage Systems and Transportation Problems load of sitting people at node i; L? := D? : unload of sitting people at node ji; L: := -D? : load of lying people at node i; L: := D: : unload of lying people at node ji; L:~ := -D: : load of wheelchairs at node i; := : unload of wheelchairs at node ji; L: :=
L? L: L: L:~
:
LY
LY L
DY -DY
service time for node n , e.g., for loading a patient driving time from node nl to node nz for vehicle v earliest permissible arrival time at node n T," latest permissible arrival time at node n T," target time associated with node n ; T: T: := T: for pickup nodes, T: := T: for delivery nodes [ T J ET; y L ] : the time window during which vehicle v is available T* : current time : maximal time difference between delivery and pickup AT
T,"
~cnp
R~~ RA2 RB
: : : : :
maximal allowed earliness w.r.t. the target time at pickup nodes maximal allowed lateness w.r.t. the target time at pickup nodes : maximal allowed lateness w.r.t. the target time at delivery nodes : :
Instead of time windows for pickup and delivery we use target times. Lateness w.r.t. these target times should be avoided or at least minimized. The earliest permissible arrival time at a pickup node, qE,is identical to the desired pickup time, i.e., the target time is qT= q E . Now we formally define a tour for an arbitrary vehicle v on a set of orders, where each order is defined by two nodes: pickup node i and its corresponding delivery node ji.
D E F I N I T I O 4.1 N A tour 7 o n a set of N o orders is a sequence of 2N0+2 nodes t o be visited exactly once. Each tour starts at a source depot and finishes at a destination depot. A tour is feasible if: for every order i, its pickup node i s visited before the corresponding delivery node ji; the load of a vehicle m u s t never exceed its capacity, i.e., L: 5 L: and L? 5 C , for any order i;
< c:,
c:,
load Liat pickup node i i s the same as load Lji at the corresponding delivery node ji, i.e., a vehicle at node ji can only deliver the same or number of persons it has picked u p at node i, where Lii s L?,
LY.
LC
As illustrated in Fig. 4.2.3 a vehicle can drive not only directly from a pickup node to a delivery node but from a pickup node to another pickup node, as well as from a delivery node to another delivery node (of course, the conditions 1 to 3 of Definition 4.1 need to be observed).
Vehicle Routing Problems in Hospitals. I pickup
Figure 4.2.3.
4.2.2
delivery
Possible tours for vehicles
Characterizing the Quality of Tours
Before discussing solution methods for VRPPDTW in detail, we first explain how the quality of a vehicle's tour is measured. The overall goal is to serve all transportation orders, i e . , to pickup all patients at the requested times and transport them to their destinations. Due to the finite capacity of the vehicle fleet, however, it is not always possible to fulfill all temporal constraints (i.e., delays may occur). For a specific vehicle, v, and its daily tour, we can thus compute its total lateness, Sf, as
where dvn is the lateness of vehicle v in node n, and tn and T: are the actual arrival time and the target time associated with node n for vehicle v, respectively. We can also determine the average lateness per order
where N: is the number of orders served by vehicle v. Additionally, we define the maximal lateness, D,, occurring in vehicle v. Note that Sf can be a more useful measure since some vehicles operate only for a few hours and thus do not serve the same amount of orders. For the whole fleet of vehicles we can further compute the total lateness, the average
Online Storage Systems and Transportation Problems
70
total lateness, and the standard deviations: v -
- total average lateness - total maximal lateness - average lateness - average maximal lateness : v E V ) - the maximal lateness
S := C,"=,S," N" SD:= DU := S Nv
xu=,
s,
:=
3
D, := max{D,
and
Ideally, we want to have routes and schedules satisfying the condition S = 0, which is equivalent to all temporal constraints being fulfilled. However, for scenarios with insufficient vehicle capacities this is not likely. Therefore several objective functions to be minimized appear promising:
as well as their combinations. In the context of the MILP model the objective function contains a driving cost term and penalty terms for violating the target time constraints (see 4.3.1), while in the heuristic approaches we will use, for instance, the merit function
to measure the quality of tours, where an appropriate value of p can be defined experimentally.
4.3. 4.3.1
Exact Solution Approaches A Mixed Integer Programming Approach
The formulation presented by Desaulniers et al. [25] (briefly listed and discussed in Section 4.1.2) has been: modified (we have transformed their nonlinear constraints into linear ones), extended (including the assignment decisions for general objective functions) and adjusted to our needs (included special features, e.g., limiting the time a passenger spends in a car, or more appropriate objective functions).
Vehicle Eouting Problems in Hospitals. I
71
As has already been discussed on page 59 this involves the following model aspects, or decisions to be made by the solver: • M l : assignment of orders to vehicles (not eo\'crfid by Desaulniers et al. for general mixed-integer linear objective functions), " M2: routing (sequencing the nodes, i.e., establishing a tour for each vehicle), • M3: scheduling (computing arrival and departure times; matching the temporal constraints), and • M4: more objective functions. multi-vehicles problems including t h e assignment problem, if solved with exact algorithms at all, are nowadays usually approached with branchand-price algorithms including column generation {cf. [26], or most recently [48]). Our approach is based on a full M I L P model including variables tracing the assignment decisions. The model developed below can also siipport several returns of a vehicle t o its depot, i.e., when a vehicle has several service periods during the day. As the problem is NP-hard wc expect that only small size problems can be solved, or jiist single-vehicle problems. Nevertheless optimal solutions help us to check the quality of the tours our heuristics generate. Depending on vehicle availability, we arc a b b to find an optimal solution with up to 15 orderg and a few vehicles, or up to 25 orders with only one vehicle (only M2 and M3) w,ithin a few minutes using the commercial MILP-solver Xpress-MP [41]; see the examples described in Chapter 5. The MILP-model can be used to caHbrate certain strategies such as 2-opt or similar teclmiques in the heuristic approach. 4.3.1.1
Data, Indices and Variables
The routing and scheduling decisions are represented by the binary flow variables dmn^n; c _ J 1 , if vehicle v drives from n\ to node 712 6n,n-^v - - j o , otherwise
V(n.i,n.2) G A V^ G V
and the assignment binary variables anv, 1 , if vehicle v serves node n ^ 0 , otherwise
\/n G Af Vv e v
As orders and picJiup nodes are represented by the same index, ajt, = 1 implies t h a t order i is assigned to vehicle v. If a single-vehicle problem
72
Online Storage S y s t e m s and Transportation Problems
or a problem with known assignment is to be solved, the aiv variables are just set to one. Here, and whenever the context leads to a unique interpretation, we use the abbreviated canonical indexing, e.g.,
Furthermore, the model contains the following non-negative continuous variables: p:, p;
t&,
tzw r r$
rg
: number of sitting people in vehicle v when leaving node n : number of lying people in vehicle v when leaving node n : number of wheelchairs in vehicle v when leaving node n : arrival time of vehicle v at node n : departure time of vehicle v from node n : earliness w.r.t. the target time at pickup node i of vehicle v : :
lateness w.r.t. the target time at pickup node i of vehicle v lateness w.r.t. the target time at delivery node j of vehicle v
4.3.1.2 The Objective Function The objective function, z,
to be minimized contains several non-negative components: 1 driving costs, cD;
2 penalty costs, cAl, cA2,and cB associated with the relaxation variables used to model the target time restrictions as soft constraints;
3 capacity load costs cL; 4 penalty costs, cP, for deviations from given target tours, S~ln,,. This can be useful in the online case if the aim is to re-schedule the tours and keep the re-scheduled tours as close as possible to the existing ones; 5 a term, cN, added for numerical reasons giving preference to solutions in which vehicles arrive at the delivery node no later than necessary. The individual components are defined as follows. The driving costs are given by NV
73
Vehicle Routing Problems in Hospitals. I
D If all values CEn2,are set to the same constant value, e.g., Cnln2, = 1, then cD just gives the number of arcs in the graph. The model considers the three penalty terms related to the time window or target times: respectively, constraints (4.3.15)-(4.3.17):
early arrivals at pickup nodes late arrivals at pickup nodes late arrivals at delivery nodes
xu=,CiEFCiv riv xfBV1 ziEp Civ riv ~f=", zjpO Cjv
cA1 :=
cA2:=
cB :=
N~
PA
A1
PB
A2
PB
B rjv
There might be real costs or penalty costs proportional to the load of a car, i. e.,
This term had been added to model the situation that a vehicle's capacity (for instance, lying capacity) is two, but that it is somewhat inconvenient to carry two lying passengers. This situation is slightly avoided or Ckw. by assigning non-zero values to CkL, Penalizing the deviation from target tours can be realized by adding the following term to the objective function:
CF
where CGn2, is a penalty cost for deviation from the target tour for vehicle v supposed to drive from node nl to n2. The term, cN,
is only added for numerical reasons. As the arrival times are coupled to the departure times by equalities involving the driving time, this is not necessary from an algebraic point of view. However, it improves the efficiency of the branch-and-bound process (helps to produce feasible solutions somewhat faster). 4.3.1.3 The Constraints Network Flow Constraints. The following constraints apply: Every pickup node, i, is served exactly once and by one vehicle, i.e.,
Online Storage Systems and Transportation Problems
)ickup node, i, is visited by a given vehicle, then the corresponding delivery node2, ji,must be visited as well, i.e.,
Each delivery node is also served exactly once and by the same vehicle that serves the corresponding pickup node. Therefore, the equalities (4.3.4) and (4.3.5) ensure that each order is served once and by the same vehicle. Each vehicle starts from its source depot. It can drive directly from the source depot to the destination depot, meaning that it did not serve any order, i. e.,
Each vehicle ends its route at its destination depot, i. e.,
Every destination node has a source node (flow conservation at each node is guaranteed), i. e.,
Temporal Constraints. The temporal constraints basically involve the arrival and departure times, t i u and tEv. The model considers constraints 1 relating the departure time from a source node with the arrival time at a destination node, 2 restricting the time a passenger spends in the vehicle, 2 ~the f orders or pickup nodes, respectively, are indexed by numerical indices 1,.. . , N O , then the delivery node ji,corresponding to the delivery i, is given by ji := i + N o . In other words, P = (1,...,N o ) and D ' = { N o 1, ..., 2N0).
+
Vehicle Routing Problems in Hospitals. I
75
3 expressing either the time window restrictions or the target time restrictions. Further, we explain each group of constraints 1-3 in detail: 1) The departure time, t g , , at node n1 and the arrival time, ti,,, at node n2 are connected by the driving time, T:, i.e.,
If 6,,,,, = 0 then (4.3.9) holds. If 6,,,,, = 1,then t ~ , -ti,,+ =~0 must be fulfilled, i.e., the arrival time at the destination node n2 is equal to the departure time from the origin node nl plus the time required to drive from node nl to node n2. If node n is not served by vehicle v, then by definition t& = t;, = 0. The nonlinear complementarity constraint (4.3.9) is discussed on page 79 and replaced by a system of linear inequalities. To tighten the model a set of valid inequalities is added. Observe that the earliest departure time, t z , from pickup node, i , satisfies the inequalities
This relation can be tightened by the inequalities
Note that the earliest arriving time, T?, sets a lower limit for departure (the patient might not be ready). Departure is delayed by the service time, As a vehicle may arrive later than T:, condition (4.3.11) might be tighter than (4.3.10). Observe that the earliest departure time from a delivery node j must satisfy the constraint
p.
Note that we list (4.3.10) and (4.3.12) and thus distinguish between pickup and delivery nodes because there is a difference for pre-assigned orders in the online case (in the online case we do not consider constraints for pickup nodes because the patients are already in vehicles). Furthermore, it should be observed that each delivery node is visited later than the associated pickup node,
~
~
Online Storage Systems and Transportation Problems
76
The inequality (4.3.13) ensures that the triangular inequality expressing that the direct connection is the shortest one is possible. 2) A patient should not be delivered later than AT hours after pickup aiv(t?, -
tk - qs - AT) 5 0
.
(4.3.14)
3) Time window constraints usually take the form
~n
-
n~v -
< , V t ~ E ~N,
where T: and T: are given earliest and latest times. However, it may be unwise to apply the time windows as hard constraints because the problem might become infeasible. In the present problem it is more appropriate to use target time restrictions and to treat them as soft constraints. Instead of the time window limits, T: and T ,: only the target times T : := T: or T: := T: are used. The earliness and lateness w.r.t. the target times of the pickup nodes follow as:
and
A2 > t P T,L aiv + riv - zv , V i E P , VV E V .
(4.3.16)
Likewise, the lateness w.r.t. the target times of arriving at delivery nodes is given by
Note that the inequalities (4.3.15)-(4.3.17) contain the assignment variables ai,. If vehicle v really serves order i (i.e., drives to pickup node i or to the corresponding delivery node ji), then ai, = 1 leads to the inequalities
Otherwise, if ai, = 0 , (4.3.15)-(4.3.17) reduce to
Note that in this case
tk = t f , = r$
= r$ = r g = 0 are feasible values.
77
Vehicle Routing Problems i n Hospitals. I
As the relaxation variables r i l , r$ and r$ appear in the objective function as penalty terms, the target time restrictions (4.3.15)-(4.3.17) can be interpreted as soft constraints that penalize deviations from the target times. The target time restrictions can be transformed into hard constraints by putting upper bounds on the relaxation variables. By coupling the relaxation variables with the assignment variables aiv the model is tightened and the performance of the solution algorithm is improved: (4.3.18) r i l 5 lzA1aiv , ' d i E P , 'dv E V , and
r$
,
rg
,
lzBajV
,
(4.3.19)
, 'dv E V ,
(4.3.20)
' d i ~ p, VVEV 'dj E D
where lzA1,lzA2 and RB denote the maximum allowed deviations from target times, e.g., 0.5 hours. However, if the maximal value is too small, the problem might become infeasible. Note that in the current case, there is no real reason why a vehicle should appear too early at a pickup node because it cannot leave the pickup node before its target time. But because the equality (4.3.9) relates the departure time from a source node and the arrival time at a destination node, non-zero values of r$ may be interpreted as waiting time at the destination node. Capacity Constraints. The capacity constraints balance and track the load of the vehicles, i.e., they relate the load after leaving a node to the load state before arriving at the node: for sitting passengers,
for lying passengers,
and for wheelchair passengers
If L
&,,,,,L= 1, then the terms in parentheses become active, for instance, L
= Pnlv f Ln2. The capacity constraints to be observed by all vehicles at the pickup nodes are given by
Pn2v
Online Storage Systems and Transportation Problems
and
Lwai, 5
pE 5 CY
,
'diEP
, YvEV .
(4.3.26)
Likewise, the capacity constraints to be observed by all vehicles at the delivery nodes, are
0 5 ~ $ + L f a ~ , < ~, f V j c D
, YVEV ,
(4.3.28)
and
The vehicle loads at the depots are by definition
Several Tour Constraints. The model developed in [25] allows each vehicle to have only one tour (driving from the source depot to the destination depot, which in our case is the same as the source depot location). To allow for several tours (leaving the source depot several times) we assume that in the considered time interval (one day) there are maximum N~ tours. In this case all variables, described in Subsection 4.3.1.1 should also depend on the tour index t , for instance: Snlnzvt :=
1 , if vehicle vt drives from nl to node rza 0 , else
'
v ( n 1 9 n 2 )A
'dv E V vt= 1, ...,N T
and
an,t :=
1 , if vehicle vt serves node n 0 , else
VnE N Vv E V V t = l , . . . , N~
.
Our modeling approach is as follows. The departure time from the source depot s, for a subsequent tour t cannot be earlier than the return time A td,,v,t-l of the same vehicle from the previous tour t - 1. Tours can be connected by
No time window constraints are considered for depot nodes s, and d,.
79
Vehicle Routing Problems in Hospitals. I
Assignment Constraints. The assignment variable ai,, besides representing the assignment decision, is useful to relax the time window constraints or, in the online case, to implement pre-given assignments of orders to vehicles. It is related to the flow variables by the equality
which expresses that "if order i is assigned to vehicle v, then there exists an arc with destination i n . Similar conditions hold for the delivery nodes
Furthermore, if vehicle v serves order i (or pickup node i), then it also serves the corresponding delivery node, ji, i. e.,
Each order can be served by one vehicle v, i e . ,
If vehicle v drives to pickup node i then it also drives to its associated delivery node ji
If this model is used for routing and scheduling only, i.e., for only one vehicle, then, IVI = 1 and obviously
Equivalent Mixed Integer Linear Formulations 4.3.1.4 As it is quite complicated to solve nonlinear models, it is worthwhile to transform the nonlinear constraints into linear ones for the model described at the beginning of the current section. The first group of non= 1, then t!l, T:, linear constraints (4.3.9) implies that if 6,,,,, ti,, = 0. This is represented by the following linear inequality
+
where n'InIn2vis a sufficiently large number, e.g.,
Online Storage Systems and Transportation Problems
80
+
So, the case S,,, = 1 leads to t& T:,,, 5 t&, and, together with T:,,, = t;,. (4.3.12), to t:, The nonlinear constraints (4.3.14) can be rewritten as follows:
+
where MD is a sufficiently large constant, e.g., MD = 4. Finally, if we set
+
L$, the equations (4.3.21) can be linearized. If Snln2, = 0, then pZ,, S pZ2, 5 M ~ ~ , , always , holds, in case Snln2, = 1, pnl, - p$,, = 0 , because all values of pZ1,, L;, , p;,, are nonnegative. So, the first of the three constraints (4.3.21) is transformed into
+ LZ,
The two other groups of constraints (4.3.22 and 4.3.23) are subject to the same transformation.
Online Version of the MILP Model 4.3.1.5 In the online version, the MILP model supports re-planning of existing tours or adding new orders to existing tours. At the current time T,, all vehicles may be positioned at known location. After re-planning, each vehicle continues from where it served the last order. It may also happen that a vehicle is in transit with loaded patients/goods when re-planning occurs. When the MILP model is used for online situations there is usually only a small set of orders involved; see, for instance, the example presented in Chapter 5. Thus, the problem can be approached fully with all its components: assigning orders to vehicles, H
routing (sequencing),
H
scheduling (matching the temporal constraints).
Let OP denote the set of pre-assigned orders, that is orders for which the passengers have already been loaded to a vehicle and still are in the car at time point T*. If the patients of order i E OP are in vehicle vi, then 0; denotes the orders pre-assigned to vehicle v. For order i E no
oP
Vehicle Routing Problems in Hospitals. I
81
assignment problem needs to be solved, because the assignment variables are just set to ai,, = 1, Yi E OP . The temporal constraints related to pickup nodes of pre-assigned orders, A i E OP, and, hence, the variables r$ and ri,2 are neglected and set to zero because the patients have already been loaded to the vehicle. However, for such orders, the actual arrival times, tk, are computed using the given information on the time the passenger spends already in a vehicle. This allows to apply (4.3.35) to limit the total time a passenger spends in a vehicle. The part of a tour related to picking up pre-assigned patients is seen as a fixed part of the tour, i.e., it is known a priori. The pre-assignment information is used to fix the corresponding binary variables ai,. From this, consistent initial conditions regarding the load variables generated. The real cases usually involve only sets 0: with a small number of orders, usually only one, two or three, i. e., lOFI 5 3. The case IOfI = 1 allows to fix the binary variables Ssvi, S S v= 1, i E 0;
, b'v E V
(4.3.37)
expressing that the vehicle drives from its source location, s,, to the pickup node of order i. Note that in the offline version s, is identical to the source depot while in the online version it can be any location. The load variables can also be fixed, i. e.,
and pZ=LW,
~EO,P ,
YVEV .
The case IOrI = 2 with pre-assigned orders il, and i2, is more complicated because the car might have first driven to the location associated with order il,, and then to i2,, or vice versa. Therefore, the constraints are:
Online Storage Systems and Transportation Problems
W
PiZVu= LKV f ~ K ~ 6 - ~7 ~Y vi E~V ~ .v
(4.3.38)
Note that alternatively to the constraints (4.3.37) to (4.3.38) the information about the pre-assigned orders could also be exploited to eliminate the associated variables completely. The current time, T,, is used to tighten the model. If the target time, T ,: of a node n representing a pickup or delivery node associated with an order i f OP is earlier than T,, for all vehicle v E V the following bounds can be added to the model:
r$
> T,-TL
if i is the pickup node associated with order i
> T,-T;,
if ji is the delivery node associated with order i f
6 oP
,
and r&
The case 4.3.1.6
oP
IOfI = 3 (or more) leads to similar constraints. Comments on the Size and the Structure of the MILP Problem
The problem formulated above is NP-hard since the standard VRP is a specific case of it and the latter is NP-hard [86]. Even for small cases one experiences an exponential growth of the number of nodes of the branchand-bound tree. This can be understood as follows. If we consider only the assignment part of the problem with n = N' vehicles and r = NO orders, there exist nT possible combinations of assigning these orders to vehicles. This problem is equivalent to assigning r distinguishable objects into n cells.
THEOREM 4.2 There exists N ( n , r) = nr combinations of how r distinguishable requests can be assigned to n vehicles. Proof. The proof is based on complete induction. Obviously, the statement is true for n = 1 and any number of requests, r E W; there is only 1 = lTway to achieve this. a) Let us first do the induction step from r to r 1, and derive the number N ( n , r 1) from the known number N ( n , r ) . If we add one request, then we take the set of all nT combinations obtained for r requests to n vehicles. Obviously, the new request can be assigned to any of these
+
+
83
Vehicle Routing Problems in Hospitals. I
n vehicles, which increases the number of elements the given set of combinations by a factor of n , i. e., we have N ( n , r 1) = n N ( r ) = nnr = nr+l, (q.e.d.). b) Now we focus on the induction step for the same number of requests. Let us increase the number of vehicles by one and show that N(n+ 1, r ) = (n 1)'. The new vehicle, n 1, can have any number, b, of requests between 0 and r, leaving r - b requests for the original n vehicles. Note
+
+
that there exists
+
combinations of how to extract b requests from
a set of r requests. Therefore, the number of combinations N ( n becomes
where we have exploited our induction knowledge about N ( n , r
+
( )
+ 1,r )
-
.
b) =
C X ' ' T - ' ~ ~(cl.e.d). b=O The binary variables, ai,, carry the assignment of orders to vehicles but they hide the fact there exists an enormous number of combinations. An underlying assumption of the proof is that both the requests (orders) and the vehicles are distinguishable. This is strictly speaking true in our case, but the vehicles may be almost alike in terms of the capacities but may have different working periods. The orders are usually distinguishable, but they are often very much alike regarding the time windows or target times which differ only little. Thus the assignment problem bears a lot of symmetry or nearby symmetry when objective functions are used which measure the delays of arrival times. As a result, the branch-and-bound tree becomes huge. Let us now investigate the complexity of the routing and scheduling problem (intra-tour problem). Here we have to put m 5 r (distinguishable) objects into the right sequence. This gives at most m! permutations. In our case for each vehicle v, m = 2~:, with N: denoting the number of orders served by vehicle v. As each pickup node precedes its delivery node, there are at most nr-b and the well known relation (x y)' =
combinations or routes to be tested for each vehicle. Note that the denominator cancels out a factor of two for each pickup-delivery node pair. For certain kinds of objective functions we have, in Section 4.3.2, formulated a branch-and-bound approach to solve the intra-tour optimization problem.
84
Online Storage Systems and Transportation Problems
Despite the hardness of the problem, for small instances the routing and scheduling problem, we can compute and prove the optimal tours for each vehicle individually. If the assignment problem is included as well, we seem to get the optimal solutions but we are not able to prove the optimality within several hours and even several days using Xpress-MP [41]. The basic reason is that the lower bound of this minimization problem improves only very slowly or does not change at all, even when the internal cuts of Xpress-MP (Release 13.26) are used. 4.3.1.7 Tightening the Model Formulation Here we discuss some valid inequalities (cuts) which can help to decrease the number of arcs. At first, the model formulation can be essentially tightened and the solution time can be significantly reduced by eliminating impossible or unlikely arcs from the set A. For deterministic time window constraints which cannot be relaxed it can be worked out exactly which arcs can be eliminated. As in the problem we are interested in the temporal constraints can be relaxed or slightly violated we can at best argue with some probabilities. For instance, if orders arrive in 5 minute sequences, it is not likely that a vehicle will ever drive from a node nl with target time 8:50am to another node n2 with target time 3:30pm. Thus, the variable ,S needs not to be generated or can be set to zero. This observation leads to the introduction of a forward cut parameter, AF. Similarly, it is not likely that an arc exists from a node with target time 3:30pm to another node with target time 9:50am. Therefore, we introduce a backward cut parameter, AB. The parameters AF and AB should be chosen with great care. Otherwise the problem can easily become infeasible. Furthermore, it is obvious that the node connection ( j i , i ) needs not to be considered because a vehicle will not drive from a delivery point back to the corresponding pickup node. Let us summarize all rules for , need not to eliminating arcs. Arcs corresponding to the variables S be generated or can be eliminated by setting S , = 0, if w
w
the arc represents driving back from a delivery to a pickup point, i. e., n2 is a pickup node and nl is the corresponding delivery node;
>
T; T; + AB, i.e., if the target time, T ,: of node n l is much smaller (by value AB) than the target time, T;, of node n2;
+
<
w
T; AF ,T : i t . , pickup time of node n2 is much smaller (by value AF) than the pickup time of node n l ;
w
n l is a destination depot;
Vehicle Routing Problems in Hospitals. I
nl is a source depot and n2 is a delivery node; nl is a pick-up node and n2 is a destination depot; n2 is a source depot. Furthermore, special cuts can be applied to tighten the model. Especially, for cars which have only space for two lying passengers, the cuts
s,~, 5 C: -pkv,
'dnE N , 'di E P, yv E V
(4.3.40)
turn out to be very useful and represent the fact that a vehicle should not drive to another pickup point if the capacity is already completely used. The same holds for orders with patients in wheelchairs, where Cy 2:
<
For single-vehicle problems the model can be tightened if a feasible tour is known from applying the heuristic approaches described in Section 4.4.2. In that case, the total lateness, s ~ can , be introduced as a new variable and is bounded by
S is an upper bound obtained, for instance, by a heuristic apwhere : proach. Of course, one could also restrict the individual sums for pickup and delivery nodes. As is illustrated in the two examples in Section 5.2.3, the effect can be very significant. 4.3.1.8 Concluding Remarks on the Model The MILP model in its current form described above can solve the problem in favorable cases. However, this is not sufficient for being embedded in a real world application. Therefore, various very special features of the real world problem have not been implemented. This includes carriage, and infectious persons.
4.3.2
A Branch-and-Bound Approach for Solving the Intra-Tour Problem
For certain objective functions, a recursive approach in the branchand-bound style can be used. This applies to objective functions which can be built-up cumulative when constructing a tour from a given set of
86
Online Storage Systems and Transportation Problems
nodes by adding nodes to it in sequential manner. For computing the objective function value when the tour has reached a size of n nodes, it is sufficient to know only the objective function values of the previous nodes and adding some extra amount for the current node, n , but nothing from the subsequent levels. The objective functions we consider in this book fulfill this condition, for instance, objective functions like z = cD cP cL cN (see page 72). Let us consider the intra-tour optimization problem for one vehicle and n nodes Nn := {nl, nz, . . . ,n,). The node n, represents the source depot of the vehicle; the index representing the vehicle is dropped. The optimization problem is formally broken into a recursive scheme3 of minimization problems depending on a smaller number of nodes. The overall objective is to determine the optimal sequence of the node set {nl, n2,. . . ,n,). In offline planning, the vehicle leaves the source depot, n,, at time to (usually leading to zero delay for the first pickup node). In an online case, to may represent the current time T,. The initial value of the objective function value is zo = 0. Finally, we need to track the load of the vehicle; the vector p (initially set to zero) serves this purpose. After leaving n,, the vehicle can drive to any of the nodes Nn. We express this by n, (nl, n2, . . . ,n,), to be read as "leave from n,, and the sequence of the node in "()" is free". The top-node eventually will have the value
+
+ +
and fnPl (to,zo, PO,nk; Nn-l,k)is the objective function value in case a vehicle drives from the top-node to node k. The functions fm(tnPm,zn-,, pnPm,n k ;Nmk)are computed recursively for m = n - 1,.. . , 2 as
The functions fm, m = n , . . . , 2 contain the following arguments: the time, tn-,, at which the vehicle is ready to leave the source node nk, the 3 ~ h i recursive s structure allows to develop a dynamic programming approach as well.
Vehicle Routing Problems i n Hospitals. I
87
accumulated objective function value, kern, associated with the previous n - m nodes, the load vector, p, the source node from which the tour should be continued, and the set of nodes, N, to be put in sequence. The initial value for zo is always zero, for to is the current time or a starting time leading to zero delay for the first pickup node. The initial load vector is zero, or if pre-assigned orders are present, to the number of passengers in the car. The tour always finishes by connecting the last node (a delivery node!) to the destination depot of the vehicle. The function, f,, of level m evaluates the new current time, tn-m+l, and the new objective function value, zn-,+l, when node is added to the tour, and passes those values to the next level function, fmPl. Now we illustrate this method with the following example.
E X A M P L E4.3 Let N O = 2, i.e., n = 4 nodes need t o be sequenced. T h e nodes I and 2 represent the orders, o r their pickup nodes, and 3 and 4 t h e corresponding delivery nodes. T h u s , we have N4 := {nl,ng ,ng ,n4) and
T h e functions f3(z0,n3;M$ and f3(zo,n q ; ~ @ ~do) n o t need t o be evaluated since a t o u r cannot start with a delivery node. Therefore, the n e x t levels t o evaluate are
Online Storage Systems and Transportation Problems and
Graphically, the tree and t h e w a y we m o v e through it (indicated by t h e subscripts) can be depicted as shown in Fig. 4.3.4. T h e subscrzpt indi-
Figure 4.3.4.
The branch-and-bound tree for the intra-tour optimization problem
cates the sequence in which t h e nodes are created. T h o s e nodes in t h e indicate infeasible nodes; the infeasibility i s caused tree displayed as 'I]" by t h e delivery node preceding t h e pickup node. I n addition t o this, nodes m i g h t become infeasible and are pruned because they violate the capacity
Vehicle Routing Problems i n Hospitals. I
89
constraints. The number of tours t o be tested derived from (4.3.39) is six; this i s identical to the number of feasible tours (fulfilling the precedence constraints) displayed at the bottom line. Note that z, can only be computed until the deepest level of the tree is reached on all branches, but never before. As indicated by the subscript in the figure above, we move through the tree in a depth-first type way. While reaching deeper levels of the tree (the top node has level 1) tours are built up by adding more and more nodes leading to increasing times, t , and possibly objective function values, z. If the deepest level of the tree is reached, and the associated node turns out to be feasible, i.e., a feasible tour has been constructed and its associated objective function value, z, has been found and evaluated, the cutoff value, Zc, is tested for updating. If z < Z c , then Zc = z (the initial value Zc := +oo). Except for eliminations of a priori identified infeasible tours, the tree, in the worst case, represents a full enumeration scheme. Nevertheless, this approach is more efficient, i.e., computationally cheaper than the full enumeration, because nodes and thus whole parts of the tree are pruned when a node turns out to be 1 infeasible, or
2 value-dominated by a previous solution found, or by a pre-set value, Zc, computed, for instance, as described in Section 4.3.3.6 or, 3 the optimal node identified by the condition z
< lop6.
However, before a new node of the tree is evaluated, the algorithm checks a priori the two following obvious conditions:
1 precedence constraints (the pickup node of an order needs to be visited earlier than the corresponding delivery node), and 2 capacity constraints (subtours driving to too many pickup nodes can be avoided). Additional computing time savings are obtained because the objective function and other quantities associated with a tour are computed successively when nodes are added. A tour with n nodes requires n successive computations of adding a node and updating the accumulated objective function and other quantities. Thus, for two tours, whose last and second last node are just exchanged as in 1234 and 1243, the total computational effort for n nodes is n - 2 2 x 2 = n 2. If both tours would have been computed independently, the effort would be 2n.
+
+
Online Storage Systems and Transportation Problems
90
This approach is limited mostly by memory requirements. The minimal amount of information we have to store for each node is as follows: 1 node number, n,
2 parent node, np
3 node level, nl 4 number of nodes in the tour already fixed, nf 5 position to be filled when the next child node is created, n, 6 status of the node, n,
7 the sequence of nodes in the tour, n l , nz, . . . ,n
8 accumulated time, t 9 accumulated objective function value, z 10 patients load (lying, sitting, wheelchair), pl, p,, p, To save memory, our program has the option not to store those nodes of the tree which have been pruned or fully evaluated. In that case, the number of nodes of tree's level to be stored is the number, NL. For our depth-first search, each child-node is stored into the node position corresponding to the level of the tree. If there are no pre-assigned orders, NL is just the number, n , of nodes. If there are mo pre-assigned orders, then NL = n - mo. Nodes on the deepest level of the tree always show up as a pair, e.g., 142356 and 142365 with 1423(56) as their parent node. If one needs the tree only for inspection purposes, it suffices to store only the first nf nodes instead of storing the full tour-node list for each tree-node. This would lead to a memory reduction of a factor two. If it is necessary to store the whole tree, the memory issue becomes problematic. Table 4.1 summarizes some numerical experiments and lists the number, NT, of nodes in the tree, the number, NF, of feasible tours evaluated, as well as the CPU time (in seconds) needed to evaluate them. Table 4.1: Numerical experiments for the branch-and-bound approach
Vehicle Routing Problems i n Hospitals. I
91
This table illustrates the scaling properties of the approach. However, NT and NF depend strongly on whether nodes can be pruned at an early stage. The algorithm can be summarized as follows. Algorithm BBA 1 Initialize the top-node;
2 If the node list is not empty, select a new node; otherwise the last created tour is optimal;
3 Create a child node and evaluate the partial tour for this node; then do one of the following substeps (a) If that child node is on the deepest level of the tree, evaluate it and thus obtain a new evaluated tour. Evaluate also its next brother to the right; this gives the evaluation of a new tour - all nodes of this level and the parent node can be pruned. Goto Step 2. (b) If it is not on the deepest level of the tree then goto Step 3. Nodes are selected deterministically following a priori depth first rules. If one allows less deterministic schemes, it becomes possible to select the most promising nodes and to continue on those parts of the tree. This strategy is accompanied by the hope to find good solutions providing cutoff bounds. Let us finally summarize and comment on the basic assumption of this branch-and-bound scheme. The basic assumption is that both the objective function and the constraints can be evaluated sequentially when the sequence of objects is constructed, i.e., it is not necessary to know the complete sequence at the beginning. The sequencing-scheduling problem involves a set of n distinguishable objects i (orders, jobs, nodes) which need to be sequenced and scheduled, and which are subject to a set of m constraints C j . Let sr be a permutation or sequence of those objects, and let rk(sr), k = 1,.. . ,n, be the set of the first k objects of that sequence sr. We call an objective function, f(sr), cumulative if it can be built up in sequence, i.e., it depends only on the current and previous objects of a given (not yet complete) permutation or sequence:
92
Online Storage Systems and Transportation Problems
The function F n ( ~ n - l , ~ n ( quantifies ~)) the contribution of the first n objects of the sequence to the objective function. A special case is that F n ( ~ n - l , ~ n (depends ~)) only on the nth object. The total lateness is a typical example. The current node can be late because there are already previous lateness. The same "cumulative" concept holds for constraints. In our branch-and-bound approach, constraints only need to be evaluated and checked; thus there is no restriction regarding its algebraic character (linear or nonlinear). If a hard constraint (e.g., capacity constraint) is violated, this is communicated back to the branch-and-bound scheme, and the node of the tree is pruned. If a soft constraint (e.g., temporal constraint) is violated, a penalty function is applied and its value is added to the objective function. Thus, our branch-and-bound method is quite general and is suitable to solve any kind of sequencing-scheduling problem involving cumulative objective functions and cumulative constraints.
4.3.3
Column Enumeration
In this section, for convenience, we use n instead of NV and r instead of
NO.
4.3.3.1 Motivating a Column Enumeration Approach On page 82 it had been shown that there exist nr combinations to assign r orders or requests to n vehicles. We later analyze an example with n = 8 vehicles and r = 6 orders (in the example, the total number of orders is 14 and there are already eight of them already pre-assigned), i.e., 262,144 combinations. Although, it might be possible to compute all those combinations and select the best one, let us consider another approach which we call column enumeration approach (CEA). This approach solves the optimization problem by exploiting its structure. The assignment decisions are decoupled from the routing and scheduling decisions. The idea of the CEA is illustrated by discussing the example below. This example is later described in Chapter 5 in greater depth. If we need to assign r = 6 orders, then we obviously can assign between 0 and 6 orders to each of the n vehicles. There are
combinations, if j indicates the number of assigned orders. Thus, as shown further down in Theorem 4.4, the total number of scenarios to evaluate is ~ r = n g C ~ ~ = =2'n ~ g (,~ ) j=O
j=O
3
(4.3.44)
93
Vehicle Routing Problems i n Hospitals. I
i e . , for n = 8 and r = 6, this gives C6 = 512 subsets. Let us assume, that for each subset of orders or column, indexed by c, we have solved the individual routing and scheduling problem to optimality, i e . , we know the objective function value 2,. The optimal tours might have been computed by the branch-and-bound approach described in Section 4.3.2. Let C6 be the set of all possible assignments, and C: be the set of feasible assignments leading to the objective function value 2,. Note that IC:l 5 C6. If the vehicles have the same capacity and time availability, symmetry could be reduced by excluding those columns c, and the time to compute Zc could be saved. Now we can formulate a set partitioning problem ensuring that all orders are assigned exactly once. In order to do so, we introduce the binary variables, y,: 7c =
{
1, if tour c is used in an optimal solution 0, otherwise.
To illustrate the idea, consider the subsets O1 = {1,2,3), (33 = (61, and O5 = {4,5) of orders which have been identified by solving the set partitioning problem formulated below. For each of them, the optimal tour has been computed given the objective function values Z1, Z3, and Z5. The overall objective function value is just the sum Z1 Z3 Z5. Other subsets, e.g., O2 and O4 have not been selected. The objective function of the set partitioning problem is thus
+ +
The set partitioning model is simple because only one type of constraint is necessary, namely that one ensuring that each order is covered exactly once. If Ici is an indicator function specifying whether column c contains order i, then the constraints
ensure that each order is contained exactly once. In addition the integrality constraints hold
The optimization problem defined by (4.3.45) to (4.3.47) is easy to solve; it finds the optimal solution within seconds. If the problem is solved, the variables y, give, via a look-up table, the orders and the vehicle these
94
Online Storage Systems and Transportation Problems
orders are assigned to. For the larger problems, it might be a problem to store all these data. The optimal solution derived from 504 columns (note that this number is less than the expected one, 512, because for each of the n = 8 vehicles there is one empty subset we are not interested in) columns takes 30 seconds, the Master problem (4.3.45) to (4.3.47) solves in 10 seconds to optimality using Xpress-MP. With this approach it is also possible to solve the problem to optimality with the same set C of columns if the same set of orders need to be assigned to a smaller set of vehicles. This eliminates the necessity to re-compute the subsets.
Comments on Column Generation Techniques The term column usually refers to variables in linear programming parlance. In the context of column generation techniques it has wider meaning and stands for any kind of objects involved in an optimization problem. In vehicle routing problems a column might, for instance, as in the previous subsection represent a subset of orders assigned to a vehicle. In network flow problems a column might represent a feasible path through the network. Finally, in cutting stock problems ([33],[34]) a column represents a pattern to be cut. Column generation is based on a decomposition into a master problem and a subproblem. In simple cases, such as the ones described by Schrage [76] in the LINDO manual, it is possible to generate all columns explicitly, even within a modeling language. Often, the decomposition has a natural interpretation. If not all columns can be generated, the columns are added dynamically to the problem. Barnhart et al. [9] give a good overview on such techniques. A more recent review focussing on selected topics of column generation is [27]. In the context of vehicle routing problems, feasible tours have been added columns as needed by solving shortest path problem with time windows and capacity constraints using dynamic programming [26]. More generally, column generation techniques are used to solve well structured MILP problems involving a huge number, say several hundred thousand or millions, of variables, i e . , columns. Such problems lead to large LP problems, if the integrality constraints of the integer variables are relaxed. If the LP problem contains so many variables (columns) that it cannot be solved with a direct LP solver (revised simplex, interior point method) one starts solving this so-called master problem with a small subset of variables yielding the restricted master problem. After the restricted master problem has been solved, a pricing problem is solved to identify new variables. This step corresponds to the identifi4.3.3.2
Vehicle Routing Problems in Hospitals. I
95
cation of a non-basic variable to be taken into the basis of the simplex algorithm and coined the term column generation. The restricted master problem is solved with the new number of variables. The method terminates when the pricing problems cannot identify any new variables. The most simple version of column generation is found in the Dantzig-Wolfe decomposition [24]. Gilmore and Gomory ([33],[34])were the first who generalized the idea of dynamic column generation to an integer programming (IP) problem: the cutting stock problem. In this case, the pricing-problem, i e . , the subproblem, is an I P problem itself - and one refers to this as a column generation algorithm. This problem is special as the columns generated when solving the relaxed master problem are sufficient to get the optimal integer feasible solution of the overall problem. In general this is not so. If not only the subproblem, but also the master problem involves integer variables, the column generation part is embedded into a branch-andbound method: this is called a branch-and-price algorithm. Note that during the branching process new columns are generated; therefore the name branch-and-price. The reader might ask why we do not use this superior techniques but use the rather special column enumeration approach. We have done so for two reasons: in the online scenarios we are interested, we need only to solve small problems instances, where column enumeration is sufficient enough and column enumeration is much easier to implement. 4.3.3.3 Developing a Column Enumeration Approach If it is possible to generate all columns explicitly rather than implicitly by a set of linear inequalities, a column enumeration approach [9]might be possible. The limits of this approach when applied to our problem are discussed later. Now we describe how to generate the complete set, C, of all columns, i.e., subsets of orders i E 0, r = 101,assigned to a set of vehicles, v E V. Let CT be the union of the sets, CTv,i. e., C, = U,=1,,., C,,, where C,, contains the subsets of orders assigned to vehicle v. Note that C, contains all subsets containing 1, 2, or r orders assigned to vehicle v. Above it was claimed that C, = 2Tn. THEOREM 4.4 Let r be the number of orders and n the number of vehicles. The cardinality C, := ICTI, of the set C,, of all generated columns
Online Storage Systems and Transportation Problems
Proof. The proof is based on some elementary combinatorial properties. The factor n is obvious. It just reflects the fact that the same combinations of orders can be assigned to each vehicle. The coefficient Crj represents the number of combinations of how to extract j elements from a set of r distinct elements, and can be found in any book on comCrj represents the number of ways in which binatorics. The sum Cjr=o a population of r elements can be partitioned into subsets if the size of the subsets is allowed to be any number j = 0 , 1 , . . . ,r . Noting that
it follows that, if we set x = 1 in (4.3.48), we obtain with 1'-j = 1
We have implemented two different approaches to generate the set C,. The first approach works as follows. As there exist 2' subsets for each vehicle, the construction of the sets explores the binary representation of the number k = 0 , 1 , . . . ,2' - 1. Note that each number n E IN has a unique binary representation. Let the orders i be indexed as 1,.. . ,r . Since k < 2', the binary representation of k is given by
where Akv is the coefficient representing the contribution of 2' to k . Assuming for the moment that all vehicles v have the same properties w.r.t. time availability, we define the subsets C.: as
which means that the binary coefficients of k select the orders uniquely. Let us illustrate this by two examples
Vehicle Routing P r o b l e m in Hospitals. I
97
Those numbers of the orders generated in such a way are subject to a permutation mapping assigning the real names of the orders. If the list of orders is {Al,B5,A4,C2), then, for k = 10, the result is CA:={B~,C~). If the vehicles differ in their time availability, some sets ,C, can be eliminated if they contain orders which drastically violate the availability. For example, if a vehicle is only available in the morning, subsets containing orders with requested pickup times at 4pm hours are completely infeasible. Note that one would not eliminate them, if they violate a time availability only slightly. To make this point clearer, consider an example in which the vehicle is available from 8am to 12am, but the requested pickup time is 7:55am. Strictly speaking, this order is not compatible with the availability of that vehicle. But if one accepts a small delay of only five minutes, then this order can be assigned to this vehicle. Therefore, the elimination of columns applies more to offline optimization scenarios covering several hours, while online scenarios have a much smaller time range. The number, N(C,), of operations to generate all columns, C,, is related to the computation of the binary representation of the numbers k = 1 , . . . ,2' - 1 and thus scales with
As discussed above in the current section there might be a need to restrict the size of the columns to at most, say, m orders. If m < r, we generate all subsets but just discard those having more than m orders. For larger values of r it seems to be recommended to use a different variant to generate the subsets, which considers m right from the beginning; otherwise the effort to generate all subsets might be too large. The idea of the second approach is to generate the subsets successively for m' = 1,.. . ,m. For m' = 1 it is clear how to proceed and to initialize the procedure. There are r subsets {i) of size m' = 1 each containing one order i = I , . . . , r . For m' 2 2 we loop over all subsets of size m' - 1. Let iL-l be the largest order in a subset, S&-l, selected from level m'. Then we loop over all orders i > i&l, adding {i) to SA-l, i. e., S&= S&, U {i), and thus generate r - iLp1 subsets of size m. Below this idea is illustrated by an example for r = 4 and m = 3:
98
Online Storage Systems and Transportation Problems
As an example, let us derive the level m' = 3 subsets from the subset {1,2). In this case, we have iLPl = 2. Thus, looping over i 2 iLPl 1 adds (3) and (4) to the subset {1,2), i.e., {1,2) generates the r-iLpl = 2 subsets {1,2,3) and {1,2,4) and so on (see Fig. 4.3.5). In order to avoid storing the subsets in memory, it is more efficient to generate them in a depth-first type fashion in the following sequence indicated by the subscript (actually, it is a lexicographical order if subsets of the same level are considered). This algorithm to generate the subsets
+
Figure 4.3.5.
Generating all subsets in the column enumeration approach
is, especially for m < r, more efficient than the one based on the binary representation. Another complication arises when generating the columns for vehicles which have already some passengers on board, i. e., mo, out of mo, r orders have already been assigned to vehicle v. Consider the case that already two orders have been assigned to vehicle v, and that the size of the column should not exceed m = 4 orders. To give an example, we take the set of freely assignable orders to be
+
0 = {Al, A2, A3, A4, A5, A6) while the orders A7 and A8 have already been assigned to vehicle v. As mo, = 2 and m = 4, only two additional orders, i e . , m - mo, orders can be assigned. All columns contain the orders A7 and A8. Then, 0, 1, or 2 orders out of 6 can to be added. Note, this time, we need to add the empty set corresponding to k = 0 as well. For this special case there exist Cso C61 C62 = 1 6 15 = 22 columns for vehicle v. In there are no pre-assigned orders for vehicle v, then for m = 4 there exist '261 C62 Cs3 C64 = 6 15 20 15 = 56 columns (note that this time the empty column set is not considered) for vehicle v instead of 512, i.e., we save almost 90% of all columns!
+ +
+ +
+ +
+
+ + +
99
Vehicle Routing Problems i n Hospitals. I
4.3.3.4 Summarizing the Column Enumeration Approach Algorithm CEA 1 Explicit generation of all columns C,, as outlined before; followed by a simple feasibility test w.r.t. the availability of the vehicles.
2 Solving the routing-scheduling problem for all columns C,, using the branch-and-bound approach described in Section 4.3.2 (the optimal objective function values, Zcor Zcv , respectively, and the associated routing-scheduling plan are stored). 3 Solving the set partitioning model (4.3.50)-(4.3.53):
subject to C,, Nv
~ ~ l C v i 7= ,1 , 'v'i= 1,...,r ,
(4.3.51)
ensuring that each order is contained exactly once, the inequality
ensuring that at most one column can exist for each vehicle, and the integrality conditions
YcvE { O , 1 )
,
'v'c = 1, ...,C,,
.
(4.3.53)
Unlike the more generic form of the optimization problem defined by (4.3.45) to (4.3.47), the binary variables ycv and the indicator function Icvinow depend on the vehicle index v:
Ycv =
(
1, if column cv is selected
0,otherwise.
7
and
Icvi =
1, if column cv includes order i
0, otherwise.
This allows us to determine easily to which vehicle an order is assigned. However, note that not all combinations of index pairs {c, v) exist; each c corresponds to exactly one v, and vice versa. But much
100
Online Storage Systems and Transportation Problems
more important, this formulation allows us to find optimal solutions with the defined columns for a smaller number of vehicles. The objective function and the set partitioning constraints are just modified by replacing
v=ljw€V
v=llv€V*
the equations (4.3.51) by
and the inequalities (4.3.52) by
CYcv <1 ,
vu
EV*
,
where V* c V is a subset of the set V of all vehicles. Alternatively, if it is not pre-specified which vehicles should be used but it is only required that not more than N: vehicles are used, then the inequality cru
Nv
C C
Ycv
v 5 N*
is imposed. 4 Re-constructing the complete solution and extracting the complete solution from the stored optimal solutions for the individual columns.
Complexity Aspects and Computational Issues 4.3.3.5 The complexity and thus, the numerical efficiency and also the size of the problems which can be solved in reasonable time on a standard computer (Pentium 111, 750 MHz, 512 MB memory, 20 GB harddisc) depends on the following parameters: 1 the number of vehicles, n, 2 the number of orders to be assigned, r , and
3 the maximal number, m, of orders to be assigned to an individual vehicle. Next we discuss how memory and computational time grow as functions of these parameters.
Vehicle Routing Problems in Hospitals. I
101
The memory requirements of our CEA growths linearly in the number, n, of vehicles, as the number of columns generated scales with n. Thus, the computational time to evaluate all the columns is also proportional to n. From our computational experiments for the number of vehicles such that 5 5 n 5 20, the complexity of the set partitioning model does not grow very fast. Using the commercial MILP solver Xpress-MP [41], the set partitioning problem is solved to optimality within seconds. The number, C,, of columns to be generated for r orders, is 2'. Note that r is the number of free orders to be assigned. Pre-assigned orders increase the number of orders contained in the columns but not the number C,. Typical scenarios to be solved are r = 10 leading to C, = 1,024, while C1:, = 32,768 and Czo = 1,048,576. The computational effort to generate all subsets growths with ZT(r- 1) as discussed before near (4.3.49). This requires solving huge set partitioning problems. The largest set partitioning problems we have solved so far included 12,030 columns, i e . , 12,030 binary variables. It seems possible to solve larger set partitioning problems but then more subproblems, and even worse, larger subproblem have to be solved. However, the subproblems become smaller in size when only up to m orders are allowed in each column. Then, only m
columns are considered and need to be stored; let us denote the associated set of all columns by CF, i. e., CF = lCFl . The number m may be derived from the requirement that approximately the same number of orders should be assigned to each of the available vehicles, i e . ,
Note that we added 2 to the approximate average value to be safe and not to miss an optimal solution. If m is significantly smaller than r, the reduction is significant as well, e.g., for r = 20 and m = 5 we are talking about
rather than z20n = 10°.3'20n= 106n. This example might be realistic when assigning 20 orders to 10 vehicles; some might have already some pre-assigned orders.
Online Storage Systems and Transportation Problems
102
For each column the optimal objective function value and its optimal tour sequencing need to be stored. Assuming that each tour node just requires 1 Byte to be stored, the total memory requirement (in Bytes) is (the proof follows after Theorem 4.5)
With lkB= 1024 = 2'' MBvtes
Bytes we get the memory requirements, Ad,: in
Thus, for n = 10 vehicles we get the following results in MBytes
This indicates that, in terms of memory, it is hard to use the CEA beyond r z 20. However, the size of the partitioning models to be solved limits the approach probably already to r w 15. As mentioned above, the problem may become significantly smaller, if not all subsets but only those up to a size of m. orders are considered. The real limiting size is that of the largest routing-scheduling problem ,: we are able to solve exactly. Thus, the critical quantity is the ratio, N of orders per vehicle to be sequenced. Thus, if the fleet has 20 vehicles, it is still possible to solve problems with approximate 2 0 ~ : orders.
THEOREM 4.5 For arbitrary r equation h ' '
E
IN,j E INo and
j
5 r the following
Proof. We prove the equation b y induction over r. r=l.
zxoj (3 )
=0
+ 1= 1= 1
2'. Thus, for r = 1 the statement
true. Now let us consider the induction step. Suppose the assumption true for arbitrary r, i. e.,
Let us calculate it for r+l:
Vehicle Routing Problems in Hospitals. I
4.3.3.6 Numerical Improvements In order to compute exact solutions for the overall problem, the routingscheduling problem also needs to be solved to optimality. As outlined in Section 4.3.2 the number of orders, or better, nodes, to be sequenced is the critical quantity. Thus, the question is whether it is possible to compute an optimal solution without the need t o evaluate all columns with a higher number of orders. The answer is yes and the approach works as follows. Let z,, = z(CF) be the optimal objective function value derived from the sets of columns, C r , defined near (4.3.55). Moreover, the cutoff value, Zc, is initialized to Zc = z,,. The size, m, of the subsets generated, leading, in the presence of pre-assigned orders, to columns with at most m 1 orders, should be chosen as small as possible. If we assume that the number, r, of free orders to be assigned is r 6, then a reasonable choice is
+
>
where r, is the maximum number of pre-assigned orders in the current vehicle set. Now we generate all the subsets needed to obtain the column of CF+l. Note that CF c CFS1 and for each C E CY+' there exists a number k E (1, . . . ,r) and a column C' E Cy such that
i e . , for each column, C, of the larger set, CF+l, of columns we can find a column, C', in the previous set, CF, of columns. Let z' denote the optimal objective function value of the routing-scheduling problem obtained for column C'. We do not evaluate those columns, C E C r + l , for which z' > Zc because such columns C can never be part of an optimal solution of the set partitioning model (4.3.50) and (4.3.53). However, we store the column and its associated objective function value to z,,+l = ZC 1 to be able to use it as a reference column in further iterations. For those new columns remaining to be evaluated, it is also passed to the branch-and-bound approach described in Section 4.3.2.
+
104
Online Storage Systems and Transportation Problems
4.3.3.7 Column Enumeration Coupled to Heuristics To fully explore the advantages of our CEA, the critical parameters r and N: should be matched to each other. While it is possible to solve the set partition problem with up to r % 15 or a little more, the branchand-bound approach becomes inefficient for N: > 10. The gap between 10 and 15 can be bridged by solving the routing-scheduling problem not the approach described in Section 4.3.2 but by solving it using the sequencing heuristic described in Section 4.4.2. Of course, this cannot be claimed to be the optimal solution; it is rather a heuristic in itself which we could call IT3. However, SH has been shown to produce good quality solutions for those scenarios for which we have been able to compute the optimal solution via the branch-and-bound approach. Thus, we hope that this heuristic IT3 produces good solutions for these scenarios as well.
4.4.
Construction and Improvement Heuristics
Here we present heuristics to solve the problem described in Section 4.3.1. The main purpose of the heuristic is to solve larger instances of the problem. Each heuristic consists of two parts: construction of tours, and improvement of existing tours. The obtained tours are improved later. After assigning orders to vehicles, the next step is to sequence the pickup and delivery nodes associated with these orders in sets 0, and to generate initial tours. The improvement part has two phases: first, improving the routing and scheduling of each tour separately (the sequence of nodes in each set 0, is changed), and, second, pickup-delivery node pairs are moved from O,, to O,, .
4.4.1
Construction Heuristics
All construction heuristics we propose consist of several stages: 1 assigning orders to vehicles;
2 distributing the orders not assigned to any vehicle during step 1; 3 sequencing the pickup and delivery nodes of orders and generating a tour. The first stage is common to all heuristics. The basic idea is to distribute the orders of set 0 among NV vehicles ( i e . , assign them to sets 0,) in such a way that 0 = 0, ni?, = 0, i # j . Using a set of N* time bins with a typical value of N B = 24, it is possible to operate in one-hour time slices (for instance, if the pickup time of an order is 8:55am, then the active time slice is 9; if 9:05am, then the active time slice is 10; if
105
Vehicle Routing Problems in Hospitals. I
4:10pm, then the active time slice is 17). First, the orders are sorted in ascending order of pickup times. Order i is assigned to set O,, if the following conditions hold simultaneously: the active time slice k of order i falls into the time window during which vehicle v is available; vehicle v has not more than N o / N v orders (average per vehicle) in time slice k; vehicle v has no orders with similar pickup times (i.e., the difference in pickup times not more than, for instance, 5 minutes); the capacity constraints are not violated for vehicle v, i.e., in time or C , are not exceeded. slice k values Ck,
Cy
If there are several vehicles satisfying these conditions, then the vehicle, vb, that has the lowest number of orders in time slice k, is chosen. Finally, N V disjunct sets, O,, of orders are produced. Orders that are not assigned using the heuristic described above, are collected in the set O U of unassigned orders. The orders i E O U are treated as additional orders to be assigned during stage 2. As orders involving lying passengers may lead easier to infeasibilities, such orders are distributed earlier then all other types of orders. At stage 2, orders o E O U have to be assigned to the existing tours I,. Again, we sort them w.r.t. increasing pickup times. Further there are two possibilities to distribute the orders. The simpler heuristic, DU, distributes the orders uniformly to the available vehicles irrespective of all constraints, i.e., the first order from the set OU is assigned to the first vehicle, the second order to the second vehicle and so on. In this case, the capacity constraints can be violated; this problem is discussed later. The second heuristic, DB, distributes the remaining orders to the vehicles, which would suffer less, i.e., each order is added at the best place of the tour, which gives minimal sum of delays, Sf.DB is usually combined with stage 3. Finally, stage 3 can be performed using two heuristics, CONHI and CONK2 described below.
4.4.1.1
Heuristic CONHl
This heuristic arranges the orders in each set 0, according to increasing pickup times of the orders, i.e., qfrn qE for all m =
<
Om+l
1 , . . . ,N, - 1, where i,, is the pickup node of order om (furthermore, we define jOm to be its delivery node). If the target time for order om 0
106
Online Storage Systems and Transportation Problems
is set for delivery instead of pickup, then the pickup time is calculated by the formula: = T= - AT. The initial tour for each vehicle v is constructed as fofows: g b e h i c l e just leaves its source depot, drives to the pickup node of the first order, delivers the patient at its delivery node, drives to the pickup node of the next order, and so on, i. e.,:
TE
respectively, the tour is defined as a sequence of nodes
The target times for such tours may be violated but possibly not too much. Obviously, the capacity constraints and the AT limit are satisfied. The quality of the tour with respect to the temporal constraints is qualified by the maximum time deviation, D,, and the total lateness
sf.
If, during the second stage, orders originally not distributed are assigned to vehicle v uniformally, some orders in a tour may have similar pickup times (not differing by more than, say, E = 0.05, in hours). They are integrated into the tour as follows (let, for instance, the orders 01, 02, 03 have the same pickup times):
If vehicle v has pre-assigned orders, at first the pre-assigned patients have to be delivered. Let opl and op2be pre-assigned orders with qf 5 T: Pl OP2 ' then the nodes are sequenced as depicted:
4.4.1.2 Heuristic CONH2 For this heuristic, all orders in each set, O,, have to be sorted according to increasing pickup times. Let order 01 E Ov have the earliest pickup ~ the latest pickup time. At the beginning, tour time and order 0 1 have 7, consists of only one order, 01:
Each subsequent order om, starting with 02, has to be added to I,. The and the delivery node j,,, associated with order om, pickup node i, will be inserted at the best positions in I,, ie., to the positions which gives minimal value for Sf. This will be done by using full enumeration
107
Vehicle Routing Problems i n Hospitals. I
illustrated in the example below. Suppose order 02 has to be added. As the delivery node of an order is visited later than the corresponding pickup node, only six potential tours are possible:
z2 sV z3 sv z5 z6 :
:
4
: sv : sv : sv
d, iOl+ io24 jo2 + jol --+ d, + ioz-+ jo2 -' iol-+ jol -+ d, -+iO2 -+ iol jo2 + jol --+ dv -+ io2-+ iol 4 jol + jog --+ d, -+
iol -+ io2-+ jol
-+ jo2 -+
-+
-$
Now we choose that tour I,* for which
Notice, that for some of 7: the capacity constraints can be violated. Since capacity constraints are hard, the penalty for violating t h e ~ nis much higher than for violating time constraints. Therefore, in the worst case CONH2 produces the same solution as CONHI. There are slight differences in the construction of the initial tour I,, if vehicle v has preis constructed assigned orders opl ,oP2,...,opb. In this case the initial 7, as follows:
The pickup and delivery nodes of the remaining orders can be inserted at positions which follows after the block iOpl+ iop2-+ ... -+ iopb, while corresponding patients are already inside the vehicle v. The heuristic inserts the remaining nodes in I,,starting with delivery nodes jopp, ...,jOpb of pre-assigned orders. For instance, jop2 has only two possible insertion positions:
S, + iOP 1 + ioPZ 4
-+jo~2 dv The following theorem estimates the performance of CONH2.
... -+ ioPb -+ jo
-+
THEOREM 4.6 Heuristic CONH2 constructs the tours i n polynomial time. Proof. Let us see how many operations are necessary to construct one tour. Consider the case when set 0,has no pre-assigned orders. Then 10vl - 1 orders have to be added to the initial tour. This means that we
108
Online Storage Systems and Transportation Problems
need to insert 2(10,1 - 1) nodes. To insert the first node from the set of remaining nodes, there are three possible insertion positions (see 4.4.1), for the second one - four positions, for the third one - five positions, and so on, for the 2(10,1 - 1)th node there exist 210,l possible insert3on positions. In total, it takes
operations to construct one tour. This procedure is applied to each vehicle, i.e., in total, N V times. Notice, that max,,l ,..,,N ~ ( O v l=) No. )~ to construct all tours. Thus, it takes 0 ( N 0 , N V ) z N ~ ( N O operations Obviously, 0 ( N 0 , N V ) is a polynom. If 0, has pre-assigned orders, the initial tour I, has at least two nodes, therefore at most 2(10,1- 1) nodes need to be inserted. Thus it takes even less number of operations to construct tours (q.e.d). After the construction phase of the heuristic, each vehicle has a sequence of nodes, I,,to be visited. Combining CONHI or CONH2 with DU or DB there are four different ways to construct tours I,. The following examples illustrate the construction heuristics. Table 4.2: Input information about orders
Table 4.3: Input information about vehicles
EXAMPLE 4.7 Consider the set of orders presented in Table 4.2 with information about the availability of the vehicle from Table 4.3. Here N o = 5, N V = 2. Let the current time be 13.75 and C , = 2, C , = 5. Notice that some orders have pickup times earlier than the current time (it means these orders will be certainly delayed). After distributing all orders, the sets 0, looks as follows: 01 = {04,0.51, O2 = (8). Orders originally not assigned are collected in the set 0' = (01, 02, 0 3 ) . Orders from oUwill be distributed using DU and DB methods.
Vehicle Routing Problems in Hospitals. I
109
EXAMPLE 4.8 Using the sets 0, from the previous example, the heuristics CONHI and CONH2 lead to the following results for I,,D, and S , (in hours). DU and C O W :
DU and CONH2:
DB and CONHI, CONH2:
v 1 2
Dv 0.33 0.00
S,U 1.00 0.00
I, iol i,,
-+
-+
iod -+ io3 -+ jo4 -+ ios j,,
-+
jO3
--f
jol
--f
joj
I n this case DU and DB distribute orders contained in OU i n the same way: 01 := 01 u {01,03), 0 2 := 0 2
U
(02).
As expected, the method CONH2 produced a better solution. The quality of the constructed tours with N: 5 2 is estimated by the following proposition.
PROPOSITION 4.9 Let I,be a n arbitrary tour. If 7, consist of two orders and 0 2 , then a solution produced by CONH2 is optimal.
01
Notice that this proposition cannot be extended to N:
2 3.
4.4.1.3 Penalty Criteria Tours constructed by the heuristics described above do usually not fulfill all temporal constraints. Capacity infeasibilities can occur due to applying DB for distributing remaining orders. In order to remove those infeasibilities we use a penalty approach in the improvement heuristics. The following parameters are used to penalize the various constraints when evaluating node n:
- penalizes capacity infeasibilities (i.e., an order is assigned to a vehicle v for which the number of sitting, lying patients or ones in srl
110
Online Storage Systems and Transportation Problems
wheelchairs exceed C k , C . or C: values, respectively); the lateness, d,,, associated with node n assigned to vehicle v is set to d,, := nl if the vehicle's capacity is exceeded, 4
- used when an order is not in the vehicle's time windows ( i e . , an order is assigned to a vehicle which is "not yet" or "already not" available); d,, is set to d,, := n2
7r2
7r3 - used to avoid that a patient needs to spend more than AT minutes in a vehicle. If t denotes the time, a patient spends already in a vehicle, d,, is set to
4.4.2
Improvement Heuristics
The constructing phase of tours is followed by a tour-improvement phase. We have developed two different heuristic approaches: improving each tour
I, separately (sequencing heuristic; SH)
;
improving tours by re-assigning orders to other vehicles (reassignment heuristic; RH) . The sequencing heuristic rearranges each tour, I,, in such a way, that the sum of lateness and maximal lateness will decrease, if this is possible at all. Initially, I, is characterized by S& The procedure starts by identifying the node n,, in this tour which has the maximum lateness and its associated pickup or delivery node, a,, i.e., in each tour I, we identify the node with maximal S g . The order ow, which contains both the worst node and the corresponding pickup or delivery node, will be removed from I,.These two nodes, which form ow, will be inserted at possibly better positions in the same tour such that new characterizing values Sf < S g . This is done by the full enumeration scheme described in Subsection 4.4.1 for heuristic CONH2. After all tours have been improved, one of the two following reassignment heuristics, I T 1 and IT2, respectively, is applied to improve the tours. 4.4.2.1 Heuristic IT1 This heuristic starts with identifying the worst tour, tour may either be identified by
the total lateness, that is
I,. The worst
111
Vehicle Routing Problems i n Hospitals. I
considering both the maximal sum of lateness and the maximal lateness:
Then, within tour 7, the worst order ow is identified. Note that this is the order associated with the maximum lateness, d,. Order ow (with its associated pickup and delivery nodes) will be removed from 7, and inserted into the tour of another vehicle. A set of different strategies is provided to select the vehicle or tour, respectively, to which order o, is reassigned: Insert order o,, removed from I,,into the tour of that vehicle, which after checking all potential vehicles, has the smallest sum of lateness and smallest maximal lateness. Insert order ow into that tour, for which this insertion leads to a minimal increase of the sum of lateness and the maximal lateness for the tour of this vehicle w.r.t. all other potential vehicles. is the best existing tour, i.e., Insert order o, into tour '&, where Ib tour with the minimal sum of lateness. Note that it may happen that no vehicle exists which is able to take this order o, according to the above criteria.
Heuristic IT2 This improvement heuristic, at the beginning, identifies the worst node, n;, for each I,, v = 1,...,N u . The associated worst orders, o;, corresponding to n: will be removed from each 7, and collected in the set, named OR. The orders in the set OR will be distributed in sequence to the vehicles, which would suffer less, i.e., the sum of delays, Sf, are computed for each tour, I,,and the orders are added to the tour with minimal sum of lateness. Notice, that it is best to use a combination of the reassignment heuristic RH and the sequencing heuristic SH. The computational experiments summarized in Appendix B.B.2.2 suggest to start improving tours with SH, then apply I T 1 , IT2 or a combination of them, and again apply SH. 4.4.2.2
4.4.2.3 Adding an Order to a Tour To add an order i to an existing tour lo,,first, the sum of lateness in this tour, and the maximal lateness Do, of lo, are computed. The basic idea is to determine the best insertion points for these nodes (the
Sg
112
Online Storage Systems and Transportation Problems
pickup and the delivery nodes of i) by a complete enumeration procedure. In an outer loop, the pickup node n l is varied over all possible insertion points. Then, in an inner loop over all remaining points, the delivery node, n2, is inserted (those nodes follow after the pickup point w.r.t. the time, i.e., n2 > nl). Let us denote this tour by I,(il, i2),the associated maximal lateness D,(il, i2)and the sum of all deviations, Sf(il,i2). The best insertion points follows for all kl = 1, . . . ,il - 1 and k2 = 1,. . . ,i2- 1 as the couple
where ?-,F is a set of all feasible tours for vehicle v. Note that the formula (4.4.1) contains the tuning parameter PDwhich allows a certain additive increase of the maximal lateness (with respect to the minimal value found so far), while otherwise, we determine the minimum of the sum of all lateness over all feasible tours, i.e., I,(il, i2) E ZF. This tuning parameter, PD,is one of the most sensitive parameters in the heuristic. Its value can be chosen in an experimental way, depending on D, .
4.4.2.4 Termination Criteria The improvement heuristics can be applied iteratively. For example, at first we apply IT1 and IT2, and when IT2 does not produce an improvement we can again apply IT1 and so on. How should we control the moves in our heuristics and when should we stop them? Let us first list some intuitive criteria and discuss whether they make sense: w
by number of iterations; by inspecting the standard deviation of the lateness in the tours; by inspecting the improvements in Dv and s f ;
by comparing the values of D, and 5 '; with some pre-given values; w
if S : = 0 for all tour.
All these criteria might appear arbitrary and it is reasonable to discuss under which conditions they are useful. The number of iterations needed to converge may be different for different problems with different orders and vehicles. Certainly, Du and Sf cannot become smaller than zero. On the other hand, if they are equal to zero, then this tour is optimal.
113
Vehicle Routing Problems i n Hospitals. I
If this holds for all vehicles v then the overall solution, i.e., the set of all tours, is optimal. If all tours have similar values of Sf, i.e., the standard deviation, as, falls below a certain value, then not much can be achieved by moving an order from one vehicle to another one. This might be a good time to stop the iterative procedure. Of course, if Sf = 0 for all vehicles we can stop because this is an optimal solution fulfilling all temporal constraints. This is the ideal stopping criteria although it probably will be become active only very seldom. Instead we can trace how Sf or 9decrease. Let S and SDbe the sum of lateness and the sum of maximum lateness after reassigning an order from one vehicle to another one, and Soand Sk the corresponding values before reassigning. There are two different schemes implemented which are applied if a new vehicle has been accepted in the cross-over routine:
I
1
I
1 If the conditions S - So 5 E and /So- S: 5 indicating that there is no significant change.
2 If the inequalities So5 S and stop.
< 1.05s'
E
are satisfied we stop
hold, we accept this slight increase
It may happen that no stopping criteria becomes active and cycling occurs. A cycle appears, for instance, when the heuristic at first moves an order from vehicle vl to v2 (vl --+ v2) and the next time back, from vehicle v2 to vl (v2 + vl). A cycle more complicated to detect looks as follows: vl v2, vs ---t v4, v2 + vl, v4 us. We check for both types of cycles and change one time from IT1 to IT2. If this change has already been applied and cycling is identified, the reassignment heuristic stops.
-
-
EXAMPLE 4.10 I n this example we illustrate the final solutions using IT1, I T 2 and CONHI and CONH2 with DB, DU for distributing remaining orders. Also we combine IT1 and IT2. For this particular example CONHI produces the same result in combination with improvement heuristics as CONH2. So, further we do not indicate which one is used. I n combination of I T 1 and I T 2 both heuristics are applied consecutively. max D, v=1,2
= 0.26,
Sf = 0.43) :
DU and I T 2 (max D, = 0.26, c:=~ SE = 0.42): v=1.2
Online Storage Systems and Transportation Problems
114
DlJand combination of I T 1 and I T 2 max Dv= 0.26, u=1,2
DB and I T 2 (max D v = 0.26, v=1.2
DB and combination of I T 1 and I T 2
S ;
Sf = 0.42) :
= 1.00):
max Dv= 0.26,
v=1,2
c:=,sf = 0.41) :
This simple example i s too small to see the eficiency of combining I T 1 and I T 2 , but in o f l i n e cases the combination of these two heuristic can improve the solution significantly.
4.4.3
Simulated Annealing and Vehicle Routing
Simulated Annealing (SA) belongs to the class of metaheuristics for solving optimization problems using a simulation-based approach. Although SA can be applied to continuous optimization problems [87],it is frequently used for finding good, not necessarily optimal solutions to a wide variety of combinatorial optimization problems. The original idea of SA stems from statistical mechanics and Monte Carlo techniques. It can be seen as a generalization of a Monte Carlo method for examining the equations of state and frozen states of n-body systems [59], especially the slow cooling of metals. The Monte Carlo method is coupled to a probability acceptance criterion, which allows to escape from local optima. While often the global optimum is reached, the method neither can guarantee this, nor can it provide a safe bound on a minimization problem. However, by finding feasible points it can provide an upper bound for minimization problems.
Vehicle Routing Problems i n Hospitals. I
115
As other metaheuristics, SA has been applied to vehicle routing problems (cf., [62],[l6]). In this section we present our own formulation of the problem to be set up for an SA routine. This enables us with little programming overhead to treat larger problems and to find (hopefully) good feasible tours. Especially, we use the SA for offline optimization scenarios with 200 to 300 orders.
4.4.3.1
Monte Carlo Methods and Simulated Annealing
In its simplest form, Monte Carlo simulation samples the possible states of a system by randomly choosing evaluation points. The ensemble of randomly chosen points in the search space provides some information about this space. This procedure is useful in some problems, e.g., finding the area of regions bounded by a complicated curve. Unlike choosing those points randomly, in SA a new point in search space is sampled by making a slight change to the current point, i. e., a new point is selected in the vicinity or neighborhood of the current point. The choice of the neighborhood depends strongly on the problem. To illustrate the neighborhood concept, consider a new orientation of the helium atoms created by making a random, small change to the coordinates of each atom. If the energy of this new orientation is less than that of the old one, this orientation is added to the ensemble. If the energy rises, a Boltzmann acceptance criteria is used. If the energy rise is small enough to fulfill a probabilistic rule involving a term such as e-AEIT with energy change A E , and temperature T, the new orientation is added to the ensemble. Conversely, if the energy rise A E is too large, the new orientation is rejected and the old orientation is again added to the ensemble. What is unique about this Boltzmann acceptance probability is that the temperature of the system must be used. In 1983, Kirkpatrick and colleagues [52] proposed a method using a Metropolis Monte Carlo simulation to find the lowest energy (most stable) orientation of a physical system. Their method is based upon the procedure used to make the strongest possible glass. This procedure heats the glass to a high temperature so that the glass is a liquid and the atoms can move relatively freely. The temperature of the glass is slowly lowered so that at each temperature the atoms can move enough to begin adopting the most stable orientation. If the glass is cooled slowly enough, the atoms are able to "relax" into the most stable orientation. This slow cooling process is known as annealing and gives the name to this method simulated annealing.
116
Online Storage Systems and Transportation Problems
Optimization Problems and Simulated Annealing Let us now consider how SA can be applied to optimization problems. Combinatorial optimization problems are often represented by graphs. Let us therefore consider a graph with an energy E assigned to each node. The energy is to be minimized, i. e., the energy plays the role of the objective function, f (x),in the optimization. In the parlance of SA, the nodes are called 'states', the arcs represent 'moves' or 'transitions' from one state to a neighboring state, and the energy is sometimes called 'cost'. Table 4.4 compares and relates the language used in both disciplines: 4.4.3.2
Table 4.4: Analogies between the physics and optimization Physics energy states, configuration moves, transition false solution ground state
O Dimization ~ objective function nodes of a graph, or the decision variables, x arcs of a graph local solution global minimum
The analogy and the generalization of this Monte Carlo approach to combinatorial problems is straightforward ([15], [52]) for some of the objects involved. The current state of the thermodynamic system is analogous to the current solution to the combinatorial problem, the energy function is analogous to the objective function, and the ground state is analogous to the global minimum. The major difficulty and art in implementing the SA algorithm is that there is no obvious analogy for the temperature T with respect to a free parameter in the combinatorial problem. Furthermore, avoidance of entrainment in local minima (quenching) is dependent on the "annealing schedule", the choice of the initial temperature, To, the choice of the number of iterations, N T , to be performed at each temperature, and the choice of temperature decrement at each step as cooling proceeds described by either A T or 6. With a randomly chosen initial state, So,the SA algorithm then works as follows: initialize state S = So repeat the outer loop (until done)
{
T = new temperature, T', repeat (until inner-loop criterion) { generate new state St = random neighbor(S) compute the energy difference A E = E(St)- E(S)
Vehicle Routing Problems in Hospitals. I
117
The temperature T is the control parameter of the algorithm. It is always decreased gradually as the annealing proceeds, but the choice of an optimal control of T is a very subtle issue. While annealing works well on a wide variety of practical problems, like other metaheuristics it always requires considerable fine-tuning depending on the optimization problem at hand: H
What is the best initial temperature?
H
How fast should be done cooling? How long should the simulation be run at each temperature, i. e., how many time the inner loop should be execute?
H
When should the outer loop be terminated?
The initial temperature depends on the expected value of the energy, i e . , objective function. The answer to the third question depends upon the maximum size of the Monte Carlo step at each temperature. While a pure Metropolis Monte Carlo simulation attempts to reproduce the correct Boltzmann distribution at a given temperature, the inner-loop of SA optimization only needs to be run long enough to explore the regions of the search space that should be reasonably populated. This allows for a reduction in the number of Monte Carlo steps at each temperature, but the balance between the maximum step size and the number of Monte Carlo steps is often difficult to achieve, and depends very much on the characteristics of the search space or energy landscape. Improving Tours by Simulated Annealing 4.4.3.3 In order to improve tours or the driving schedule of the whole vehicle fleet we have to develop a neighborhood concept, a transition mechanism and a cooling scheme. We investigated two different SA implementations: H
improving only each tour for each vehicle separately, and
H
reassigning orders from one tour to another one.
Improving tours individually, i. e., single-vehicle tour improvement, produces usually an improvement by 20 t o 30% compared to using heuristics alone. Our implementation of SA applied to reassigning orders was not successful. Let us start by adjusting SA variant for improving an individual tour. If we neglect the temporal and capacity constraints for the moment, such a tour can be understood as a tour in the traveling salesman problem
118
Online Storage Systems and Transportation Problems
(TSP) with a different objective function. However, this objective function is not the sum of terms which only depend on the distance between adjacent nodes but an objective function depending on the whole tour characterized by the sum of lateness and maximal lateness. Nevertheless, this analogy with the TSP helps us to define the neighborhood concept or to define appropriate transitions. In TSP-like problems one often just reverses the direction between two nodes. Therefore, we will call this operation swap. It just depends on two numbers n l and n2, n2 # n l , 1 5 n l , n2 5 N and transforms a given tour 7 with N nodes vl, v2,. . . ,VN
into
Note that the only requirement is n2 # nl. In the example we have n2 > n l but this has been chosen only for demonstration purposes. Alternative to this operation swap we may also wish to shift whole tour segment. This operation is called shzfi and is characterized it by three numbers n l < nz, and n3; with 1 n17n2,n3 5 N and another condition described below. Let us demonstrate this operation by a small tour consisting of 10 nodes and n l = 3, n2 = 6 and n3 = 4. At first we extract the node segment starting at node 3 and ending at node 6 from the original tour
<
which gives
where I, is the extracted path segment. Note that
I, contains
nodes. Now we insert the node segment I, after position ng of 7'which gives
7'
:=
v6,vg,vl~)
.
From this small example we can derive the necessary condition
for obtaining a feasible shift.
119
Vehicle Routing Problems in Hospitals. I
We can now define how often the swap and the shzft operations should be applied. We want to use these operations randomly. Thus, we just need to define the frequency of one operation with respect to another one. Let p, 0 < p < 1, define the probability that we choose the shift operation. If we let a uniform random generator decide which operation to choose, we obtain the following limit:
.
lim
nS
P
-= IC+W nR 1- p
.
As described in Section 5.2.6, p = 0.0125 turns out to be a good value. Let us now concentrate on the cooling scheme. We start with an initial cooling temperature To. If z is the objective function value associated with a tour before applying SA, our numerical experiments in Section 5.2.6 show that To = 0 . 1 ~is a good value. For each sequence of n successful transitions, the cooling temperature is decreased according to the proportional cooling scheme with S = 0.9 established in Section 5.2.6.
Treating Constraints. Constraints are enforced by penalizing violations as this gives maximal flexibility to incorporate all the features present in the real world problem. As was mentioned in Section 4.4.1.3, penalty parameters nl and n2 are applied to capacity and time window constraints. Violations of the time windows related to the availability of vehicles are penalized by the penalty parameter sr3. Objective Function. The objective function is composed of the total lateness, S, and the maximum lateness, Dv. We might choose, for instance, z = S, + WDD, with WD = 15. Other test runs with different values of WD gave worse results. The values S, and D, contain penalty contributions if a tour violates a temporal or capacity constraint. Termination Criteria. Here we might choose either the number of iterations, i e . , how often the temperature has been decreased, the temperature itself, or the number of successful moves. In our numerical experiments we stopped after NT = 100 temperature decreases. Applications Variants. There are many degrees of freedom in applying SA to our problem. We use it either after the first improvement of the constructed tours (IFSAI= I), then start the cross-over heuristics, and then apply it again to the each individual tour (IFSA2= I), or alternatively (IFSA~=0, IFSA2= l ) , we apply it only after the cross-over
120
Online Storage Systems and Transportation Problems
heuristic finished. The latter worked significantly better. This can be understood as follows. The better the solutions of the individual tours, the more difficult is it for the cross-over heuristic to obtain successful moves and to reassign an order to a different vehicle. We also developed a SA scheme for cross-over and inter-tour optimization, but this approach turned out not to be successful. Almost all attempts to reassign an order to another vehicle did not improve the objective function used in SA. Thus, we gave up on this and used SA only for intra-tour optimization.
4.5.
Summary
In this chapter we have developed several approaches to solve VRPPDTWs in hospital transportation. These include exact optimization algorithms (MILP and column enumeration) and heuristic methods. The exact methods are designed to solve online problems of small or modest size. While the MILP approach (Section 4.3.1) often requires a long time to prove optimality, the column enumeration approach (CEA, Section 4.3.3) allows to compute optimal solutions very fast. This approach is based on decomposing the problem into a master problem (a set partitioning problem controlling the assignment of orders to vehicles) and a set of subproblems (intra-tour problem, routing and scheduling). To solve the routing and scheduling problem exactly we have developed a branchand-bound method which prunes nodes if they are value-dominated by previous found solutions or if they are infeasible w.r.t. the capacity or temporal constraints. This approach works fast for up to 10 orders per vehicle. This branch-and-bound method is suitable to solve any kind of sequencing-scheduling problem involving cumulative objective functions and constraints, which can be evaluated sequentially. To solve intra-tour problems containing more than 10 orders we have developed various construction and improvement heuristics (Section 4.4). Especially, to treat larger offline problems with several hundred orders we developed a heuristics to reassign orders to other vehicles, and improve existing tours by simulated annealing (Section 4.4.3).
Chapter 5
VEHICLE ROUTING PROBLEMS IN HOSPITAL TRANSPORTATION. I1 APPLICATIONS AND CASE STUDIES
In Chapter 4 algorithms and heuristic methods have been developed to solve the vehicle routing problem arising in hospital transportation. Here we apply them to the real world problem described in Section 5.1. Real world data enable us to test the models and the heuristics (see Section 5.2).
Here we briefly review only those aspects of the hospital project "OptiTrans" with the Klinikum des Saarlandes in Homburg which are relevant to the online optimization requirements, because this joint project between the ITWM and the Klinikum des Saarlandes in Homburg has been described earlier in great detail [22]. Homburg has a major hospital campus consisting of many buildings spread over 300 ha (see Fig. 5.1.I). The transportation inside the campus is served by a vehicle fleet. One may need to use a vehicle, because some buildings are located very far from each other. Further, the physical state of some patients may also require transportation by a vehicle (passenger transport). Moreover, some passengers need to lie in bed while being transported, others can sit, others can only sit in a wheel chair, some need assistance, i.e., they are accompanied. A few need a special car which carries them in their bed. And again, some others are infectious persons requiring that the car is completely cleaned after a tour.
122
Online Storage Systems and Transportation Problems
Figure 5.1.1. A map showing the hospital campus of the Homburg University
In addition, various objects (medical goods, laundry, food, documents, etc.) have to be transported between buildings every day (the buildings will be called as "pickup location" and "delivery location"). Usually hospitals run their own vehicle fleet to cover their transportation needs. There are 13 vehicles in the Homburg hospital. There are two hospital employees responsible for one vehicle. Each vehicle provides space for two lying and five sitting passengers. The main daily operating time is from 7am to 5pm, but as shown in Fig. 5.1.2 there are also orders at other times. The dispatcher in the central office at first collects the data characterizing orders, and then passes them to the drivers (Fig. 5.1.3). Orders are characterized by their name, pickup and delivery location, required or preferred pickup and delivery times, number and type of passengers or objects to be transported, accompanying personnel to be transported, service times for picking-up and delivering a patient. Special orders are those involving infectious passengers or goods, or those requiring a doctor accompanying the passengers. The dispatcher has to assign those
Vehicle Routing Problems in Hospitals. 11
Time
Figure 5.1.2. Time distribution of the orders over the day
mtrd office
order flow
Figure 5.1.3. Information flow in hospitals
orders to the drivers and vehicles, keeping in mind that waiting and driving times as well as empty drives have to be minimized while passenger satisfaction has to be maximized (see Fig. 5.1.4). Each day, about 200 to 300 transport orders have to be served by this fleet, most of them between 7am and 5pm. The life of the dispatcher
124
Online Storage Systems and Transportation Problems
becomes more complicated because many orders arrive at short notice. Every hour about 20 to 30 new orders appear and need to be assigned and scheduled to the available vehicles requiring that tours can be modified and extended. Typically, one or two passengers are already in a vehicle, when a new order, i.e., pickup location is assigned to a vehicle. The orders associated with the passengers already loaded to the vehicle are called pre-assigned or active orders (i.e., not all old orders are fulfilled when new orders arrive: some patients are still on the way to their destinations).
Figure 5.1.4. Scheduling of orders to the vehicles that done by hands
Orders are allocated to the vehicles according to their availability. If there are many orders with the same target time it is important to ensure that the vehicles are exploited appropriately. Some vehicles may not be available at all or only partially available during the day, i. e., each vehicle has its own time window. Homburg's university hospital is one of the very few hospitals which has already implemented an IT-based transport system. This provides us with a database large enough to use mathematical optimization and optimal routing to allocate orders to vehicles. The optimization model helps to allocate them in such a way that all of them are fulfilled in time, or at least with minimal delay and the capacity of each vehicle is not exceeded.
Vehicle Routing Problems in Hospitals. 11
125
Knowing all orders for a day in advance would lead us to an offline optimization problem in which a tour starts and ends at the depot. However, the reality of this hospital transportation needs leads us to an online optimization situation in which we find a vehicle in a given location and it stops at the last order served. Of course, in order to evaluate the efficiency of our online optimization strategies we need to be able to compare them to the optimal solution of the offline problem. When we do online optimization it may happen that the patient is already in the vehicle. In this case, for this active order we have to consider additional input information, i.e., the number of this vehicle and how long this patient is already in the vehicle. For offline optimization these data are not required. Our online approach solves the online version of the problem but uses an exact optimization method to do so, i.e., to solve this online version. For solving online optimization scenarios it suffices to solve problems which add at most six orders to a vehicle; sometimes there are already two passengers in the vehicle, i.e., two pre-assigned orders present. Thus, in total, eight orders need to be assigned and scheduled. In peak hours there are about 20 to 30 orders, but the dispatcher assigns new orders and re-schedules existing tours every few minutes; actually, he does this immediately, when a new order arrives. Thus, the problem size remains small.
5.2. 5.2.1
Numerical Tests Inputdata
Four ASCII data files contain the required input data: 1 a list of orders each characterized by several parameters;
2 a list of vehicles with time windows indicating when each is available, and the current time; 3 a distance matrix (usually non-symmetric);
4 control files assigning values to the various control parameters. The content of these files is described in detail in Appendix B.B.1.1.
5.2.2
Offline and Online Versions
Both, the models and the heuristics, are tested for online versions. Moreover, we compare the solution, produced by the heuristics for the offline- and online- versions. For the offline version the current time is not relevant. All orders are known in advance and all vehicles are
126
Online Storage Systems and Transportation Problems
located at their depot. For the online version one or several orders could be re-planned. At the current time, T,, all vehicles may be positioned at any location. After re-planning, the vehicle remains where it served the last order. It may also happen that a vehicle has already picked up a passenger, and is just driving from this pickup point to another location when re-planning starts. In this section several experiments under various conditions are presented: 1 intra-tour optimization (no assignment problem involved, single vehicle experiments) ;
2 an offline optimization scenario covering a full day (200 to 300 orders); and 3 online optimization scenarios including pre-assigned orders.
5.2.3
MILP Model
The MILP model involves too many binary variables to apply it to the offline case covering a whole day. Thus, in this section, we present only experiments for
1 intra-tour optimization (no assignment problem involved, single-vehicle experiments); and 2 online optimization scenarios for the whole problem (assignment plus routing and scheduling) including pre-assigned orders. In the sequel we use the following notations:
p is the number of binary variables; rn r is the number of requests (orders), involved in the model;
N is the number of nodes in the branch-and-bound tree of the MILP solver. The cases discussed in this section are named in sequence, M01, ..., MI0 and their detailed tabular results are collected in Appendix B.B.2.1. 5.2.3.1 Intra-Tour Optimization (Single-Vehicle Cases) In this section we analyze an offline data set to illustrate how strongly the performance of the MILP approach depends on the data and structure of the problem. From a given set of orders with overlapping pickup requests we generated several test examples which only differ by the number of orders. The input data are shown in Table 5.1.
Vehicle Routing Problems i n Hospitals. 11
Table 5.1: The input data of the single-vehicle experiment i
order
pickup
delivery
type flagl flag2 servl serv2
..................................................................
type : flagl: flag2: servl: serv2:
I (lying in bed passenger), 2 (sitting passenger) indicate, whether the patient is infectious number of accomponying personnel service time (in min.) required to pickup the patient service time (in min.) required to deliver the patient
Especially difficult to assign are the pairs of orders ({l,2),{3,4),{lO,ll)) with identical pickup times, because the usually lead to situations in which a vehicle arrives significantly late. Table 5.2 shows the results of the Xpress-MP MILP solver when solving the offline scenarios MO1, M02, M03, and M04: Table 5 . 2 : The results of the scenarios M01, M02, M03, and M04 name
r
/3
N
timels
z
All problems have been solved without any special tuning of the XpressMP MILP solver (Release 13.26) or special tightening of the model. The
Online Storage Systems and Transportation Problems
128
objective function values are optimal up to a percentage cut of 1%. Already for seven orders (14 nodes in the tour) the problem cannot be solved easily and in reasonable time. In order to analyze somewhat larger scenarios we apply the arc elimination techniques described in Section 4.3.1.7, and also the cuts (4.3.19) and (4.3.20). Here we report on two experiments using this approach. Case 1 covers 12 orders {1,2,3,4,5,6,11,12,13,14,15,16) while case 2 covers all 16 orders. The results are shown in Table 5.3: Table 5.3: The results of the scenarios M05 and MOB name M05 M06
r 12 16
aB aF 1.00 0.75
~~2
1.00 0.75
0.2
R~
,L?
0.2
149 241
nodes 45496 6,468,076
time/s 188 117.836
z
0.265996 0.283891
Note that RA2and RB have been set to 0.2 because the maximal lateness of the tour obtained by the heuristics was somewhat smaller than this value. These two examples show how the solution time and number of nodes required to prove optimality grow as functions of the number of binary variables. Only four more orders lead to approximately additional 100 binary variables. The running time increases, however, by a factor of 626. What is said in the previous paragraph might give an impression that the MILP model, even in the single-vehicle case, is not useful. This is definitely not so. Below we summarize two experiments with 13 to 16 orders but this time we supported the branch-and-bound process with extra knowledge derived from the solution of the heuristic. For such feasible solutions we know the sum of lateness which is exploited to set the upper bound, SL,used in (4.3.42). Table 5.4 shows the results of the exact optima (no percentage cut) of the MILP model. Case M09 includes all 16 orders while M07 and M08 do not include the orders {2,11,13) and (2,131, respectively. Table 5.4: The results of the exact optima based on the MILP model case M07 M08 M09
r 13 14 16
AB
AF
1.00 1.00 0.70
1.00 1.00 0.70
~~2
0.2
R~
SL
p
0.2
0.16 0.10 0.30
199 227 237
nodes 487 834 247,268
time/s
3 3 1408
z
0.041216 0.074163 0.283887
Note that M09 produces the same solution and detailed tour as M06, but in a much shorter time. Thus the detailed tour is not displayed in the appendix. The small examples in this section show that the performance depends critically on the structure of the problem, less on the number of binary
Vehicle Routing Problems i n Hospitals. 11
129
variables. The objective function values correspond to those obtained by the heuristic approach. The main difference between the easy cases M07 and M08, on the one hand, and the dzficult case M09, one the other hand, is that in the cases M07 and M08 the objective function value is almost zero, while in the latter case it is not. Therefore, in M09 one observes the general problem intrinsic to the problem when using a MILP model: the lower bound increases only very slowly. This is almost equivalent to the fact that feasible integer solutions are only found deep in the tree. If the tree is large it can take a very long time to reach those nodes deep in the tree. We conclude this set of numerical experiments by summarizing that the MILP model can optimally solve single-vehicle problems with a smaller number of orders, but in each specific case it depends strongly on the input data and fine tuning. Thus, it might not be easy to implement this approach into a decision support tool which should work similar in all situations. 5.2.3.2 An Online Case Including Pre-assigned Orders Consider the set of orders presented in Table 5.5 containing the information about the availability of the vehicle from Table 5.6. Here No = 14, NV = 12. Let the current time be T, = 14.128 and C , = 2, C: = 5. Notice, that some orders have pickup times earlier than the current time (this means that these orders will be definitely delayed). Some vehicles have already patients inside, for instance: w
vehicle 2 has one lying patient (order A25525), vehicle 3 has one lying patient (order A25532), vehicle 4 has two sitting patients (orders A25524 and A25504),
w
vehicle 5 has two sitting patients (orders A25501 and A25531),
w
vehicle 6 has one sitting patient (order A25508),
w
vehicle 7 has one sitting patient (order A25441)
The last column of Table 5.5 indicates how many minutes, A,, the passenger is already in the vehicle.
Online Storage Systems and Transportation Problems Table 5.5: Input data for an online case study
I
order
I
Th
I
tvve
I
car
I
A*
I
While all vehicles are available from the current time, T, = 14.128, they differ in the latest time of their availability, as shown in the following Table 5.6. Table 5.6: The input data of the single-vehicle experiment
The best solution obtained using the MILP model is shown in Table 5.7. Table 5.7: The best solutions obtained by the MILP model
Vehicle Routing Problems i n Hospitals. 11
131
Each line of the Table 5.7 contains the following data (from the left to the right):
1 the number of the vehicle, v;
2 the name of the node (a node starting with A is a pickup node); 3 the earliest permissible arrival time, T:, at a pickup node (this is the desired target time);
132
Online Storage Systems and Transportation Problems
4 the real arrival time, t i , in the solution (an asterisk indicates that the passengers assigned to these vehicles were already loaded to the car); 5 the latest permissible time,
qL,(target time for delivery nodes);
6 the lateness, r p , for pickup nodes (a hyphen indicates there was none at all) ;
7 the lateness,
?;B,
for delivery nodes (a hyphen indicates there was
none at all) ; 8 the number, p:,
of sitting passengers in the vehicle; and
9 the number, p;, of lying passengers in the vehicle. The objective function was (4.3.1) evaluated with C z t = 1, and all other components of (4.3.1) were set to zero, i e . , z := cT = cP contained only the penalty cost term for earliness and lateness. The objective function value after 500,000 nodes (or 16 hours CPU time) was z = 1.316780; the best lower bound was z- = 1.202968 which corresponds to an integrality gap of A = 8.6%. This values were already obtained after 4000 nodes, or 4 minutes. In this example, during 16 hours of CPU time the lower bound increased by less than Thus, it may take very long to prove optimality with the MILP solver in this case. Using the column enumeration approach in Section 5.2.4, this value is proven to be optimal. Note that in one case vehicle 3 transports two lying passenger simultaneously. Strictly speaking, the vehicle has capacity for two lying passengers but the dispatcher usually tries to avoid this situation. To avoid this situation, in another run cL was included in the objective function with C E = Cif = 0.001. Table 5.8: Optimal tours with no more than one lying passenger v
node
TE
1
A25528 25528 DDI
13.766
I 1
tA
tL
14.143 14.308 14.266 14.458
rB
S L
0.377089
-
-
0.042389
0 1 0 0 0 0
rA2
-
-
Vehicle Routing Problems in Hospitals. 11
+
The results (see Table 5.8) after a few thousands nodes are z := cT cL = 1.334780 with cT = 1.316780 and an integrality gap of A = 8.5%. Note that this is again the same value, cT, for the sum of lateness as in the previous example. But this time, there is no more than one lying passenger in a vehicle. Numerically, the inclusion of the load term into the objective function had the consequence that the lower bound, z-, increased very slowly.
134
Online Storage Systems and Transportation Problems
We also did further experiments, with a driving cost term included into the objective function (4.3.1) with CE,,, = 0.001. Our intention was to investigate whether this would destroy the intrinsic symmetry in the problem. The effect was, however, very small and the integrality gap even increased. While these examples show that the MILP model can compute feasible solutions even in short time, the time to prove optimality is by far too large for implementing this approach in real world applications.
5.2.4
Column Enumeration Experiments
In this section we discuss the performance of our column enumeration approach (CEA) when applied to the online example described on page 129, and present one additional example. Table 5.9 shows the results of the CEA for the test case TC9RC; the character R indicates that the restricted availability of the vehicles has been considered, C stands for CEA. The penalty parameter 71.3 has been set to zero, i.e., it might happen that a passengers spends more than 30 minutes in a vehicle. The objective function value, the sum of the lateness, is z = 1.317333, while the maximal lateness which occurred was 0.526 for vehicle 5 associated with the delivery of order A25364. It took only 14 seconds to compute this optimal solution involving C6,3= 140 columns. Note that the tolerance parameters for the time availability of the vehicle have been set to 15 minutes (0.25 hours). Therefore, the tours for vehicle 2 and 3, which are actually only available till 14.20, are considered as feasible although the arrival time of vehicle 2 at the last delivery node is 14.203, which is just feasible. Table 5.9: Optimal tours with restricted availability of the vehicles
135
Vehicle Routing Problems i n Hospitals. 11
Note that an asterisk in the Table 5.9 indicates pre-assigned orders. For the pickup nodes of such pre-assigned orders the arrival times is not displayed. To compare the CEA approach with the MILP approach, we applied it to the example TC9RC analyzed in Section 5.2.3.2, i.e., we solved TC9RC under the assumption that the vehicles are available the whole day. In this case, we obtained z = 1.317333 with the tours shown in Table 5.10. Table 5.10: Optimal tours with restriction on vehicle availability v s-node
d-node
tD
TD
tA
TT
delay
..................................................................
z
S L IC
136
Online Storage Systems and Transportation Problems
Note that this value is the same as in the more restrictive case described above. The MILP model gave a slightly different objective function is caused by numerical value z = 1.31678. The difference of 5.53 x rounding. Table 5.9 shows that only 9 vehicles are needed. Using the same set of columns it is easy to investigate how the objective function value increases if less vehicles are allowed or available. As there are already 6 vehicles with pre-assigned orders, only the cases 6 5 N~ 5 9 leading to the results
are of interest. In this example, the results were obtained within seconds. Allowing a total increase of about 11% for the sum of the delays, 3 vehicles could be saved completely.
137
Vehicle Routing Problems in Hospitals. II
Let us now solve another online example with NA4 = 13 pre-assigned and NF = 13 free orders to be assigned to 10 vehicles. This set of orders involves one, A64439, requiring a wheelchair passenger needs to be transported, and another one, A64453, which just needs to carry some goods not requiring any capacity. In this case study the penalty parameter controlling that a passenger does not spend more than A T = 30 minutes in a vehicle, has been set to a high value of 200. The solution table below indicates pre-assigned orders by an asterisk in some lines; the same line shows in the last column how many minutes the passengers is already in the car when the clock is set to the current time of T, = 11.004. Vehicle 4 has three pre-assigned orders. With 13 orders to be distributed to 10 vehicles, we set the number, m , of orders per subset to m = 5 , i e . , those vehicles with no pre-assigned orders can pickup at most 5 orders. The columns for vehicles containing pre-assigned orders are allowed to have a total of m 1, i e . , 6 orders. Note that wheelchair orders are treated as loading two sitting passengers. Due to the strong penalization of having passengers spending more than 30 minutes in a car, the orders close to that limits are always delivered before other orders. It turns out in the optimal solution that all vehicles have about the same load (number of orders). The total number of columns generated was C13,6= 12030. It took 20 seconds to generate all of them, but 44 minutes to evaluate them. The set partitioning problem was solved within 3 seconds giving the optimal solution with an objective function value of z = 0.382422. None of the 10 vehicles had a total of more than 3 orders in the optimal solution, except for vehicle 4 which had already 3 pre-assigned orders and got one additional order assigned. Therefore, we did a comparative run based on C13,3= 3779 columns. Within 10 seconds an optimal solution with the same objective function value but a different assignment of the vehicles was obtained. As the computational time of 44 minutes is too much time for the online dispatcher, the numerical experiments based on C13,5and CI3,3 triggered those improvements described in Section 4.3.3.6 using the cutoff value, Zc, in the routing-scheduling tree. Using this approach the problem is solved within 4 minutes giving the same solution with objective function value z = 0.382422. The detailed solution is shown in Table 5.11.
+
138
Online Storage Systems and Pansportation Problems
Table 5.11: Online optimization with 13 pre-assigned and 13 free orders v s-node
d-node
tD
TD
tA
TT
delay
..................................................................
z
S L IC
Vehicle Routing Problems i n Hospitals. 11
5.2.5
139
Construction and Improvement Heuristics
Here we present the results of several experiments for the implemented heuristics described in Section 4.4. For the numerical experiments we use the real data recorded on September 1, 18 and 19, 2001 (for the input data see Appendix B.B.2.2.1). We tested our heuristics in an offline situation (as we know all orders in the morning in advance) and in an online situation (the algorithm is applied subsequently, when 10 new orders have been collected). In our program, online and offline cases are controlled by parameter IOPTMD (see Appendix for the possible values of all control parameters). The quality of the tours is characterized by the quantities listed on page 69:
1 the total lateness, z =
NV
sf;
2 the sum of maximal lateness, SD;
3 the average sum of lateness, 4 the average maximum lateness,
NV
z , / ~ ~ ;
SD;
5 the maximal lateness, D,. 5.2.5.1 Offline Version We test and compare all combinations of the heuristic steps CONHl, CONH2 with I T l , IT2 and distribution of non-assigned orders using DB. We
Online Storage Systems and Transportation Problems
140
do not use DU because in most offline cases there are many orders that are originally not assigned to any vehicle. If these unassigned order would be distributed uniformally over the vehicles, too many infeasibilities would be produced. When applying the combination IT1 and IT2 heuristics, we test the following acceptance criteria:
1 a new tour for a vehicle v is accepted, if:
2 a new tour is accepted unconditionally. Thus, we have eight possible combinations of how to combine the steps CONHI, CONH2 with the steps ITI, IT2: I: 11: 111:
IV: v: VI : VII: VIII:
CONHI and CONHI and CONHI and CONHI and CONH2 and CONH2 and CONH2 and CONH2 and
IT1 ITI+IT2 with ITI+IT2 with IT2 IT1 ITI+IT2 with ITI+IT2 with IT2
the first acceptance criteria the second acceptance criteria
the first acceptance criteria the second acceptance criteria
The results of various experiments are summarized in Tables 5.12, 5.13 and 5.14 using the real data for 1, 18 and 19 September, 2001 (see Appendix B.B.2.2.1). Table 5.12: Comparison of the algorithms for September, 1
Table 5.13: Comparison of the algorithms for September, 18
Vehicle Routing Problems in Hospitals. II Table 5.14: Comparison of the algorithms for September, 19
The results in the tables above lead us to the conclusion that there is no best heuristic which outperforms all other for all data instances. What in average performed best was a combination of IT1 and I T 2 with either CONHI or CONH2.
Online version The online version of the construction and improvement heuristic is only slightly different from the offline version. Instead of the depot, any position is used as the original location of a vehicle. Furthermore, there is no need to return to the depot. All information about the original locations of the vehicles, their availability and the current time is located in a file displayed in Fig. B.1.2. In Table 5.15 we show the results of our heuristic approaches for the test case TCSRH; the character R indicates the restricted availability of the vehicles has been considered, H stands for heuristics. This example case is the same as TC9RC considered in Section 5.2.4. Using the heuristics, the objective function value, i. e., the total lateness is z = 1.537877, while the maximal lateness which occurred was 0.528155 for vehicle 6 (again the delivery of order A25364). Note that the objective function value differs approximately by 17%, i. e., 0.22 from that of the optimal solution derived in Section 5.2.4. 5.2.5.2
Table 5.15: Results of experiments for the test example TC9RH v s-node
d-node
tD
TD
tA
TT
delay
z
S L IC
142
Online Storage S y s t e m s and Transportation Problems
If it is assumed that the vehicles are available the whole day (test case TCSH), the heuristic produces a set of tours with z = 1.352643 and the following tours (see Table 5.16). Table 5.16: Results of the test case TC9H v s-node
d-node
tD
TD
tA
TT
delay
z
S L IC
Vehicle Routing Problems in Hospitals. I1
In this case, the difference to the optimal solution with z = 1.3173 is again only very small. The large difference obtained for the test case TC9H indicates that the use of penalty strategies is not ideal for the inter-tour heuristic; it seems to be difficult to reassign time-critical orders to a different vehicle.
5.2.6
Simulated Annealing Examples
Simulated annealing when applied to a problem requires to specify the following tuning parameters: w
the initial tuning temperature, To,
w
how many iterations, NT, are performed at each temperature,
w
how much the temperature is decreased at each step as cooling proceeds described by either A T or 6,and the frequency ratio, p, of swaps and shifts.
In a series of initial numerical experiments we derived some appropriate values for the tuning parameters p and S involved in the simulated annealing method described in Section 4.4.3. Usually, p = 0.0125 is a good value to select shifts or swaps, while S = 0.9 should be chosen to connect subsequently chosen temperatures. The initial temperature, To,is set to To = 0 . 1 ~ 0where , zo is the objective function value of the tours initially provided. The temperature is decreased for at most NT = 100 times.
144
Online Storage Systems and Transportation Problems
In this section we apply SA to three examples. For these examples, we tested the following combinations: A:
CIH only; no SA (IFSAl=IFSA2= 0)
B: C:
SA to each individual tour after applying CIH; (IFSAI= 0, IFSA2= 1) after B, the optimal tours are used as input to the CIH, followed by a final SA step.
For the three September data sets (scenarios S2, S f , and Sg) we got the following results: Sep 1, 2001 (Sz)
Sep 18, 2001 (Sf)
Sep 19, 2001 (S,)
where in each row the quantities introduced at the beginning of Section 5.2.5 are given, and r is the CPU time in seconds. The first heuristic (A) corresponds to combination I1 (for Sep 1) and combination I11 (Sep 18 and 19) described in the previous subsection. The last combination of all heuristics (C) which might be considered less good because of the strongly increased value of the maximum lateness. Thus, the overall conclusion is that SA, applied to single-tour optimization and used at the right places, can improve the quality of offline solutions covering a whole day.
5.2.7
Summary of the Numerical Experiments
In this section we have applied various algorithms to offline and online problems. While the offline problems with several hundred orders can only be solved with heuristics and metaheuristics, we are able to find optimal solutions for the online cases, relevant to our real world problem, in short time. The taylor-suited heuristics produces significantly better results than the simulated annealing method for the overall problem, however, SA can improve existing single-vehicle tours or can lead to better solutions in combination with the heuristic. The MILP model produces optimal solutions only in small and special cases with less than 5 or 10 orders. In some cases, we also have solved intra-tour optimization problems with up to 16, sometimes even 25, orders to optimality using the MILP approach. Although the MILP model can solve problems with a smaller number of orders to optimality, it depends too strongly
145
Vehicle Routing Problems in Hospitals. II
on the data structure and fine tuning and thus is not appropriate to be implemented into a decision support tool which should deliver a good quality solutions in all situations. Optimal solutions of online problems including up to 20 or 30 orders to be assigned to a fleet of 10 vehicles are obtained by a column enumeration approach. The exact solutions are further used to evaluate the quality of our heuristic intra-tour algorithms. This shows that the heuristic methods in many cases produce optimal or near-optimal solutions. Table 5.17 shows the range of the number of orders when to apply which method to solve the intra-tour optimization problem. Table 5.17: The performance of the solution approaches for solving the intra-tour problem as a function of the number of orders.
In Table 5.17, the preferred method for each range of number of orders is indicated by %". The symbol "$' means, that for this range the method works reasonably but may be not the most efficient one; "( J)" means that this may be possible but is not really recommended due to its low efficiency. Table 5.18 shows the range for the ratio, NF/NV, free orders, NF, to be assigned over the number, N V , of available vehicles. It gives the optimal range for solving the overall problem including the assignment and the sequencing problem. Table 5.18: The performance of the solution approaches for solving the complete
VRPPDTW (assignment, sequencing, and scheduling) as a function of the ratio: free orders over available vehicles. -
~
MILP CEA+B&B
1d 1 I *
-
-
-
(d) l ( d )
I *
1
-
~
1
Note that the range NF/NV 5 8 covers most of the online scenarios. In rush-hours about 20 to 30 new orders arrive per hour. Usually, re-
146
Online Storage Systems and Transportation Problems
scheduling is done after each 10 minutes. With a fleet of about 10 vehicles, the ratio N F / N V 5 8 is easily met. The range 15-40 corresponds rather to the offline scenarios. The sequence of online solutions obtained during a day can be compared to the approximate solutions derived from the input data of all orders assumed to be known in advance. A key quantity to inspect is the average maximum delay. The numerical experiments covering a whole day in Section 5.2.5 and 5.2.6 show that the average maximum delay is of the order of 0.15 hours, ie., nine minutes. This knowledge and the usage of our online strategy can w
reduce the waiting times for passenger's pickup, decrease delayed pickup and delivery,
w
reduce the time a passenger spends in a car, and
w
lead to a better load balance of all vehicles.
Some of the algorithms, especially the column enumeration approach discussed here, can be embedded into a dispatcher support system for a hospital. The construction and improvement heuristics have already been implemented as a decision support tool used for simulation purposes. The heuristics alone lead already to significant reductions of the passenger waiting time by at least 12% (see Fig. 5.2.5) and vehicle driving times (see Fig. 5.2.6). More details are given in [22, Section 2.31. Without Optimization
With Optimization
Simulation Time
I I
Figure 5.2.5. Waiting times during the course of a day
5.3.
Summary
The quality of the online tours produced by our heuristics has been compared to the exact optimal solution where available. The comparison
Vehicle Routing Problems in Hospitals. I1
Without Optimization
With Optimization
Arrival n m e
Arrival n m e
Figure 5.2.6. Driving times during the course of a day
shows that for small and medium size scenarios the heuristic solutions are often close to the optimal solution. However, if soft constraints, (e.g., the vehicle availability constraints) are modeled by penalty functions the solution quality decreases. For larger offline scenarios the solution produced by the heuristic method are improved by simulated annealing. Thus, there is some room to improve the heuristic methods. One possible approach to solve the problem faster is to use a combination of the MILP model and heuristic approaches. Because solving the MILP problem or proving optimality of its solutions may take too long, it could be reasonable to treat the assignment part, i e . , distributing orders over all vehicles, using some heuristic (for instance, CONHi or CONH2). The heuristic step gives the assignment of the orders to the vehicles and the upper bounds on the sum of lateness. This upper bound is exploited by the MILP model or the branch-and-bound approach to compute the optimal solution of the intra-tour problem. ~lternatively,full column generation techniques involving a branchand-price algorithm can be applied to solve larger scenarios. The current version is based on column enumeration generating all possible columns in advance - this prevents us from solving large problems to optimality. For the offline case to check the quality of solutions produced by our heuristics it can be useful to apply a column generation approach, while for solving subproblems of smaller size - to use our suggested branchand-bound approach. Finally, we want to comment on the quality of the online solutions compared to the offline solutions. Instead of a competitive analysis we have estimated the quality of our online algorithms by comparing the characteristic properties of the online and offline solutions. The most relevant quantity is the average delay per order. The values of the average delay of orders are similar in the offline and online solutions. More cannot be expected.
Chapter 6
SUMMARY
In this book we have analyzed and developed online algorithms involving exact optimization and heuristic techniques to support decision making in inventory and transportation logistics. We have applied those methods to two real life problems: a special carousel based high-speed storage system - Rotastore and a hospital transportation problem. In Chapter 2 we showed that some types of logistics problem are NPhard and not easy to solve to optimality in offline situations. We considered a polynomial case and developed an exact algorithm to solve a certain type of the Batch Presorting Problem (BPSP) in offline situations. To estimate the quality of our algorithms developed for online cases we use competitive analysis showing that the proposed online algorithm is ;-competitive. To check how the knowledge of future requests can improve the performance of the algorithm, we constructed new online algorithms with lookahead. Some of them are able to improve the online solutions. Moreover, we investigated the origin of the problem complexity and proved that the problem without the capacity constraint on an additional storage has an integer polyhedron. The vehicle routing problem we solved for the health sector is a typical online optimization problem (Chapter 4). It was demonstrated that reasonable solutions for the offline case covering a whole day with a few hundred orders can be constructed with a heuristic approach, as well as by simulated annealing. For small cases our MILP model and exact optimization works as well but it is impractical in terms of running times. Optimal solutions for small instances (up to ten additional orders per vehicle) are computed by a column enumeration approach (CEA) based on decomposing the problem into a master problem (a set partitioning problem controlling the assignment of orders to vehicles) and a set of
150
Online Storage Systems and Transportation Problems
subproblems (intra-tour problem, routing and scheduling). To solve the routing and scheduling problem exactly we have developed a branchand-bound method which prunes nodes if they are value-dominated by previous found solutions or if they are infeasible w.r.t. to the capacity constraints. This approach works fast for up to 10 orders per vehicle. This branch-and-bound method is suitable to solve any kind of sequencing-scheduling problem involving cumulative objective functions and constraints, which can be evaluated sequentially. The CEA we have developed to solve the hospital transportation problem is of general nature. Thus, it can be embedded into other decision-support systems involving assigning, sequencing and scheduling, if the size of the problem and the structure of the sequencing and scheduling problem problem are appropriate. Further work in this direction might focus on solving exactly larger instances of the subproblems with larger numbers of orders per vehicle. The comparison of the results obtained by the heuristic methods with those for which we were able to compute the optimal solution shows that the heuristic in many cases produces optimal or near-optimal solutions. What can a logistics manager responsible for an inventory storage systems and the developer of decision support systems for a hospital campus learn from this book? They can learn that their problems can be solved using online optimization techniques. The methods and algorithms we have developed can be adapted to solve similar logistic problems. And there is good reason to believe that they can improve the quality and reliability of the decisions significantly.
Summary
GLOSSARY Arc: An object within a graph. Arcs, sometimes also called edges, usually represent roads, pipelines, or similar paths along which some material can flow. Often arcs have a capacity. Arcs connect the nodes in a graph. Basic variables: Those variables in optimization problems whose values, in non-degenerate cases, are away from their bounds and are uniquely determined from a system of equations. Basis (Basic feasible solution): In an LP problem with constraints Ax = b and x > 0 the set of m linearly independent columns of the m x n system matrix A of an LP problem with m constraints and n variables forming a regular matrix B. The vector X B = B-'b is called a basic solution. X B is called a basic feasible solution if X B > 0. Bound: Bounds on variables are special constraints. A bound involves only one variable and a constant which fixes the variable to that value, or serves as a lower or upper limit. Branch & Bound: An implicit enumeration algorithm for solving combinatorial problems. A general Branch & Bound algorithm for MILP problems operates by solving an LP relaxation of the original problem and then performing a systematic search for an optimal solution among sub-problems formed by branching on a variable which is not currently at an integer value to form a sub-problem, resolving the sub-problems in a similar manner. Branch & Cut: An algorithm for solving mixed integer linear programming problems which operates by solving a linear program which is a relaxation of the original problem and then performing a systematic search for an optimal solution by adjoining to the relaxation a series of valid constraints (cuts) which must be satisfied by the integer aspects of the problem to the relaxation, or to sub-problems generated from the relaxation, and resolving the problem or sub-problem in a similar manner. Branch & Price: An algorithm for solving large structured mixed integer linear programming problems. This algorithms is usually part of a column generation algorithms. Column enumeration: An algorithm for solving large mixed integer linear programming problems which operates by solving a master problem and a set of subproblems. Unlike column generation, in this case all columns are generated and evaluated a priori. The master problem is often a set partitioning problem. Column enumeration is a special case of column generation.
152
Online Storage Systems and Transportation Problems
Column generation: An algorithm for solving large linear or mixed integer linear programming problems which operates by solving a master problem and then generating new columns (variables or more general objects) by solving a subproblem. If the subproblem contains integer variables, a Branch & Price algorithm is used in addition. Constraint: A relationship that limits implicitly or explicitly the values of the variables in a model. Usually, constraints are formulated as inequalities or equations representing conditions imposed on a problem, but other types of relations exist, e.g., set membership relations. Feasible point (feasible problem): A point (or vector) to an optimization problem that satisfies all the constraints of the problem. (A problem for which at least one feasible point exists.) Graph: A mathematical object consisting of nodes and arcs, useful in describing network flow problems. The structure and properties of graphs are analysed in graph theory, a mathematical discipline. Heuristic solution: A feasible point of an optimization problem which is not necessarily optimal and has been found by a constructive technique which could not guarantee the optimality of the solution. Infeasible problem: A problem for which no feasible point exists. Node: An object within a graph. Nodes usually represent plants, depots, or a point in a network. Nodes can be connected by arcs. N P completeness: Characterization of how difficult it is to solve a certain class of optimization problems. The computational requirements increase exponentially with some measure of the problem size. Objective (objective function): An expression in an optimization problem that has to be maximized or minimized. Online Optimization: A sub-discipline of optimization applied to real life decision problems where decision should be made online based on partial, insufficient information or without any knowledge of future. Offline Optimization: A technical term used in opposition to online optimization. It is assumed that all information about the future are given completely and deterministically. Optimization: The process of finding the best solution (according to some criterion technically called objective function) of an optimization problem subject to constraints. Optimum (optimal solution): A feasible point of an optimization problem that cannot be improved on, in terms of the objective function, without violating the constraints of the problem.
Summary
153
Relaxation: An optimization problem created from another where some of the constraints have been removed or weakened. Simplex algorithm: Algorithm for solving LP problems that investigates vertices of polyhedra. Unimodularity: A property of a matrix. A squared matrix is called unimodular if its determinant is +l. An LP matrix is called unimodular if all its sub-matrices have determinants with value +1, 0 or -1. If an LP matrix is unimodular, and the right-side constraint vector has only integer entries, then all basic feasible solutions to the LP take integer values. Variable: An algebraic symbol used to represent a decision or other varying quantity. Variables are also called "unknowns" or "columns".
Appendix A Rotastore
A.1.
Tabular Results for Different Models
The first set of tables shows the results for BPSPl for test example M60-1 with
N~ = 2, ..., 5 . Table: BPSPl for test example M60-1 with N' Cycle
NS
1
2 2
2 3 4 5 6 7 8 9 10 11
12 13 14 15
2
2 2 2 2 2 2 2 2 2 2 2 2
CPU,sec.
NOC
opt NOC
= 2.
Optimality gap
2.453 2.343 2.383 2.313 2.153 2.163 2.173 2.153 2.203 2.233 2.403 2.193 2.193 2.223 2.223
45 75 93 107 124 140 154 175 187 199 210 225 242 254 262
44 68 79 86 88 92 98 103 112 120 128 134 142 152 161
2.27% 10.29% 17.72% 24.42% 40.91% 52.17% 57.14% 69.90% 66.96% 65.83% 64.06% 67.91% 70.42% 67.11% 62.73%
33.805
262
161 av: 49.32%
..................................................... total:
Table: BPSPl for test example M60-1 with N' Cycle
NS
CPU,sec.
NOC
opt NOC
= 3.
Optimality gap
156 7 8 9 10 11 12 13 14 15
Online Storage Systems and Transportation Problems 3 3 3 3 3 3 3 3 3
2.133 2.163 2.193 2.183 2.323 2.173 2.133 2.163 2.173
158 181 194 209 220 235 255 265 272
95 98 105 114 125 134 140 149 156
66.32% 84.69% 84.76% 83.33% 76.00% 75.37% 82.14% 77.85% 74.36%
32.777
272
156 av: 56.41%
.................................................... total:
Table: BPSPl for test example M60-1 with N S = 4. Cycle
NS
CPU,sec.
I 2 3 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
2.313 2.233 2.153 2.153 2.154 2.153 2.173 2.153 2.163 2.143 2.153 2.133 2.173 2.143 2.173
44 75 96 112 127 142 156 177 190 205 215 230 248 260 266
44 68 79 85 87 91 95 97 102 111 122 132 139 149 155
32.566
266
155 av: 57.22%
NOC
opt NOC
Optimality gap
....................................................
total:
0.00% 10.29% 21.52% 31.76% 45.98% 56.04% 64.21% 82.47% 86.27% 84.68% 76.23% 74.24% 78.42% 74.50% 71.61%
Table: BPSPl for test example M60-1 with N S = 5. Cycle
total:
NS
CPU,sec.
33.916
NOC
269
opt NOC
Optimality gap
155 av: 56.84%
Appendix A: Rotastore The next set of tables shows the results for BPSP2 for test example M6O-1 with N~ = 2 , ..., 5.
Table: BPSPz for test example M60-1 with N S = 2. Cycle
NS
total:
CPU,sec.
115.79
NOC
181
opt NOC
161
av:
Optimality gap
7.79%
Table: BPSPz for test example M60-1 with N S = 3. Cycle
NS
total:
CPU,sec.
115.25
NOC
171
opt NOC
156
av:
Optimality gap
6.86%
Table: BPSP2 for test example M60-1 with N S = 4. Cycle
NS
I 2 3 4
4 4 4 4
CPU,sec.
NOC
opt NOC
Optimality gap
.................................................... 8.40 6.81 6.59 6.64
44 68 79 85
44 68 79 85
0.00% 0.00% 0.00% 0.00%
158 5 6 7 8 9 10 11 12 13 14 15
Online Storage Systems and Transportation Problems 4 4 4 4 4 4 4 4 4 4 4
6.64 7.75 8.40 6.75 6.59 6.64 6.81 6.65 6.81 6.92 7.03
87 98 107 112 124 129 141 147 152 163 172
105.43
172
0.00% 7.69% 12.63% 15.46% 21.57% 16.22% 15.57% 11.36% 9.35% 9.40% 10.97%
- ------------
.......................... total:
av:
8.68%
Table: BPSPz for test example M60-1 with N S = 5. Cycle
NS
CPU,sec.
NOC
opt NOC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
5 5 5 5 5 5 5 5 5 5 5 5 5 5 5
13.12 8.08 6.70 6.54 6.38 7.47 7.14 6.70 6.81 7.04 7.53 6.86 6.98 9.34 7.63
44 68 79 85 87 94 101 112 123 129 139 149 155 164 174
44 68 79 85 87 91 96 98 103 111 122 132 138 147 155
114.32
174
155
Optimality gap 0.00% 0.00% 0.00% 0.00% 0.00% 3.30% 5.21% 14.29% 19.42% 16.22% 13.93% 12.88% 12.32% 11.56% 12.26%
....................................................
total:
av:
8.09%
Finally, the results for BPSP3 for test example M6O-1 with N' Table: BPSP3 for test example M60-1 with N S = 2. Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14
2 2 2 2 2 2 2 2 2 2 2 2 2 2
CPU,sec. opt NOC
............................ 263666.65 3.68 1.32 1.37 1.26 1.27 2.42 2.30 2.75 1.32 1.43 1.81 2.52 1.64
44 68 79 86 88 92 98 103 112 120 128 134 142 152
= 2, ...,5 .
Appendix A: Rotastore
total:
263694.65
161
Table: BPSP3 for test example M60-1 with N' Cycle
NS
= 3.
CPU,sec, opt NOC
............................ total:
122.64
156
Table: BPSP3 for test example M60-1 with N' Cycle
NS
CPU,sec. opt NOC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
10.38 8.13 7.69 7.85 7.75 8.40 7.47 8.02 7.75 10.98 8.24 8.02 7.80 11.09 8.07
= 4.
............................
44 68 79 85 87 91 95 97 102 111 122 132 139 149 155
............................
total:
127.64
155
Table: BPSP3 for test example M60-1 with N ' = 5. Cycle
NS
1 2 3 4
5 5 5 5
CPU,sec. opt NOC
............................ 9.06 8.35 8.40 8.07
44 68 79 85
160
Online Storage Systems and Transportation Problems
total:
Results for BPSPl for test example M60-2 with N S = 2, ..., 5 Table: BPSPl for test example M60-2 with N S = 2. Cycle NS CPU,sec.
NOC
opt NOC
Optimality gap
..................................................... I 2 3 4 5 6 7 8 9 10 11 12 13 14 15
2 2 2 2 2 2 2 2 2 2 2 2 2 2 2
2.473 2.574 2.494 2.403 2.353 2.493 2.344 2.494 2.484 2.293 2.453 2.433 2.323 2.273 2.483
46 73 94 110 126 139 162 179 191 201 218 236 249 257 274
45 64 77 82 88 90 96 101 108 118 128 136 146 152 160
2.23% 14.06% 22.08% 34.15% 43.18% 54.44% 68.75% 77.23% 76.85% 70.34% 70.31% 73.53% 70.55% 69.08% 71.25%
36.370
274
160 av: 54.53%
.....................................................
total:
Table: BPSPl for test example M60-2 with N S = 3. Cycle NS CPU,sec.
NOC
opt NOC
Optimality gap
Appendix A: Rotastore
total:
34.349
275
155
av: 61.08%
Table: BPSPl for test example M60-2 with N' Cycle
NS
total:
CPU,sec.
35.672
NOC
271
opt NOC
153
Optimality gap
av: 59.06%
Table: BPSPl for test example M60-2 with N' Cycle
total:
NS
CPU,sec.
34.938
NOC
283
opt NOC
155
= 4.
= 5.
Optimality gap
av: 62.56%
Results for BPSP2 for test example M60-2 with N S = 2, ...,5
162
Online Storage Systems and Transportation Problems
Table: BPSP2 for test example M60-2 with N' Cycle NS CPU,sec.
NOC
opt NOC
= 2.
Optimality gap
.....................................................
I 2 3 4 5 6 7 8 9 10 11 12 13 14 15
2 2 2 2 2 2 2 2 2 2 2 2 2 2 2
2.72 2.63 2.64 2.49 2.64 2.46 2.71 2.44 2.47 2.65 2.46 2.48 2.50 2.47 2.53
45 64 77 82 131 132 151 162 166 170 172 217 222 225 234
45 64 77 82 88 90 96 101 108 118 128 136 146 152 160
0.00% 0.00% 0.00% 0.00% 48.86% 46.67% 57.29% 60.40% 53.70% 44.07% 34.38% 59.56% 52.05% 48.03% 46.25%
38.34
234
160 av: 36.75%
..................................................... total:
Table: BPSP2 for test example M60-2 with N' Cycle NS CPU,sec.
NOC
opt NOC
= 3.
Optimality gap
....................................................
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3
2.97 3.03 2.75 2.81 2.82 2.81 2.73 2.75 2.71 2.79 2.82 2.74 2.74 2.81 3.05
45 64 77 82 88 126 140 153 156 167 167 224 224 227 234
45 64 77 82 88 89 94 97 103 113 125 132 141 147 155
42.39
234
155 av: 34.19%
0.00% 0.00% 0.00% 0.00% 0.00% 41.57% 48.94% 57.73% 51.46% 47.79% 33.60% 69.70% 58.87% 54.42% 50.97%
....................................................
total:
Table: BPSPz for test example M60-2 with N ' = 4. Cycle NS CPU,sec.
NOC
opt NOC
Optimality gap
.................................................... I 2 3 4 5 6 7 8
4 4 4 4 4 4 4 4
3.07 2.94 2.93 2.76 2.74 2.76 2.75 2.91
45 64 77 82 88 88 133 142
45 64 77 82 88 89 93 97
0.00% 0.00% 0.00% 0.00% 0.00% -1.12% 43.01% 46.39%
Appendix A: Rotastore
total:
42.78
153 av: 29.61%
237
Table: BPSPz for test example M60-2 with N S = 5. Cycle NS CPU,sec. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
5 5 5 5 5 5 5 5 5 5 5 5 5 5 5
NOC
opt NOC
Optimality gap
3.03 2.88 2.74 2.69 2.72 2.60 2.79 2.73 2.71 2.82 2.63 2.77 2.72 2.82 2.65
45 64 77 82 88 88 133 148 155 163 165 222 231 231 237
45 64 77 82 88 88 92 96 102 111 123 132 141 147 155
0.00% 0.00% 0.00% 0.00% 0.00% 3.30% 44.57% 54.17% 51.96% 46.85% 34.15% 68.18% 63.83% 57.14% 12.26%
41.36
174
155 av:31.58%
....................................................
total:
Results for BPSP3 for test example M60-2 with N~ = 2, ..., 5 Table: BPSP3 for test example M60-2 with N S = 2.
total:
81.21
160
Online Storage Systems and Transportation Problems
164
Table: BPSP3 for test example M60-2 with N' Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3
= 3.
CPU,sec. o p t NOC
............................
total:
4.51 3.02 2.62 2.61 2.66 2.62 2.71 2.64 2.72 2.78 2.81 2.97 2.76 2.82 3.20
45 64 77 82 88 89 94 97 103 113 125 132 141 147 155
43.51
155
Table: BPSP3 for test example M60-2 with N' Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
= 4.
CPU,sec. o p t NOC
............................ 3.31 2.63 2.63 2.65 2.62 2.50 2.66 2.70 2.68 2.71 2.58 2.66 2.98 2.63 2.62
45 64 77 82 88 89 93 97 103 112 124 131 141 146 153
40.63
153
............................
total:
Table: BPSP3 for test example M60-2 with N S = 5 . Cycle
NS
1 2 3 4 5 6 7 8
5 5 5 5 5 5 5 5
CPU,sec. o p t NOC
............................ 3.30 2.58 2.69 2.59 2.65 2.51 2.84 2.72
45 64 77 82 88 88 92 96
Appendix A: Rotastore 9 10 11 12 13 14 15
5 5 5 5 5 5 5
2.74 2.69 2.60 2.94 3.01 2.73 3.06
102 111 123 132 141 147 155
............................ total:
41.70
155
Results for BPSPl for test example M60-3 with N S = 2, ...,5 Table: BPSPl for test example M60-3 with N' Cycle
NS
total:
CPU,sec.
38.666
NOC
275
opt NOC
159
= 2.
Optimalitygap
a v : 57.89%
Table: BPSPl for test example M60-3 with N S = 3. Cycle
total:
NS
CPU,sec.
40.529
NOC
276
optNOC
154
Optimalitygap
av: 63.32%
166
Online Storage Systems and Transportation Problems
Table: BPSPl for test example M60-3 with N' Cycle
NS
CPU,sec.
NOC
opt NOC
= 4.
Optimality gap
.................................................... 39.117
total:
269
153
av: 60.46%
Table: BPSPl for test example M60-3 with N S = 5. Cycle
NS
CPU,sec.
NOC
opt NOC
Optimalitygap
1
5 5 5
2.423 2.274 2.523 2.424 2.744 2.724 2.433 2.724 2.965 2.804 2.704 2.713 2.753 2.814 2.804
46 74 90 111 131 151 164 177 192 209 226 236 244 258 271
42 67 75 84 86 89 93 98 104 114 123 132 136 143 152
9.52% 10.45% 20.00% 32.14% 52.33% 69.66% 76.34% 80.61% 84.62% 83.33% 83.74% 78.79% 79.41% 80.42% 78.29%
39.826
271
152
av: 61.31%
....................................................
2 3 4 5 6 7 8 9 10 11
12 13 14 15
total:
5
5 5 5 5 5 5 5 5 5 5 5
Results for BPSPz for test example M60-3 with N' Table: BPSP2 for test example M60-3 with N'
= 2.
= 2, ..., 5
Appendix A: Rotastore
..................................................... 39.22
total:
240
159 av: 38.29%
Table: BPSP2 for test example M6O-3 with N ' = 3. Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3
CPU,sec.
NOC
opt NOC
Optimality gap
2.84 2.55 2.53 2.53 2.58 2.58 2.55 2.57 2.60 2.72 2.65 2.57 2.62 2.56 2.59
42 67 75 84 86 132 146 154 161 166 172 174 213 222 230
42 67 75 84 86 89 93 100 106 116 125 134 137 144 154
0.00% 0.00% 0.00% 0.00% 0.00% 48.31% 56.99% 54.00% 51.89% 43.10% 37.60% 29.85% 55.47% 54.17% 49.35%
39.10
230
154 av: 32.05%
....................................................
total:
Table: BPSP2 for test example M60-3 with N' Cycle
NS
I 2 3 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
CPU,sec.
NOC
opt NOC
Optimality gap
....................................................
total:
= 4.
2.67 2.73 2.53 2.59 2.60 2.54 2.58 2.44 2.57 2.57 2.56 2.56 2.61 2.57 2.61
42 67 75 84 124 143 154 159 163 167 174 174 212 224 229
42 67 75 84 86 89 93 98 105 115 123 132 137 144 153
0.00% 0.00% 0.00% 0.00% 44.19% 60.67% 65.59% 62.24% 55.24% 45.22% 41.46% 31.82% 54.74% 55.56% 49.67%
38.78
229
153 av: 37.76%
168
Online Storage Systems and Dunsportation Problems
Table: BPSPz for test example M60-3 with N S = 5. Cycle NS
CPU,sec.
total:
39.58
NOC
228
opt NOC
Optimality gap
152 av:31.91%
Results for BPSP3 for test example M60-3 with N' Table: BPSP3 for test example M60-3 with N S = 2. Cycle NS CPU,sec. opt NOC
............................
I 2 3 4 5 6 7 8 9 10 11 12 13 14 15
2 2 2 2 2 2 2 2 2 2 2 2 2 2 2
total:
30.44 6.71 2.62 2.78 2.68 3.03 3.01 3.53 3.15 3.81 2.88 2.98 3.29 3.70 2.73
42 67 75 84 87 92 97 103 111 121 130 138 144 153 159
77.61
159
Table: BPSP3 for test example M60-3 with N S = 3. Cycle NS
CPU,sec. opt NOC
............................ 1 2 3 4 5
3 3 3 3 3
4.05 2.75 2.75 2.71 2.71
42 67 75 84 86
= 2,
..., 5
Appendix A: Rotastore
total:
Table: BPSP3 for test example M60-3 with Cycle
NS
total:
CPU,sec. opt NOC
42.73
153
Table: BPSP3 for test example M60-3 with Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
5 5 5 5 5 5 5 5 5 5 5 5 5 5 5
CPU,sec. opt NOC
............................
total:
NS = 4.
3.44 2.74 2.54 2.84 2.75 2.68 2.77 2.52 2.88 2.89 2.80 2.71 2.85 2.80 2.91
42 67 75 84 86 89 93 98 104 114 123 132 136 143 152
42.16
152
NS = 5.
170
Online Storage Systems and Transportation Problems
Results for BPSPl for test example M60-4 with
N S = 2, ..., 5
Table: BPSPl for test example M60-4 with N S = 2. Cycle NS CPU,sec.
total:
43.582
NOC
271
opt NOC
Optimality gap
160 av: 53.75%
Table: BPSPl for test example M60-4 with Cycle NS CPU,sec.
NOC
opt NOC
NS = 3.
Optimality gap
.................................................... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
total:
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3
2.744 2.724 2.324 2.533 2.294 2.383 2.223 2.233 2.213 2.243 2.184 2.293 2.213 2.253 2.394
48 75 97 115 132 147 165 176 194 208 223 233 249 262 274
47 67 83 85 89 92 95 99 107 116 123 129 137 148 154
2.13% 11.94% 16.87% 35.29% 48.31% 59.78% 73.68% 77.78% 81.31% 79.31% 81.30% 80.62% 81.75% 77.03% 77.92%
35.251
274
154 av: 59.00%
Table: BPSPl for test example M60-4 with N S = 4. Cycle NS CPU,sec.
NOC
opt NOC
Optimality gap
Appendix A: Rotastore 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4
2.895 2.864 2.884 2.874 2.624 2.794 2.834 2.744 2.704 2.604 2.724 2.804
....................
36.47% 51.69% 64.13% 80.85% 80.81% 86.67% 81.03% 81.30% 80.62% 87.31% 81.51% 81.70%
153
av: 61.91%
.........................
41.681
total:
85 89 92 94 99 105 116 123 129 134 146 153
Table: BPSPl for test example M60-4 with N S = 5. Cycle
NS
CPU,sec.
34.059
total:
NOC
269
opt NOC
152
Optimality gap
av: 58.63%
Results for BPSPz for test example M60-4 with N~ = 2, ..., 5 Table: BPSPz for test example M60-4 with N S = 2. Cycle
NS
CPU,sec.
NOC
opt NOC
Optimality gap
Online Storage Systems and 5'3-ansportation Problems
43.68
total:
229
160
av: 35.84%
Table: BPSP2 for test example M60-4 with N' Cycle
NS
CPU,sec.
44.93
total:
NOC
224
opt NOC
154
Optimality gap
av: 33.57%
Table: BPSPz for test example M6O-4 with N' Cycle
NS
1 2 3 4 5 6 7 8 9 10
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
CPU,sec.
NOC
= 3.
opt NOC
= 4.
Optimality gap
....................................................
11
12 13 14 15
2.84 2.55 2.90 3.09 3.12 3.11 3.04 3.06 3.08 3.12 3.07 3.03 3.04 3.02 3.05
47 67 83 85 132 136 146 159 159 167 167 167 173 215 219
47 67 83 85 89 92 94 99 105 116 123 129 134 146 153
0.00% 0.00% 0.00% 0.00% 48.31% 47.83% 55.32% 60.61% 51.43% 43.97% 35.77% 29.46% 29.10% 47.26% 43.14%
45.16
219
153
av: 32.69%
.................................................... total:
Table: BPSP2 for test example I\/160-4 with N' Cycle
NS
CPU,sec.
NOC
opt NOC
= 5.
Optimality gap
Appendix A: Rotastore 3 4 5 6 7 8 9 10 11 12 13 14 15
5 5 5 5 5 5 5 5 5 5 5 5 5
3.07 2.80 3.00 2.84 2.70 3.15 3.20 3.08 3.16 3.19 3.20 3.01 3.18
83 85 132 145 152 162 164 172 173 171 176 216 225
83 85 89 92 94 99 105 115 122 128 133 146 152
0.00% 0.00% 48.31% 57.61% 61.70% 63.64% 56.19% 49.57% 41.80% 33.59% 32.33% 47.95% 48.03%
45.45
225
152
av: 36.05%
....................................................
total:
Results for BPSP3 for test example M60-4 with N S = 2, ..., 5 Table: BPSP3 for test example M60-4 with N ' =2 Cycle
NS
total:
CPU,sec. opt NOC
219023.43
160
Table: BPSP3 for test example M60-4 with N S Cycle
NS
CPU,sec. opt NOC
= 3.
174
Online Storage Systems and Transportation Problems
51.98
total:
154
Table: BPSP3 for test example M60-4 with N' Cycle
NS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
= 4.
CPU,sec. opt NOC 3.58 3.37 3.24 3.19 3.49 3.04 3.31 3.67 3.60 3.33 3.17 3.42 3.41 3.21 3.32
47 67 83 85 89 92 94 99 105 116 123 129 134 146 153
50.36
153
............................
total:
Table: BPSP3 for test example M60-4 with N' Cycle
NS
CPU,sec. opt NOC
48.55
total:
= 5.
152
Results for BPSPl for test example M60-5 with N'
= 2, ..., 5
Table: BPSPl for test example M60-5 with N S = 2. Cycle
NS
CPU,sec.
NOC
opt NOC
Optimality gap
Appendix A: Rotastore
..................................................... total:
41.159
279
160
av: 58.82%
Table: BPSPl for test example M60-5 with N' Cycle
NS
CPU,sec.
NOC
opt NOC
= 3.
Optimalitygap
.................................................... total:
39.988
275
157
av: 61.07%
Table: BPSPl for test example M60-5 with Cycle
NS
CPU,sec.
NOC
opt NOC
N '
= 4.
Optimality gap
176
Online Storage Systems and Dunsportation Problems
41.629
total:
278
156
av: 63.84%
Table: BPSPl for test example M60-5 with N S = 5. Cycle
NS
CPU,sec.
40.628
total:
NOC
270
opt NOC
156
Optimality gap
av: 61.74%
Results for BPSP2 with N S = 2, ...,5 for test example M60-5 Table: BPSPz for test example M60-5 with N' Cycle
total:
NS
CPU,sec.
45.33
NOC
234
opt NOC
160
= 2.
Optimality gap
av: 33.51%
Table: BPSP2 for test example M60-5 with N S = 3.
Appendix A: Rotastore Cycle
NS
total:
CPU,sec.
46.29
NOC
229
opt NOC
Optimality gap
157 av: 34.63%
Table: BPSPz for test example M60-5 with N ' = 4. Cycle
NS
total:
CPU,sec.
37.57
NOC
231
opt NOC
Optimality gap
156 av: 36.48%
Table: BPSP:! for test example M60-5 with N ' = 5. Cycle
NS
I 2 3 4 5 6 7 8 9 10
5 5 5 5 5 5 5 5 5 5
CPU,sec.
NOC
........................... 2.81 2.58 2.61 2.76 2.88 3.16 3.00 2.90 3.05 3.02
41 67 77 85 131 133 143 152 162 165
opt NOC
Optimality gap
178
Online Storage Systems and Transportation Problems
44.12
total:
225
156
av: 35.35%
Results for BPSP3 for test example M60-5 with N S = 2, ..., 5
Table: BPSP3 for test example M60-5 with N' Cycle
NS
CPU,sec. opt NOC
26768.97
total:
= 2.
160
Table: BPSP3 for test example M60-5 with N S = 3. Cycle
NS
CPU,sec. opt NOC
Appendix A: Rotastore 51.56
total:
157
Table: BPSP3 for test example M60-5 with N S = 4. Cycle
NS
CPU,sec. opt NOC
49.83
total:
156
Table: BPSP3 for test example M6O-5 with N' Cycle
NS
CPU,sec. opt NOC
49.45
total:
= 5.
156
Results for combination of BPSPz and BPSP3 for test example M60-4 with N S = 2 (cycle 1: BPSP2; cycle 2-14: BPSP3) Cycle
NS
CPU,sec.
NOC
180
Online Storage Systems and Transportation Problems
total:
50.38
161
Results for combination of BPSPz and BPSP3 for test example I\/I60-5 with N' (cycle 1: BPSP2; cycle 2-14: BPSP3) Cycle
total:
NS
CPU,sec.
NOC
49.57
163
=2
As one can see applying combinations of the models produce near optimal (A zz 0.1% - 0.2%) solutions (A zz 0.1% - 0.2%) much faster than using BPSP3 only.
A.2.
Tabular Results for Different Algorithms
In the following tables and figures the numerical results for the algorithms Dz, WL1, WL;, WL:, SL, are presented. Note that the CPU time is not reported because it is always was less than 6 seconds. The figures do not show the results obtained using the algorithm SL, as those values cannot easily displayed on the same scale. n 1
1
D2
I
WLI
I
WLA
1 484 1 480 1 484
I
WL:
1 484
I
SL,
1 549
Table 1: Results with lower bound 472
Appendix A: Rotastore
Table 1
Table 2: Results with lower bound 475
481
1
2
3
Table 2
4
5
Online Storage Systems and Tkansportation Problems
n
1
( D2 I WLI I WLA I W L i I SL, 1 490 1 489 1 487 1 484 1 562
Table 3: Results with lower bound 478
-"&
,
1
2
3 Table 3
4
Table 4: Results with lower bound 470
5
Appendix A: Rotastore
,"----.." .. \A
-
48 1
0
0
0
l
479
;
475
i 1
2
3
4
5
Table 4
Table 5 : Results with lower bound 472
1
2
3
Table 5
4
5
K - WLNP
Online Storage Systems and Transportation Problems
Table 6: Results with lower bound 475
1
3
2
5
4
Table 6
n
1 2
Dz 479 479
WL1 476 476
WL; 477 481
SL, 564 563
WL: 477 480
Table 7: Results with lower bound 467 483
r-...--"
474
i
"""..."
"
"
"
,
..........
"
"
...........................
1
I 1
2
3
Table 7
4
5
Appendix A: Rotastore
Table 8: Results with lower bound 473
W"
1
3
2
5
4
Table 8
n 1 2
Dn 485 485
WL1 484 484
WLA 491 490
WL; 489 488
SL, 565 565
Table 9: Results with lower bound 478
482 1
4 1
2
3 Table 9
4
5
Online Storage Systems and Transportation Problems n 1
2
Dz 479 479
WLI 478 478
WLA 480 484
WL: 478 482
SL, 548 547
Table 10: Results with lower bound 472
476
4
1 1
2
3
Table 10
4
5
Appendix B Opt iTrans
B.1. B.l.l
InputData Input Data Common t o all Solution Approaches
Our implementation requires the following order-specific information displayed in Fig. B.l.l:
1 The name of a pick-up order; 2 The name of a delivery order;
3 The name of the pick-up building; 4 The physical node of the pick-up building;
5 The name of the delivery building;
6 The physical node of the delivery building; 7 Desired pick-up time (if no time specified, then we set this time to zero and do not consider any pick-up time);
8 Desired delivery time (if no time specified, then we set this time to zero and do not consider any pick-up time); 9 The type of an order (i.e., whether a vehicle transport sitting, lying patient or some materials and so on...); 10 A flag, indicating whether a patient is infectious;
11 The number of accompanied persons; 12 The service time required for picking-up a patient;
13 The service time required for delivering a patient; 14 The number of the vehicle, if the patient is already in that vehicle (if an order still need to be served, then zero);
15 In case the previous parameter is not zero, then this is the amout of minutes a patient is in a car already.
Online Storage Systems and Tramportutio,n Problems RA-A 87 A-04 8 A-02 8 M3-KARD71 M3-OP 8 0 M3-08 7 1 NN-A 55
M5-01 M2-A M2-A M3-02 M5-03 M3-OP CM-A
60 86 86 80 60 80 69
13.5 13.75 13.75 13.766 14 13.85 13.888
0 0
2 2
0
2
0 0 0 0
1 1 2 1
Figure B. 1.1. Input file: order-dependent information Column nine might indicate : H
1 - the patient is in bed; 2 - regular patient;
H
3 - the patient is in a wheel-chair;
H
4
H
- materials should be transported;
10 - break for the car, it means the car has to drive to the depo and to stay there for the time specified in columns 12 and 13.
If the value in column nine is negative it means that corresponding order is urgent. For offline cases the colunins 14 and 15 are neglected, because all values in those are zero. Fig. B.1.2 contains the vehicle-dependent information: H
The total nunlber of vehicles and the current time in seconds; Starting from the second line, the content of the colunln: The number of the vehicle;
N
Current locnt,ion of the vehicle (nuntber of the building):
H
Earliest finie when the vehicle is axrailable in seconds;
H
Latest time when the vehicle is available in seconds:
H
The number of patients in bed t,he vehicle can transport:
H
The number of sitting patients the vehicle can transport; The wheel-chair capacity of the vehicle.
In addition, all control parameters specified in Section B.B.1.3.2 are required.
B.1.2
Specific Input Data for the MILP Model and the Column Enumeration Approach
The MILP models involves several parameters used in the fine tuning process generating cuts:
Appendix B: Opti D u n s
Figure 8.1.2. Input file: vehicle-dependent information
H
8
- used t,o reduce the arc system AF 2.0 - used to reduce the arc system AB 2.0
(backward) seen by thc hIILP nlotlel, (forward) seen by the LIILP ~nodcl;
R*~2 . 0 - the maximum allowed deviations (earliness) from target time for pickup nodes, R*Z 2.0
- the maximum allowed deviations
(lateness) from target time for pickup (lateness) from target time for delivery
nodes, H
R~ 2.0 nodes,
- the maximum allowed deviations
H
5'2 2.0
- the maximum
allowed sum of lateness, e.g., derived from the heuristic.
B.1.3
Specific Input Data for the Heuristic Methods
B.1.3.1
Penalty Criteria
We use several parameters to penalize violations of some constraints: H
PENINFi 5555.0 - used to penalize capacity infeasibility (i.e., an order is assigned cjY = C,"' or c s = Cf). to a vehicle 7, for which either cf =
c,",
PENPAR1 3001.0 - used when an order is not in vehicle's time windows (2.e.. an order is assigned to a vehicle which is "not yet" or "already not" available, see Fig. B.1.2). PENPAR2 1000.0 - used when a pre-assigned order is arrived too late. PENPAR3 200.0 - used to avoid that a patient is in a vehicle for more than AT = 40 minutes. All what is more than 40 minutes is penalized. H
PENPAR4 444.0 - used to enforce the desired time when a vehicle should take its lunch break.
190
Online Storage S y s t e m s and Transportation Problems
B.1.3.2
Control Parameters of the OptiTrans Software
In this section we provide a detailed list of the control parameters used in our construction and improvement heuristics. IFDRO is used to decide how remaining orders should be distributed.
1 IFDRO 0 implies that remaining orders are neglected;
2 IFDRO I implies that remaining orders are distributed using DU heuristic;
3 IFDRO 2 implies that remaining orders are distributed using DB heuristic. IFRDSTR is used to choose the imprrovement heuristic.
1 IFRDSTR 0 implies that IT1 heuristic is used; 2 IFRDSTR 1 implies that the combination of IT1 and IT2 is used with first acceptance criteria (see p.140);
3 IFRDSTR 2 implies that the combination of IT1 and IT2 is used with second acceptance criteria (see p.140);
4 IFRDSTR 3 implies that IT2 heuristic is used. w
INCOH is used to choose the construction heuristic 1 INCOH 1 implies that remaining orders are distributed using CONHl heuristic;
2 INCOH 2 implies that remaining orders are distributed using CONH2 heuristic. IOPTMD is used to select either offline or online optimization. 1 IOPTMD I selects offline optimization;
2 IOPTMD 2 selects online optimization. PXINC 0.05 is the permitted increase of the maximal lateness in accepting a tour to take an order in the cross-over scheme. This tuning parameter is one of the most sensitive parameters in the heuristic. Its value is recommend to be chosen as 0.15D, to 0.50,. TIMECT 125.0 defines the cleaning time after transporting an infectious person. W
TIMECCI 5.0 defines the time in minutes for changing a car at the depot. TIMECC2 5.0 defines the time in minutes for changing a car at the depot. TOLO 0.058 sets the tolerance on accepting two orders having the same pick-up time for the same vehicle. TOLI 0.25 sets the tolerance on accepting the lower limit of the vehicle's availability. TOL2 0.25 sets the tolerance on accepting the upper limit of the vehicle's availability.
A p p e n d i x B: OptiTrans
B.2. B.2.1
Tabular Results Tabular Results for the MILP Model Case M01: optimal tour for the set of 4 orders
v
node
TE
tA
tL
rA2
rB
S L
Case M02: optimal tour for the set of 5 orders v
node
TE
tA
tL
rA2
rB
S L
Case M03: optimal tour for the set of 6 orders
v
node
TE
tA
tL
rA2
rB
S L
192
Online Storage Systems and Transportation Problems
Case M04: optimal tour for the set of 7 orders
v
node
TE
tA
tL
rA2
rB
S L
..................................................................
Case M05: optimal tour for the set of 13 orders
v
node
TE
tA
tL
rA2
rB
S L
Appendix B: O p t i Trans
Case MOB: optimal tour for the whole set of 16 orders v
node
TE
tA
tL
rA2
rB
S L
194
Online Storage Systems and Transportation Problems
Case M08: optimal tour for a special set incl. 14 orders, z = 0.074
v
node
TE
tA
tL
rA2
rB
S L
Appendix
B:
OptiTrans
195
B.2.2
Tabular Results for the Heuristic Methods
B.2.2.1
Input Data for a Whole Day - Offline Analysis
The input data for 18 September, 2001^ contain 298 orders. •
Information about orders;
293 A18 Al A12 AB A5 A16 All A2 A10 AISOSSY A1B0839 4150841 A150843 A150851 A1508E2 A150859 A1B0860 A150862 A150855 A150S66 A1B0868 A150878 A150829 A1B0864 A150874 A150842 AiB0752 A1B0826 A1B0847 AiB0873 A150a46 A150886 A150887 A1S0857 A1B0898 A150869 A150a89 Al 50870 A1B0890 A150894 A150910 A150902 A160833 A150899 A150909 A150908
18 1 12 8 5 16 11 2 10
ibosav 1E0839 160841 150843 150851 150852 150859 150860 150862 150855 150866 150868 150878 150829 1B0864 150874 150842 150752 150826 150847 150873 150846 150886 1508B7 150857 150898 160369 150889 150870 150890 150894 150910 150902 150333 150399 150909 150908
GEB79-LS GEB79-LS GEB79-LS GEB79-LS aEB79-L3 GEB79-LS GEB79-LS GEB79-LS GEE79-LS ur-BB GT-BB GH-A HO-DP FR-03 CH-01 H3-08
U-A FR-03 HN-03 NC-03 GK-09 CK-09 KK-03 KK-04 M3-08 RA-02 M5-03 HO-02 NG-02 Ml-01 NC-02 HH-02 NH-02 tJN-03 M3-02 M2-02 H2-01 M2-02 FR-01 A-03 H3-KARD M3-06 HA-01 M4-02 HO-05 M2-03
70 70 70 70 70 70 70 70 70 69 69 69 74 11 69 71 5 11 55 55 68 68 75 75 71 37 60 5 55 80 55 55 55 55 80 73 73 73 11 8 71 80 87 5 5 73
GEB79-LS GEB79-LS GEB79-LS GEB79-LS aEB79-LS GEB79-LS GEB79-LS GEB79-LS GEB79-LS HU-'il M2-01 KG-40 M2-01 CT-BB KC-40
U-A H3-08 GT-BB M4-03 CT-A CA-DP CA-DP H3-0P RK-KSK ZE-A H5-A
U-A RD-ANGIQ RK-A NN-EMG M5-A M2-FUSS
U-A H3-ANGI0 H5-LUFU M5-END0 M2-A M3-KARD H2-A H4-03 H3-0P M3-A1JG HD-A M3-ECKa HR-CT H3-ECH0
70 70 70 70 70 70 70 70 70 73 73 80 73 69 80 5 71 69 30 36 69 69 30 90 42 60 5 87 85 55 60 86 5 71 60 60 86 71 B6 81 80 71 5 80 55 80
13.00 0.00 13.00 O.OO 12.50 O.OO 12.50 0.00 12.50 0.00 12.00 O.OO 12.00 0.00 12.00 0.00 11.50 0.00 0,25 0.00 0.25 O.OO 0.17 0.00 0.2S 0.00 1,50 0.00 1.72 0.00 3.20 0.00 4.25 0.00 5.50 0.00 6.50 0.00 6.05 0.00 7.28 7.33 7.28 7.33 7.25 0.00 7.25 0.00 7.BO 0.00 7.75 0.00 7.50 0.00 7.50 O.OO 7.50 0.00 7.75 0.00 8.00 0.00 3.00 O.OO 8.00 0.00 3,00 0.00 7.92 0.00 8.00 0.00 8.00 0.00 8.00 0.00 8.0O O.OO 8.00 O.OO 8.22 0.00 8.25 0.00 a. 25 O.OO 7.95 0.00 3.25 0.00 3.25 0.00
10 10 10 10 10 10 10 10 10 4 4 4 2 4 4 1 1 4 1 4 5 5 1 1 2 1 2 1 1 1 1 1 2 1 1 2 1 1 2 2 2 1 2 2 1 1
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 2 2 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
' F o r the description of thss content of the columns see Section B.B.l.l,
6.O0 a. 00 2.O0 9.O0 3.O0 8,00 23,00 7.00 6.00 3.00 4.00 3.00 3.00 0.00 3.00 10.00 3.00 0.00 17.00 l.OO 0.00 O.OO 12.00 9,00 l.OO 4.O0 4.O0 4.O0 2.00 12,00 12.00 2.O0 3.00 7.00 2.00 0.00 6.00 4.00 14.00 O.OO 14.00 7.00 4.00 0.00 15.00 13.00
5.00 3.00 4.00 3.00 9.00 5.00 15.00 3.00 8.00 0.00 4.00 0.00 0.00 0.00 2.00 5.00 3.00 0.00 6.00 6.00 0.00 0.00 4.00 15.00 0.00 5.00 5.00 2.00 9.00 2.00 4.00 7.00 5.00 8.00 4.00 0.00 6.00 5.00 1.00 4.00 7.00 9.00 0.00 0.00 5.00 4.00
196 A150913 A150900 A1B0901 A150912 A150865 A1E0877 A15091E A1509ia A150799 A1B0S67 A150921 A150916 A150917 A160914 A150743 A150920 A150a53 A150854 A150919 A1S0925 A1S0926 A150892 A160893 A150881 A15OB80 A150891 A1507B1 A150B71 A150750 A150922 A1B0930 A150929 A150907 A150844 A150928 A150923 A150897 A150934 A1B0882 A150883 Al50924 A150885 A150931 A1B0856 A150937 A150938 Ai50936 A150788 A150941 Al50944 A150945 A1B0939 A150946 A150952 A1509BO A1S093B A150943
Online Storage Systems 150913 150900 160901 150912 150365 150877 1S0915 150918 150799 160867 1B0921 150916 150917 150914 150748 150920 150853 150854 150919 150925 150926 150892 150893 150881 150880 150891 1B07B1 150871 150750 1B0922 150930 150929 1BO907 1B0844 150928 150923 1B0897 150934 1B0882 1B08S3 150924 150835 150931 150856 150937 150938 150936 150788 150941 150944 150945 150939 150946 150952 150950 150935 150943
H3-08 KP-06 KP-06 KK-04 KK-04 D-04 H3-08 M3-KARD FR-02 Fa-03 FR-01 m-03 MS-03 H5-02 N5-03 KK-05 H4-02 H4-02 H5-03 RK-KSN KK-04 H3-04 M3-04 Hl-05 Ml-05 M5-02 M5-03 M2-02 M5-03 RK-A NN-02 A-02 CH-02 RA-02 M3-0P M3-KARD FR-01 FR-01 FR-Ol FR-01 M2-02 H2-03 H2-A MN-03 M-EMG H3-ECH0 H4-01 U-04 M3-ANGI0 CH-01 M3-ECH0 M2-03 H3-ANGI0 HD-OP H5-ENDa CK-DP D-04
71 55 55 75 75 21 71 71 76 11 11 55 60 60 60 75 5 5 60 90 11 30
ao 80 80 60 60 73 60 85 55 8 34 87 80 71 76 76 11 11 73 73 36 55 55 80 30 5 71 69 SO 73 71 74 60 69 21
HW-ANGIO M2-ESK0P M2-ESKDP CK-OP RK-KSN HO-A M3-ECH0 H3-QP H5-END0
M-A RD-R0E57 H3-ECHD H2-ESK0P RD-CT49 HD-A RK-KSN Ml-A CU-A M3-ANG KK-04 RK-KSN H5-A M5-A H5-A H5-A HO-A H3-ANG H6-LFA RN-A NC-02 CU-A CA-A M4-02 HO-A KK-03 M3-ECH0 RN-A H3-ANGI0 M2-A RN-A H2-ESKDP HO-A NN-02 RH-A Hl-01 M2-03 FR-A RN-A M5-03 M5-03 M4-02
U-A A-A H5-01 RA-02 GK-09 ED-CT49
55 86 86 69 90 5 80 80 60 55 69 80 36 87 5 90 12 69 71 75 90 60 60 60 60 5 71 60 31 55 69 69 5 5 75 SO 31 71 86 31 86 5 56 31 80 73 76 31 60 60 5 5 8 60 87 68 87
8.35 8.25 8.25 3.33 9.00 a. 25 8.40 3.45 3,50 8.50 8.57 8.43 8.75 8.50 8.50 9.00 8.50 8.50 8.75 8.77 8.80 8.75 3.75 8.75 8.75 9.00 9,00 8.50 9.50 8,58 8.95 9.00 3,75 8.75 8.88 8.72 9.50 9.75 9.00 9.50 8.83 9.25 9.05 9.50 9.50 9.30 9.42 9.76 9.42 9.43 9.53 9.50 9.60 9.73 9.76 9.50 9.50
and Tmnsportation
0.00 0.00 O.OO 0.00 0.00 0.00 0.00 0.00 0.00 O.OO 0.00 0.00 O.OO 0.00 0,00 0.00 0.00 0.00 0.00 0.00 O.OO O.OO 0.00 0.00 0.00 0.00 0.00 0.00 0.00 O.OO 0.00 O.OO 0.00 0.00 0.00 0.00 0.00 0.00 0,00 0,00 O.OO O.OO 0.00 0.00 0.00 0.00 0.00 0.00 0,00 O.OO 0.00 0.00 0.00 0.00 O.OO 0.00 0.00
1 2 2 1 1 2 2 2 1 2 2 2 2 2 2 1 1 1 2 1 2 1 1 2 2 1 3 1 2 1 2 2 1 3 1 2 1 1 2 2 1 1 1 1 1 1 1 1 2 1 2 2 1 2 1 6 1
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 1 1 0 0 0 0 0 0 0 0 0 1 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 4 0 3 0
6.00 1.00 0.00 8.00 12.00 0.00 6.00 5.00 3.00 4.00 0.00 1,00 3.00 7.00 1,00 15.00 15.00 7.00 0.00 12.00 0.00 5.00 10.00 0.00 5.O0 3.00 5.00 5.00 0.00 12.00 O.OO 0.00 8.00 9.00 9.00 1.00 2.00 5.00 O.OO 3.00 9.00 5.00 16.00 13.00 12.00 13.00 8.00 10. OO 1.00 4.00 5.00 0.00 12.00 O.OO 9.00 7.00 8.00
Probkms 37.00 2.00 6.00 6.00 10.00 0.00 0.00 0.00 2.00 0.00 0.00 0.00 37.00 0.00 0.00 5.00 5.00 9.00 0.00 4.00 6.00 6.00 9.00 0.00 1.00 5.00 9.00 4.00 5.00 8.00 0.00 0.00 7.00 5.00 3.00 1.00 4.00 2.00 O.OO 37.00 6.00 5.00 4.00 8,00 3.00 5.00 2.00 15.00 0.00 3.00 1.00 0.00 7,00 O.OO 5.00 0.00 5.00
Appendix B: OptiTrans NP-06 55 9.67 M2-ESKOP 86 M2-03 73 9.60 M2-ESKOP 86 M5-03 60 9.75 HO-A 5 D-04 21 10.00 HO-A 5 NC-02 55 9.80 M5-LUEU 60 M3-02 80 9.82 M5-LUEU 60 CA-A 69 10.25 D-01 77 M4-02 5 10.02 CU-A 69 HO-05 5 9.75 NR-CT 55 NN-03 55 10.05 M3-ECHO 80 M3-08 71 10.00 NR-ANGIO 55 KK-04 75 9.87 RK-KSN 90 RK-KSN 90 10.38 KK-04 11 RK-KSN 90 10.42 KK-04 75 RN-A 31 9.50 0-05 63 M5-02 60 10.18 RD-CT49 87 FR-01 76 10.20 RN-A 31 FR-01 76 10.25 M3-ANGIO 71 M3-08 71 9.77 ZE-A 42 M3-08 71 9.98 M3-ECHO 80 M3-06 80 9.98 M3-ANGIO 71 M2-03 73 10.15 M2-ESKOP 86 HO-05 5 10.40 RD-ANGIO 87 M4-02 5 M3-ECHO 80 10.20 NC-01 90 10.00 CT-BB 69 FR-A 11 10.25 CA-04 69 FR-01 11 10.43 M2-A 86 KK-05 75 10.62 RK-KSN 90 RD-A 87 10.00 D-03 21 U-04 5 10.60 RN-A 31 M4-02 5 RD-ANGIO 87 10.75 M5-03 60 10.52 M3-ANGIO 71 CA-A 69 10.43 M3-ANGIO 71 RA-A 87 11.00 M5-03 60 RA-A 87 11.00 M5-02 60 MI-05 80 11.07 M5-LUFU 60 D-A 78 10.25 RA-02 87 NN-03 55 10.75 RN-A 31 RA-PA 87 10.75 NN-04 55 FR-03 11 11.00 NN-A 55 NN-02 55 10.95 U-A 5 NP-04 55 M3-KARD 71 11.00 FR-02 76 10.88 M5-END0 60 FR-A 76 11.00 RA-02 87 D-01 77 11.12 RD-CT57 69 D-04 21 11.17 RD-CT49 87 M2-A 86 11.00 0-01 63 M2-03 73 11.05 U-A 5 CK-09 68 10.75 CK-OP 69 RK-KSN 90 11.25 KK-07 75 RK-KSN 90 11.48 KK-04 11 KK-04 75 11.28 RK-KSN 90 HO-OP 74 11.28 M5-01 60 0-05 63 11.25 RN-A 31 RD-DL 87 11.20 HO-03 5 M3-KARD 71 M3-ECHO 80 11.72 M3-KARD 71 M3-ECHO 80 10.98
198
Online Storage Systems and Transportation Problems FR-01 11 RK-A 85 11.45 0.00 FR-A 76 M4-01 30 11.57 0.00 M2-ESKOP 86 M2-02 73 11.25 0.00 M2-ESKOP 86 M2-03 73 11.17 0.00 D-03 21 FR-OP 76 11.67 0.00 U-04 5 RD-ROE49 86 11.50 0.00 M4-03 30 NN-03 55 11.50 0.00 RA-01 87 NN-A 55 11.50 0.00 M5-LUFU 60 M3-04 80 11.65 0.00 A-A 8 NN-03 55 11.82 0.00 NN-02 55 RK-A 85 11.50 0.00 0-05 63 RD-ANGIO 87 11.50 0.00 NC-01 90 M5-LUFU 60 11.35 0.00 NC-01 90 GK-OP 89 12.25 0.00 HO-02 5 NN-A 55 12.50 0.00 D-03 21 11.70 0.00 RD-ROE49 86 M5-02 60 M3-OP 80 11.75 0.00 M5-02 60 M3-OP 80 11.75 0.00 M3-OP 80 M3-08 71 12.00 0.00 D-A 78 RA-02 87 12.40 0.00 M3-04 80 12.25 0.00 M5-LUFU 60 M2-A 86 M2-01 73 11.48 0.00 M3-A 71 12.50 0.00 M2-03 73 KK-07 11 RK-KSN 90 12.38 0.00 KK-07 75 12.38 0.00 RK-KSN 90 KK-05 75 RK-KSN 90 12.50 0.00 NN-04 55 FR-PA 11 11.75 0.00 FR-02 76 RD-CT57 69 12.48 0.00 RN-A 31 12.50 0.00 FR-01 76 RD-DL 87 FR-01 11 12.60 0.00 M5-02 60 12.00 0.00 GEB49-RB 87 M5-LUFU 60 M2-02 73 12.50 0.00 0-02 63 12.37 0.00 M2-A 86 M3-ECHO 80 M4-02 5 12.58 0.00 M2-03 73 12.48 0.00 HO-A 5 M2-A 86 0-02 63 12.52 0.00 u-01 5 RN-A 31 12.75 0.00 HO-A 5 RA-02 87 12.75 0.00 HO-03 5 12.78 0.00 RD-DL 87 U-A 5 12.75 0.00 A-03 8 RD-ANGIO 87 M4-02 5 13.13 0.00 M3-ECHO 80 M3-KARD 71 12.93 0.00 CA-A 69 A-02 8 13.00 0.00 CA-A 69 M2-02 73 13.07 0.00 M2-02 73 M2-E 86 13.07 0.00 NP-04 55 13.20 0.00 M3-KARD 71 NN-05 55 M4-03 30 12.75 0.00 M4-03 30 A-03 8 12.67 0.00 RN-A 31 13.25 0.00 U-04 5 RD-CT49 87 U-04 5 13.30 0.00 NN-A 55 HO-02 5 13.50 0.00 D-03 21 M5-A 60 13.25 0.00 NN-04 55 13.43 0.00 FR-PA 11 RD-ANGIO 87 0-05 63 13.05 0.00 0-05 63 RN-A 31 13.25 0.00 0-02 63 RK-A 85 13.75 0.00 U-A 5 13.08 0.00 CU-01 69
Appendix B: 01;)tiTrans
A151120
MI-A 12 M4-02 5 13.17 RK-A 85 NN-04 55 13.10 M2-ESKOP 86 M2-02 73 13.25 D-04 21 NN-A 55 13.75 RK-A 85 NN-02 55 13.80 NN-03 55 RN-PET 31 13.25 NN-03 55 M4-A 30 14.00 RK-A 85 FR-01 11 14.00 RA-A 87 M5-03 60 14.00 D-03 21 RD-A 87 14.00 RD-CT57 69 FR-02 76 13.85 U-A 5 A-03 8 14.13 M3-ANGIO 71 M2-03 73 14.00 M5-02 60 14.28 RD-FRKI 11 KK-04 11 CK-OP 69 14.25 CK-OP 69 KK-04 75 14.50 RD-FRKI 76 RA-02 87 14.37 FR-02 76 GEB40-EC 80 14.43 RN-A 31 RD-ROE57 69 14.43 RD-ROE49 86 D-03 21 14.48 M3-KARD 71 D-04 21 14.45 M2-ESKOP 86 M2-02 73 14.38 M2-ESKOP 86 M2-03 73 14.48 M3-08 71 RK-KSN 90 14.75 RK-KSN 90 KK-05 75 14.55 KK-05 11 RK-KSN 90 14.62 RN-A 31 FR-01 76 14.67 RD-FRKI 11 M5-02 60 15.02 M3-OP 80 M5-02 60 15.00 RN-A 31 0-05 63 15.00 0-02 63 RK-A 85 14.75 RD-CT57 69 U-04 5 15.25 NN-A 55 D-04 21 15.25 FR-02 76 15.25 M3-ECHO 80 RK-A 85 0-02 63 15.17 RN-A 31 NN-03 55 15.37 NN-02 55 RK-A 85 15.50 NN-03 55 RK-A 85 15.50 CM-A 69 M5-03 60 15.40 CT-BB 69 M5-02 60 15.50 D-03 21 15.67 M5-END0 60 M2-02 73 15.67 M2-ESKOP 86 A-01 8 RD-ROE49 86 15.50 NN-03 55 15.83 M4-A 30 RK-A 85 15.98 NC-02 55 U-01 5 16.00 RN-A 31 M2-01 73 RD-CT57 69 16.00 CM-A 69 MI-01 80 16.07 A-01 8 16.23 RD-ROE49 86 U-A 5 CU-01 69 16.72 M5-02 60 16.75 M3-OP 80 0-02 63 16.58 RK-KS 85 M2-01 73 17.00 RD-CT57 69 CT-BB 69 U-LABOR 5 16.75 RK-A 85 17.50 NC-03 55 NR-CT 55 17.50 KK-04 75 151120 RK-A 85 NN-02 55 17.65 0.00 1 0 1 4.00 6.00
200
Online Storage Systems and Transportation Problems RK-KSN 90 M4-03 30 RK-A 85 RK-A 85 M2-ESKOP 86 0-06 63 CH-01 69 NR-CT 55 M3-04 80 RK-A 85 A-03 8 CT-BB 69 CT-BB 69 RD-ROE57 69 RK-A 85 RK-KSN 90 CU-A 69 CM-A 69 CU-OP 69 NC-01 90 CT-BB 69 M2-01 73 CM-01 69 NN-A 55
M3-08 71 NN-05 55 NN-03 55 NC-02 55 FR-05 76 RK-A 85 KK-01 11 KK-04 75 RK-KSN 90 NC-03 55 RD-CT57 69 KK-01 11 M5-03 60 A-03 8 0-06 63 M3-04 80 NN-A 55 KC-40 80 CK-09 68 CT-BB 69 MI-03 80 KC-40 80 KC-40 80 CM-01 69
17.75 18.00 18.02 18.40 17.83 18.50 18.52 19.00 19.00 19.05 19.53 19.87 20.25 20.38 20.73 20.72 21.93 5.88 22.42 23.00 22.32 23.00 22.68 23.25
Information about vehicles include the number of vehicles (11 vehicles), the current time (O), the time when the vehicles are available, and their capacities for lying, sitting and wheelchair passengers:
B.2.2.2
ResultsforCIHandSA
Here we display the final tours for some combinations of CIH and SA, applied to the input data of 18 September, 2001 (see page 144). The table of results obtained when SA applied after the CIH: v s-node d-node
tD
TD
tA
TT
delay
z
S L IC
Appendix B: Opti P a n s
Online Storage Systems and Transportation Problems
Appendm B: OpUTrom-s
203
2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2
A1S096S A150970 1S0970 15096B A150978 150978 A150749 A15084E 150749 150845 A151002 151002 A151015 151015 4151004 151004 A151044 151044 A151046 151046 A1S1026 151026 A1S1061 151061
Al50970 150970 150965 A15097S 150978 A150749 A150845 150749 150845 A151002 151002 A151016 1B1015 A151004 151004 A151044 IE1044 A151046 151046 A151026 151026 A151061 1S1061 A151063 2 Aisioes 1B1068 2 1S106S DDl
10,031 10.2B0 10.285 10.411 10,750 10.860 11.000 11.227 11.227 11.290 11,577 11,755 11.971 12,123 12.717 12,368 12.955 13.050 13.225 13.357 13.525 13,699 13.356 14.042 14.284 14.447
0.056 0.035 0.076 0.131 0.003 O.0E9 0.060 0.000 0.030 0.070 0.078 0.016 0.036 0.000 0,068 0,004 0,045 0,041 0,015 0,069 0,057 0,073 0,036 0,042 0,046 0,078
10,250 10,285 10.361 10,750 10,753 11,000 11,060 11,227 11,257 11,360 11,666 11,771 12,007 12,600 12,785 12,872 13,000 13,092 13,240 13,425 13,533 13,773 13,892 14,084 14.330 14,525
10.250 10.750 10,483 10,750 11,250 11,000 11,000 11,500 11.500 11,167 11,667 11,667 12.167 12.500 13.000 12.783 13.283 12.933 13.433 13.250 13.750 13,750 14,250 14.000 14.500 24.000
1,009 1.009 1,009 1,009 1,009 1,009 0..060 1,069 - 1,069 - 1.069 0..194 1.262 - 1,262 0..104 1.366 - 1.366 - 1.366 - 1.366 0 .089 1.455 - 1.455 0..153 1.613 - 1.613 0 ,175 1.789 - 1.789 0..023 l.Bll - 1.811 0 ,084 1.B95 - 1.89B - 1.895
1 0 0 3 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
1 1 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 0
0 3 22 0 1 0 0 14 12 0 18 0 15 0 18 0 8 0 9 0 10 0 8 0 15 15
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3
D31 A150829 A150752 150829 A1S0S73 150752 1B0873 A150748 A1S0914 150914 A150907 1S074S 150907 A1E0B65 150865 A150B56 150356 A150967 150967 A1509S3 150983 A150888 150S8S A151003 Al50933 151003 150933 A151028 151028 A151029
7.232 7.450 7.586 7.727 7.950 3.072 8.171 S.S17 S.633 3.693 8,887 8.935 9.051 9.281 9.505 9.742 9.918 10.217 10.324 10.650 10.806 11.133 11,293 11.497 11.812 11.895 12.007 12.333 12.480 12.720
0.018 0,069 0,074 0,000 0,039 0,065 0.040 0.000 0.060 0.060 0.043 0.000 0.029 0.057 0.021 0.042 0.060 0.057 0,036 0,056 0,041 0,060 0,004 0,081 0.000 0,061 0,093 0,030 0,057 0,066
7.250 7.519 7.660 7.750 7.939 8.137 8.500 8.517 8.693 8.754 8.935 8,935 9.OBI 9.338 9.526 9.784 10.017 10.274 10.433 10.706 11.000 11.193 11,297 11,579 11.812 11.957 12,250 12,364 12,537 12.786
7.250 7.500 7.750 7.750 8.000 8.250 8.500 8.500 9.000 8.750 9.000 9.250 9.000 9.500 9,600 10,000 10.017 10.517 10.433 10,933 11.000 11.500 11.250 11.500 11.750 12,000 12,250 12,750 12.500 13.000
- 0.000 0 ,019 0.019 - 0.019 - 0.019 - 0.019 - 0.019 - O.019 0 ,017 0.036 - 0,036 0 ,004 0,039 - 0,039 - 0,039 0 ,081 0,120 - 0.120 0 ,026 0,146 - 0,146 - 0,146 - 0,146 - 0,146 - 0,146 - 0.146 - 0.146 0.,047 0.193 0.,079 0.272 0 .062 0.334 - 0,334 - 0,334 - 0,334 0..037 0.371 - 0.371
2 3 1 1 0 0 2 3 2 2 0 0 1 0 0 0 0 0 0 0 0 0 0 1 1 0 1 0 0 0
1 1 0 1 1 0 0 0 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 1 0 0 1 0 1 0
0 0 25 0 29 24 0 0 11 0 27 11 0 16 0 16 0 16 0 17 0 12 0 0 31 23 0 7 0 15
A150B29 A150752 150829 A1S0873 150752 150873 A150748 A150914 150914 A150907 150743 150907 A150865 1B0865 A150856 150S56 A150967 150967 Al50983 150983 A150888 150883 A151003 A150933 151003 160933 A15102S 151028 A151029 1E1029
-
204
Online Storage Systems and Transportation Problems
Appendix B: OptiTrans
205
3 151143 151150 23.292 0.000 23.292 23,750 3 1S1150 DDl 23.292 0.026 23.318 24,000 4 4 i 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4
DSl A1E0847 1E0847 A150842 150842 A1E0887 A150890 A1B0877 150390 A150913 150877 150687 150913 Al50876 150876 A1B0948 A150952 A150957 150948 150957 150952 A150973 A150966 150973 A150987 150966 150987 A150995 150995 A151011 151011 A151014 1E1014 A16 16 A151032 151032 A151024 151024 A161051 151051 A151022 1S1022
A150847 150847 4150842 150842 A150887 Al50890 A150877 150890 A150913 150877 150B87 150913 A150376 1S0B76 A150948 A150952 A150957 150948 1S09E7 150952 A150973 A150966 150973 A150987 150966 150987 A150995 150995 A151011 151011 A151014 151014 A16 16 A151032 151032 A15i024 151024 A151051 151051 A151022 1S1022 DDl
7.500 7.570 7.759 7.840 8.004 8.121 8.406 8.477 8.539 8.658 8.686 8.770 9.452 9.600 9.691 9.910 9.956 10.075 10.210 10,221 10.264 10.408 10.524 10.605 10.595 10.834 10.955 11.141 11.290 11.533 11.678 11.880 12.071 12.245 12.329 12.583 12.740 12.923 13.047 13.326 13.425 13.605 13.747
0.037 0.039 0.014 0.081 0.067 0.052 0.071 0.045 O.020 0.026 0.000 0.065 0.043 0.057 0.002 0.047 0.052 0.019 0.011 0.044 O.060 0.000 0.081 0.056 0.073 0.O38 0.036 0.065 0,063 0.078 0.052 0.074 0.041 0,000 0.046 0.057 0.000 O.0S7 0.029 0.016 0.030 0.042 0.074
7.537 7.609 7.773 7.921 8.071 8.173 8.477 8.522 3.558 8.686 8.686 8.836 9.500 9.657 9,693 9,956 10,008 10.093 10,221 10,264 10.324 10,408 10,605 10.661 10.767 10,872 10.991 11.207 11,483 11.611 11.730 11.955 12.112 12.245 12.383 12.640 12.740 12.980 13.076 13.342 13.455 13.647 13.821
7.500 6.000 7,750 6.250 6,000 8,000 3.250 3,500 8.350 6,750 8,500 3.850 9.500 10.000 9.667 9.733 10.000 10.167 10,500 10,233 10.133 10,250 10,683 10.600 10.750 11,100 10.933 11.483 11.483 11.983 11.650 12.150 12,000 12,500 12.383 12.S83 12.E00 13.000 13,067 13,567 13.250 13,750 24.000
5 5 5 5 5 5 5 5 5 5
DSl A1E0870 A150870 150870 150870 Al50908 A150908 150908 150908 A150871 A150871 A160923 A150923 150871 150871 Al50930 A150930 A150924 fll50924150923
7.987 8.067 8.179 8.467 8.547 8.704 8.749 8.689 8.956 9.139
0.013 0.029 0.066 0.014 0.073 0.029 0.073 0,067 0,033 0.014
8.000 8.095 8.250 8.480 8.620 8.732 8.822 8,956 8.939 9.152
8.000 S.EOO 8.250 8.750 8.500 8.717 9.000 8.950 8.333 9.217
-
0.721 0 0 3 0.721 0 0 3
0 ,037 0.037 0 0.037 0 0 .023 0.060 0 0,060 0 0 ,071 0.131 1 0 .173 0.304 2 0 .227 0,531 3 0 .022 0.553 2 0 ,208 0.761 2 0.761 1 0 .186 0.947 0 0,947 0 0,947 0 0,947 0 0 .026 0.974 0 0.,223 1.197 6 0..008 1.205 5 1,205 5 1,205 5 0.,031 1.236 0 0,.141 1,377 1 0..158 1,535 3 1.535 2 0 .061 1.596 2 0.,017 1.613 0 1.613 0 0..008 1.621 0 1.621 0 1.621 0 1.621 0 0 ,080 1.702 0 1.702 0 0 ,112 1.814 5 1.814 0 1.814 0 1.814 0 0 ,240 2.053 1 2.053 0 0 ,009 2.063 0 2.063 0 0 ,205 2.263 0 2.266 0 2.2S8 0 -
_ 0 .120 0.,016
0.,006 0..155
-
0.000 0.000 0.000 0.000 0.120 0.136 0.136 0.142 0.297 0.297
0 0 0 0 0 1 1 2 2 1
1 0 1 0 0 0 0 0 1 1 1 0 1 0 i 1 1 0 0 0 0 0 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 0
0 0 0 21 C 13 37 17 0 10 0 0 0 2E 13 19 C 0 17 0 22 13 0 13 0 8 0 14 0 3 0 16 0 16 0 16 0 12 12
1 0 1 0 1 1 0 0 1 1
0 6 0 14 0 0 13 0 0 26
0 6 0 3
206
Online Storage System,s and Transpo'rtation Problems
5 5 5 5 5 S 5 5 5 5 5 5 5 S 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5
150923 150930 1.B0930 150924 150924 A150941 AI60941 A150943 A150943 150943 150943 150941 150941 A150958 Al50958 150958 150958 A150971 A150971 150971 150971 A150984 A150984 150984 150984 A150985 A150985 A150986 A150986 150985 150985 150986 150986 A150994 Al50994 A150840 A150840 150994 150994 150840 150840 A1S1019 A151019 151019 151019 All All 11 11 AS A5 5 5 A151041 A151041 A151046 Ai51045 151041 161041 161045 151045 A1510e3 A151083 1S1083 1510B3 DDl
9.169 9.226 9.345 9.433 9.633 9.763 9.844 9.927 10.152 10.298 10.409 10.448 10.623 10.755 10.874 10.984 11.183 11.419 11.500 11.600 11.6B2 11.800 11.941 12.383 12.633 12.767 12.917 13.011 13.217 13.287 13.433 14.860 14.937
0.057 0.019 0,020 0.060 0.046 0.081 0.000 O.074 0.063 0.078 0.039 0.075 0.016 0.085 0,044 0.087 0.032 0.076 0.000 0.082 0.040 0.074 0.041 0.000 O.OOO 0.000 0.061 0.055 0.021 0.O45 0.036 0.087 0.047
9.226 9.245 9.417 9.500 9.680 9.844 9.844 10.002 10.216 10.376 10,448 10,523 10.539 10.840 10.917 11.071 11.219 11.500 11.500 11.632 11.750 11.874 12.000 12.383 12.633 12.767 12,978 13,083 13,237 13.333 14.617 14.937 14.984
9.450 9.333 9.417 9.500 10.000 9.917 9.817 10.317 10.150 10.650 10.433 10.933 10,517 10.617 11.017 11.117 11.200 11.500 11.250 12.000 11.750 12.250 12.000 12.500 12.500 13.000 12.750 13,083 13,250 13.683 14,617 15.117 24,000
6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6
DSl A150398 A150898 1S0898 1B0S9B A150902 A150902 150902 150902 A150854 A150854 150854 1503B4 A150880 A150830 A15092a Al50928 150880 1508S0 150923 160928 A150935 A160935 160935 150935 A150883 A150883 A150950 A160950 150950 150950 150883 150883 A150927 A150927 1S0927 150927 A151008 A151008 A150972 A150972 151008 161008 160972 150972 A151018
7.904 7.950 8,091 8,367 a.E32 8.67T 8.882 8.988 9.133 9.229 9.367 9.617 9.726 9,793 10.019 10.162 10.783 11.200 11.310 11.450 11,643 11.682 11.799
0.013 0.075 0.074 0.015 0.028 0.055 0.023 0.000 0.076 0,087 0.128 0.003 0.017 0.075 0.060 0.004 0.081 O.060 0.075 0.076 0.039 0.000 0.051
7.917 8.025 8.260 8.382 8.560 8.732 8.905 8.988 9.213 9.317 9.500 9.620 9.743 9.869 10.079 10.166 11.000 11.260 11.450 11.526 11.682 11.682 11.850
7,917 8,417 8.250 8.750 8.500 9.000 8.750 8.883 9.250 9.383 9.500 10,000 9,500 9.750 10.250 10.000 11.000 11.500 11.450 11,500 11,950 12.000 11.750
0 .027
0 .065
0 .015
_. 0 .022 0 .224
0 .019
0 .250
0 .133
0 .228
0.,060
0,.155 0..106
0 ,243 0.,119
0,,166
0..026
0. 100
0.297 0,297 0.297 0.297 0.297 0.297 0.325 0.325 0.389 0.389 0.404 0.404 0.426 0.650 0.660 0.660 0.669 0.669 0.919 0.919 0.919 0,919 0.919 0.919 1.052 1.052 1.280 1.280 1.28Q 1.280 1.280 1.280 1.280
0 0 1 1 1 0 0 0 0 0 1 0 2 4 2 0 0 1 1 0 0 0 5 0 6 0 2 2 0 0 1 0 0
1 0 0 1 0 0 1 0 1 0 0 0 0 1 1 0 1 1 0 0 1 0 1 0 1 0 0 1 1 0 0 0 0
17 16 0 0 11 26 0 10 0 10 0 5 0 0 23 14 0 0 17 11 0 8 0 23 0 8 0 0 16 15 0 20 20
0.000 0.000 0.000 0.000 0.060 0.O6O 0.215 0,319 0.319 0.319 0.319 0.319 0.563 0.681 0.681 0.847 0,847 0.847 0.847 0.874 0.874 0.874 0.974
0 0 0 0 0 0 1 1 0 0 5 0 1 1 1 0 0 0 1 1 0 0 0
1 0 1 0 1 0 0 1 1 0 1 0 0 1 0 0 1 0 0 1 1 0 1
0 7 0 8 0 11 0 0 19 20 0 S 0 0 13 26 0 16 0 0 14 10 0
Appendix B: Opti Trans
208
Online Storage Systems and Transportation Problems
Appendix B: OptiTmns
209
8 3 8 8 S 8
A151084 151084 A151099 151099 A15110S 151108
151084 A151099 151099 A1B1108 151108 DDl
14.317 14.926 15.567 15.691 16.150 16.257
0.026 0.064 0.041 0.053 0.023 0.072
14.843 15,400 15.608 16.067 16.173 16.328
15,167 15,400 15.900 16.067 16.567 24.000
9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9
DSl A1S0SS6 A150886 150336 150886 A150910 A15O910 A150915 A150915 150910 150910 A150381 A150881 A150892 Al50892 1E0916 150915 A150929 Al50929 150929 150929 150331 150881 150892 150892 A150933 Al50938 Ai507SO A150750 150938 150938 150750 150760 A150934 A1E0934 150934 150934 A150961 Al50961 A150960 A150960 150960 150960 150961 150961 A150993 Al50993 A150997 Al50997 150997 160997 150993 150993 A151005 A151005 151005 151005 A151006 A151006 A150911 A150911 lElOOS 151006 150911 150911 A151035 A151035 151035 151035 A151033 A151038 151033 151038 A15105S A151055 151055 151055 A151064 A1S1064 151064 151064 A151072 A1S1072 A151078 A15107S 151072 151072 161073 151078 A151089 AIB1039 151089 151D89 A15109S A151096 151096 151096 A151103 A151103 151103
8.000 8.070 8.231 3.484 8.584 8,766 3.766 8.849 8.349 9.000 9.056 9,093 9.193 9.517 9.591 9.742 9.362 9.971 10.013 10.042 10.313 10,491 10,525 11.000 11.050 11,092 11,189 11,333 11.457 11,609 11,786 11,346 11,953 12,533 12.692 13.031 13.214 13.315 13.490 14.000 14.129 14.350 14.667 14.740 14.883 15.083 15.159 16.467 15,612 16.250
0.037 0.044 0.020 0.000 0.065 0.000 0.000 0.000 0.017 0.056 0.041 0.000 0.074 0.07S 0.067 0.036 0.026 O.009 0.028 0.076 0,057 0.017 0.033 0,000 0.042 0.030 0,011 0.057 0.069 0.061 O.043 0.062 0.074 0.042 0.039 0,034 0.068 0.O53 0.053 0.045 0.062 0.016 0.073 0.077 0.016 0.075 0.056 O.07B 0.033 0.020
3.037 3.114 8.250 8.484 3.649 3.766 8.766 8.849 9.000 9.066 9.098 9.098 9.300 9.691 9.659 9.773 9.888 9.980 10.042 10.118 10.374 10.508 10.950 11.050 11.092 11.122 11.283 11.390 11.526 11.670 11.829 11.908 12.483 12.575 12.731 13.114 13.282 13.373 13.800 14.045 14.283 14.450 14.740 14.816 15.017 15.159 15.367 15.545 16.000 16.270
3.000 3,500 B.217 8.400 a. 717 3.750 8.750 8.900 9.0O0 9.600 9.250 9.250 9.300 9.500 9.800 10.000 9.750 10.250 10.000 9.867 10.367 10.500 10.960 11.050 11.550 11.450 11.283 11.783 11.283 11.500 11.783 12.000 12.483 12.983 12.517 13.017 13.250 13.750 13.800 14.300 14.283 14.450 14.783 14.950 15.017 15.517 15.367 15.367 16.000 16.500
1.898 1,898 1.898 1.898 1.898 1.898
0 0 0 0 0 0
0 1 0 1 0 0
11 0 13 0 7 7
0 .037 0.037 0 0.037 0 0 .034 0.070 1 0 .084 0.154 2 0.154 1 0 .016 0.170 2 0 .016 0.186 2 0.186 1 - 0.186 2 0.186 1 0.186 0 0.186 0 ~ - 0.186 0 0 .091 0.277 1 0.277 1 0.277 0 0 .138 0.415 0 0.415 0 0 .042 0.457 1 0 .251 0.707 2 0 .007 0,715 1 0 .008 0,723 0 0,723 1 0,723 2 0,723 1 0,723 0 0.723 1 0,723 0 0 .242 0.965 5 0 .170 1.135 5 0 .046 1.181 0 1.181 0 1,181 0 1.131 0 0 .214 1,395 0 0 .093 1.493 0 0..032 1.B26 0 1.525 0 1.525 0 1.525 0 1.525 1 1.525 1 1.525 0 1,525 0 1.525 1 1,525 0 1.525 0 1.525 0 1.526 0 1,526 0 -
1 0 0 0 0 0 1 1 1 1 1 0 1 1 0 0 1 0 0 1 0 0 0 0 0 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 0 1 1 0 0 0 1 0 1 0
0 5 0 0 24 0 0 22 0 4 20 20 0 0 22 12 0 6 0 0 16 29 0 0 3 11 0 7 0 0 19 15 0 6 0 24 0 6 0 15 0 0 28 22 0 9 0 11 0 17
-
210 9 151103 DDI
Online Storage Systems and Transportation Problems 16.436 0.026 16.463 24.000
-
1.525 0 0 17
Appendix B: Opti Trans
References
[I] E. H. L. Aarts and J . H. M. Korst. Simulated Annealing and Boltzmann Machines. Wiley, Chichester, UK, 1989. [2] E. H. L. Aarts, J . H. M. Korst, and P. J. M. van Laarhoven. Simulated Annealing. In E. H. L. Aarts and J. K. Lenstra, editors, Local Search in Combinatorial Optimization, pages 91-120. Wiley, Chichester, UK, 1997. [3] S. Albers. The Influence of Lookahead in Competitive Online Algorithms. Phd thesis, University of Saarland, Saarbriicken, 1993. [4] S. Albers. Online Algorithms: A Survey. Mathematical Programming series B, 97:3-26, 2003. [5] N. Ascheuer, M. Fischetti, and M. Grotschel. Solving the Asymmetric Travelling Salesman Problem with Time Windows by Branch-and-Cut. Mathematical Programming, Ser. A 90:475-506, 2001. [6] P. Augerat, J . Belenguer, E. Benavent, A. CorberBn, D. Naddef, and G. Rinaldi. Computational Results with a Branch and Cut Code for the Capacitated Vehicle Routing Problem. Technical Report RR 949-M, Universitk Joseph Fourier, Grenoble, France, 1995. [7] B. M. Baker and M. A. Ayechew. A Genetic Algorithm for the Vehicle Routing Problem. Computer and Operations Research, 30, 2003. [8] R. Baldacci, A. Mingozzi, and E. Hadjiconstantinou. An Exact Algorithm for the Capacitated Vehicle Routing Problem based on a Two-Commodity Network Flow Formulation. Technical Report 16, Departament of Mathematics, University of Bologna, Italy, 1999. [9] C. Barnhart, E. L. Johnson, G. L. Nemhauser, M. W. P. Savelsberg, and P. H. Vance. Branch-and-Price: Column Generation for Solving Huge Integer Programs. Operations Research, 46(3):316-329, 1998. [lo] L. Bianco, A. Mingozzi, and S. Ricciardelli. An Exact Algorithm for Combining
Vehicle Trips. In J. R. Daduna, L. Branco, and J. Paixao, editors, ComputerAided Transit Scheduling, volume 430 of Lecture Notes in Economics and Mathematical Systems, pages 145-172. Springer, Berlin, 1995.
214
Online Storage Systems and Transportation Problems
[ll] A. Borodin and R. El-Yaniv. Online Computation and Competitive Analysis. Cambridge University Press, New York, USA, 1998.
1121 J. Bramel and D. Simchi-Levi. The Logic of Logistics. Springer, New York, USA, 1997. 1131 J. Brandao. Metaheuristic for the Vehicle Routing Problem with Time Windows. In S. Voss, S. Martello, I. H. Osman, and C. Roucairol, editors, Meta Heuristics: Advances and Trends in Local Search Paradigms for Optimisation, pages 19-36. Kluwer, Boston, MA, 1998. [14] C. C. Carce and R. Schultz. Dual Decomposition in Stochastic Integer Programming. Operations Research Letters, 24:37-45, 1999. [15] V. Cerny. Thermodynamical Approach to the Traveling Salesman Problem: An Efficient Simulation Algorithm. Opt. Theory Appl., 45(1):41-51, 1985. [16] W.-C. Chiang and R. Russell. Simulated Annealing Metaheuristics for the Vehicle Routing Problem with Time Windows. Annals of Operations Research, 63:3-27, 1996. [17] W.-C. Chiang and R. Russell. A Reactive Tabu Search Metaheuristic for the Vehicle Routing Problem with Time Windows. INFORMS Journal on Computing, 9:417-430. 1997. [I81 T . A. Ciriani, S. Gliozzi, E. L. Johnson, and R. Tadei. Operational Research in Industry. Macmillan, Houndmills, Basingstoke, UK, 1999. [19] W. Cook and J. L. Rich. A Parallel Cutting Plane algorithm for the Vehicle Routing Problem with Time Windows. Technical report, Computational and Applied Mathematics, Rice University, Houston, TX, USA, 1999. 1201 J.-F. Cordeau, M. Gendreau, and G. Laporte. A Tabu Search Heuristic for Periodic and Multidepot Vehicle Routing Problem. Networks, 30:105-119, 1997. [21] R. Cordone and R. W. Calvo. Note on Time Window Constraints in Routing Problems. Internal Report 96.005, Politecnico di Milano, Dipartimento di Elettronica e Informazione, Milan, Italy, 1996. 1221 N. Cwikla. Patiententransporte in Krankenhauser - Vergleich uerschiedener Informationswege. Diploma Thesis, Universitat Kaiserslautern, Kaiserslautern, Germany, 2004. 1231 C. F. Daganzo. Logistics System Analysis. Springer, Berlin, Heidelberg, Germany, 2nd edition, 1996. [24] B. Dantzig and P. Wolfe. The Decomposition Algorithm for Linear Programming. Operations Research, 8:101-111, 1960. [25] G. Desaulniers, J. Desrosiers, A. Erdmann, M. M. Solomon, and F. Soumis. VRP with Pickup and Delivery. In P. Toth and D. Vigo, editors, The Vehicle Routing Problem, pages 225-242. Society for Industrial and Applied Mathematics, Philadelphia, 2001.
REFERENCES
215
[26] M. Desrochers, J. Desrosiers, and M. M. Solomon. A New Optimization Algorithm for the Vehicle Routing Problem with Time Windows. Operations Research, 40(2) :342-354, 1992, March-April. [27] J. Desrosiers and M. E. Lubbecke. Selected Topics in Column Generation. Operations Research, 2004, submitted. [28] R. W. Eglese. Simulated Annealing: A Tool for Operational Research. European Journal of Operational Research, 46:271-281, 1990. [29] M. Esen. Design, Implementation and Analysis of Online Bin Packing Algorithms. Diploma thesis, University of Kaiserslautern, Kaiserslautern, September 2000. [30] A. Fiat and G. J . Woeginger. Online Algorithms - The State of the Art. Springer, Berlin, Heidelberg, Germany, 1998. [31] M. Fischetti, P. Toth, and D. Vigo. A Branch-and-Bound Algorithm for the Capacitated Vehicle Routing Problem on Directed Graphs. Operations Research, 42:846-859, 1994. [32] M. R. Garey and D. S. Johnson. Computers and Intractability - A Guide to the Theory of N P Completeness. Freeman, New York, USA, 22nd edition, 2000. [33] P. C. Gilmore and R. E. Gomory. A Linear Programming Approach to the Cutting Stock Problem, Part I. Operations Research, 9:849-859, 1961. [34] P. C. Gilmore and R. E. Gomory. A Linear Programming Approach to the Cutting Stock Problem, Part 11. Operations Research, 11963-888, 1963. [35] F. Glover and M. Laguna. Tabu Search. Kluwer Academic Publisher, Dordrecht, The Netherlands, 1997. [36] B. L. Golden, E. A. Wasil, J. P. Kelly, and I. M. Chao. Metaheuristics in Vehicle Routing. In T . G. Crainic and G. Laporte, editors, Fleet Management and Logistics, pages 33-56. Kluwer, Boston, MA, USA, 1998. [37] S. C. Graves, A. H. G. Rinnooy Kan, and P. H. Zipkin. Logistics of Production and Inventory. Elsevier, Amsterdam, The Netherlands, 1993. [38] E. F. Grove. Online Bin Packing with Lookahead. In Proceedings of the Sixth Annual ACM-SIAM Symposium on Discrete Algorithms, pages 430-436, San Francisco, CA, 1995. ACMISIAM. [39] H. W. Hamacher, M. C. Muller, and S. Nickel. Modelling Rotastore - a Highly Parallel, Short Term Storage System. In Operations Research Proceedings, pages 513-521, Berlin, 1998. Springer Verlag. [40] P. Hansen and N. Mladenovic. Variable Neighborhood Search: Principles and Applications. EJOR, 130:449-467, 2001. [41] S. Heipcke. Applications of Optimization with Xpress-MP. Dash Optimization, Blisworth, UK, 2002.
216
Online Storage Systems a n d Transportation Problems
[42] J . H. Holland. Adaption in Natural and Artificial Systems. MIT Press, Cambridge, MA, 1975. [43] J. H. Holland. Adaption in Natural and Artificial Systems. University of Michigan Press, Ann Arbor, MI, 1975. [44] S. Homberger and H. Gehring. Two Evolutionary Metaheuristics for the Vehicle Routing Problem with Time Windows. INFOR, 37:297-318, 1999. [45] T. Hurlimann. Mathematical Modeling and Optimization, An Essay for the Design of Computer-Based Modeling Tools, volume 31 of Applied Optimization. Kluwer Academic Publishers, Dordrecht, The Netherlands, 1999. [46] T . Ibaraki, S. Imahori, M. Kubo, T. Masuda, T. Uno, and M. Yagiura. Effective Local Search Algorithms for the Vehicle Routing Problem with General Time Window Constraints. Transportation Science, 2004, to appear. 1471 ILOG Optimization Suite. ILOG, Inc., Incline Village, Nevada, 2000. http://www.ilog.com/products/optimization. 1481 S. Irnich and D. Villeneuve. The Shortest Path Problem with k-Cycle Elim3): Improving a Branch-and-Price Algorithm for the VRPTW. ination (k Technical Report G-2003-55, GERAD, Montreal, Canada, 2003.
>
[49] D. P. Jacobs, J. C. Peck, and J. S. Davis. A Simple Heuristic for Maximizing Service of Carousel Storage. Computers and Operations Research, 27:1351-1356, 2000. [50] J. Kallrath. Modeling Languages in Mathematical Optimization. Kluwer Academic Publisher, Dordrecht, The Netherlands, 2004. [51] G. Kartnig. Wege zur Leistungssteigerung won Umlaufregallagern des Typs Rotary-Rack. Habilitation, Technische Universitat Graz, Fordertechnik, May 1997. [52] S. Kirkpatrick, C. D. Gelatt, and M. P. Vecchi. Optimization by Simulated Annealing. Science, 220:671-680, 1983. [53] W. K. Klein-Haneveld and M. H. van der Vlerk. Stochastic Integer Programming: General Models and Algorithms. Annals of Operational Research, 85:3957, 1999. [54] A. K. Klinger. Spielzeitberechnung und Lagerdimensionierung des Typs RotaryRack. Phd thesis, Technische Universitat Graz, Institut fur Allgemeine Machinenlehre und Fordertechnik, Abteilung fiir Fordertechnik und Machinenzeichnen, January 1994. [55] G. Laporte, M. Desrochers, and Y. Nobert. Two Exact Algorithms for the Distance-Constrained Vehicle Routing Problem. Networks, 14:161-172, 1984. [56] H. F. Lee. Perfomance Analysis for Automated Storage and Retrieval Systems. IIE Transactions, 29:15-28, 1997.
REFERENCES [57] H. F. Lee and S. K. Schaefer. Sequencing Methods for Automated Storage and Retrieval Systems with Dedicated Storage. Computers and Industrial Engineering, 32:351-362, 1997. [58] S. Lin. Computer Solutions of the Traveling Salesman Problem. Bell System Technical Journal, 44, 1965. [59] N. Metropolis, A. W. Rosenbluth, M. N. Rosenbluth, A. H. Teller, and E. Teller. Equation of State Calculations by Fast Computing Machines. Chemical Physic, 21:1087-1092, 1953. [60] A. Mingozzi, L. Bianco, and S. Ricciardelli. Dynamic Programming Strategies for the Traveling Salesman Problem with Time Window and Precedence Constraints. Operations Research, 45:365-377, 1997. [61] G. L. Nemhauser and L. A. Wolsey. Integer and Combinatorial Optimization. Wiley, New York, USA, 1988. [62] I. H. Osman. Metastrategy Simulated Annealing and Tabu Search Algorithms for the Vehicle Routing Problem. Annals of Operations Research, 41, n.l-4:421451, 1993. [63] M. Padberg and G. Rinaldi. A Branch-and-Cut Algorithm for the Resolution of Large-Scale Symmetric Traveling Salesman Problems. SIAM Review, 33:60-100, 1991. [64] C. H. Papadimitriou and K. Steiglitz. Combinatorial Optimization: Algorithms and Complexity. DOVER, Mineola, USA, 1998. [65] J.-Y. Potvin and S. Bengio. The Vehicle Routing Problem with Time WindowsPart 11: Genetic Search. INFORMS Journal on Computing, 8:165-172, 1996. [66] J.-Y. Potvin, T . Kervahut, B. Garcia, and J.-M. Rousseau. The Vehicle Routing Problem with Time Windows-Part 1: Tabu Search. INFORMS Journal on Computing, 8:158-164, 1996. [67] J.-Y. Potvin and J.-M. Rousseau. A Parallel Routing Building Algorithm for the Vehicle Routing and Scheduling Problems with Time Windows. EJOR, 66:331-340, 1993. [68] J.-Y. Potvin and J.-M. Rousseau. An Exchange Heuristic for Routing Problems with Time Windows. Journal of Operational Research Society, 46:1433-1446, 1995. [69] T. K. Ralphs. Parallel Branch and Cut for the Vehicle Routing. PhD thesis, Cornell University, Ithaca, NY, 1995. [70] J. Rethmann and E. Wanke. Storage Controlled Pile-Up System, Theoretical Foundations. European Journal of Operational Research, 103:515-530, 1997. [71] G. Righini. Approximation Algorithms for the Vehicle Routing Problem with Pick-up and Delivery. Technical Report 33, Note del Polo - Ricerca, July 2000. [72] K. H. Rosen. Handbook of Discrete and Combinatorial Mathematics. CRC Press, Boca Raton, USA, 2000.
218
Online Storage Systems and Transportation Problems
[73] ROTASTORE. psb. GmbH, gmbh.de/scripts/en/index.php.
Pirmasens,
Germany,
http://www.psb-
[74] M. W. P. Savelsbergh. Local Search in Routing Problems with Time Windows. Annals of Operations Research, 4:285-305, 1985. [75] M. W. P. Savelsbergh. An Efficient Implementation of Local Search Algorithms for Constrained Routing Problems. European Journal of Operational Research, 47:75-85, 1990. [76] L. Schrage. Optimization Modeling with LINGO, 2004. LINDO Systems. [77] R. Schultz. On Structure and Stability in Stochastic Programs with Random Technology Matrix and Complete Integer Recourse. Mathematical Programming, 70:73-89, 1995. [78] R. Schultz. Stochastic Programming with Integer Variables. Mathematical Programming Ser. B, 97:285-309, 2003. [79] F. Semet and E. Taillard. Solving Real-Life Vehicle Routing Problems Efficiently Using Tabu Search. Annals of Operations Research, v.41 n.1-4:469-488, 1993. [80] M. M. Solomon. Algorithms for the Vehicle Routing and Scheduling Problems with Time Window Constraints. Operations Research, 35(2):254-265, 1987. [81] M. M. Solomon, E. Baker, and J . Schaffer. Vehicle Routing and Scheduling Problems with Time Windows Constraints. In B. L. Golden and A. A. Assad, editors, Vehicle Routing: Methods and Studies, pages 85-106. North-Holland, Amsterdam, 1988. [82] M. M. Solomon and J . Desrosiers. Time Window Constrained Routing and Scheduling Problems. Transportation Science, 22:l-13, 1988. [83] H. Stadtler. Linear and Mixed Integer Programming. In H. Stadtler and C. Kilger, editors, Supply Chain Management and Advanced Planning, pages 335-344. Springer, Berlin, Deutschland, 2000. [84] E. Taillaird, P. Badeau, M. Gendreau, F. Guertin, and J.-Y. Potvin. A Tabu Search Heuristic for the Vehicle Routing Problem with Soft Time Windows. Transportation Science, 31:170-186, 1997. [85] P. M. Thompson and H. N. Psarafatis. Cyclic Transfer Algorithms for MultiVehicle Routing and Scheduling Problems. Transportation Science, 22:l-13, 1993. [86] P. Toth and D. Vigo. The Vehicle Routing Problem. SIAM, Philadelphia, USA, 1st edition, 2002. [87] D. Vanderbilt and S. G. Louie. A Monte Carlo Simulated Annealing Approach to Optimization over Continuous Variables. Journal of Computational Physics, 56:259-271, 1984. [88] H.-J. Zimmermann. An Application-Oriented View of Modeling Uncertainty. European Journal of Operations Research, 122:190-198, 2000.
About the Author
Julia Kallrath was born in January 19, 1976 in Omsk, Russia. In 1992 she started her studies at the mathematical faculty at Omsk State University. Under the supervision of Prof. Dr. A. A. Kolokolov she finished her master's thesis on the modeling the social infrastructure of Omsk's region. In 2001 she started as a Ph.D. student at the Fraunhofer Institute for Industrial Mathematics (ITWM, Kaiserslautern, Germany) under supervision of Prof. Dr. S. Nickel. Her thesis was focused on online optimization problems and the solution of two real-life projects.
Index
algorithm offline, 2, 30, 35-37, 48 online, 2, 30, 34, 37, 38, 48, 53, 54, 149 with lookahead, 34, 149 polynomial, 25, 42, 43 arc, 61, 62, 79, 84, 128, 151 basis, 95, 151 Batch Presorting Problem, xiii Boltzmann acceptance criteria, 115 bounds, 77, 82, 91, 147, 151 BPSB see Batch Presorting Problem, xiii BPSP, xii, 3, 5, 6, 8, 10, 11, 13-16, 20-26, 33, 34, 43, 48-50, 52, 53, 149 Branch and Bound, xii, 52, 57, 63, 65, 82, 83, 85, 95, 99, 103, 104, 126, 147, 151 Branch and Cut, 151 Branch and Price, 71, 95, 147, 151
CEA see column enumeration, xiii column enumeration, xii, xiii, 57, 65, 92, 95, 99, 132, 134, 145-147, 149, 151 column generation, 61, 63, 65, 71, 94, 95, 147, 152 competitive analysis, xiii, 2, 37, 149 complexity, 5, 13, 42, 43, 83, 100, 101 constraints, 12, 23, 65, 70, 73-75, 79-82, 89, 93, 94, 100, 105, 109 accumulative, 92 assignment, 12 hard, 76, 77 soft, 72, 76, 77
temporal, 59, 60, 69-71, 74, 80, 81, 84, 106, 107, 109, 117, 119 time window, 57, 59, 60, 63, 73, 76, 78, 79, 84, 94, 119 cuts, 84, 85, 128, 151 dynamic programming, 63 graph, 33, 73, 116, 152 heuristic construction, 63 exchange, 63 improvement, 63 reassignment, xiii, 110, 111 sequencing, xiii, 104, 110, 111 Integer Program, 95 inter-tour, 65, 66, 120, 143 intra-tour, 65, 66, 83, 86, 120, 126, 144, 145, 147, 150 metaheuristics, 64 MINLP, 62 MINLP see M k e d Integer Nonlinear Progr., xiii Mixed Integer Nonlinear Programming, xiii neighborhood, 64, 115, 117, 118 node, 59-62, 67-69, 71-79, 81-91, 102, 104-107, 109-112, 116, 118, 131, 134, 152 objective function, 6, 10, 12, 13, 21, 26, 31-34, 38-41, 49, 52, 54, 59, 60, 62, 64, 70, 72, 73, 77, 86, 87, 89, 90, 93, 99, 100, 102, 103, 116-120, 128, 129, 132134, 136, 137, 141, 143, 152
222
Online Storage Systems and Transportation Problems
accumulative, 92, 120, 150 optimization offline, 2, 97, 115, 125, 126, 152 online, xiii, 2, 121, 125, 126, 149, 150. 152 problem infeasible, 76, 77, 84, 152 multi-vehicles, 63, 65, 71 SAT, 43 satisfiability, xiii, 43 set partitioning, 61, 93, 99, 101-103, 137, 149 single-vehicle, 65, 71, 85, 117, 128, 129, 144 programming linear, 12, 94 reassignment, 66 relaxation, 63, 72, 77, 153 RH see heuristic, reassignment, xiii
SA see simulated annealing, xiii SAT see problem, satisfiability, xiii sequencing, 66 SH see heuristic, sequencing, xiii simplex algorithm, 9, 95, 153 simulated annealing, xiii, 64, 66, 115-117, 143, 144, 147, 149 stopping criteria, 112, 113 tabu search, xiii, 64 termination criteria, 112, 113 TS see tabu search, xiii unimodular, 9, 24, 25, 153 variable neighborhood search, xiii, 64 variables, 153 basic, 151 Vehicle Routing Problem, xii, xiii, 3, 57, 58, 60, 63-65, 69, 82, 146 VNS see variable neighborhood search, xiii VRP see Vehicle Routing Problem, xiii