Four Soviets Walk the Dog: Improved Bounds for Computing the Fréchet Distance
 650 Downloads
 2 Citations
Abstract
Given two polygonal curves in the plane, there are many ways to define a notion of similarity between them. One popular measure is the Fréchet distance. Since it was proposed by Alt and Godau in 1992, many variants and extensions have been studied. Nonetheless, even more than 20 years later, the original \(O(n^2 \log n)\) algorithm by Alt and Godau for computing the Fréchet distance remains the state of the art (here, n denotes the number of edges on each curve). This has led Helmut Alt to conjecture that the associated decision problem is 3SUMhard. In recent work, Agarwal et al. show how to break the quadratic barrier for the discrete version of the Fréchet distance, where one considers sequences of points instead of polygonal curves. Building on their work, we give a randomized algorithm to compute the Fréchet distance between two polygonal curves in time \(O(n^2 \sqrt{\log n}(\log \log n)^{3/2})\) on a pointer machine and in time \(O(n^2(\log \log n)^2)\) on a word RAM. Furthermore, we show that there exists an algebraic decision tree for the decision problem of depth \(O(n^{2\varepsilon })\), for some \(\varepsilon > 0\). We believe that this reveals an intriguing new aspect of this wellstudied problem. Finally, we show how to obtain the first subquadratic algorithm for computing the weak Fréchet distance on a word RAM.
Keywords
Frechet distance Word RAM Pointer machine Algebraic decision tree Four Russian trick1 Introduction
Shape matching is a fundamental problem in computational geometry, computer vision, and image processing. A simple version can be stated as follows: given a database \({\mathcal {D}}\) of shapes (or images) and a query shape S, find the shape in \({\mathcal {D}}\) that most resembles S. However, before we can solve this problem, we first need to address an issue: what does it mean for two shapes to be “similar”? In the mathematical literature, on can find many different notions of distance between two sets, a prominent example being the Hausdorff distance. Informally, the Hausdorff distance is defined as the maximal distance between two elements when every element of one set is mapped to the closest element in the other. It has the advantage of being simple to describe and easy to compute for discrete sets. In the context of shape matching, however, the Hausdorff distance often turns out to be unsatisfactory: it does not take the continuity of the shapes into account. There are well known examples where the distance fails to capture the similarity of shapes as perceived by human observers [6].
In order to address this issue, Alt and Godau introduced the Fréchet distance into the computational geometry literature [8, 45]. They argued that the Fréchet distance is better suited as a similarity measure, and they described an \(O(n^2\log n)\) time algorithm to compute it on a real RAM or pointer machine.^{1} Since Alt and Godau’s seminal paper, there has been a wealth of research in various directions, such as extensions to higher dimensions [7, 23, 26, 28, 33, 46], approximation algorithms [9, 10, 37], the geodesic and the homotopic Fréchet distance [29, 34, 38, 48], and much more [2, 22, 25, 35, 36, 51, 54, 55]. Most known approximation algorithms make further assumptions on the curves, and only an \(O(n^2)\)time approximation algorithm is known for arbitrary polygonal curves [24]. The Fréchet distance and its variants, such as dynamic timewarping [13], have found various applications, with recent work particularly focusing on geographic applications such as mapmatching tracking data [15, 63] and moving objects analysis [19, 20, 47].
Despite the large amount of published research, the original algorithm by Alt and Godau has not been improved, and the quadratic barrier on the running time of the associated decision problem remains unbroken. If we cannot improve on a quadratic bound for a geometric problem despite many efforts, a possible culprit may be the underlying 3SUMhardness [44]. This situation induced Helmut Alt to make the following conjecture.^{2}
Conjecture 1.1
(Alt’s conjecture) Let P, Q be two polygonal curves in the plane. Then it is 3SUMhard to decide whether the Fréchet distance between P and Q is at most 1.
Here, 1 can be considered as an arbitrary constant, which can be changed to any other bound by scaling the curves. So far, the best unconditional lower bound for the problem is \(\Omega (n \log n)\) steps in the algebraic computation tree model [21].
Recently, Agarwal et al. [1] showed how to achieve a subquadratic running time for the discrete version of the Fréchet distance, running in \(O\big (n^2 \, \frac{\log \log n}{\log n}\big )\) time. Their approach relies on reusing small parts of the solution. We follow a similar approach based on the socalled FourRussiantrick which precomputes small recurring parts of the solution and uses tablelookup to speed up the whole computation.^{3} The result by Agarwal et al. is stated in the word RAM model of computation. They ask whether their result can be generalized to the case of the original (continuous) Fréchet distance.
1.1 Our Contribution
We address the question by Agarwal et al. and show how to extend their approach to the Fréchet distance between two polygonal curves. Our algorithm requires total expected time \(O(n^2 \sqrt{\log n} (\log \log n)^{3/2})\). This is the first algorithm with a running time of \(o(n^2 \log n)\) and constitutes the first improvement for the general case since the original paper by Alt and Godau [8]. To achieve this running time, we give the first subquadratic algorithm for the decision problem of the Fréchet distance. We emphasize that these algorithms run on a real RAM/pointer machine and do not require any bitmanipulation tricks. Therefore, our results are more in the line of Chan’s recent subcubictime algorithms for allpairsshortest paths [30, 31] or recent subquadratictime algorithms for minplus convolution [16] than the subquadratictime algorithms for 3SUM due to Baran et al. [12]. If we relax the model to allow constant time tablelookups, the running time can be improved to be almost quadratic, up to \(O(\log \log n)\) factors. As in Agarwal et al., our results are achieved by first giving a faster algorithm for the decision version, and then performing an appropriate search over the critical values to solve the optimization problem.
In addition, we show that nonuniformly, the Fréchet distance can be computed in subquadratic time. More precisely, we prove that the decision version of the problem can be solved by an algebraic decision tree [11] of depth \(O(n^{2\varepsilon })\), for some fixed \(\varepsilon > 0\). It is, however, not clear how to implement this decision tree in subquadratic time, which hints at a discrepancy between the decision tree and the uniform complexity of the Fréchet problem.
Summary of results
Problem  Model  Old  New  Comment 

Continuous (D)  PM  \(O(n^2)\)  \(O\big (n^2\, \frac{(\log \log n)^{3/2}}{\sqrt{\log n}}\big )\)  
Continuous (D)  WRAM  \(O(n^2)\)  \(O\big (n^2\, \frac{(\log \log n)^{2}}{\log n}\big )\)  
Continuous (D)  DT  \(O(n^2)\)  \(O(n^{2  \varepsilon })\)  For \(0< \varepsilon < 1/6\) 
Continuous (C)  PM  \(O(n^2\log n)\)  \(O\big (n^2\sqrt{\log n}(\log \log n)^{3/2}\big )\)  
Continuous (C)  WRAM  \(O(n^2\log n)\)  \(O\big (n^2(\log \log n)^{2}\big )\)  
Discrete (D)  PM  \(O(n^2)\)  \(O\big (n^2 \, \frac{\log \log n}{\log n}\big )\)  [1] uses WRAM 
Discrete (C)  DT  \(O(n^2)\)  \(O\big (n^{4/3}\log ^c n\big )\)  Implicit in [1] 
Weak (D)  PM  \(O(n^2)\)  \(O\big (n^2 \, \frac{\alpha (n)\log \log n}{\log n}\big )\)  
Weak (D)  WRAM  \(O(n^2)\)  \(O\big (n^2 \, \frac{(\log \log n)^5}{\log ^2 n}\big )\)  
Weak (C)  PM  \(O(n^2\log n)\)  \(O\big (n^2 \alpha (n)\log \log n\big )\)  
Weak (C)  WRAM  \(O(n^2\log n)\)  \(O\big (n^2 \frac{(\log \log n)^5}{\log n}\big )\) 
1.2 Recent Developments
Recently, Ben Avraham et al. [14] presented a subquadratic algorithm for the discrete Fréchet distance with shortcuts that runs in \(O(n^{4/3}\log ^3 n)\) time. This running time resembles, at least superficially, our result on algebraic computation trees for the general discrete Fréchet distance.
When we initially announced our results, we believed that they provided strong evidence that Alt’s conjecture is false. Indeed, for a long time it was conjectured that no subquadratic decision tree exists for 3SUM [57] and an \(\Omega (n^2)\) lower bound is known in a restricted linear decision tree model [4, 40]. However, in a recent–and in our opinion quite astonishing–result, Grønlund and Pettie showed that if we allow only slightly more powerful algebraic decision trees than in the previous lower bounds, one can decide 3SUM nonuniformly in \(O(n^{2\varepsilon })\) steps, for some fixed \(\varepsilon > 0\) [52]. They also show that this leads to a general subquadratic algorithm for 3SUM, a situation very similar to the Fréchet distance as described in the present paper. Thus, despite some interesting developments, the status of Alt’s conjecture remains as open as before. However, we can now see that there exists a wide variety of efficiently solvable problems such as (in addition to 3SUM and the Fréchet distance) Sorting \(X+Y\) [41], MinPlusConvolution [16], or finding the Delaunay triangulation for a point set that has been sorted in two orthogonal directions [27], for which there seems to be a noticeable gap between the decision tree complexity and the uniform complexity.
In our initial announcement, we also asked whether, besides 3SUMhardness, there may be other reasons to believe that the quadratic running time for the Fréchet distance cannot be improved. Karl Bringmann provided an interesting answer to this question by showing that any algorithm for the Fréchet distance with running time \(O(n^{2\varepsilon })\), for some fixed \(\varepsilon > 0\), would violate the strong exponential time hypothesis (SETH) [17]. These results were later refined and improved to show that the lower bound holds in basically all settings (with the notable exception of the onedimensional continuous Fréchet distance, which is still unresolved) [18]. We believe that these developments show that the Fréchet distance still holds many interesting aspects to be discovered and remains an intriguing object of further study.
2 Preliminaries and Basic Definitions
The structure of \({{\mathrm{FSD}}}(P,Q)\) is easy to describe. Let \(R :=[0,n] \times [0, n]\) be the ground set. We subdivide R into \(n^2\) cells \(C(i,j) = [i, i+1] \times [j, j+1]\), for \(i,j = 0, \dots , n1\). The cell C(i, j) corresponds to the edge pair \(e_{i+1}\) and \(f_{j+1}\), where \(e_{i+1}\) is the \((i+1)\)th edge of P and \(f_{j+1}\) is the \((j+1)\)th edge of Q. Then the set \(F(i,j) :={{\mathrm{FSD}}}(P,Q) \cap C(i,j)\) represents all pairs of points on \(e_{i+1} \times f_{j+1}\) with distance at most 1. Elementary geometry shows that F(i, j) is the intersection of C(i, j) with an ellipse [8]. In particular, the set F(i, j) is convex, and the intersection of \({{\mathrm{FSD}}}(P,Q)\) with the boundary of C(i, j) consists of four (possibly empty) intervals, one on each side of \({\partial }C(i,j)\). We call these intervals the doors of C(i, j) in \({{\mathrm{FSD}}}(P,Q)\). A door is said to be closed if the interval is empty, and open otherwise.
A path \(\pi \) in \({{\mathrm{FSD}}}(P,Q)\) is bimonotone if it is both x and ymonotone, i.e., every vertical and every horizontal line intersects \(\pi \) in at most one connected component. Alt and Godau observed that it suffices to decide whether there exists a bimonotone path from (0, 0) to (n, n) inside \({{\mathrm{FSD}}}(P,Q)\). We define the reachable region \({{\mathrm{reach}}}(P,Q)\) as the set of points in \({{\mathrm{FSD}}}(P,Q)\) that are reachable from (0, 0) on a bimonotone path. Then, \(d_F(P,Q) \le 1\) if and only if \((n,n) \in {{\mathrm{reach}}}(P,Q)\), see Fig. 1. It is not necessary to compute all of \({{\mathrm{reach}}}(P,Q)\): since \({{\mathrm{FSD}}}(P,Q)\) is convex inside each cell, we only need the intersections \({{\mathrm{reach}}}(P,Q) \cap {\partial }C(i,j)\). The sets defined by \({{\mathrm{reach}}}(P,Q) \cap {\partial }C(i,j)\) are subintervals of the doors of the freespace diagram, and they are defined by endpoints of doors in the freespace diagram in the same row or column. We call the intersection of a door with \({{\mathrm{reach}}}(P,Q)\) a reachdoor. The reachdoors can be found in \(O(n^2)\) time through a simple breadthfirsttraversal of the cells [8]. In the next sections, we show how to obtain the crucial information, i.e., whether \((n,n) \in {{\mathrm{reach}}}(P,Q)\), in \(o(n^2)\) time instead.
2.1 Basic Approach and Intuition
In our algorithm for the decision problem, we basically want to compute \({{\mathrm{reach}}}(P,Q)\). But instead of propagating the reachability information cell by cell, we always group \(\tau \times \tau \) cells (with \(1 \ll \tau \ll n\)) into an elementary box of cells. When processing a box, we can assume that we know which parts of the left and the bottom boundary of the box are reachable. That is, we know the reachdoors on the bottom and left boundary, and we need to compute the reachdoors on the top and right boundary of the elementary box. These reachdoors are determined by the combinatorial structure of the box. More specifically, suppose we know for every row and column the order of the door endpoints (including for the reachdoors on the left and bottom boundary). Then, we can deduce which of these door boundaries determine the reachdoors on the top and right boundary. We call the sequence of these orders, the (full) signature of the box.
The total number of possible signatures is bounded by an expression in terms of \(\tau \). Thus, if we pick \(\tau \) sufficiently small compared to n, we can precompute for all possible signatures the reachdoors on the top and right boundary, and build a data structure to query these quickly (Sect. 3). Since the reachdoors on the bottom and left boundary are required to make the signature, we initially have only incomplete signatures. In Sect. 4, we describe how to compute these efficiently. The incomplete signatures are then used to preprocess the data structure such that we can quickly find the full signature once we know the reachdoors of an elementary box. After building and preprocessing the data structure, it is possible to determine \(d_F(P,Q) \le 1\) efficiently by traversing the freespace diagram elementary box by elementary box, as explained in Sect. 5.
3 Building a Lookup Table
3.1 Preprocessing an Elementary Box
Before it considers the input, our algorithm builds a lookup table. As mentioned above, the purpose of this table is to speed up the computation of small parts of the freespace diagram.
Let \(\tau \in {\mathbb {N}}\) be a parameter.^{4} The elementary box is a subdivision of \([0,\tau ]^2\) into \(\tau \) columns and rows, thus \(\tau ^2\) cells.^{5} For \(i,j = 0, \dots , \tau 1\), we denote the cell \([i,i+1] \times [j, j+1]\) with D(i, j). We denote the left side of the boundary \({\partial }D(i,j)\) by l(i, j) and the bottom side by b(i, j). Note that l(i, j) coincides with the right side of \({\partial }D(i1, j)\) and b(i, j) with the top of \({\partial }D(i, j1)\). Thus, we write \(l(\tau , j)\) for the right side of \(D(\tau  1, j)\) and \(b(i, \tau )\) for the top side of \(D(i, \tau  1)\). Figure 2 shows the elementary box.
We can now define the (full) signature of the elementary box as the aggregation of the doororders of its rows and columns. Therefore, a signature \(\Sigma \,{=}\, (\sigma _1^c, \dots , \sigma _\tau ^c, \sigma _1^r, \dots , \sigma _\tau ^r)\) consists of \(2\tau \) doororders: one doororder \(\sigma _i^c\) for each column i and one doororder \(\sigma _j^r\) for each row j of the elementary box. Similarly, an incomplete signature is the aggregation of incomplete doororders.
For a given signature, we define the combinatorial reachability structure of the elementary box as follows. For each column i and for each row j, the combinatorial reachability structure indicates which door boundaries in the respective column or row define the reachdoor of \(b(i, \tau )\) or \(l(\tau , j)\).
Lemma 3.1
Let \(\Sigma \) be a signature for the elementary box. Then we can determine the combinatorial reachability structure of the box in total time \(O(\tau ^2)\).
Proof
We use dynamic programming, very similar to the algorithm by Alt and Godau [8]. For each vertical edge l(i, j) we define a variable \({\widehat{l}}(i,j)\), and for each horizontal edge b(i, j) we define a variable \({\widehat{b}}(i,j)\). The \({\widehat{l}}(i,j)\) are pairs of the form \((s_u, t_v)\), representing the reachdoor \({{\mathrm{reach}}}(P,Q) \cap l(i,j)\). If this reachdoor is closed, then \(t_v <_j^r s_u\) holds. If the reachdoor is open, then it is bounded by the lower endpoint of the door on l(u, j) and by the upper endpoint of the door on l(v, j). (Note that in this case we have \(v = i\).) Once again \(s_0\) and \(t_0\) are special and represent the reachdoor on l(0, j). The variables \({\widehat{b}}(i,j)\) are defined analogously.
Case 1: Suppose \({\widehat{b}}(i1, j)\) is open. This means that \(b(i1, j)\) intersects \({{\mathrm{reach}}}(P,Q)\), so \({{\mathrm{reach}}}(P,Q) \cap l(i,j)\) is limited only by the door on l(i, j), and we can set \({\widehat{l}}(i,j) :=(s_i, t_i)\).
Case 2: If both \({\widehat{b}}(i1, j)\) and \({\widehat{l}}(i1, j)\) are closed, it is impossible to reach l(i, j) and thus we set \({\widehat{l}}(i,j) :={\widehat{l}}(i1,j)\).
Case 3: If \({\widehat{b}}(i1, j)\) is closed and \({\widehat{l}}(i1, j)\) is open, we may be able to reach l(i, j) via \(l(i1,j)\). Let \(s_u\) be the lower endpoint of \({\widehat{l}}(i1, j)\). We need to pass l(i, j) above \(s_u\) and \(s_i\) and below \(t_i\), and therefore set \({\widehat{l}}(i,j) :=(\max (s_u, s_i), t_i)\), where the maximum is taken according to the order \(<_j^r\).
The recursion for the variable \({\widehat{b}}(i,j)\) is defined similarly. We can implement the recursion in time \(O(\tau ^2)\) for any given signature, for example by traversing the elementary box column by column, while processing each column from bottom to top. \(\square \)
There are at most \(((2\tau +2)!)^{2\tau } = \tau ^{O(\tau ^2)}\) distinct signatures for the elementary box. We choose \(\tau = \lambda \sqrt{\log n/\log \log n}\) for a sufficiently small constant \(\lambda >0\), so that this number becomes o(n). Thus, during the preprocessing stage we have time to enumerate all possible signatures and determine the corresponding combinatorial reachability structure inside the elementary box. This information is then stored in an appropriate data structure.
3.2 Building the Data Structure
Before we describe this data structure, we first explain how the doororders are represented. This depends on the computational model. By our choice of \(\tau \), there are o(n) distinct doororders. On the word RAM, we represent each doororder and incomplete doororder by an integer between 1 and \((2\tau )!\). This fits into a word of \(\log n\) bits. On the pointer machine, we create a record for each doororder and incomplete doororder; we represent an order by a pointer to the corresponding record.
The data structure has two stages. In the first stage, we assume we know the incomplete doororder for each row and for each column of the elementary box,^{6} and we wish to determine the incomplete signature. In the second stage we have obtained the reachdoors for the left and bottom sides of the elementary box, and we are looking for the full signature. The details of our method depend on the computational model. One way uses table lookup and requires the word RAM; the other way works on the pointer machine, but is a bit more involved.
3.2.1 Word RAM
We organize the lookup table as a large tree T. In the first stage, each level of T corresponds to a row or column of the elementary box. Thus, there are \(2\tau \) levels. Each node has \((2\tau )!\) children, representing the possible incomplete doororders for the next row or column. Since we represent doororders by positive integers, each node of T may store an array for its children; we can choose the appropriate child for a given incomplete doororder in constant time. Thus, determining the incomplete signature for an elementary box requires \(O(\tau )\) steps on a word RAM.
For the second stage, we again use a tree structure. Now the tree has \(O(\tau )\) layers, each with \(O(\log \tau )\) levels. Again, each layer corresponds to a row or column of the elementary box. The levels inside each layer then implement a balanced binary search tree that allows us to locate the endpoints of the reachdoor within the incomplete signature. Since there are \(2\tau \) endpoints, this requires \(O(\log \tau )\) levels. Thus, it takes \(O(\tau \log \tau )\) time to find the full signature of a given elementary box.
3.2.2 Pointer machine
Unlike in the word RAM model, we are not allowed to store a lookup table on every level of the tree T, and there is no way to quickly find the appropriate child for a given doororder. Instead, we must rely on batch processing to achieve a reasonable running time.
Thus, suppose that during the first stage we want to find the incomplete signatures for a set B of m elementary boxes, where again for each box in B we know the incomplete doororder for each row and each column. Recall that we represent the doororder by a pointer to the corresponding record. With each such record, we store a queue of elementary boxes that is empty initially.
We now simultaneously propagate the boxes in B through T, proceeding level by level. In the first level, all of B is assigned to the root of T. Then, we go through the nodes of one level of T, from left to right. Let v be the current node of T. We consider each elementary box b assigned to v. We determine the next incomplete doororder for b, and we append b to the queue for this incomplete doororder—the queue is addressed through the corresponding record, so all elementary boxes with the same next incomplete doororder end up in the same queue. Next, we go through the nodes of the next level, again from left to right. Let \(v'\) be the current node. The node \(v'\) corresponds to a next incomplete doororder \(\sigma \) that extends the known signature of its parents. We consider the queue stored at the record for \(\sigma \). By construction, the elementary boxes that should be assigned to \(v'\) appear consecutively at the beginning of this queue. We remove these boxes from the queue and assign them to \(v'\). After this, all the queues are empty, and we can continue by propagating the boxes to the next level. During this procedure, we traverse each node of T a constant number of times, and in each level of the T we consider all the boxes in B. Since T has o(n) nodes, the total running time is \(O(n + m\tau )\).
For the second stage, the data structure works just as in the word RAM case, because no table lookup is necessary. Again, we need \(O(\tau \log \tau )\) steps to process one box. After the second stage, we obtain the combinatorial reachability structure of the box in constant time since we precomputed this information for each box (Lemma 3.1). Thus, we have shown the following lemma, independently of the computational model.
Lemma 3.2

given a set of m elementary boxes where the incomplete doororders are known, we can find the incomplete signature of each box in total time \(O(n + m \tau )\);

given the incomplete signature and the reachdoors on the bottom and left boundary of an elementary box, we can find the full signature in \(O(\tau \log \tau )\) time;

given the full signature of an elementary box, we can find the combinatorial reachability structure of the box in constant time.
4 Preprocessing a Given Input
Next, we perform a second preprocessing phase that considers the input curves P and Q. Our eventual goal is to compute the intersection of \({{\mathrm{reach}}}(P,Q)\) with the cell boundaries, taking advantage of the data structure from Sect. 3. For this, we aggregate the cells of \({{\mathrm{FSD}}}(P,Q)\) into (concrete) elementary boxes consisting of \(\tau \times \tau \) cells. There are \(n^2/\tau ^2\) such boxes. We may avoid rounding issues by either duplicating vertices or handling a small part of \({{\mathrm{FSD}}}(P,Q)\) without lookup tables.
We aggregate the columns of \({{\mathrm{FSD}}}(P,Q)\) into vertical strips, each corresponding to a single column of elementary boxes (i.e., \(\tau \) consecutive columns of cells in \({{\mathrm{FSD}}}(P,Q)\)). See Fig. 5.
Let A be such a strip. It corresponds to a subcurve \(P'\) of P with \(\tau \) edges. The following lemma implies that we can build a data structure for A such that, given any segment of Q, we can efficiently find its incomplete doororder within the elementary box in A.
Lemma 4.1
Given a subcurve \(P^{\prime }\) with \(\tau \) edges, we can compute in \(O(\tau ^6)\) time a data structure that requires \(O(\tau ^6)\) space and that allows us to determine the incomplete doororder of any line segment on Q in time \(O(\log \tau )\).
Proof
We use the standard duality transform that maps a line \(\ell : y = ax + b\) to the point \(\ell ^* : (a, b)\), and vice versa. Consider a unit circle C in \({\mathcal {A}}\) with center \((c_x, c_y)\). Elementary geometry shows that the set of all lines that are tangent to C from above dualizes to the curve \(t_a^*(C): y = c_x x  c_y  \sqrt{1+x^2}\). Similarly, the lines that are tangent to C from below dualize to the curve \(t_b^*(C): y = c_x x  c_y + \sqrt{1+x^2}\). Define \(C^* :=\{t_a^*(C), t_b^*(C) \mid C \in {\mathcal {A}}\}\). Since any pair of distinct circles \(C_1\), \(C_2\) has at most four common tangents, one for each choice of above/below \(C_1\) and above/below \(C_2\), it follows that any two curves in \(C^*\) intersect at most once.
Let V be the set of vertices in \({\mathcal {A}}\), and let \(V^*\) be the lines dual to the points in V (note that \(V = O(\tau ^2)\)). Since for any vertex \(v \in V\) and any circle \(C \in {\mathcal {A}}\) there are at most two tangents through v on C, each line in \(V^*\) intersects each curve in \(C^*\) at most once. Thus, the arrangement \({\mathcal {B}}\) of the curves in \(V^* \cup C^*\) is an arrangement of pseudolines with complexity \(O(\tau ^4)\). Furthermore, it can be constructed in the same expected time, together with a point location structure that finds the containing cell in \({\mathcal {B}}\) of any given point in time \(O(\log \tau )\) [60, Chap. 6.6.1].
Now consider a line segment s and the supporting line \(\ell _s\). As observed in the first paragraph, the combinatorial structure of the intersection between \(\ell _s\) and \({\mathcal {A}}\) is completely determined by the cell of \({\mathcal {B}}\) that contains the dual point \(\ell _s^*\). Thus, for every cell \(f(s) \in {\mathcal {B}}\), we construct a list \(L_{f(s)}\) that represents the combinatorial structure of \(\ell _s \cap {\mathcal {A}}\). There are \(O(\tau ^4)\) such lists, each having size \(O(\tau )\). We can compute \(L_{f(s)}\) by traversing the zone of \(\ell _s\) in \({\mathcal {A}}\). Since circles intersect at most twice and since a line intersects any circle at most twice, the zone has complexity \(O(\tau 2^{\alpha (\tau )})\), where \(\alpha (\cdot )\) denotes the inverse Ackermann function [60, Thm. 5.11]. Since \(O(\tau 2^{\alpha (\tau )}) \subset O(\tau ^2)\), we can compute all lists in \(O(\tau ^{6})\) time.
Given the list \(L_{f(s)}\), the incomplete doororder of s is determined by the position of the endpoints of s in \(L_{f(s)}\). There are \(O(\tau ^2)\) possible ways for this, and we build a table \(T_{f(s)}\) that represents them. For each entry in \(T_{f(s)}\), we store a representative for the corresponding incomplete doororder. As described in the previous section, the representative is a positive integer in the word RAM model and a pointer to the appropriate record on a pointer machine.
The total size of the data structure is \(O(\tau ^{6})\) and it can be constructed in the same time. A query works as follows: given s, we can compute \(\ell _s^*\) in constant time. Then we use the point location structure of \({\mathcal {B}}\) to find f(s) in \(O(\log \tau )\) time. Using binary search on \(T_{f(s)}\) (or an appropriate tree structure in the case of a point machine), we can then determine the position of the endpoints of s in the list \(L_{f(s)}\) in \(O(\log \tau )\) time. This bound holds both on the word RAM and on the pointer machine. \(\square \)
Lemma 4.2
Given the data structure of Lemma 3.2, the incomplete signature for each elementary box can be determined in time \(O(n\tau ^{5} + n^2 (\log \tau ) / \tau )\).
Proof
5 Solving the Decision Problem
With the data structures and preprocessing from the previous sections, we have all ingredients in place to determine whether \(d_F(P,Q) \le 1\). We know for each elementary box its incomplete signature and we have a data structure to derive its full signature (and with it, the combinatorial reachability structure) when its reachdoors are known. What remains to be shown is that we can efficiently process the freespace diagram to determine whether \((n,n) \in {{\mathrm{reach}}}(P,Q)\). This is captured in the following lemma.
Lemma 5.1
If the incomplete signature for each elementary box is known, we can determine whether \((n,n) \in {{\mathrm{reach}}}(P,Q)\) in time \(O(n^2(\log \tau )/\tau )\).
Proof
We go through all elementary boxes of \({{\mathrm{FSD}}}(P,Q)\), processing them one column at a time, going from bottom to top in each column. Initially, we know the full signature for the box S in the lower left corner of \({{\mathrm{FSD}}}(P,Q)\). We use the signature to determine the intersections of \({{\mathrm{reach}}}(P,Q)\) with the upper and right boundary of S. There is a subtlety here: the signature gives us only the combinatorial reachability structure, and we need to map the resulting \(s_i, t_j\) back to the corresponding vertices on the curves. On the word RAM, this can be done easily through table lookups. On the pointer machine, we use representative records for the \(s_i, t_i\) elements and use \(O(\tau )\) time before processing the box to store a pointer from each representative record to the appropriate vertices on P and Q.
We proceed similarly for the other boxes. By the choice of the processing order of the elementary boxes we always know the incoming reachdoors on the bottom and left boundary when processing a box. Given the incoming reachdoors, we can determine the full signature and find the structure of the outgoing reachdoors in total time \(O(\tau \log \tau )\), using Lemma 3.2. Again, we need \(O(\tau )\) additional time on the pointer machine to establish the mapping from the abstract \(s_i\), \(t_i\) elements to the concrete vertices of P and Q. In total, we spend \(O(\tau \log \tau )\) time per box. Thus, it takes time \(O(n^2(\log \tau )/\tau )\) to process all boxes, as claimed. \(\square \)
As a result, we obtain the following theorem for the pointer machine (and, by extension, for the real RAM model). For the word RAM model, we can obtain an even faster algorithm (see Sect. 6).
Theorem 5.2
There is an algorithm that solves the decision version of the Fréchet problem in \(O(n^2 (\log \log n)^{3/2}/\sqrt{\log n})\) time on a pointer machine.
6 Improved Bound on Word RAM
6.1 Clusters and Extended Signatures
We introduce a second level of aggregation in the freespace diagram (see Fig. 7): a cluster is a collection of \(\tau \times \tau \) elementary boxes, that is, \(\tau ^2 \times \tau ^2\) cells in \({{\mathrm{FSD}}}(P,Q)\). Let R be a row of cells in \({{\mathrm{FSD}}}(P,Q)\) of a certain cluster. As before, the row R corresponds to an edge e on Q and a subcurve \(P'\) of P with \(\tau ^2\) edges. We associate with R an ordered set \(Z = \langle e_0, z_0', z_1, z_1', z_2, z_2', \dots , z_{k}, z_{k}', e_1 \rangle \) with \(2 \cdot k + 3\) elements. Here k is the number of intersections of e with the unit circles centered at the \(\tau ^2\) vertices of \(P'\) (all but the very first). Hence, k is bounded by \(2 \tau ^2\) and Z is bounded by \(4 \tau ^2 + 3\). The order of Z indicates the order of these intersections with e directed along Q. Elements \(e_0\) and \(e_1\) represent the endpoints of e and take a special role. In particular, these are used to represent closed doors and snap open doors to the edge e. The elements \(z_i'\) are placeholders for the positions of the endpoints of the reachdoors: \(z_0'\) represents a possible reachdoor endpoint between \(e_0\) and \(z_1\), the element \(z_1'\) represents an endpoint between \(z_1\) and \(z_2\), etc.
Consider a row \(R'\) of an elementary box inside the row R of a cluster, corresponding to an edge e of Q. The doorindex of \(R'\) is an ordered set \(\langle s_0, t_0, \ldots , s_\tau , t_\tau \rangle \) of size \(2 \tau + 2\). Similar to a doororder, elements \(s_0\) and \(t_0\) represent the reachdoor at the leftmost boundary of \(R'\); the elements \(s_i\) and \(t_i\) (\(1 \le i \le \tau \)) represent the door at the right boundary of the ith cell in \(R'\). However, instead of rearranging the set to indicate relative positions, the elements \(s_i\) and \(t_i\) simply refer to elements in Z. If the door is open, they refer to the corresponding intersections with e (possibly snapped to \(e_0\) or \(e_1\)). If the door is closed, \(s_i\) is set to \(e_1\) and \(t_i\) is set to \(e_0\). The elements \(s_0\) and \(t_0\) are special, representing the reachdoor, and they refer to one of the elements \(z_i'\). An incomplete doorindex is a doorindex without \(s_0\) and \(t_0\). The advantage of a doorindex over a doororder is that the reachdoor is always at the start. Hence, completing an incomplete doorindex to a full doorindex can be done in constant time. Since a doorindex has size \(2 \tau + 2\), the number of possible doorindices for \(R'\) is \(\tau ^{O(\tau )}\).
We define the doorindices for the columns analogously. We concatenate the doorindices for the rows and the columns to obtain the indexed signature for an elementary box. Similarly, we define the incomplete indexed signature. The total number of possible indexed signatures remains \(\tau ^{O(\tau ^2)}\).
For each possible incomplete indexed signature \(\Sigma \) we build a lookup table \(T_\Sigma \) as follows: the input is a word with \(4\tau \) fields of \(O(\log \tau )\) bits each. Each field stores the positions in Z of the endpoints of the ingoing reachdoors for the elementary box: \(2\tau \) fields for the left side, \(2\tau \) fields for the lower side. The output consists of a word that represents the indices for the elements in Z that represent the outgoing reachdoors for the upper and right boundary of the box. Thus, the input of \(T_\Sigma \) is a word of \(O(\tau \log \tau )\) bits, and \(T_\Sigma \) has size \(\tau ^{O(\tau )}\). Hence, for all incomplete indexed signatures combined, the size is \(\tau ^{O(\tau ^2)} = o(n)\) by our choice of \(\tau \).
6.2 Preprocessing a Given Input
Lemma 6.1
Let X be a sequence of \(\tau \) words that contain \(\tau \) fields each, so that X can be interpreted as a \(\tau \times \tau \) matrix. Then we can compute in time \(O(\tau \log \tau )\) on a word RAM a sequence Y of \(\tau \) words with \(\tau \) fields each that represents the transpose of X.
Proof
The algorithm is recursive and solves a more general problem: let X be a sequence of a words that represents a sequence M of b different \(a\times a\) matrices, such that the ith word in X contains the fields of the ith row of each matrix in M from left to right. Compute a sequence of words Y that represents the sequence \(M'\) of the transposed matrices in M.
The recursion works as follows: if \(a=1\), there is nothing to be done. Otherwise, we split X into the sequence \(X_1\) of the first a / 2 words and the sequence \(X_2\) of the remaining words. \(X_1\) and \(X_2\) now represent a sequence of 2b \((a/2) \times (a/2)\) matrices, which we transpose recursively. After the recursion, we put the \((a/2) \times (a/2)\) submatrices back together in the obvious way. To finish, we need to transpose the offdiagonal submatrices. This can be done simultaneously for all matrices in time O(a), by using appropriate bitoperations (or table lookup). Hence, the running time obeys a recursion of the form \(T(a) = 2T(a/2) + O(a)\), giving \(T(a) = O(a \log a)\), as desired. \(\square \)
6.3 The Actual Computation
We traverse the freespace diagram cluster by cluster (recall that a cluster consists of \(\tau \times \tau \) elementary boxes). The clusters are processed column by column from left to right, and inside each column from bottom to top. Before processing a cluster, we walk along the left and lower boundary of the cluster to determine the incoming reachdoors. This is done by performing a binary search for each box on the boundary, and determining the appropriate elements \(z_i'\) which correspond to the incoming reachdoors. Using this information, we assemble the appropriate words that represent the incoming information for each elementary box. Since there are \(n^2/\tau ^4\) clusters, this step requires time \(O((n^2/\tau ^4)\tau ^2\log \tau ) = O(n^2 (\log \tau ) / \tau ^2)\). We then process the elementary boxes inside the cluster, in a similar fashion. Now, however, we can process each elementary box in constant time through a single table lookup, so the total time is \(O(n^2/\tau ^2)\). Hence, the total running time of our algorithm is \(O(n^2(\log \tau )/\tau ^2)\). By our choice of \(\tau = \lambda \sqrt{\log n/ \log \log n}\) for a sufficiently small \(\lambda >0\), we obtain the following theorem.
Theorem 6.2
The decision version of the Fréchet problem can be solved in \(O(n^2 (\log \log n)^{2}/\log n)\) time on a word RAM.
7 Computing the Fréchet Distance
The optimization version of the Fréchet problem, i.e., computing the Fréchet distance, can be done in \(O(n^2 \log n)\) time using parametric search with the decision version as a subroutine [8]. We showed that the decision problem can be solved in \(o(n^2)\) time. However, this does not directly yield a faster algorithm for the optimization problem: if the running time of the decision problem is T(n), parametric search gives an \(O((T(n)+n^2) \log n)\) time algorithm [8]. There is an alternative randomized algorithm by Raichel and HarPeled [49]. Their algorithm also needs \(O((T(n)+n^2) \log n)\) time, but below we adapt it to obtain the following lemma.
Lemma 7.1
The Fréchet distance of two polygonal curves with n vertices each can be computed by a randomized algorithm in \(O(n^2 2^{\alpha (n)} + T(n) \log n)\) expected time, where T(n) is the time for the decision problem.
 1.
the distance between a vertex of one curve and a vertex of the other curve (vertex–vertex);
 2.
the distance between a vertex of one curve and an edge of the other curve (vertex–edge); and
 3.
for two vertices of one curve and an edge of the other curve, the distance between one of the vertices and the intersection of e with the bisector of the two vertices (if this intersection exists) (vertex–vertex–edge).
The remainder of the algorithm proceeds as follows: first, we find all critical values of type vertex–vertex and vertex–edge that lie inside the interval \([a', b']\). This can be done in \(O(n^2)\) time by checking all vertex–vertex and vertex–edge pairs. Among these values, we again use medianfinding to determine the interval \([a, b] \subseteq [a',b']\) that contains the Fréchet distance in \(O(K' + T(n) \log K')\) time. It remains to determine the critical values corresponding to vertex–vertex–edge tuples that lie in [a, b].
For this, take an edge e of P and the vertices of Q. Conceptually, we start with circles of radius a around the vertices of Q, and we increase the radii until b. During this process, we observe the evolution of the intersection points between the circle arcs and e. Because all vertex–vertex and vertex–edge events have been eliminated, each circle intersects e in either 0 or 2 points, and this does not change throughout the process. A critical value of vertex–vertex–edge type corresponds to the event that two different circles intersect e in the same point, i.e., that two intersection points meet while growing the circles. Two intersection points can meet at most once, and when they do, they exchange their order along e.
This suggests the following algorithm: let \({\mathcal {A}}_a\) be the arrangement of circles with radius a around the vertices of Q, and let \({\mathcal {A}}_b\) be the concentric arrangement of circles with radius b. We determine the ordered sequence \(I_a\) of the intersection points of the circles in \({\mathcal {A}}_a\) with e, and we number them in their order along e. Next, we find the ordered sequence of intersection points \(I_b\) between e and the circles in \({\mathcal {A}}_b\). We assign to each point in \(I_b\) the number of the corresponding intersection points in \(I_a\). Since \(I_a = I_b\), this gives a permutation of \(\{1, \dots , I_a\}\), Two intersection points change their order from \(I_a\) to \(I_b\) exactly if there is a vertex–vertex–edge event in [a, b], so these events correspond to the inversions of the resulting permutation. Given that there are k such inversions, we can find them in time \(O(I_a + k)\) using insertion sort. Thus, the overall running time to find the critical events in [a, b], ignoring the time for computing \(I_a\) and \(I_b\), is \(O(n^2 + K')\).
It remains to show that we can quickly find \(I_a\) and \(I_b\). We describe the algorithm for \(I_a\). First, compute the arrangement \({\mathcal {A}}_a\) of circles with radius a around the vertices of Q. This takes \(O(n^2)\) time [32]. To find the intersection order, traverse in \({\mathcal {A}}_a\) the zone of the line \(\ell \) spanned by e. The time for the traversal is bounded by the complexity of the zone. Since the circles pairwise intersect at most twice and \(\ell \) intersects each circle only twice, the complexity of the zone is \(O(n 2^{\alpha (n)})\) [60, Thm. 5.11]. Summing over all edges e, this adds a total of \(O(n^2 2^{\alpha (n)})\) to the running time. To find \(I_b\), we proceed similarly with \({\mathcal {A}}_b\). Thus the overall time is \(O(T(n) \log (n) + n^2 2^{\alpha (n)} + K')\). The event \(K' > 8 n \ln n\) has probability less than \(1/n^4\), and we always have \(K' = O(n^3)\). Thus, this case adds o(1) to the expected running time. Given \(K' \le 8 n \ln n\), the running time is \(O(n \log n)\). Lemma 7.1 follows. Theorem 7.2 now results from Lemma 7.1, Theorem 5.2, and Theorem 6.2.
Theorem 7.2
The Fréchet distance of two polygonal curves with n edges each can be computed by a randomized algorithm in time \(O(n^2 \sqrt{\log n}(\log \log n)^{3/2})\) on a pointer machine and in time \(O(n^2(\log \log n)^2)\) on a word RAM.
8 Discrete Fréchet Distance on the Pointer Machine
As mentioned in the introduction, Agarwal et al. [1] give a subquadratic algorithm for finding the discrete Fréchet distance between two point sequences, using the word RAM. In this section, we explain how their algorithm for the decision version of the problem can be adapted to the pointer machine. This shows that, at least for the decision version, the speedup does not come from bitmanipulation tricks but from a deeper understanding of the underlying geometric structure. Our presentation is slightly different from Agarwal et al. [1], in order to allow for a clearer comparison with our continuous algorithm.
We now describe a subquadratic pointer machine algorithm for the decision version. Thus, let point sequences P, Q be given, and suppose without loss of generality that \(\delta = 1\). The discrete analogue of the freespace diagram is an \(n \times n\) Boolean matrix F where \(F_{ij} = 1\), if \(d(p_i, q_j) \le 1\), and \(F_{ij} = 0\), otherwise, for \(i, j = 1, \dots , n\). We call F the freespace matrix. Similarly, the discrete analogue of the reachable region is an \(n \times n\) Boolean matrix M that is defined recursively as follows: \(M_{11} = F_{11}\), and for \(i,j = 1, \dots , n\), \((i,j) \ne 1\), we have \(M_{ij} = 1\) if and only if \(F_{ij} = 1\) and at least one of \(M_{i1,j}\), \(M_{i,j1}\) or \(M_{i1, j1}\) equals 1 (we set \(M_{i,0} = M_{0, j} = 0\), for \(i, j = 1, \dots n\)). Then the discrete Fréchet distance between P and Q is at most 1 if and only if \(M_{nn} = 1\). We call M the reachability matrix; see Fig. 9.
Adapting the method of Agarwal et al. [1], we show how to use preprocessing and table lookup in order to decide whether \(M_{nn} = 1\) in \(o(n^2)\) steps on a pointer machine. Let \(\tau = \lambda \log n\), for a suitable constant \(\lambda > 0\). We subdivide the rows of M into \(k = O(n/\tau )\) strips, each consisting of \(\tau \) consecutive rows: the first strip \(L_1\) consists of rows \(1, \dots , \tau \), the second strip \(L_2\) consists of rows \(\tau + 1, \dots , 2\tau \), and so on. Each strip \(L_i\), \(i = 1,\dots , k\), corresponds to a contiguous subsequence \(P_i\) of \(\tau \) points on P. Let \({\mathcal {A}}_i\) be the arrangement of disks obtained by drawing a unit disk around each vertex in \(P_i\). The arrangement \({\mathcal {A}}_i\) has \(O(\tau ^2)\) faces.
Next, we determine for each elementary box \(B_{ij}\) its incomplete signature. For this, we use the point location structure for \({\mathcal {A}}_i\) to determine for each vertex in \(Q_j\) the face of \({\mathcal {A}}_i\) that contains it. There are \(O(n^2/\tau \rho )\) elementary boxes, each \(Q_j\) has \(\rho \) vertices, and one point location query takes \(O(\log \tau )\) time, so the total time for this step is \(O((n^2/\tau \rho )\cdot \rho \cdot \log \tau ) = O((n^2/\log n)\log \log n)\). Using this information, we can store with each elementary box a pointer to the lookup table for the corresponding incomplete signature.
Finally, we can now use the lookup tables to propagate the reachability information through M, one elementary box at a time, as in the continuous case. The time to process one elementary box is \(O(\rho + \tau )\), because we need to traverse the corresponding lookup table to find the reach bits for the adjacent boxes. Thus, the total running time is \(O((n^2/\tau \rho ) \cdot (\rho + \tau )) = O(n^2/\rho ) = O((n^2/\log n) \log \log n)\). Thus, we get the following pointer machine version of the result by Agarwal et al. [1]
Theorem 8.1
There is an algorithm that solves the decision version of the discrete Fréchet problem in \(O((n^2/\log n) \log \log n)\) time on a pointer machine.
Remark
Agarwal et al. [1] further describe how to get a faster algorithm for the decision version by aggregating the elementary boxes into larger clusters, similar to the method given in Sect. 6. This improved algorithm finally leads to a subquadratic algorithm for computing the discrete Fréchet distance. Unfortunately, as in Sect. 6, it seems that this improvement crucially relies on constant time table lookup, so it does not directly translate to the pointer machine.
The reader may also notice that in this section we could choose \(\tau , \rho \approx \log n\), whereas in the previous sections we had \(\tau \approx \sqrt{\log n}\). This is due to the slightly different definition of signature: in the discrete case, once the subsequence \(P_i\) is fixed, there are only \(\tau ^{O(\rho )}\) possible ways how the subsequence \(Q_j\) might interact with \(P_i\). In the continuous case, this does not seem to be so clear, and we work with the weaker bound of \(\tau ^{O(\tau ^2)}\) possible interactions.
9 Decision Trees
Our results also have implications for the decisiontree complexity of the Fréchet problem. Since in that model we account only for comparisons between input elements, the preprocessing comes for free, and hence the size of the elementary boxes can be increased. Before we consider the continuous Fréchet problem, we first note that a similar result can be obtained easily for the discrete Fréchet problem.
Theorem 9.1
The discrete Fréchet problem has an algebraic computation tree of depth \({\widetilde{O}}(n^{4/3})\).
Proof
First, we consider the decision version: we are given two sequences \(P \,{=}\, p_1, \dots , p_n\) and \(Q = q_1, \dots , q_n\) of n points in the plane, and we would like to decide whether the discrete Fréchet distance between P and Q is at most 1. Katz and Sharir [53] showed that we can compute a representation of the set of pairs \((p_i, q_j)\) with \(\Vert p_i  q_j\Vert \le 1\) in \({\widetilde{O}}(n^{4/3})\) steps. This information suffices to complete the reachability matrix without further comparisons. As shown by Agarwal et al. [1], one can then solve the optimization problem at the cost of another \(O(\log n)\)factor, which is absorbed into the \({\widetilde{O}}\)notation. \(\square \)
Given our results above, we prove an analogous statement for the continuous Fréchet distance.
Theorem 9.2
There exists an algebraic decision tree for the Fréchet problem (decision version) of depth \(O(n^{2  \varepsilon })\), for a fixed constant \(\varepsilon > 0\).
Proof
We reconsider the steps of our algorithm. The only phases that actually involve the input are the second preprocessing phase and the traversal of the elementary boxes. The reason of our choice for \(\tau \) was to keep the time for the first preprocessing phase small. This is no longer a problem. By Lemmas 4.2 and 5.1, the remaining cost is bounded by \(O(n\tau ^{5} + n^2 (\log \tau )/\tau )\). Choosing \(\tau = n^{1/6}\), we get a decision tree of depth \(n \cdot n^{5/6} + n^{21/6}\log n\). This is \(O(n^{2(1/6)}\log n) = O(n^{2  \varepsilon })\), for any fixed \( 0< \varepsilon < 1/6\). \(\square \)
10 Weak Fréchet Distance
10.1 A Decision Algorithm for the Pointer Machine
Next, we subdivide each strip into \(\ell = O(n/\rho )\) elementary boxes, each consisting of \(\rho \) consecutive rows. We label the elementary boxes as \(B_{ij}\), with \(1 \le i \le k\), \(1 \le j \le \ell \). The rows of an elementary box \(B_{ij}\) correspond to a subcurve \(Q_j\) of Q with \(\rho \) edges. The signature of \(B_{ij}\) consists of (i) the index i of the corresponding strip; (ii) for each vertex of \(Q_j\) the face of \({\mathcal {A}}_i\) that contains it; and (ii) for each edge e of \(Q_j\) the face of \({\mathcal {B}}_i\) that contains the point that is dual to the supporting line of e, plus two indices \(a,b \in \{1, \dots , \tau \}\) that indicate the first and the last unit circle around a vertex of \(P_i\) that e intersects, as we walk from one endpoint to another.
Given an elementary box B, the connection graph \(G_B\) of B has \(\tau \rho \) vertices, one for each cell in B, and an edge between two cells C, \(C'\) of B if and only if C and \(C'\) share a (horizontal or vertical) edge with an open door. The connectivity list of B is a linked list with \(2\tau + 2\rho  4\) entries that stores for each cell C on the boundary of B a pointer to a record that represents the connected component of the connection graph \(G_B\) that contains C.
Lemma 10.1
There are \(O(n\tau ^{8\rho + 1})\) different signatures. The connection graph of an elementary box \(B_{ij}\) depends only on its signature, and the connectivity list can be computed in \(O(\tau \rho )\) time on a pointer machine, given the signature.
Proof
First, we count the signatures. There are \(O(n/\tau )\) strips. Once the strip index i is fixed, a signature consists of \(\rho +1\) faces of \({\mathcal {A}}_i\), \(\rho \) faces of \({\mathcal {B}}_i\), and \(\rho \) pairs of indices \(a,b \in \{1, \dots , \tau \}\). The arrangement \({\mathcal {A}}_i\) has \(O(\tau ^2)\) faces, and the arrangement \({\mathcal {B}}_i\) has \(O(\tau ^4)\) faces, as explained in the proof of Lemma 4.1. Finally, there are \(\tau ^2\) pairs of indices. Thus, the number of possible signatures in one strip is \(\tau ^{8\rho + 2}\). In total, we get \(O(n\tau ^{8\rho +1})\) signatures.
Next, the connection graph of an elementary box \(B_{ij}\) is determined solely by which doors are open and which doors are closed. We explain how to deduce this information from the signature. A horizontal edge of \(B_{ij}\) corresponds to an edge e of \(P_i\) and a vertex q of \(Q_j\). The door is open if and only if q has distance at most 1 from e. This is determined by the face of \({\mathcal {A}}_i\) containing q. Similarly, a vertical edge of \(B_{ij}\) corresponds to a vertex p of \(P_i\) and an edge e of \(Q_j\). The door is open if and only if e intersects the unit circle with center p. As in Lemma 4.1, this can be inferred from the face of \({\mathcal {B}}_i\) that contains the point dual to the supporting line of e, together with the indices (a, b) of the first and last circle intersected by e.
Finally, given the signature, we can build the connection graph \(G_{B_{ij}}\) in \(O(\tau \rho )\) time, assuming that the arrangements \({\mathcal {A}}_i\) and \({\mathcal {B}}_i\) provide suitable data structures. With \(G_{B_{ij}}\) at hand, the connection list can be found in \(O(\tau \rho )\) steps, using breadth first search. \(\square \)
As usual, our strategy now is to preprocess all possible signatures and to determine the signature of each elementary box. Using this information, we can then process the elementary boxes quickly in our main algorithm. The next lemma describes the preprocessing steps.
Lemma 10.2
We can determine for each elementary box \(B_{ij}\) a pointer to its connectivity list in total time \(O(n\tau ^{8\rho + 2}\rho + (n^2/\tau )\log \tau )\) on a pointer machine.
Proof
First, we compute the arrangements \({\mathcal {A}}_i\) and \({\mathcal {B}}_i\) for each vertical strip. By Lemma 4.1, this takes \(O(\tau ^6)\) steps per strip, for a total of \(O(\tau ^6 \cdot n/\tau ) = O(n\tau ^5)\). Then, we enumerate all possible signatures, and we compute the connectivity list for each of them. By Lemma 10.1, this needs \(O(n\tau ^{8\rho + 2} \rho )\) time. We store the signatures and their connectivity lists
Next, we determine the signature for each elementary box. Fix a strip \(L_i\). For each vertex q and each edge e of Q, we determine the containing faces of \({\mathcal {A}}_i\) and \({\mathcal {B}}_i\) and the pair (a, b) that represents the first and least intersection of e with the unit circles around the vertices of \(P_i\). This takes \(O(n\log \tau )\) steps in total, using appropriate point location structures for the arrangements. Now, we use the data structure from the preprocessing to connect each elementary box to its connectivity list. A simple pointerbased structure supports one lookup in \(O(\rho \log \tau )\) time. Since there are \(O(n/\rho )\) elementary boxes in one strip, we get a total running time of \(O(n \log \tau )\) per strip. Since there are \(O(n/\tau )\) strips, the resulting running time is \(O((n^2/\tau )\log \tau )\). \(\square \)
With the information from the preprocessing phase, we can easily solve the decision problem with a unionfind data structure.
Lemma 10.3
Suppose that each elementary box has a pointer to its connectivity list. Then we can decide whether \(d_{wF}(P, Q) \le 1\) in time \(O\big (\frac{n^2(\tau + \rho )\alpha (n)}{\tau \rho }\big )\) on a pointer machine, where \(\alpha (\cdot )\) denotes the inverse Ackermannfunction.
Proof
Let S be the set that contains the boundary cells of all elementary boxes. Then, \(S = O\big (\frac{n^2(\tau + \rho )}{\tau \rho }\big )\). We create a UnionFind data structure for S. Then, we go through all elementary boxes \(B_{ij}\), and for each \(B_{ij}\), we use the connectivity list to connect those subsets of boundary cells that are connected inside \(B_{ij}\). This can be done with \(O(\tau + \rho )\) Unionoperations. Hence, the total running time for this step is \(O\big (\frac{n^2(\tau + \rho )}{\tau \rho }\big )\). (We do not need any Findoperations yet, because we can store the representatives of the sets with the representatives of the connected components in the connectivity list as we walk along the boundary of an elementary box.)
Next, we iterate over the boundary cells of all elementary boxes. For each boundary cell C, we determine the neighboring boundary cells on neighboring elementary boxes that share an open door with C. For each such cell D, we perform Findoperations on C and D, followed by a Unionoperation. This takes \(O\big (\frac{n^2(\tau + \rho )\alpha (n)}{\tau \rho }\big )\) time [61]. Finally, we return True if and only if (i) the pairs of start and end vertices of P and Q have distance at most 1, and (ii) C(0, 0) and \(C(n1, n1)\) are in the same set of the resulting partition of S. The running time follows. \(\square \)
The following theorem summarizes our algorithm for the decision problem.
Theorem 10.4
Let P and Q be two polygonal curves with n edges each. We can decide whether \(d_{wF}(p, q) \le 1\) in \(O((n^2/\log n)\alpha (n)\log \log n)\) time on a pointer machine, where \(\alpha (\cdot )\) denotes the inverse Ackermann function.
Proof
We set \(\tau = \log n\) and \(\rho = \lambda \log n/\log \log n\), for a suitable constant \(\lambda > 0\). If \(\lambda \) is small enough, then \(\tau ^{8\rho + 2} = O(n^{4/3})\), and the algorithm from Lemma 10.2 runs in time \(O((n^2/\log n)\log \log n)\). After the preprocessing is finished, we can use Lemma 10.3 to obtain the final result in time \(O((n^2/\log n)\alpha (n)\log \log n)\). \(\square \)
10.2 A Faster Decision Algorithm on the Word RAM
Theorem 10.4 is too weak to obtain a subquadratic algorithm for the weak Fréchet distance. This requires the full power of the word RAM.
Theorem 10.5
Let P and Q be two polygonal curves with n edges each. We can decide whether \(d_{wF}(p, q) \le 1\) in \(O((n^2/\log ^2 n)(\log \log n)^5)\) time on a word RAM.
Proof
We set \(\tau = \lambda \log ^2 n / \log \log n\) and \(\rho = \lambda \log n/ \log \log n\). If \(\lambda \) is small enough, then \(\tau ^{8\rho + 2} = O(n^{4/3})\), and we can perform the algorithm from Lemma 10.2 in time \(O((n^2/\log ^2 n)\log \log n)\).
We modify the algorithm from Lemma 10.2 slightly. Instead of a pointerbased connectivity list, we compute a packed connectivity list. It consists of \(O(\log n)\) words of \(\log n\) bits each. Each word stores \(\Theta (\log n / \log \log n)\) entries of \(O(\log \log n)\) bits. An entry consists of O(1) fields, each with \(O(\log \log n)\) bits. As in Lemma 10.2, the entries in the packed connectivity list represent the connected components of the connection graph \(G_B\) for the boundary cells of a given elementary box B. This is done as follows: each entry of the connectivity list corresponds to a boundary cell C of B. In the first field, we store a unique identifier from \(\{1, \dots , 2\tau + 2\rho 4\}\) that identifies C. In the second field, we store the smallest identifier of any boundary cell of B that lies in the same connected component as C. The remaining fields of the entry are initialized to 0. Furthermore, we compute for each elementary box B a sequence of \(O((\tau / \log n)\log \log n)\) words that indicates for each boundary cell of B whether the corresponding door to the neighboring elementary box is open. This information can be obtained in the same time by adapting the algorithm from Lemma 10.2.
Lemma 10.6
Given a cluster, we can compute the connectivity list for its boundary in total time \(O((\tau + \rho )(\log \log n)^4)\) on a word RAM.
Proof
Our algorithm makes extensive use of the word RAM capabilities. Data is processed in packed form. That is, we usually deal with a sequence of packed words, each with \(O(\log n/\log \log n)\) entries. Each entry has O(1) fields of \(O(\log \log n)\) bits. We restrict the number of entries in each word so that the total number of bits used is at most, say, \((1/3)\log n\). Then, we can support any reasonable binary operation on two packed words in O(1) time after o(n) preprocessing time. Indeed, we only need to build a lookuptable during the preprocessing phase. First, we observe that we can sort packed data efficiently.\(\square \)
Claim 10.7
Suppose we are given a sequence of \(\mu \) packed words, representing a sequence of \(O(\mu (\log n/\log \log n))\) entries. We can obtain a sequence of \(\mu \) packed words that represents the same entries, sorted according to any given field, in \(O(\mu \log \mu )\) time.
Proof
We adapt usual techniques for packed integer sorting [5]. We precompute a mergeoperation that receives two packed words, each with their entries sorted according to a given field, and returns two packed words that represent the sorted sequence of all entries. We also precompute an operation that receives one packed word and returns a packed word with the same entries, sorted according to a given field. Then, we can perform a merge sort in \(O(\mu \log \mu )\) time, because in each level of the recursion, the total time for merging is \(O(\mu )\). Once we are down to a single word, we can sort its entries in one step. More details can be found in the literature on packed sorting [5, 27]. \(\square \)
Now we describe the strategy of the main algorithm. As explained above, a cluster consists of \(\log n\) vertically adjacent elementary boxes. We number the boxes \(B_1, \dots , B_{\log n}\), from bottom to top. For \(i = 1, \dots , \log n\), we denote by \(G_i\) the connection graph for the boxes \(B_1, \dots , B_i\). That is, \(G_i\) is obtained by taking the union \(\bigcup _{j = 1}^i G_{B_j}\) of the individual connection graphs and adding edges for adjacent cells in neighboring boxes that share an open door. Our algorithm proceeds in two phases. In the first phase, we propagate the connectivity information upwards. That is, for \(i = 1, \dots , \log n\), we compute a sequence \(W_i\) of \(O((\tau + \rho )\log \log n/ \log n)\) packed words. Each entry in \(W_i\) corresponds to a cell C on the boundary of \(B_i\). The first field stores a unique identifier for the cell, and the second entry stores an identifier of the connected component of C in \(G_i\). In the second phase, we go in the reverse direction. For \(i = \log n, \dots , 1\), we compute a sequence \(W_i'\) of \(O((\tau + \rho )\log \log n/\log n)\) packed words that store for each cell C on the boundary of \(B_i\) an identifier of the connected component of C in \(G_{\log n}\). Once this information is available, the (pointerbased) connectivity list for the cluster boundary can be extracted in \(O(\tau + \rho )\) time, using appropriate precomputed operations on packed words, see Fig. 14 .
We begin with the first phase. The upper boundary of an elementary box are the \(\tau \) cells in the topmost row of the box, the lower boundary are the \(\tau \) cells in the bottommost row. From the preprocessing phase, we have a pointer to the packed connectivity lists for all elementary boxes \(B_1, \dots , B_{\log n}\). We make local copies of these packed connectivity lists, and we modify them so that the identifiers of all cells and connected components are unique. For example, we can increase all identifiers in the connectivity list for \(B_i\) by \(i \log ^3 n\). Using lookuptables for these wordoperations, this step can be carried out in \(O((\tau + \rho )\log \log n)\) time for the whole cluster.
The sequence \(W_1\) for \(B_1\) is exactly the packed connectivity list of \(G_1\). Now, suppose that we have computed for \(B_i\) a sequence \(W_i\) of packed words that represent the connected component in \(G_i\) for each boundary cell of \(B_i\). We need to compute a similar sequence \(W_{i+1}\) for \(B_{i+1}\). For this, we need to determine how the doors between \(B_i\) and \(B_{i+1}\) affect the connected components in \(G_{B_{i+1}}\).
Let \(H = (V_H, E_H)\) be the graph that has one vertex for each connected component of \(G_i\) that contains a cell at the upper boundary of \(B_i\) and one vertex for each connected component of \(G_{B_{i+1}}\) that contains a cell at the lower boundary of \(B_{i+1}\). The vertices of H are labeled by the identifiers of their corresponding components. Suppose that \(v \in V_H\) represents a component \(D_v\) in \(G_{i}\) and \(w \in V_H\) represents a component \(D_w\) in \(G_{B_{i+1}}\). There is an edge between v and w in \(E_H\) if and only if \(D_v\) contains a cell on the upper boundary of \(B_{i}\) and \(D_w\) contains a cell on the lower boundary of \(B_{i+1}\) such that these two cells share an open door. The graph H has \(O(\tau )\) vertices and \(O(\tau )\) edges. Our goal is to obtain the connected components of H. From this, we will then derive the next sequence \(W_{i+1}\). To obtain the components of H, we adapt the parallel connectivity algorithm of Hirschberg, Chandra, and Sarwate [50].
Claim 10.8
We can determine the connected components of H in time \(O((\tau /\log n) \log \log ^4)\) time.
Proof
First, we obtain a list of \(O((\tau /\log n)\log \log n)\) packed words that represent the vertices of H, as follows: we extract from \(W_i\) and from the connectivity list of \(B_{i+1}\) the entries for the upper boundary of \(B_i\) and for the lower boundary of \(B_{i+1}\). If all these entries are stored together in the respective packed lists, this takes \(O((\tau /\log n)\log \log n)\) time to copy the relevant data words. Then, we sort these packed sequences according to the component identifier, in time \(O(\tau /\log n)\log \log ^2 n)\) (Claim 10.7). Finally, we go over the sorted packed sequence to extract a sorted lists of the distinct component identifiers. This takes \(O((\tau /\log n)\log \log n)\) time, using an appropriate operation on packed words.

Step 1: Find for each vertex of H the neighbor with the smallest and with the largest identifier. This can be done in \(O((\tau /\log n)\log \log ^2 n)\) time by sorting the edge lists twice, once in lexicographic order and once in reverse lexicographic order of the identifiers of the endpoints. From these sorted lists, we can extract the desired information in the claimed time, using appropriate word operations.

Step 2: Let \(V_H'\) be the vertices of H with at least one neighbor, and let \(V_H'' \subseteq V_H'\) be the vertices \(v \in V_H'\) having a neighbor with a smaller identifier than the identifier of v. If \(V_H'' \ge V_H'/2\), we set the successor of each \(v \in V_H''\) to the neighbor of v with the smallest identifier. Otherwise, at least half of the nodes in \(V_H'\) have a neighbor with a larger identifier. In this case, we let \(V_H'''\) be the set of these nodes, and we set the successor of each \(v \in V_H'''\) to the neighbor of v with the largest identifier. The successor relation defines a directed forest F on \(V_H\) such that at least half of the vertices in \(V_H'\) are not a root in F. Given the information available from Step 1 and appropriate word operations, this step can carried out in \(O((\tau /\log n)\log \log n)\) time.

Step 3: Use pointer jumping to determine for each vertex \(v \in V_H\) the identifier of the root of the tree in F that contains v. For this, we set the successor of each \(v \in V_H\) that does not yet have a successor to v itself. Then, for \(\log V_H = O(\log \log n)\) rounds, we set simultaneously for each \(v \in V_H\) the new successor of v to the old successor of the old successor of v (pointer jumping). Each step at least halves the distance of v to its root in F, so it takes \(O(\log V_H)\) rounds until each vertex in \(V_H\) has found the root of its tree in F. Each round can be implemented in \(O((\tau /\log n)\log \log ^2 n)\) time by sorting the vertices according to their successors. Thus, this step takes \(O((\tau /\log n)\log \log ^3 n)\) time in total.

Step 4: Contract each tree of F into a single vertex whose identifier is the smallest identifier in the tree.. Maintain for the original vertices of H a list that gives the identifier of the contracted node that represents it. Again, this step can be carried out in \(O(\tau /\log n)\log \log ^2 n)\) time using sorting.
Given the connected components of H, we can find the desired sequence \(W_{i+1}\) for the boundary \(B_{i+1}\). Indeed, the procedure from Claim 10.8 outputs a sequence of \(O((\tau /\log n)\log \log n)\) packed words that gives for each vertex in H an identifier of the component in H that contains it. We can use this list as a lookup table to update the identifiers of the components in the connectivity list of \(B_{i+1}\). This takes \(O((\tau +\rho )/\log n)\log \log ^2 n)\) time, using sorting.
In summary, since we consider \(\log n\) elementary boxes, the total time for the first phase if \(O((\tau + \rho )\log \log ^4 n)\). The second phase is much easier. For \(i = \log _n, \dots , 2\), we propagate the connectivity information from \(B_{i+1}\) to \(B_i\). For this, we need to update the identifiers of the connected components for the cells on the upper boundary of \(B_i\) using the identifiers of the connected components on the lower boundary of \(B_{i+1}\), and then adjust the connectivity list \(B_{i+1}\) with these new indices. Again, this takes \(O((\tau +\rho )/\log n)\log \log ^2 n)\) time, using sorting. \(\square \)
10.3 Computing the Weak Fréchet Distance
To actually compute the weak Fréchet distance, we use a simplified version of the procedure from Sect. 7. In particular, for the weak Fréchet distance, there are only critical values of the type vertex–vertex and vertex–edge, i.e., there are only \(O(n^2)\) critical values. However, we aim for a subquadratic running time, so we need to perform the sampling procedure in a slightly different way.
Theorem 10.9
Suppose we can answer the decision problem for the weak Fréchet distance in time T(n), for input curves P and Q with n edges each. Then, we can compute the weak Fréchet distance of P and Q in expected time \(O(n^{3/2}\log ^c n + T(n)\log n)\), for some fixed constant \(c > 0\).
Proof
First, we sample a set S of \(K = 6n^{1/2}\) critical values uniformly at random. Then, we find a, b such that the weak Fréchet distance lies between a and b and such that the interval [a, b] contains no other element from S. This takes \(O(K + T(n) \log n)\) time, using median finding.
Next, we find all critical values in the interval [a, b]. For this, we must determine all vertex–vertex and vertex–edge pairs with distance in [a, b]. We report for every vertex p of P or Q the set of vertices of the other curve that lie in the annulus with radii a and b around p. Furthermore, we report for every edge e of P or Q the set of vertices of the other curve that lie in the stadium with radii a and b. This can be done efficiently with a rangesearching structure for semialgebraic sets. Agarwal, Matoušek and Sharir [3] show that we can preprocess the vertices of P and the vertices of Q into a data structure that can answer our desired range reporting queries in time \(O(n^{1/2}\log ^c n + k)\), where k is the output size and \(c > 0\) is some fixed constant. The expected preprocessing time is \(O(n^{1+\varepsilon })\), where \(\varepsilon > 0\) can be made arbitrarily small. We perform O(n) queries, and the total expected output size of our queries is \(O(n^{3/2}\ln n)\), so it takes expected time \(O(n^{3/2}\log ^{c} n)\) to find the critical values in [a, b]. Finally, we perform a binary search on theses critical values to compute the weak Fréchet distance. This takes \(O(T(n)\log n)\) time. \(\square \)
The following theorem summarizes our results on the weak Fréchet distance.
Theorem 10.10
The weak Fréchet distance of two polygonal curves, each with n edges, can be computed by a randomized algorithm in time \(O(n^2 \alpha (n)\log \log n)\) on a pointer machine and in time \(O((n^2/\log n)(\log \log n)^5)\) on a word RAM.
11 Conclusion
We have broken the longstanding quadratic upper bound for the decision version of the Fréchet problem. Moreover, we have shown that this problem has an algebraic decision tree of depth \(O(n^{2\varepsilon })\), for some \(\varepsilon > 0\) and where n is the number of vertices of the polygonal curves. We have shown how our faster algorithm for the decision version can be used for a faster algorithm to compute the Fréchet distance. If we allow constanttime tablelookup, we obtain a running time in close reach of \(O(n^2)\). This leaves us with intriguing open research questions. Can we devise a quadratic or even a slightly subquadratic algorithm for the optimization version? Can we devise such an algorithm on the word RAM, that is, with constanttime tablelookup? What can be said about approximation algorithms?
Footnotes
 1.
For a brief overview of the different computational models in this paper, refer to Appendix.
 2.
Personal communication 2012, see also [6].
 3.
It is well known that the four Russians are not actually Russian, so we refer to them as four Soviets in the title.
 4.
A preview for the impatient reader: we later set \(\tau = \Theta (\sqrt{\log n/\log \log n})\).
 5.
For now, the elementary box is a combinatorial concept. In the next section, we overlay these boxes on the freespace diagram to obtain “concrete” elementary boxes.
 6.
In the next section, we describe how to determine the incomplete doororders efficiently.
 7.
\(\text {AC}^0\) is the class of all functions \(f:\{0,1\}^* \rightarrow \{0,1\}^*\) that can be computed by a family of circuits \((C_n)_{n \in {\mathbb {N}}}\) with the following properties [11]: (i) each \(C_n\) has n inputs; (ii) there exist constants a, b, such that \(C_n\) has at most \(an^b\) gates, for \(n\in {\mathbb {N}}\); (iii) there is a constant d such that for all n the length of the longest path from an input to an output in \(C_n\) is at most d (i.e., the circuit family has bounded depth); (iv) each gate has an arbitrary number of incoming edges (i.e., the fanin is unbounded).
Notes
Acknowledgements
We would like to thank Natan Rubin for pointing out to us that Fréchetrelated papers require a witty title involving a dog, Bettina Speckmann for inspiring discussions during the early stages of this research, Günter Rote for providing us with his Ipelet for the freespace diagram, and Otfried Cheong for Ipe. We would also like to thank anonymous referees for suggesting simpler proofs of Lemmas 4.1 and 7.1, for pointing out [53] for Theorem 9.1, and for suggesting a section on the weak Fréchet distance. K. Buchin and M. Buchin in part supported by European Cooperation in Science and Technology (COST) ICT Action IC0903 MOVE. M. Buchin supported in part by the Netherlands Organisation for Scientific Research (NWO) under Project No. 612.001.106. W. Meulemans supported by the Netherlands Organisation for Scientific Research (NWO) under Project No. 639.022.707. W. Mulzer supported in part by DFG Projects MU/3501/1 and MU/3501/2.
References
 1.Agarwal, P.K., Ben Avraham, R., Kaplan, H., Sharir, M.: Computing the discrete Fréchet distance in subquadratic time. SIAM J. Comput. 43(2), 429–449 (2014)MathSciNetCrossRefzbMATHGoogle Scholar
 2.Agarwal, P.K., HarPeled, S., Mustafa, N.H., Wang, Y.: Nearlinear time approximation algorithms for curve simplification. Algorithmica 42(3–4), 203–219 (2005)MathSciNetCrossRefzbMATHGoogle Scholar
 3.Agarwal, P.K., Matoušek, J., Sharir, M.: On range searching with semialgebraic sets. II. SIAM J. Comput. 42(6), 2039–2062 (2013)MathSciNetCrossRefzbMATHGoogle Scholar
 4.Ailon, N., Chazelle, B.: Lower bounds for linear degeneracy testing. J. ACM 52(2), 157–171 (2005)MathSciNetCrossRefzbMATHGoogle Scholar
 5.Albers, S., Hagerup, T.: Improved parallel integer sorting without concurrent writing. Inf. Comput. 136(1), 25–51 (1997)MathSciNetCrossRefzbMATHGoogle Scholar
 6.Alt, H.: The computational geometry of comparing shapes. In: Albers, S., Alt, H., Näher, S. (eds.) Efficient Algorithms. Lecture Notes in Computer Science, vol. 5760, pp. 235–248. Springer, Berlin (2009)CrossRefGoogle Scholar
 7.Alt, H., Buchin, M.: Can we compute the similarity between surfaces? Discrete Comput. Geom. 43(1), 78–99 (2010)MathSciNetCrossRefzbMATHGoogle Scholar
 8.Alt, H., Godau, M.: Computing the Fréchet distance between two polygonal curves. Int. J. Comput. Geom. Appl. 5(1–2), 75–91 (1995)CrossRefzbMATHGoogle Scholar
 9.Alt, H., Knauer, C., Wenk, C.: Comparison of distance measures for planar curves. Algorithmica 38(1), 45–58 (2003)MathSciNetCrossRefzbMATHGoogle Scholar
 10.Aronov, B., HarPeled, S., Knauer, C., Wang, Y., Wenk, C.: Fréchet distances for curves, revisited. In: Azar, Y., Erlebach, T. (eds.) Algorithms—ESA 2006. Lecture Notes in Computer Science, vol. 4168, pp. 52–63. Springer, Berlin (2006)CrossRefGoogle Scholar
 11.Arora, S., Barak, B.: Computational Complexity. Cambridge University Press, Cambridge (2009)CrossRefzbMATHGoogle Scholar
 12.Baran, I., Demaine, E.D., Pătraşcu, M.: Subquadratic algorithms for 3SUM. Algorithmica 50(4), 584–596 (2008)MathSciNetCrossRefzbMATHGoogle Scholar
 13.Bellman, R., Kalaba, R.: On adaptive control processes. IRE Trans. Autom. Control 4(2), 1–9 (1959)CrossRefzbMATHGoogle Scholar
 14.Ben Avraham, R., Filtser, O., Kaplan, H., Katz, M.J., Sharir, M.: He discrete and semicontinuous Fréchet distance with shortcuts via approximate distance counting and selection. ACM Trans. Algorithms 11(4), 29 (2015)Google Scholar
 15.Brakatsoulas, S., Pfoser, D., Salas, R., Wenk, C.: On mapmatching vehicle tracking data. In: Böhm, K., et al. (eds.) Proceedings of the 31st VLDB Conference, pp. 853–864. ACM, New York (2005)Google Scholar
 16.Bremner, D., Chan, T.M., Demaine, E.D., Erickson, J., Hurtado, F., Iacono, J., Langerman, S., Pătraşcu, M., Taslakian, P.: Necklaces, convolutions, and \(X+Y\). Algorithmica 69(2), 294–314 (2012)MathSciNetCrossRefzbMATHGoogle Scholar
 17.Bringmann, K.: Why walking the dog takes time: Fréchet distance has no strongly subquadratic algorithms unless SETH fails. In: 55th Annual IEEE Symposium on Foundations of Computer Science—FOCS 2014, pp. 661–670. IEEE Computer Society, Los Alamitos (2014)Google Scholar
 18.Bringmann, K., Mulzer, W.: Approximability of the discrete Fréchet distance. J. Comput. Geom. 7(2), 46–76 (2016)MathSciNetzbMATHGoogle Scholar
 19.Buchin, K., Buchin, M., Gudmundsson, J.: Constrained free space diagrams: a tool for trajectory analysis. Int. J. GIS 24(7), 1101–1125 (2010)Google Scholar
 20.Buchin, K., Buchin, M., Gudmundsson, J., Löffler, M., Luo, J.: Detecting commuting patterns by clustering subtrajectories. Int. J. Comput. Geom. Appl. 21(3), 253–282 (2011)MathSciNetCrossRefzbMATHGoogle Scholar
 21.Buchin, K., Buchin, M., Knauer, C., Rote, G., Wenk, C.: How difficult is it to walk the dog? In: Aichholzer, O., Hackl, T. (eds.) 23rd EuroCG/FWCG, pp. 170–173. Technischen Universität Graz, Graz (2007)Google Scholar
 22.Buchin, K., Buchin, M., Meulemans, W., Speckmann, B.: Locally correct Fréchet matchings. In: Epstein, L., Ferragina, P. (eds.) Algorithms—ESA 2012. Lecture Notes in Computer Science, vol. 7501, pp. 229–240. Springer, Heidelberg (2012)CrossRefGoogle Scholar
 23.Buchin, K., Buchin, M., Schulz, A.: Fréchet distance of surfaces: some simple hard cases. In: de Berg, M., Meyer, U. (eds.) Algorithms—ESA 2010. Part II. Lecture Notes in Computer Science, vol. 6347, pp. 63–74. Springer, Berlin (2010)Google Scholar
 24.Buchin, K., Buchin, M., van Leusden, R., Meulemans, W., Mulzer, W.: Computing the Fréchet distance with a retractable leash. Discrete Comput. Geom. 56(2), 315–336 (2016)MathSciNetCrossRefzbMATHGoogle Scholar
 25.Buchin, K., Buchin, M., Wang, Y.: Exact algorithms for partial curve matching via the Fréchet distance. In: Proceedings of the Twentieth Annual ACMSIAM Symposium on Discrete Algorithms, pp. 645–654. SIAM, Philadelphia (2009)Google Scholar
 26.Buchin, K., Buchin, M., Wenk, C.: Computing the Fréchet distance between simple polygons. Comput. Geom. 41(1–2), 2–20 (2008)MathSciNetCrossRefzbMATHGoogle Scholar
 27.Buchin, K., Mulzer, W.: Delaunay triangulations in \(O({\rm sort}(n))\) time and more. J. ACM 58(2), 6 (2011)MathSciNetCrossRefzbMATHGoogle Scholar
 28.Buchin, M.: On the Computability of the Fréchet Distance Between Triangulated Surfaces. PhD thesis, Free University Berlin, Berlin (2007). http://www.diss.fuberlin.de/diss/receive/FUDISS_thesis_000000002618
 29.Chambers, E.W., Colin de Verdière, É., Erickson, J., Lazard, S., Lazarus, F., Thite, S.: Homotopic Fréchet distance between curves or, walking your dog in the woods in polynomial time. Comput. Geom. 43(3), 295–311 (2010)MathSciNetCrossRefzbMATHGoogle Scholar
 30.Chan, T.M.: Allpairs shortest paths with real weights in \({O}(n^3 / \log n)\) time. Algorithmica 50(2), 236–243 (2008)MathSciNetCrossRefzbMATHGoogle Scholar
 31.Chan, T.M.: More algorithms for allpairs shortest paths in weighted graphs. SIAM J. Comput. 39(5), 2075–2089 (2010)MathSciNetCrossRefzbMATHGoogle Scholar
 32.Chazelle, B.M., Lee, D.T.: On a circle placement problem. Computing 36(1–2), 1–16 (1986)MathSciNetCrossRefzbMATHGoogle Scholar
 33.Cook IV, A.F., Driemel, A., HarPeled, S., Sherette, J., Wenk, C.: Computing the Fréchet distance between folded polygons. In: Dehne, F., Iacono, J., Sack, J.R. (eds.) Algorithms and Data Structures. Lecture Notes in Computer Science, vol. 6844, pp. 267–278. Springer, Heidelberg (2011)CrossRefGoogle Scholar
 34.Cook IV, A.F., Wenk, C.: Geodesic Fréchet distance inside a simple polygon. ACM Trans. Algorithms 7(1), 9 (2010)zbMATHGoogle Scholar
 35.de Berg, M., Cook IV, A.F., Gudmundsson, J.: Fast Fréchet queries. Comput. Geom. 46(6), 747–755 (2013)MathSciNetCrossRefzbMATHGoogle Scholar
 36.Driemel, A., HarPeled, S.: Jaywalking your dog: computing the Fréchet distance with shortcuts. SIAM J. Comput. 42(5), 1830–1866 (2013)MathSciNetCrossRefzbMATHGoogle Scholar
 37.Driemel, A., HarPeled, S., Wenk, C.: Approximating the Fréchet distance for realistic curves in near linear time. Discrete Comput. Geom. 48(1), 94–127 (2012)MathSciNetCrossRefzbMATHGoogle Scholar
 38.Efrat, A., Guibas, L.J., HarPeled, S., Mitchell, J.S.B., Murali, T.M.: New similarity measures between polylines with applications to morphing and polygon sweeping. Discrete Comput. Geom. 28(4), 535–569 (2002)MathSciNetCrossRefzbMATHGoogle Scholar
 39.Eiter, T., Mannila, H.: Computing Discrete Fréchet Distance. Technical report CDTR 94/65, Christian Doppler Laboratory (1994)Google Scholar
 40.Erickson, J.: Bounds for linear satisfiability problems. Chic. J. Theor. Comput. Sci. 1999, 8 (1999)MathSciNetzbMATHGoogle Scholar
 41.Fredman, M.L.: How good is the information theory bound in sorting? Theor. Comput. Sci. 1(4), 355–361 (1975/76)Google Scholar
 42.Fredman, M.L., Willard, D.E.: Surpassing the informationtheoretic bound with fusion trees. J. Comput. Syst. Sci. 47(3), 424–436 (1993)MathSciNetCrossRefzbMATHGoogle Scholar
 43.Fredman, M.L., Saxe, J.B., Sipser, M.: Parity, circuits, and the polynomialtime hierarchy. Math. Syst. Theory 17(1), 13–27 (1984)MathSciNetCrossRefzbMATHGoogle Scholar
 44.Gajentaan, A., Overmars, M.H.: On a class of \({O}(n^2)\) problems in computational geometry. Comput. Geom. 5(3), 165–185 (1995)MathSciNetCrossRefzbMATHGoogle Scholar
 45.Godau, M.: A natural metric for curves—computing the distance for polygonal chains and approximation algorithms. In: Choffrut, C., Jantzen, M. (eds.) STACS 91. Lecture Notes in Computer Science, vol. 480, pp. 127–136. Springer, Berlin (1991)CrossRefGoogle Scholar
 46.Godau, M.: On the Complexity of Measuring the Similarity Between Geometric Objects in Higher Dimensions. PhD thesis, Free University Berlin, Berlin (1998)Google Scholar
 47.Gudmundsson, J., Wolle, T.: Towards automated football analysis: algorithms and data structures. In: Proceedings of the 10th Australasian Conference on Mathematics and Computers in Sport 2010. ANZIAM, Darwin (2010)Google Scholar
 48.HarPeled, S., Nayyeri, A., Salavatipour, M., Sidiropoulos, A.: How to walk your dog in the mountains with no magic leash. In: Dey, T., Whitesides, S. (eds.) Computational Geometry (SCG’12), pp. 121–130. ACM, New York (2012)Google Scholar
 49.HarPeled, S., Raichel, B.: The Fréchet distance revisited and extended. ACM Trans. Algorithms 10(1), 3 (2014)CrossRefzbMATHGoogle Scholar
 50.Hirschberg, D.S., Chandra, A.K., Sarwate, D.V.: Computing connected components on parallel computers. Commun. ACM 22(8), 461–464 (1979)MathSciNetCrossRefzbMATHGoogle Scholar
 51.Indyk, P.: Approximate nearest neighbor algorithms for Frechet distance via product metrics. In: Computational Geometry (SCG’02), pp. 102–106. ACM, New York (2002)Google Scholar
 52.Grønlund, A., Pettie, S.: Threesomes, degenerates, and love triangles. In: 55th Annual IEEE Symposium on Foundations of Computer Science—FOCS 2014, pp. 621–630. IEEE Computer Society, Los Alamitos (2014)Google Scholar
 53.Katz, M.J., Sharir, M.: An expanderbased approach to geometric optimization. SIAM J. Comput. 26(5), 1384–1408 (1997)MathSciNetCrossRefzbMATHGoogle Scholar
 54.Maheshwari, A., Sack, J.R., Shahbaz, K., ZarrabiZadeh, H.: Fréchet distance with speed limits. Comput. Geom. 44(2), 110–120 (2011)MathSciNetCrossRefzbMATHGoogle Scholar
 55.Maheshwari, A., Sack, J.R., Shahbaz, K., ZarrabiZadeh, H.: Improved algorithms for partial curve matching. In: Demetrescu, C., Halldórsson, M.M. (eds.) Algorithms—ESA 2011. Lecture Notes in Computer Science, vol. 6942, pp. 518–529. Springer, Heidelberg (2011)CrossRefGoogle Scholar
 56.Preparata, F.P., Shamos, M.I.: Computational Geometry. Texts and Monographs in Computer Science. Springer, New York (1985)CrossRefzbMATHGoogle Scholar
 57.Pătraşcu, M.: Towards polynomial lower bounds for dynamic problems. In: STOC’10, pp. 603–610. ACM, New York (2010)Google Scholar
 58.Schönhage, A.: On the power of random access machines. In: Maurer, H.A. (ed.) Automata, Languages and Programming. Lecture Notes in Computer Science, vol. 71, pp. 520–529. Springer, Berlin (1979)CrossRefGoogle Scholar
 59.Schönhage, A.: Storage modification machines. SIAM J. Comput. 9(3), 490–508 (1980)MathSciNetCrossRefzbMATHGoogle Scholar
 60.Sharir, M., Agarwal, P.K.: DavenportSchinzel Sequences and Their Geometric Applications. Cambridge University Press, Cambridge (1995)zbMATHGoogle Scholar
 61.Tarjan, R.E.: Efficiency of a good but not linear set union algorithm. J. Assoc. Comput. Mach. 22(2), 215–225 (1975)MathSciNetCrossRefzbMATHGoogle Scholar
 62.Thorup, M.: Randomized sorting in \({O}(n \log \log n)\) time and linear space using addition, shift, and bitwise Boolean operations. J. Algorithms 42(2), 205–230 (2002)MathSciNetCrossRefzbMATHGoogle Scholar
 63.Wenk, C., Salas, R., Pfoser, D.: Addressing the need for mapmatching speed: localizing global curvematching algorithms. In: Proceedings of the 18th International Conference on Scientific and Statistical Database Management, pp. 379–388. IEEE Computer Society, Los Alamitos (2006)Google Scholar
Copyright information
Open AccessThis article is distributed under the terms of the Creative Commons Attribution 4.0 International License (http://creativecommons.org/licenses/by/4.0/), which permits unrestricted use, distribution, and reproduction in any medium, provided you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons license, and indicate if changes were made.