Sariel Har-Peled, Benjamin Raichel, Eliot W. Robson
More applied than theory…
Started with (Alt and Godau 1995)
Easy to compute.
Not necessarily monotone!
But almost monotone!
Bottleneck shortest path
For general graphs
\(O(n \log n + m)\) Dijkstra
\(O(m \log^* m)\)
\(O(n \log n + m)\): Via MST.
(Alt and Godau 1995) alg to compute weak Fréchet
\(O(n^2)\).
\(G\): Directed graph with weights on edges
Definition:
Claim: \(\forall \pi, \sigma\) : \(\,\,\) \(\mathsf{d}_{\mathcal{F}}(\pi, \sigma) \geq \mathsf{d}^{ve}_{\mathcal{F}}(\pi, \sigma)\).
Optimal Fréchet \(\in[\mathsf{d}^{ve}_{\mathcal{F}}. \mathrm{mono}(\mathsf{d}^{ve}_{\mathcal{F}})]\).
Algorithm for (exact) Retractable Fréchet
Retractablity is important…
\(\pi\): Polygonal curve
\(n = |\pi|\)
Exact: \(O(n \log n)\).
Practice: Simple + linear time
\(3\)-approx. \(O(n)\) time for Fréchet dist between curve and segment.
High quality “slow”.
Idea: Pick vertices greedy fashion…
\(\pi, \sigma\): Input curves.
\(d \leftarrow\) silly upper bound on \(\mathsf{d}_{\mathcal{F}}(\pi, \sigma)\).
do
Simplify curves (speedup).
Do simplification preserving bottleneck.
\(\Rightarrow\) Fast exact algorithm.
Many details…
Task: Preprocess \(\pi\) (\(10,000\)s of vertices).
Query: Given \(\delta > 0\) output curve \(\sigma\) s.t. \(\mathsf{d}_{\mathcal{F}}(\pi, \sigma) \leq \delta\).
Running time: \(O( |V(\sigma)|)\).
Given \(\alpha\): Extract all vertices label \(>\alpha\).
Running time: Output sensitive.
repeats many Fréchet distance queries on same curves.
Cache simplifications curves (a hierarchy).
use hierarchy to extract simplification quickly.
Precompute the simplification hierarchy.
Good idea if persistent data/task…
Python without the stupidity.
As much typed as you want.
built-in package manager
Many libraries.
Source code of everything available.
Compiled on execution.
Designed for multi-threaded/parallel and distributed computing
Fun.
The Fréchet distance is defined as the minimal length of a leash connecting a dog on one trajectory with its owner on a second trajectory, both never moving backwards. For this challenge, the “true” Fréchet distance shall be used, though teams are free to exploit the existing approximations including the Discrete Fréchet distance as they wish. The challenge for this year consists of finding and combining spatiotemporal indexing schemes with efficient algorithms for Range Queries in very large databases of trajectories…
(Bringmann, Künnemann, and Nusser 2021): C++ implementation.
(Bringmann, Künnemann, and Nusser 2021): C++ implementation.
Handling noise/outliers.
Consensus curve?