# Simpler is Faster: Practical Distance Reporting by Sorting Along a Space-Filling Curve

**Authors:** Sarita de Berg, Emil Toftegaard G{\ae}de, Ivor van der Hoog, Henrik Reinst\"adtler, Eva Rotenberg

arXiv: 2508.19891 · 2025-12-05

## TL;DR

This paper demonstrates that sorting points along a space-filling curve alone can significantly improve distance reporting queries, outperforming complex data structures in speed and space efficiency.

## Contribution

It shows that a simple approach of sorting points along a space-filling curve can outperform traditional complex range reporting data structures in practical scenarios.

## Key findings

- Outperforms eight state-of-the-art range searching implementations.
- Uses less space and has faster construction times.
- Achieves superior query performance, especially in dynamic settings.

## Abstract

Range reporting is a classical problem in computational geometry. A (rectangular) reporting data structure stores a point set $P$, such that, given a (rectangular) query region $\Delta$, it returns all points in $P \cap \Delta$. A variety of data structures support such queries with differing asymptotic guarantees such as k-d trees, range trees, R-trees, and quadtrees. A common variant of range queries are distance reporting queries, where the input is a query point $q$ and a radius $\delta$, and the goal is to report all points in $P$ within distance $\delta$ of $q$. Such queries frequently arise as subroutines in geometric data structures. Practical implementations typically answer distance queries through rectangular range queries using the data structures listed before.   This paper revisits a simple and practical heuristic for distance reporting, originally proposed in TCS'97: sort the input point set~$P$ along a space-filling curve. Queries then reduce to scanning at most four contiguous ranges along the sorted curve. The fact that sorting along a space-filling curve is beneficial for range reporting is well-known. Many implementations use this technique to speed up their query and construction times. The point that this paper makes is subtle, but interesting: we argue that often, it is the space-filling curve rather than the overall data structure that provides the performance benefits. Thus, we offer a simple but effective alternative: only sort $P$ along a space-filling curve instead.   We compare this approach to eight range searching implementations, across an elaborate test suite of real-world and synthetic data. Our experiments confirm this simple 200-line code approach out-performs all high-end implementations in terms of space usage and construction time. It presents almost always the best query times. In a dynamic setting, our approach dominates in performance.

## Figures

30 figures with captions in the complete paper: https://tomesphere.com/paper/2508.19891/full.md

---
Source: https://tomesphere.com/paper/2508.19891