arXiv:1009.5030v1 [cs.CC] 25 Sep 2010 Approximability of the Multiple Stack TSP Sophie Toulouse 1 LIPN (UMR CNRS 7030) - Institut Galil´ee - Universit´e Paris 13, 99 av. Jean-Baptiste Cl´ement, 93430 Villetaneuse, France Abstract STSP seeks a pair of pickup and delivery tours in two distinct networks, where the two tours are related by LIFO contraints. We address here the problem approxima- bility. We notably establish that asymmetric MaxSTSP and MinSTSP12 are APX, and propose a heuristic that yields to a 1/2, 3/4 and 3/2 standard approximation for respectively Max2STSP, Max2STSP12 and Min2STSP12. Keywords: Approximation algorithms, multiple stack TSP, TSP, LIFO constraints 1 Introduction The multiple Stack Traveling Salesman Probem, STSP, has been recently in- troduced in [1] and is very well motivated by the initial request of a trans- portation company. Consider a company that owns a vehicle fleet and a depot in m distinct cities C1, . . . , Cm. For any pair (Cj, Cj′) of cities, the company handles orders from Cj suppliers to Cj′ customers, proceeding as follows: in Cj, a single vehicle picks up all the orders that involve a Cj′ customer; during this tour, the commodities are packed within a single container that consists of a given number k of rows; the container is then sent to Cj′, where a local vehicle delivers the commodities. The operator thus is faced with two levels of 1 Email: sophie.toulouse@lipn.univ-paris13.fr transportation: the local one inside the cities, the long-haul one between the cities. STSP models the local level problem; namely, in the context we have just described, every pair of cities defines an instance of STSP. The problem specificity relies on the way the containers are managed: their rows behave like stacks, and no repacking is allowed. The rows of the containers thus are subject to LIFO “Last In First Out” constraints. Therefore, the delivery tour in Cj′ must handle at first orders that have been handled at last in Cj. Formally, an instance I of STSP considers a number k of stacks (the container rows), together with two distinct networks IA = (GA, dA), IB = (GB, dB), where V (Gα) ≡[n + 1] and dα : E(Gα) →N, α ∈{A, B}. In both networks, vertex 0 represents the depot, whereas vertex i ∈[n] represents the ith order (the ith supplier in IA, the ith customer in IB). A solution consists of a pickup tour ⃗T A on IA, a delivery tour ⃗T B on IB, and a packing P = {P 1, . . . , P k} of the commodities into the stacks, where a stack P β is described as a sequence (i1, . . . , ipβ) of commodities (index 1 refers to the bot- tom of P β). We denote by <α, α ∈{A, B} the complete order that ⃗T α induces on [n]: i <α i′ iff⃗T α handles order i earlier than it handles i′. Similary, we denote by
B i′)
(1)
The value of a solution (P, ⃗T A, ⃗T B) is given by the sum dA(⃗T A) + dB(⃗T B)
of the distance of its two tours. The ultimate goal naturally consists in finding
the feasible triple (P, ⃗T A, ⃗T B) of optimum value.
In what follows, the stacks are assumed to have unlimited capacities. The
most often, input graphs are complete.
For TSP (the Traveling Salesman
Problem), as well as for STSP, A(S)TSP, ∆(S)TSP and (S)TSPab respec-
tively refer the asymmetric, the metric and the bivaluated cases.
Finally,
kSTSP considers that k is a universal constant. Since one manipulates both
maximization and minimization goals, we use notations ⪰, ≻, opt, opt in-
stead of ≥, >, max, min (resp., ≤, <, min, max) if the goal is to maximize
(resp., to minimize). Finally, because one jointly considers pickup and delivery
tours, we respectively denote by E−1 = {(i′, i) | (i, i′) ∈E}, G−1 = (V, E−1),
d−1 : E−1 →N : d−1(i, i′) = d(i′, i) and I−1 = (G−1, d−1) the reverse of an
edge set E, a graph G = (V, E), a distance d : E →N, a network I = (G, d).
Hence, ⃗T is a tour of value d(⃗T) on I iff⃗T −1 is a tour of value d(⃗T) on I−1.
2
Preliminaries
The problem trivially is NP −hard, from TSP. Indeed, for extremal val-
ues of the number of stacks, STSP strictly is equivalent to TSP: if STSP
assumes a single stack, then it reduces to TSP, considering the distance
d : (i, i′) 7→dA(i, i′) + dB(i′, i); if on the opposite STSP assumes n stacks,
then it reduces to two independent TSP (packings that store one commodity
per stack do not induce any LIFO constraint). The litterature on computa-
tional aspects of STSP is rather thin: see [1,2] for metaheuristic approachs,
[3] for an exact approach (that solves 2STSP via the computation of the k
best tours in IA, IB), [4] for an analysis of STSP complexity. We here make
use of natural connections to TSP and observations made in [4] in order to
locate STSP within the approximation hierarchy.
Besides its practical impacts, STSP presents a rather intricate combina-
torial structure. One the one hand, one could wonder on what part of the
problem does structure / impact the most the solution / its complexity. It
appeared in [4] that both the packing and the tour subproblems are tractable:
Theorem 2.1 ([4]) In arbitrary input graphs:
(i) Deciding, given a pair (⃗T A, ⃗T B), whether it admits or not a consistent
packing P (and to design this packing if the answer is YES) is in P.
(ii) When k is a universal constant: given a packing P, computing a pair
of tours that are optimal for P is in P.
On the other hand, STSP has strong connections to coloring and schedul-
ing. Indeed, subproblem (i) reduces to graph coloring in C(⃗T A, ⃗T B) = {i ̸=
i′ ∈[n] | i P) precedence constraints.
3
A first classification of STSP
Property 1
(i) There exists a standard approximation preserving reduction
from ASTSP to ATSP that maps a ρ-approximate solution of ATSP to
a ρ/2, ρ/2 + (a/2b), ρ/2 + (b/2a)-approximate solution of ASTSP for
Max(S)TSP, Max(S)TSPab and Min(S)TSPab, respectively.
(ii) Case of arbitrary graphs. Any approximate factor ρ for any restriction
of STSP also holds for the same restricton of TSP.
Proof. i. Associate with the instance I = (IA, IB) of ASTSP the pair (IA, IB)
(i)
i1
j
?
i1
j′
i1
j
?
i1
j′
i2
h
i2
h′
(ii)
i1
j
i1
j′
i2
h
i2
h′
?
(iii)
i1
j
i1
j+1
i2
h+1
i2
h
?
i1
j
i1
j+1
i2
h+1
i2
h
?
Fig. 1. The three configurations that contradict consistency.
of instances of ATSP. Compute ⃗T α, α ∈{A, B} an approximate tour on Iα.
Pick the tour ⃗T A or ⃗T B that performs the best among dA(⃗T A) + (dB)−1(⃗T A),
(dA)−1(⃗T B) + dA(⃗T B). ii. Associate with the instance I = (G, d) of TSP the
instance I′ = (I, I−1) of STSP.
✷
Proposition 3.1 (Immediate from Property 1)
(i) Max(A)STSP, Max∆(A)STSP, Max(A)STSP01,
Min(A)STSP12 are standard-approximable within the following factor:
MaxSTSP
MaxASTSP
Max∆STSP
Max∆ASTSP
61/162 −o(1), [8]
1/3, [9]
7/16 −o(1), [7]
31/80, [10]
MaxSTSP01
MaxASTSP01
MinSTSP12
MinASTSP12
3/7, [12]
3/8, [11]
11/7, [12]
13/8, [11]
(ii) Max∆STSP∈MaxSNP-hard, [5]; MaxSTSP12∈APX-hard, [6]; Min-
STSP is not 2p(n+1) standard-approximable for any polynomial p, or P = NP
4
A matching based heuristic for the symmetric 2STSP
In what follows, we say that an edge set N is consistent with a packing P iff
there exists a completion N′ of N into a tour T s.t. T is feasible with respect
to P. We first provide a characterization of consistency for 2STSP.
Proposition 4.1 (Due to lack of space, the proof is omitted.) Given a
packing P, Jβ = {0, . . . , pβ +1} denotes the index set on P β, β ∈{1, 2}. Arti-
ficial indexes 0, pβ+1 are introduced in order to represent the depot vertex, i.e.,
iβ
0 = iβ
pβ+1 = 0. Let N be a collection of pairwise disjoint elementary chains on
[n + 1], then N is consistent with P iffit satifies the three following properties
(configurations that contradict consistency are illustrated in Figure 1):
(i) No jump: ∀β ∈{1, 2}, ∀j < j′ ∈Jβ,
{iβ
j , iβ
j′} ∈N
∨
∃h ≤h′ ∈J3−β, {iβ
j , i3−β
h
, . . . , i3−β
h′ , iβ
j′} ⊆N
⇒j′ = j + 1
(ii) No crossing edges: ∀j ̸= j′ ∈J1, ∀h ̸= h′ ∈J2, {{i1
j, i2
h}, {i1
j′, i2
h′}} ⊆N
⇒(j < j′ ⇔h < h′)
(iii) No way back: ∀j ∈J1, ∀h ∈J2, {{i1
j, i1
j+1}, {i2
h, i2
h+1}} ⊆N
⇒
{i1
j, i2
h}
/∈N ∧
{i1
j+1, i2
h+1}
/∈N
P 1 :
P 2 :
c1
1 = 0
c1
2
c1
3
c2
1
c2
2
c2
3
c2
4
c3
1
c3
2
c4
1
c4
2
c4
3
c4
4
c4
5
c4
6
MA
T A, T B\Mα
MB
e∗
B
A
A
B
0
Fig. 2. Possible completions of the approximate packing P: case n even.
j, j′ ̸= 1, j ≡j′ + 1[2]
0
c1
2
c1
3
c1
4
c1
5
c1
6
c1
7
c1
8
c1
9
e∗
j, j′ ̸= 1, j ≡j′[2]
0
c1
2
c1
3
c1
4
c1
5
c1
6
c1
9
c1
8
c1
7
0
e∗
j′ = 1
0
c1
2
c1
3
c1
4
c1
5
c1
6
c1
7
c1
8
c1
9
0
e∗
MA
MB
Fig. 3. The approximate packing when n is even and p = 1.
The algorithm relies on a pair (MA, MB) of optimum weight matchings
on IA, IB. Given such a pair, together with some additional edge e∗, it aims
at computing a packing P s.t. Nα, α ∈{A, B}, is consistent with P, where
Nα coincides with Mα (resp., Mα ∪{e∗}) when n is odd (resp., even). Let H
denote the multigraph ([n+1], MA∪MB), and C1, . . . , Cp denote its connected
components. We assume w.l.o.g., that the depot vertex (i.e., node 0) coincides
with vertex c1
1 in C1. If n is odd (iffn+1 is even), then every component Ch is
an elementary cycle {ch
1, . . . , ch
qh, ch
1} of even length qh ≥2. Otherwise, Ch =
{ch
1, . . . , ch
qh, ch
1}\{{ch
ℓ, ch
ℓ+1}} is an elementary chain of even length qh −1 ≥0
for a lonely index h ∈[p]. We define the additional edge e∗as follows:
∀p,
e∗
= arg opt{ opt
α=A,B
{dα(f)} | f ∈F(p)}, where:
(2)
F(1) =
{0} ∪{c1
3, . . . , c1
ℓ}
×
{0} ∪{c1
ℓ+1, . . . , c1
n}
\{{0, 0}}
(3)
F(p) = ∪p
(h