# Space-filling tree

Space-ﬁlling trees are geometric constructions that are analogous to space-filling curves,[1] but have a branching, tree-like structure and are rooted. A space-ﬁlling tree is deﬁned by an incremental process that results in a tree for which every point in the space has a ﬁnite-length path that converges to it. In contrast to space-filling curves, individual paths in the tree are short, allowing any part of the space to be quickly reached from the root. [2] [3] The simplest examples of space-filling trees have a regular, self-similar, fractal structure, but can be generalized to non-regular and even randomized/Monte-Carlo variants (see Rapidly exploring random tree). Space-filling trees have interesting parallels in nature, including ﬂuid distribution systems, vascular networks, and fractal plant growth, and many interesting connections to L-systems in computer science.

## Definition

A space-filling tree is defined by an iterative process whereby a single point in a continuous space is connected via a continuous path to every other point in the space by a path of finite length, and for every point in the space, there is at least one path that converges to it.

The term "space-filling tree" in this sense was created in a 2009 tech report [4] that defines "space-filling" and "tree" differently than their traditional definitions in mathematics. As explained in the space-filling curve article, in 1890, Peano found the first space-filling curve, and by Jordan's 1887 definition, which is now standard, a curve is a single function, not a sequence of functions. The curve is "space filling" because it is "a curve whose range contains the entire 2-dimensional unit square" (as explained in the first sentence of space-filling curve).

In contrast, a space-filling tree, as defined in the tech report, is not a single tree. It is only a sequence of trees. The paper says "A space-filling tree is actually defined as an infinite sequence of trees". It defines $T_{square}$ as a "sequence of trees", then states "$T_{square}$ is a space-filling tree". It is not space-filling in the standard sense of including the entire 2-dimensional unit square. Instead, the paper defines it as having trees in the sequence coming arbitrarily close to every point. It states "A tree sequence T is called 'space filling' in a space X if for every x in X, there exists a path in the tree that starts at the root and converges to x.". The standard term for this concept is that it includes a set of points that is dense everywhere in the unit square.

## Examples

The simplest example of a space-filling tree is one that fills a square planar region. The images illustrate the construction for the planar region $[0,1]^2 \subset \Re^2$. At each iteration, additional branches are added to the existing trees.

Space-filling trees can also be defined for a variety of other shapes and volumes. Below is the subdivision scheme used to define a space-filling for a triangular region. At each iteration, additional branches are added to the existing trees connecting the center of each triangle to the centers of the four subtriangles.

The first six iterations of the triangle space-filling tree are illustrated below:

Space-filling trees can also be constructed in higher dimensions. The simplest examples are Cubes in $\Re^3$ and hypercubes in $\Re^n$. A similar sequence of iterations used for the square space-filling tree can be used for hypercubes. The third iteration of such a space-filling tree in $\Re^3$ is illustrated below: