# An Optimal Single-Path Routing Algorithm in the Datacenter Network DPillar 

Alejandro Erickson, Abbas E. Kiasari, Javier Navaridas and lain A. Stewart


#### Abstract

DPillar has recently been proposed as a server-centric datacenter network and is combinatorially related to (but distinct from) the well-known wrapped butterfly network. We explain the relationship between DPillar and the wrapped butterfly network before proving that the underlying graph of DPillar is a Cayley graph; hence, the datacenter network DPillar is node-symmetric. We use this symmetry property to establish a single-path routing algorithm for DPillar that computes a shortest path and has time complexity $O(k)$, where $k$ parameterizes the dimension of DPillar (we refer to the number of ports in its switches as $n$ ). Our analysis also enables us to calculate the diameter of DPillar exactly. Moreover, our algorithm is trivial to implement, being essentially a conditional clause of numeric tests, and improves significantly upon a routing algorithm earlier employed for DPillar. Furthermore, we provide empirical data in order to demonstrate this improvement. In particular, we empirically show that our routing algorithm improves the average length of paths found, the aggregate bottleneck throughput, and the communication latency. A secondary, yet important, effect of our work is that it emphasises that datacenter networks are amenable to a closer combinatorial scrutiny that can significantly improve their computational efficiency and performance.


Index Terms—Datacenter networks, routing algorithms, shortest paths, symmetry.

## 1 Introduction

Datacenters are assuming an increasingly important role in the global computational infrastructure. They provide platforms for a wide range of data-intensive applications and activities including web search, social networking, online gaming, large-scale scientific deployments and serviceoriented cloud computing. There is an increasing demand that datacenters incorporate more and more servers, and do so in a cost-effective fashion, but still so that the resulting platform is computationally efficient (in various senses of the term).

A datacenter network ( DCN ) comprises the physical communication infrastructure underpinning a datacenter. One of the main aspects of a datacenter network is the topology by which the servers, switches and other components of the datacenter are interconnected; the choice of topology strongly influences the datacenter's practical performance (see, e.g., [19]). For simplicity, henceforth by DCN we refer to the datacenter network topology. Originally, DCNs were hierarchical with expensive core routers that became bottlenecks in terms of both performance and cost. They evolved into tree-like, switch-centric DCNs, built from commodity-off-the-shelf (COTS) components; that is, so that the servers are located at the 'leaves' of a tree-like structure that is composed entirely of switches and where the routing intelligence resides within the switches. Such DCNs can offer better load balancing capabilities and so are less prone to

- Abbas Kiasari and Javier Navaridas are with the School of Computer Science, University of Manchester, Oxford Road, Manchester M13 9PL, U.K.

E-mail: \{abbas.kiasari,javier.navaridas\}@manchester.ac.uk

- Alejandro Erickson and Iain Stewart are with the School of Engineering and Computing Sciences, Durham University, South Road, Durham DH1 3LE, U.K.
E-mail: \{alejandro.erickson,i.a.stewart\}@durham.ac.uk
bottlenecks but have limited scalability due to (the size of) routing tables within the switches. Typical examples of such switch-centric DCNs are ElasticTree [14], Fat-Tree [5], VL2 [10], HyperX [3], Portland [20] and Flattened Butterfly [1].

Alternative architectures have recently emerged and server-centric DCNs have been proposed whereby the interconnection intelligence resides within the servers as opposed to the switches. Now, switches only operate as dumb crossbars (and consequently the need for high-end switches is diminished as are the infrastructure costs). This paradigm shift means that more scalable topologies can be designed and the fact that routing resides within servers, which are easier to program than are switches, means that more effective routing algorithms can be adopted. However, server-centric DCNs are not a panacea as packet latency can increase, with the need to handle routing providing a computational overhead on the server. Typical examples of server-centric DCNs are DCell [12], BCube [13], FiConn [16], CamCube [2], MCube [23], DPillar [18], HCN and BCN [11] and SWCube, SWKautz, and SWdBruijn [17]. An additional positive aspect of some server-centric DCNs is that not only can commodity switches be used to build the datacenters but commodity servers can too; the DCNs FiConn, MCube, DPillar, HCN, BCN, SWCube, SWKautz, and SWdBruijn are all such that any server only needs two NIC ports (the norm in commodity servers) in order to incorporate it into the DCN.

It is with the DCN DPillar that we are concerned here. DPillar is an established and one of the most promising benchmark dual-port server-centric DCNs. Moreover, DPillar is one of the even fewer dual-port server-centric DCNs for which no server-node is adjacent to any other servernode, the others being SWKautz, SWCube, and SWdBruijn. DPillar has recently been compared with other dual-port server-centric DCNs [17]. It was shown that when the di-
ameter of the DCN is normalized, DPillar can incorporate more servers than FiConn and BCN, a similar number of servers to SWCube, and (usually) less servers than SWKautz and SWdBruijn. However, DPillar, SWCube, SWKautz, and SWdBruijn were shown to have similar bisection widths and all have better bisection widths than FiConn and BCN. Whilst SWCube, SWKautz, and SWdBruijn were compared with each other in [17] with regard to aspects of routing in relation to fault-tolerance and handling congestion, there was no comparison of these three DCNs with DPillar. Such an evaluation is currently missing and would obviously be tied to a particular routing algorithm for DPillar, an observation that we will return to in a moment.

As we shall see, DPillar is essentially obtained by replacing complete bipartite subgraphs $K_{\frac{n}{2}, \frac{n}{2}}$ in a wrapped butterfly network (see, e.g., [15]) with a switch with $n$ ports. In [18], basic properties of DPillar are demonstrated and single-path and multi-path routing algorithms are developed (along with a forwarding methodology for the latter). Our focus here is on single-path routing (also known as single-source deterministic routing). The algorithm in [18] is appealing in its simplicity but for most source-destination pairs it does not produce a path of shortest length; indeed, there is often a significant discrepancy between the lengths of the path produced by the algorithm in [18] and a shortest path (as we demonstrate later). We remedy this situation and develop a single-path routing algorithm that always outputs a shortest path. Although the proof of correctness of our algorithm is non-trivial, the actual algorithm itself is a very simple sequence of numeric tests and has the same time complexity as the original single path routing algorithm, i.e., linear in the number of columns within DPillar.

Furthermore, we undertake an empirical evaluation and show that according to our experiments, the original single path routing algorithm for DPillar from [18] fails to provide a shortest path route for more than $51 \%$ and up to $78 \%$ of the server pairs; this translates into our algorithm giving an improvement in the range of $20-30 \%$ in terms of the average path length derived. Note that a reduction in path length not only means that the latency of the network traffic will be reduced (between 20 and $25 \%$, in our experiments), but also that as less resources are required for transmitting data, the overall throughput of the network should also increase. To verify this latter contention, we empirically measure the aggregate bottleneck throughput (the most widely accepted datacenter throughput metric) for both algorithms and we find that our algorithm yields improvements in the range of $25-120 \%$, with a mean of $65 \%$ and a median of $75 \%$. The substantial improvements in average path length and throughput, together with the algorithmic simplicity of our proposal, more than motivates its utilization in production systems. As by-products of the development of our algorithm, we prove that the DCN DPillar is, in essence, a Cayley graph, and thus node-symmetric (that is, there is an automorphism mapping any server to any other server), and we obtain the diameter of the DCN DPillar exactly.

Let us now return to our earlier remark as regards the current lack of a comparison in the literature of DPillar with SWCube, SWKautz, and SWdBruijn with respect to aspects of routing in relation to fault-tolerance and handling congestion. Were we to embark on this comparison prior
to the results of our paper then we would be doing a disservice to DPillar as we would be working with the routing algorithm from [18] which we prove (and empirically validate) here to be significantly worse in all respects than the routing algorithm we develop in this paper. We intend in future to undertake an extensive evaluation of aspects of routing for dual-port server-centric DCNs including DPillar, SWCube, SWKautz, and SWdBruijn but thanks to the results of this paper, this will now be with respect to our improved routing algorithm for DPillar (of course, such an evaluation is beyond the scope of this paper).

In the next sections, we give an explicit definition of the DCN DPillar, both algebraically and as a derivation from wrapped butterfly networks, before showing how to abstract DPillar as a directed graph and proving that the resulting directed graph is a Cayley graph; an immediate consequence is that the DCN DPillar is node-symmetric. In Section 4, and using the newfound property of nodesymmetry, we explain how solving the single-path routing problem in our abstraction of DPillar can be further abstracted so that it is equivalent to a routing problem in what we call a marked cycle, and in Section 5 we prove that shortest paths in this marked cycle must have severe restrictions on their structure. We use these restrictions to develop our single-path routing algorithm for DPillar in Section 6 and establish its correctness and its time complexity. To support our theoretical analysis, we provide empirical evidence that the length of the (shortest) path obtained by our single-path routing algorithm is significantly shorter than the length of the path obtained by the single-path routing algorithm from [18] for many source-destination pairs, and we calculate the diameter of DPillar explicitly. Our conclusions and directions for further research are given in Section $8^{1}$.

## 2 The DCN DPilLAR

In this section, we explicitly define the DCN DPillar and explain how the DCN DPillar can be (informally) constructed from a wrapped butterfly network.

### 2.1 A definition of DPillar

The DCN DPillar [18] consists of a collection of switches, each of which has $n$ ports, with $n \geq 2$ even, and a collection of servers, each of which has 2 NIC ports. The names of the servers are $\left\{\left(c, v_{k-1} v_{k-2} \ldots v_{0}\right): 0 \leq c \leq k-1 ; 0 \leq\right.$ $\left.v_{i} \leq \frac{n}{2}-1 ; 0 \leq i \leq k-1\right\}$ where $k \geq 2$ (we refer to $k$ as the dimension): the first parameter, $c$, is the column-index and denotes the column in which the server resides, whilst the second parameter $v_{k-1} v_{k-2} \ldots v_{0}$ is the row-index and denotes the server's position within a column (from the left, the bit positions are $k-1, k-2, \ldots, 0$; note that we refer to the values as 'bits' and their positions as 'bit' positions). We denote the DCN DPillar with parameters $n$ and $k$, as above, by DPillar ${ }_{n, k}$. Consequently, DPillar $_{n, k}$ has $k\left(\frac{n}{2}\right)^{k}$ servers.

1. Some results from this paper appeared in preliminary form in: A. Erickson, A. Kiasari, J. Navaridas and I.A. Stewart, An efficient shortest path routing algorithm in the data centre network DPillar, Proc. of 9th Ann. Int. Conf. on Combinatorial Optimization and Applications, 2015, pp. 209-220; some proofs and results were omitted and there was no experimental evaluation.

We term the collections of servers 'columns' as we visualize the servers within a column as being stacked vertically within that column, with the row-indices of the servers, from top to bottom, being given in increasing lexicographic order on $\left\{0,1, \ldots, \frac{n}{2}-1\right\}^{k}$; so, if $n=6$ and $k=4$, for example, then the ordering is given by $0000<0001<$ $0002<0010<0011<0012<0020<\ldots$ and so on. There are $\left(\frac{n}{2}\right)^{k-1}$ switches located between column $i$ and column $i+1$, for $i=0,1, \ldots, k-2$, and also between column $k-1$ and column 0 ; thus, there are $k\left(\frac{n}{2}\right)^{k-1}$ switches in DPillar $_{n, k}$. We think of the switches between two columns of servers as appearing in a column too, with the names of the switches in a column being $\left\{0,1, \ldots, \frac{n}{2}-1\right\}^{k-1}$ and again stacked from top to bottom in increasing lexicographic order. If a switch lies between server-column $c$ and servercolumn $c+1$, where $c \in\{0,1, \ldots, k-1\}$ and addition is modulo $k$, then we say that its column is column $c$ (henceforth, we assume that addition and subtraction on the names of columns are always modulo $k$ ). The columns of servers and switches for DPillar $_{6,3}$ can be visualized as in Fig. 1 (note that the servers in the right-most and left-most columns are identical but are shown separately to facilitate visualization).

All links are server-switch links and are from a server in (server-)column $c$ to a switch in (switch-)column $c$ or from a server in (server-)column $c+1$ to a switch in (switch-)column $c$ (where $c \in\{0,1, \ldots, k-1\}$ ). Let $\left(c, v_{k-1} v_{k-2} \ldots v_{0}\right)$ be a server in column $c$. The switch to which it is connected in column $c$ is the switch named $v_{k-1} \ldots v_{c+1} v_{c-1} \ldots v_{0}$. If $\left(c+1, v_{k-1} v_{k-2} \ldots v_{0}\right)$ is a server in column $c+1$ then the switch to which it is connected in column $c$ is the switch named $v_{k-1} \ldots v_{c+1} v_{c-1} \ldots v_{0}$. So, for example, the server $\left(c, v_{k-1} \ldots v_{c+1} * v_{c-1} \ldots v_{0}\right)$, where $*$ denotes that we may substitute in any number from $\left\{0,1, \ldots, \frac{n}{2}-1\right\}$, is connected to the switch $v_{k-1} \ldots v_{c+1} v_{c-1} \ldots v_{0}$ in column $c$, which in turn is connected to the server $\left(c+1, v_{k-1} \ldots v_{c+1} * v_{c-1} \ldots v_{0}\right)$. Similarly, the server $\left(c, v_{k-1} \ldots v_{c} * v_{c-2} \ldots v_{0}\right)$ is connected to the switch $v_{k-1} \ldots v_{c} v_{c-2} \ldots v_{0}$ in column $c-1$, which in turn is connected to the server $\left(c-1, v_{k-1} \ldots v_{c} * v_{c-2} \ldots v_{0}\right)$. The server-switch links for DPillar ${ }_{6,3}$ can be visualized as in Fig. 1.

An alternative informal definition of DPillar $_{n, k}$ can be given. With reference to Fig. 1, we can replace every switch with a complete bipartite graph $K_{\frac{n}{2}, \frac{n}{2}}$ (the bipartition is the obvious one). What results is the well-known wrapped butterfly network (see, e.g., [15]; this network has been well-studied within the context of multiprocessor systems). The primary difference between DPillar ${ }_{n, k}$ and the resulting wrapped butterfly network is that a switch in DPillar ${ }_{n, k}$ enables direct server-to-server communication between servers connected to the same switch and in the same column, whereas such communication is absent in the wrapped butterfly network.

### 2.2 Abstracting DPillar

We can abstract DPillar ${ }_{n, k}$ as a digraph as follows: the nodes of this graph are the servers of DPillar $_{n, k}$; and there is an edge from a source-node to a target-node if there is a link from the corresponding source-server to a switch and a link from that switch to the corresponding target-server (so, the
edges correspond to server-switch-server paths). There are 4 types of edges in the digraph abstracting DPillar $_{n, k}$ :
(i) clockwise edges (c-edges) which are edges of the form

$$
\begin{aligned}
& \left(\left(c, v_{k-1} \ldots v_{c+1} v_{c} v_{c-1} \ldots v_{0}\right)\right. \\
& \left.\quad\left(c+1, v_{k-1} \ldots v_{c+1} * v_{c-1} \ldots v_{0}\right)\right)
\end{aligned}
$$

(ii) anti-clockwise edges (a-edges) which are edges of the form

$$
\begin{aligned}
& \left(\left(c, v_{k-1} \ldots v_{c} v_{c-1} v_{c-2} \ldots v_{0}\right)\right. \\
& \left.\quad\left(c-1, v_{k-1} \ldots v_{c} * v_{c-2} \ldots v_{0}\right)\right)
\end{aligned}
$$

(iii) basic static edges (b-edges) which are edges of the form

$$
\begin{aligned}
& \left(\left(c, v_{k-1} \ldots v_{c+1} v_{c} v_{c-1} \ldots v_{0}\right)\right. \\
& \left.\quad\left(c, v_{k-1} \ldots v_{c+1} * v_{c-1} \ldots v_{0}\right)\right)
\end{aligned}
$$

(iv) decremented static edges (d-edges) which are edges of the form

$$
\begin{aligned}
& \left(\left(c, v_{k-1} \ldots v_{c} v_{c-1} v_{c-2} \ldots v_{0}\right)\right. \\
& \left.\quad\left(c, v_{k-1} \ldots v_{c} * v_{c-2} \ldots v_{0}\right)\right)
\end{aligned}
$$

So, within our abstraction of DPillar $_{n, k}$ as a digraph, the nodes are the servers and are located in columns $0,1, \ldots, k-1$ (as before) with all edges joining nodes in consecutive columns (clockwise and anticlockwise edges) or nodes in the same column (static edges). In fact, our digraph (where each node has in- and out-degree $2 n-2$ ) can also be thought of as an undirected graph (that is regular of degree $2 n-2$ ) as all edges come in oppositely oriented pairs. Note that the clockwise (resp. anti-clockwise, basic static, decremented static) edge above corresponds to a server-switch-server path in the DCN DPillar ${ }_{n, k}$ from a column $c$ server through a column $c$ (resp. $c-1, c, c-1$ ) switch and on to a column $c+1$ (resp. $c-1, c, c$ ) server. Henceforth, we denote the digraph abstracting DPillar $_{n, k}$ by DPillar $_{n, k}$ too (this causes no confusion). The abstraction of DPillar can be visualized as in Fig. 1 where we show how the switch 00 in column 2 gives rise to a set of edges in the abstraction of DPillar as a graph. We annotate edges as follows: an edge annotated ' $a$ ' is an anti-clockwise edge relative to the node $(0,000)$ (the arrow on the edge from $(0,000)$ denotes that the label is with respect to $(0,000)$ ); an edge annotated ' b ' is a basic static edge relative to node ( 2,000 ); an edge annotated ' $\mathbf{c}$ ' is a clockwise edge relative to node ( 2,000 ); and an edge annotated ' $d$ ' is a decremented static edge relative to node $(0,000)$ (so, an edge has two labels: one relative to one incident node; and another relative to the other incident node). In short, for some node, the adjacent switch 'to the right' gives rise to b-edges and c-edges, and the one 'to the left' gives rise to a-edges and d-edges.

## 3 DPillar is a Cayley Graph

In this section, we prove that the digraph DPillar $_{n, k}$ is a Cayley graph, and consequently node-symmetric (we exploit this node-symmetry later on in our single-path routing algorithm and in our experimental work). Recall that a graph is a Cayley graph if the nodes can be labelled with the elements of a (algebraic) group $G$ and there is a generating subset $S \subseteq G$ that is closed under inverses so that every


Fig. 1. Visualizing DPillar $_{6,3}$.
directed edge $(u, v)$ is labelled with an element of $s \in S$ if, and only if, $u s=v$ (within the group $G$ ). We say that a digraph is node-symmetric if given any 2 distinct nodes $s r c$ and $d s t$, there is an automorphism (that is, a one-to-one mapping $\varphi$ of the node-set onto itself such that if $(u, v)$ is an edge then $(\varphi(u), \varphi(v))$ is an edge) mapping src to dst. It is well-known, and trivial to prove, that every Cayley graph is node-symmetric. The first paper to establish that being a Cayley graph is a useful property for an interconnection network is [4] and since then, there has been much research into representing interconnection networks using finite groups. Not only do we immediately obtain that any Cayley graph is node-symmetric (which is a fundamental property of interconnection networks [7]) but Cayley graphs have been shown to be relevant to various networks in a variety of ways; for example, with regard to the design of interconnection networks by pruning nodes and edges from tori [24], the design of wireless DCNs [22], and the design of high-dimensional mesh-based interconnection networks [6].

### 3.1 DPillar Symmetry

Whilst it was stated in [18] that the DCN DPillar is 'symmetric', it was not stated as to what 'symmetric' meant (hence, there was no proof of 'symmetry'). Our main intention is to show that DPillar is node-symmetric (defined above) but we do this by proving that DPillar is a Cayley graph.

## Lemma 1. The digraph DPillar $_{n, k}$ is a Cayley graph.

Proof: Our proof is related to the proof in [9] that the wrapped butterfly network (called the cyclic cube in [9]) is a Cayley graph. The full proof can be found in the supplemental material.

We obtain the immediate corollary.
Corollary 1. The digraph DPillar $_{n, k}$ is node-symmetric.

## 4 Abstracting routing in DPillar

In this section, we abstract the problem of finding a path in the digraph DPillar $_{n, k}$ from a given source-node to a given destination-node so that ultimately this problem is equivalent to finding a path from a source-node to a destinationnode in a cycle of length $k$ but where the actual node-tonode moves are more complicated than in a digraph. We also explain the single-path routing algorithm from [18].

### 4.1 Fixing bits

It is important to appreciate what might be accomplished by moving along one of the 4 different types of edge highlighted above. Suppose that we are attempting to move from some source-node $s r c$ to some destination-node $d s t$ within DPillar $_{n, k}$ and that we are currently at some node in column c. We can choose a clockwise (resp. anti-clockwise, basic static, decremented static) edge so as to set the $c$ th (resp. $(c-1)$ th, $c$ th, $(c-1)$ th) bit in the row-index to whatever value from $\left\{0,1, \ldots, \frac{n}{2}-1\right\}$ that we like. Consequently, by choosing a clockwise (resp. anti-clockwise, basic static, decremented static) edge along which to move, we can 'fix' the $c$ th (resp. $(c-1)$ th, $c$ th, $(c-1)$ th) bit of the rowindex so that it matches that of the destination-node. We say that: a clockwise edge covers the column in which its source-node lies; an anti-clockwise edge covers the column in which its target-node lies; a basic static edge covers the column in which both its source- and target-nodes lie; and a decremented static edge covers the column that is adjacent in an anti-clockwise direction to the column in which both its source- and target-nodes lie. Thus, if we wish to move along some path from $s r c$ to $d s t$ then we need to ensure that we move from column to column so as to fix all of the bits of the row-index that need fixing, but so that we don't subsequently 'unfix' them, and so that we end up in the column within which $d s t$ resides (with regard to not
'unfixing' a bit, note that we can always move from a node in one column to a node in an adjacent column so that the row-index remains unchanged). This is equivalent to moving from column to column so that every row-index bit-position, i.e., column, where the bit values of $s r c$ and $d s t$ differ is necessarily covered by some edge and so that we end up in the column within which $d s t$ resides. If we are looking for a shortest path from src to $d s t$ then we have to do this using as few moves as possible. Of course, any path of length $l$ in our abstraction of DPillar $_{n, k}$ as a digraph translates to a path consisting of $l$ server-switch-server linkpairs in the DCN DPillar ${ }_{n, k}$, and vice versa (for the sake of uniformity, we measure the length of server-to-server paths in the DCN DPillar in terms of the number of server-switchserver link-pairs in the path; this is also common practice in the DCN community).

As an illustration, suppose we are at $(1,12530)$ in DPillar $_{6,5}$ and wish to get to the destination $(4,54314)$. If $x$ denotes any element of $\{0,1,2,3,4,5\}$, there is: an anti-clockwise edge taking us to $(0,1253 x)$; a basic static edge taking us to $(1,125 x 0)$; a clockwise edge taking us to ( $2,125 x 0$ ); and a decremented static edge taking us to $(1,1253 x)$. Given our destination, when we move we can choose $x$ accordingly and fix the appropriate bit so that we move: via an anti-clockwise edge to ( $0,1253 \underline{4}$ ); via a basic static edge to $(1,125 \underline{10})$; via a clockwise edge to $(2,125 \underline{1} 0)$; or via a decremented static edge to $(1,1253 \underline{4})$.

### 4.2 Another abstraction

A crucial observation arising from the above discussion is that when routing in DPillar $n_{n, k}$, the actual value of some bit in a row-index of some node is unimportant: what matters is whether this value is equal to or different from the value of the corresponding bit in the row-index of the destinationnode (that is, whether the bit needs to be 'fixed' or not). Consequently, in order to solve the problem of finding a path from $s r c$, which lies in column $s r c^{\prime}$, to $d s t$, which lies in column $d s t^{\prime}$, in DPillar ${ }_{n, k}$, we can abstract the problem as a (more involved) routing problem in the following digraph $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right):$

- we think of there being one node for each of the $k$ columns of nodes of DPillar $_{n, k}$ with nodes in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ that correspond to adjacent columns being joined by an oppositely oriented pair of edges (so, we can also think of $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ as an undirected cycle of length $k$ )
- we mark every node $c$, corresponding to some column $c$ (or, alternatively, some bit-position $c$ in the row-index of some node of DPillar $_{n, k}$ ) that needs to be covered (because bit $c$ of the row-index of $s r c$ is different from bit $c$ of the row-index of $d s t$ ), with the set of marked nodes being denoted by $B$
- we move from node to node in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$, starting at the node $s r c^{\prime}$ so as to end at the node $d s t^{\prime}$ and making moves where:
(i) a c-move means we move from node $c$ to node $c+1$ and such a move covers node $c$
(ii) an $a$-move means we move from node $c$ to node $c-1$ and such a move covers node $c-1$
(iii) a b-move means we stay at node $c$ and such a move covers node $c$
(iv) a d-move means we stay at node $c$ and such a move covers node $c-1$
(note the correspondence between the above moves and the edge types given in Section 2.2). We call $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ a marked cycle. Note that it might be the case that $s r c^{\prime}=d s t^{\prime}$ in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ (this would mean that the nodes $s r c$ and $d s t$ lie in the same column in DPillar $_{n, k}$ ).

With regard to our illustration in the previous section, the edge from $(1,12530)$ : to $(0,12534)$ results in an a-move covering node 0 in the marked cycle; to $(1,12510)$ results in a b-move covering node 1 in the marked cycle; to $(2,12510)$ results in a c-move covering node 1 in the marked cycle; and to $(1,12534)$ results in a d-move covering node 0 in the marked cycle.

It should be clear as to how moves in the marked cycle $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ correspond to moves along corresponding edges in DPillar ${ }_{n, k}$ (and so to server-switch-server linkpairs in the DCN DPillar ${ }_{n, k}$ ) with the coverage of a node in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ and a node of DPillar $_{n, k}$ being in direct correspondence. A path in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ is a sequence of moves leading from $s r c^{\prime}$ to $d s t^{\prime}$ and corresponds to a path in DPillar ${ }_{n, k}$ from node $s r c$ to node $d s t$ (and vice versa) with the lengths of the two paths being identical. Consequently, in order to find a shortest path from $s r c$ to $d s t$ in the DCN DPillar $_{n, k}$, it suffices to find a shortest path in the marked cycle $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ (from the node $s r c^{\prime}$ to the node $d s t^{\prime}$ ) so that every marked node is covered by a move. Note that if $s r c^{\prime}=d s t^{\prime}$ then the empty sequence of moves does not constitute a legitimate path.

### 4.3 Basic routing in DPillar

Before we continue, let us discuss the single-path routing algorithm for DPillar as detailed in [18]; we refer to this algorithm as DPillarSP. The routing algorithm DPillarSP operates in 2 phases: in the first phase (the so-called 'helix' phase), a path in the DCN DPillar ${ }_{n, k}$ is chosen so that movement is always in a clockwise direction (that is, the columnindex is always incremented) or always in an anti-clockwise direction (that is, the column-index is always decremented) in order that the row-index is 'fixed' so that it is identical to that of the destination-node; and in the second phase (the so-called 'ring' phase), a path is subsequently chosen so as to reach the destination-node without amending the row-index and so that movement is in the same direction as in the first phase. Although not explicitly mentioned when discussing their algorithm, it is clear that the time complexity of the single-path routing algorithm from [18] is $O(k)$ (we have suppressed the $\log n$ component required to represent each bit-value).

It is stated in [18, Section 3.1] that this single-direction movement is so that 'loops' might be avoided. While this statement was not explained further, it is probable that what was meant by 'loops' was a loop within a single route for a source-destination pair. Of course, our shortest-path routing algorithm means that loops in a single path will never occur. Alternatively (though unlikely), the rationale for the decision in [18] to restrict to single-direction movement might have been to avoid either network-level deadlock
or livelock due to dependency loops (see, e.g., [7, Ch. 14]). Irrespective of the intentions in [18], it is worth commenting on the potential for deadlocks in DPillar and server-centric DCNs in general. Given that the topology of DPillar is basically a sophisticated ring of columns, moving in a single direction does not completely prevent dependency loops from appearing. We give an example in Fig. 2 where there is a (bold) route from $(0,000)$ to $(2,200)$ and a (dotted) route from $(1,200)$ to $(1,000)$ so that there is a cyclic dependency graph, due to the shared switches $(0,00)$ and $(1,20)$, even though we are using single-direction routing. Nevertheless, there are many reasons to believe that, in the context of server-centric DCNs based on COTS hardware and software (i.e., Ethernet hardware and TCP/IP stack), network level deadlocks should be a minor concern. First, commodity Ethernet hardware uses packet-switching which prevents network frames from spreading across many network components; therefore a cyclic dependency between frames is unlikely to happen. Second, servers have virtually unlimited memory (and indeed, many orders of magnitude more than switches); hence we can assume infinite FIFOs at the servers. Considering that one of the necessary conditions for deadlocks to appear is for FIFOs to become full, it is, again, very unlikely that we end up in a deadlock situation. Finally, in the very unlikely situation of a cyclic dependency appearing and all the FIFOs becoming full, the packet-dropping mechanism of Ethernet-based hardware provides seamless deadlock recovery, whereas TCP ensures data delivery. The upshot is that deadlocks are not a primary concern in DCNs.


Fig. 2. A dependency loop between two routes with DPillarSP. Server (0, $000)$ sends to $(2,200)$ and server $(1,200)$ sends to $(1,000)$. The paths through switches $(0,00)$ and $(1,20)$ are conflicted.

It is very easy to see (by looking at some typical sourcedestination examples) that the routing algorithm DPillarSP is by no means optimal and that more often than not much shorter paths exist (an upper bound of $2 k-1$ on the lengths of paths produced was stated in [18]). For example, if one chooses to route in a clockwise fashion in DPillar ${ }_{n, k}$ with the source $(0,00 \ldots 0)$ and the destination $(1,10 \ldots 0)$ then the DPillarSP yields a path of length $k+1$, and if one routes in an anti-clockwise fashion then the algorithm also yields a path of length $k-1$; however, a shortest path has length 2
(a d-move followed by a c-move). Our contention is that by relaxing this insistence on single-direction movement, we can obtain a much improved routing algorithm; indeed, as we shall see, we develop an optimal single-path routing algorithm (where the implementation overheads are negligible and where there are significant practical benefits).

## 5 Routing in a marked cycle

We begin by making some initial observations as regards routing along a shortest path (from $s r c^{\prime}$ to $d s t^{\prime}$ ) in a marked cycle $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ before proving that any such shortest path has a restricted structure.

### 5.1 Some initial observations

Henceforth, $\rho$ is a shortest path from $s r c^{\prime}$ to $d s t^{\prime}$ in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$. Consider two consecutive moves in $\rho$. We can often rule out consecutive pairs of moves. For example, suppose that we have within $\rho$ a c-move followed by an amove. We can replace this pair within $\rho$ by a b-move so as to obtain a path with identical coverage to $\rho$ and which is shorter. This yields a contradiction. Similarly, suppose that we have an a-move followed by a c-move within $\rho$. We can replace this pair within $\rho$ by a d-move so as to again obtain a contradiction. In Table 1, we detail all pairs of consecutive moves in $\rho$ that are forbidden by including the substitution that would result in a shorter path that has equivalent coverage. In this table, the first move is detailed in the rows and the second move in the columns. A blank cell means that the corresponding pair of moves cannot immediately be ruled out.

TABLE 1
Disallowed pairs of moves.

|  | a-move | b-move | c-move | d-move |
| :--- | :--- | :--- | :--- | :--- |
| a-move |  | a-move | d-move |  |
| b-move |  | b-move | c-move |  |
| c-move | b-move |  |  | c-move |
| d-move | a-move |  |  | d-move |

For clarity, rather than say, for example, 'a c-move followed by an a-move', in future we will simply write $c a$ to denote this circumstance. Consequently, subsequences of moves within $\rho$ will be written as strings over $\{a, b, c, d\}$ (as will $\rho$ itself) and we compress subsequences of the same symbol, such as aaaa, by using powers, such as $a^{4}$.

We can say more. If we have a subsequence of moves $b d$ then this has the same effect as the subsequence $d b$, and so we may suppose that a subsequence $d b$ within $\rho$ is forbidden. Also, note that if $\rho$ has length at least 3 then we cannot have a subsequence $b d$ :

- a subsequence $b d b$ can be replaced by $b d$; a subsequence $b d c$ can be replaced by $d c$; and we cannot have a subsequence $d a$ or $d d$
- a subsequence $c b d$ can be replaced by $c b$; a subsequence $d b d$ can be replaced by $d b$; and we cannot have a subsequence $a b$ or $b b$.
Consequently, if $\rho$ has length at least 3 then:
- if a c-move is not the final move of $\rho$ then it must be followed by another c-move or a b-move
- if an a-move is not the final move of $\rho$ then it must be followed by another a-move or a d-move
- if a b-move is not the final (resp. first) move of $\rho$ then it must be followed by an a-move (resp. preceded by a c-move)
- if a d-move is not the final (resp. first) move of $\rho$ then it must be followed by a c-move (resp. preceded by an a-move).

Consequently, if $\rho$ has length at least 3 then it must be of one of two forms:
(1) possibly a d-move (but maybe not) followed by a sequence of c-moves followed by a b-move followed by a sequence of a-moves followed by a d-move followed by a sequence of c-moves followed by ... followed by a sequence of c-moves (resp. a-moves) possibly followed by a b-move (resp. d-move); that is,

$$
d^{\epsilon} c^{i_{1}} b a^{j_{1}} d c^{i_{2}} \ldots c^{i_{m}} b^{\delta} \text { or } d^{\epsilon} c^{i_{1}} b a^{j_{1}} d c^{i_{2}} \ldots a^{j_{m}} d^{\delta}
$$

for some $m \geq 1$, where $i_{1}, i_{2}, \ldots, i_{m}, j_{1}, j_{2}, \ldots, j_{m} \geq$ 1 and where $\epsilon, \delta \in\{0,1\}$
possibly a b-move followed by a sequence of amoves followed by a d-move followed by a sequence of c-moves followed by a b-move followed by a sequence of a-moves followed by ... followed by a sequence of a-moves (resp. c-moves) possibly followed by a d-move (resp. b-move); that is,

$$
b^{\epsilon} a^{i_{1}} d c^{j_{1}} b a^{i_{2}} \ldots a^{i_{m}} d^{\delta} \text { or } b^{\epsilon} a^{i_{1}} d c^{j_{1}} b a^{i_{2}} \ldots c^{j_{m}} b^{\delta},
$$

for some $m \geq 1$, where $i_{1}, i_{2}, \ldots, i_{m}, j_{1}, j_{2}, \ldots, j_{m} \geq$ 1 and where $\epsilon, \delta \in\{0,1\}$
(when we say 'sequence', above, we mean 'non-empty sequence').

### 5.2 Restricting the number of turns

If we have a subsequence $c b a$ in $\rho$ then we say that an anticlockwise turn, or simply an a-turn, occurs at the b-move; similarly, if we have a subsequence $a d c$ then we say that a clockwise turn, or simply a c-turn, occurs at the d-move. Note that if we have an a-turn in $\rho$ then the node at which this turn occurs, i.e., the node that is covered by the d-move, must be marked in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ as otherwise we could delete the corresponding d-move from $\rho$ and still have a sequence from $s r c^{\prime}$ to $d s t^{\prime}$ covering all the marked nodes, which would yield a contradiction. Similarly, if we have a cturn then the node at which this c-turn occurs, i.e., the node that is covered by the b-move, must be marked. We will use these observations later; but now we prove that any shortest path $\rho$ must contain at most 2 turns.

Suppose that $\rho$ is a shortest path and has at least 3 turns. What we do now is undertake a case by case analysis of the different configurations that might arise. These cases arise from the forms derived at the end of the previous subsection: the first two cases correspond to form (1) and the next two cases to form (2). The technique employed in each case is to modify the path $\rho$, by replacing sequences of moves within $\rho$, so as to obtain a new path that has the same coverage but is shorter; this yields a contradiction to our assumption that $\rho$ has at least 3 turns.


Fig. 3. Visualizing paths with 2 turns.

Case (a): Suppose that $\rho$ is of form (1) and has a prefix $\rho^{\prime}$ of the form $c^{i} b a^{j} d c^{l} b a$, where $i, j, l \geq 1$.
By this we mean that $\rho$ begins with $i$ c-moves followed by a b-move followed by $j$ a-moves followed by a d-move followed by $l$ c-moves followed by a b-move followed by an a-move.

If $j<i$ then we can replace the prefix $c^{i} b a^{j} d c$ in $\rho^{\prime}$ with $c^{i} b a^{j-1}$ and still obtain the same coverage; this contradicts that $\rho$ is a shortest path (note that we have actually only assumed so far that $\rho$ has 2 turns). If $j=i$ then we can replace the prefix $c^{i} b a^{i} d c$ in $\rho^{\prime}$ with $d c^{i} b a^{i-1}$ so as to obtain a contradiction (we have still actually only assumed that $\rho$ has 2 turns). Hence, we must have that $j>i$. Suppose that $j \geq l>j-i$. We can replace the prefix $c^{i} b a^{j} d c^{l}$ in $\rho^{\prime}$ with $a^{j-i} d c^{j} b a^{j-l}$ so as to obtain a contradiction (we have still actually only assumed that $\rho$ has 2 turns). Hence, $j>i$ and either $l \leq j-i$ or $l>j$.

Suppose that $l>j$. We can replace the prefix $c^{i} b a^{j} d c^{l}$ in $\rho^{\prime}$ with $a^{j-i} d c^{l}$ so as to obtain a contradiction (we have still actually only assumed that $\rho$ has 2 turns). Hence, we must have that $j>i$ and $l \leq j-i$. However, if we replace $\rho^{\prime}$ with $c^{i} b a^{j} d c^{l-1}$ then we obtain a contradiction (here we do use the fact that $\rho$ has at least 3 turns). So, $\rho$ has at most 2 turns and if it has 2 turns then $\rho$ is of the form $c^{i} b a^{j} d c^{l}$ where $j>i$ and $l \leq j-i$.

We can say more if $\rho$ has 2 turns. Suppose that $j \geq$ $k-1$. The b-move can be deleted from $\rho^{\prime}$ and we obtain a contradiction. Hence, if $\rho$ has 2 turns then $\rho$ is of the form $c^{i} b a^{j} d c^{l}$ where $k-1>j>i \geq 1$ and $1 \leq l \leq j-i$. We can visualize $\rho$ as in Fig. 3(i). The marked cycle $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ is shown as a cycle where a black node denotes a node of $B$; that is, a node that needs to be covered by some path in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ (from $s r c^{\prime}$ to $d s t^{\prime}$, with $0=s r c^{\prime} \neq d s t^{\prime}=x$ in this illustration). The path $\rho$ is depicted as a dotted line partitioned into composite moves.
Case (b): Suppose that $\rho$ is of form (1) and has a prefix $\rho^{\prime}$ of the form $d c^{i} b a^{j} d c^{l} b a$, where $i, j, l \geq 1$.
If $j \leq i$ then we can replace the prefix $d c^{i} b a^{j} d c$ in $\rho^{\prime}$ with $d c^{i} b a^{j} c$ so as to obtain a contradiction, and if $j>i$ then we can delete the first d-move from $\rho$ to obtain a contradiction. Hence, if $\rho$ starts with a d-move then it has at most 1 turn.
Case (c): Suppose that $\rho$ is of form (2) and has a prefix $\rho^{\prime}$ of the form $a^{i} d c^{j} b a^{l} d c$, where $i, j, l \geq 1$.
If $j<i$ then we can replace the prefix $a^{i} d c^{j} b a$ in $\rho^{\prime}$ with $a^{i} d c^{j-1}$ so as to obtain a contradiction. If $i=j$ then we can
replace the prefix $a^{i} d c^{i} b a$ in $\rho^{\prime}$ with $b a^{i} d c^{i-1}$ so as to obtain a contradiction. Hence, $j>i$.

Suppose that $j \geq l>j-i$. We can replace the prefix $a^{i} d c^{j} b a^{l}$ in $\rho$ with $c^{j-i} b a^{j} d c^{j-l}$ so as to obtain a contradiction. Suppose that $l>j$. We can delete the first occurrence of a d-move in $\rho$ so as to obtain a contradiction. Hence, $l \leq j-i$. Note that if $\rho$ has 2 turns then $\rho$ is of the form $a^{i} d c^{j} b a^{l}$ where $j>i$ and $l \leq j-i$. Alternatively, suppose that $\rho$ has at least 3 turns. We can replace the prefix $a^{i} d c^{j} b a^{l} d c$ in $\rho$ with $a^{i} d c^{j} b c^{l-1}$ so as to obtain a contradiction. Hence, $\rho$ has at most 2 turns.

We can say more if $\rho$ has 2 turns. Suppose that $j \geq$ $k-1$. The d-move can be deleted from $\rho^{\prime}$ and we obtain a contradiction. Hence, if $\rho$ has 2 turns then $\rho$ is of the form $a^{i} d c^{j} b d^{l}$ where $k-1>j>i \geq 1$ and $1 \leq l \leq j-i$. We can visualize $\rho$ as in Fig. 3(ii).
Case (d): Suppose that $\rho$ is of form (2) and has a prefix $\rho^{\prime}$ of the form $b a^{i} d c^{j} b a^{l} d c$, where $i, j, l \geq 1$.
If $j \leq i$ then we can replace the prefix $b a^{i} d c^{j} b a$ with $b a^{i} d c^{j} a$ so as to obtain a contradiction, and if $j>i$ then we can delete the first b-move from $\rho$ to obtain a contradiction. Hence, if $\rho$ starts with a b-move then it has at most 1 turn.

So, we have proven the following lemma.
Lemma 2. If $\rho$ is a shortest path (from $s r c^{\prime}$ to $d s t^{\prime}$ ) in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ then $\rho$ has at most 2 turns, and if $\rho$ has 2 turns then it must be of the form $c^{i} b a^{j} d c^{l}$ or $a^{i} d c^{j} b a^{l}$, where $k-1>j>i \geq 1$ and $1 \leq l \leq j-i$.

With reference to Fig. 3, the numerical constraints in Lemma 2 mean that there is no interaction or overlap involving the 2 turns in $\rho$.

## 6 AN OPTIMAL ROUTING ALGORITHM FOR DPILLAR

We now develop an optimal single-path routing algorithm for DPillar, based around Lemma 2. We do this by finding a small set $\Pi$ of paths (from $s r c^{\prime}$ to $d s t^{\prime}$ ) in $G_{n, k}\left(s r c^{\prime}, d s t^{\prime}\right)$ so that at least one of these paths is a shortest path (and consequently we obtain a shortest path in the DCN DPillar ${ }_{n, k}$ ). By Lemma 1, we may assume that $\operatorname{src}=(0,00 \ldots 0)$ and $d s t=\left(x, v_{k-1} v_{k-2} \ldots v_{0}\right)$, and by Lemma 2 , we may assume that any shortest path has at most 2 turns.

Our technique is as follows. Essentially, we want to make the set $\Pi$ as small as possible; that is, we want our resulting algorithm to have to consider as few paths as possible (when looking for the shortest). Lemma 2 precisely describes the set of paths we need to consider from the paths involving exactly 2 turns; of course, we also need to consider paths involving 1 or 0 turns (if they exist). There are different situations depending upon the distribution of the marked nodes needing to be covered; in particular, upon the distribution of marked nodes along the natural clockwise and anti-clockwise paths from the source to the destination on the marked cycle, assuming the source and destination to be distinct (this is the case in Section 6.1; the case when the source and destination are the same is considered in Section 6.2). Sometimes the distribution of marked nodes rules out the possibility of certain types of paths.


Fig. 4. Visualizing our notation.

### 6.1 Building our set of paths when $x \neq 0$

We first suppose that $0 \neq x$. Let $B=\left\{i: 0 \leq i \leq k-1, v_{i} \neq\right.$ $0\}$ (that is, the bit-positions that need to be 'fixed'). Suppose that $B \backslash\{0, x\}=\left\{i_{l}: 1 \leq l \leq r\right\} \cup\left\{j_{l}: 1 \leq l \leq s\right\}$ so that we have $0<j_{s}<j_{s-1}<\ldots<j_{1}<C<i_{1}<$ $i_{2}<\ldots<i_{r}<k$ (we might have that either $r$ or $s$ is 0 , when the corresponding set is empty). If $r \geq 2$ then define $\delta_{l}=i_{l+1}-i_{l}$, for $l=1,2, \ldots, r-1$, with $\delta=\max \left\{\delta_{l}: l=\right.$ $1,2, \ldots, r-1\}$; and if $s \geq 2$ then define $\epsilon_{l}=j_{l}-j_{l+1}$, for $l=1,2, \ldots, s-1$, with $\epsilon=\max \left\{\epsilon_{l}: l=1,2, \ldots, s-1\right\}$. Also: define $\Delta_{0}=1$ (resp. 0 ), if $0 \in B$ (resp. $0 \notin B$ ); and $\Delta_{x}=1$ (resp. 0 ), if $x \in B$ (resp. $x \notin B$ ). We can visualize the resulting marked cycle $G_{n, k}(0, x)$ as in Fig. $4(i)$. Note that in this particular illustration $0 \notin B$ and $x \in B$; so, $\Delta_{0}=0$ and $\Delta_{x}=1$. Of course, what we are looking for is a sequence of (a-, b-, c- and d-)moves that will take us from 0 to $x$ in $G_{n, k}(0, x)$ so that all nodes of $B$ have been covered.

In what follows, we examine different scenarios involving the number of marked nodes, $r$, and also the number of marked nodes, $s$. Each scenario for $r$ contributes certain paths to $\Pi$ as does each scenario for $s$. Note that perhaps the most obvious paths to consider as potential members of $\Pi$ are the paths $c^{k+x}$ and $a^{2 k-x}$ which have lengths $k+x$ and $2 k-x$, respectively. So, we begin by setting $\Pi=\left\{c^{k+x}, a^{2 k-x}\right\}$.

From Lemma 2, any shortest path $\rho$ from 0 to $x$ having 2 turns requires that $r \geq 2$ or $s \geq 2$ and that both nodes at which these turns occur are different from 0 and $x$ and lie on the anti-clockwise path from 0 to $x$ or on the clockwise path from 0 to $x$, accordingly. Recall also that the node at which any turn occurs on a shortest path $\rho$ is necessarily a marked node (irrespective of the number of turns in $\rho$ ).
Case (a): Suppose that $r=0$.
In this scenario, we contribute either the path $c^{x} b$ to $\Pi$, if $x \in B$, or the path $c^{x}$ to $\Pi$, if $x \notin B$; either way, the length of the path contributed is $x+\Delta_{x}$.
Case (b): Suppose that $s=0$.
In this scenario, we contribute either the path $b a^{k-x}$ to $\Pi$, if $0 \in B$, or the path $a^{k-x}$ to $\Pi$, if $0 \notin B$; either way, the length of the path contributed is $k-x+\Delta_{0}$.
Case (c): Suppose that $r=1$.
In this scenario, we contribute 2 paths to $\Pi$. If $x \in B$ then we contribute the path $a^{k-i_{1}-1} d c^{k-i_{1}-1+x} b$ to $\Pi$, or if $x \notin B$ then we contribute the path $a^{k-i_{1}-1} d c^{k-i_{1}-1+x}$ to $\Pi$; either
way, the length of the resulting path is $2 k-2 i_{1}+x-1+\Delta_{x}$. We also contribute the path $c^{i_{1}} b a^{i_{1}-x}$ to $\Pi$ of length $2 i_{1}-$ $x+1$. There is potentially another path when $i_{1}=x+1$ and $x \in B$, namely $a^{k-x-1} d c^{k-1}$, but the length of this path is $2 k-x-1$ which is greater than $2 k-x-3+\Delta_{x}$, which in turn is $2 k-2 i_{1}+x-1+\Delta_{x}$ evaluated with $i_{1}=x+1$.
Case (d): Suppose that $s=1$.
In this scenario, we contribute 2 paths to $\Pi$. If $0 \in B$ then we contribute the path $b a^{k-j_{1}-1} d c^{x-j_{1}-1}$ to $\Pi$, or if $0 \notin B$ then we contribute the path $a^{k-j_{1}-1} d c^{x-j_{1}-1}$ to $\Pi$; either way, the length of the resulting path is $k-2 j_{1}+x-1+\Delta_{0}$. We also contribute the path $c^{j_{1}} b a^{k+j_{1}-x}$ to $\Pi$ of length $k+$ $2 j_{1}-x+1$. There is potentially another path when $j_{1}=1$ and $0 \in B$, namely $a^{k-1} d c^{x-1}$, but the length of this path is $k+x-1$ which is greater than $k+x-3+\Delta_{0}$, which in turn is $k-2 j_{1}+x-1+\Delta_{0}$ evaluated with $j_{1}=1$.
Case (e): Suppose that $r \geq 2$.
In this scenario, we contribute $r+1$ paths to $\Pi$. For each $l \in\{1,2, \ldots, r-1\}$, we contribute the path $a^{k-i_{l+1}-1}$ $d c^{k-i_{l+1}-1+i_{l}} b a^{i_{l}-x}$ to $\Pi$ of length $2 k-2 \delta_{l}-x$. If $x \in B$ then we contribute the path $a^{k-i_{1}-1} d c^{k-i_{1}-1+x} b$ to $\Pi$, or if $x \notin B$ then we contribute the path $a^{k-i_{1}-1} d c^{k-i_{1}-1+x}$ to $\Pi$; either way, the length of the path is $2 k-2 i_{1}+x-1+\Delta_{x}$. We also contribute the path $c^{i_{r}} b a^{i_{r}-x}$ to $\Pi$ of length $2 i_{r}-x+1$. (These last 2 paths mirror those constructed in Case (c).)
Case ( $f$ ): Suppose that $s \geq 2$.
In this scenario, we contribute $s+1$ paths to $\Pi$. For each $l \in\{1,2, \ldots, s-1\}$, we contribute the path $c^{j_{l+1}}$ $b a^{j_{l+1}+k-j_{l}-1} d a^{x-j_{l}-1}$ to $\Pi$ of length $k-2 \epsilon_{l}+x$. If $0 \in B$ then we contribute the path $b a^{k-j_{s}-1} d c^{x-j_{s}-1}$ to $\Pi$, or if $0 \notin B$ then we contribute the path $a^{k-j_{s}-1} d c^{x-j_{s}-1}$ to $\Pi$; either way, the length of the path is $k-2 j_{s}+x-1+\Delta_{0}$. We also contribute the path $c^{j_{1}} b a^{j_{1}+k-x}$ to $\Pi$ of length $k+2 j_{1}-x+1$. (These last 2 paths mirror those constructed in Case (c).)

Thus, our set $\Pi$ of potential shortest paths contains $r+$ $s+2$ paths (from which at least one is a shortest path).

### 6.2 Building our set of paths when $x=0$

Now we suppose that $x=0$. We proceed as we did above and build a set $\Pi$ of potential shortest paths. Let $B=\{i$ : $\left.0 \leq i \leq k-1, v_{i} \neq 0\right\}$. Suppose that $B \backslash\{0\}=\left\{i_{l}: 1 \leq l \leq\right.$ $r\}$ so that we have $0<i_{1}<i_{2}<\ldots<i_{r}<k$ (we might have that $r$ is 0 when the corresponding set is empty). If $r \geq 2$ then define $\delta_{l}=i_{l+1}-i_{l}$, for $l=1,2, \ldots, r-1$, with $\delta=\max \left\{\delta_{l}: l=1,2, \ldots, r-1\right\}$. We define $\Delta_{0}=1$, if $0 \in B$, and $\Delta_{0}=0$, if $0 \notin B$. We can visualize the resulting marked cycle $G_{n, k}(0,0)$ as in Fig. 4(ii). Again, the most obvious path to consider is $c^{k}$ (or $a^{k}$ ) which has length $k$. We begin by setting $\Pi=\left\{c^{k}\right\}$.
Case(a): Suppose that $r=0$.
In this scenario, we contribute the path $b$ of length 1 (note that in this case the node 0 is necessarily marked as we originally assumed that we started with distinct source and destination servers in the DCN DPillar $_{n, k}$ ).
Case(b): Suppose that $r=1$.
If $i_{1}=k-1$ then we contribute the path $b d$, if $0 \in B$, and the path $d$, if $0 \notin B$; either way, the path has length $1+\Delta_{0}$.

If $1=i_{1} \neq k-1$ then we contribute the path $c b a$ of length 3. If $1 \neq i_{1} \neq k-1$ then we contribute 2 paths. The first of these paths is the path $b a^{k-i_{1}-1} d c^{k-i_{1}-1}$, if $0 \in B$, and the path $a^{k-i_{1}-1} d c^{k-i_{1}-1}$, if $0 \notin B$; either way, this path has length $2 k-2 i_{1}-1+\Delta_{0}$. The second of these paths is the path $c^{i_{1}} b a^{i_{1}}$ of length $2 i_{1}+1$.
Case(c): Suppose that $r \geq 2$.
In this scenario, we contribute $r+1$ paths to $\Pi$. For each $l \in\{1,2, \ldots, r-1\}$, we contribute the path $a^{k-i_{l+1}-1}$ $d c^{k-i_{l+1}-1+i_{l}} b a^{i_{l}}$ to $\Pi$ of length $2 k-2 \delta_{l}$. If $0 \in B$ then we contribute the path $b a^{k-i_{1}-1} d c^{k-i_{1}-1}$ to $\Pi$, or if $0 \notin B$ then we contribute the path $a^{k-i_{1}-1} d c^{k-i_{1}-1}$ to $\Pi$; either way, this path has length $2 k-2 i_{1}-1+\Delta_{0}$. We also contribute the path $c^{i_{r}} b a^{i_{r}}$ to $\Pi$ of length $2 i_{r}+1$. (These last 2 paths mirror those constructed in Case (b).)

Thus, our set $\Pi$ of potential shortest paths contains at most $r+1$ paths (from which at least one is a shortest path).

### 6.3 Our algorithm

We now use our set $\Pi$ of potential shortest paths so as to find a shortest path or the length of a shortest path. Our algorithm, DPillarMin, for finding the length of a shortest path in $G_{n, k}(0, x)$ is as follows.

```
Algorithm: DPillarMin
calculate \(B\)
if \(0 \neq x\) then
        \(L=\min \{k+x, 2 k-x\}\)
        calculate \(r, s, \delta, \epsilon, \Delta_{0}\) and \(\Delta_{x}\)
        if \(r=0\) then \(L=\min \left\{L, x+\Delta_{x}\right\}\)
        if \(s=0\) then \(L=\min \left\{L, k-x+\Delta_{0}\right\}\)
        if \(r=1\) then
            \(L=\min \left\{L, 2 k-2 i_{1}+x-1+\Delta_{x}\right.\),
                \(\left.2 i_{1}-x+1\right\}\)
        if \(s=1\) then
            \(L=\min \left\{L, k-2 j_{1}+x-1+\Delta_{0}\right.\),
                                    \(\left.k+2 j_{1}-x+1\right\}\)
        if \(r \geq 2\) then
            calculate \(\delta \%\) only need consider max. \(\delta_{l}\)
            \(L=\min \{L, 2 k-2 \delta-x\),
                    \(\left.2 k-2 i_{1}+x-1+\Delta_{x}, 2 i_{r}-x+1\right\}\)
        if \(s \geq 2\) then
            calculate \(\epsilon\) \% only need consider max. \(\epsilon_{l}\)
            \(L=\min \left\{L, k-2 \epsilon+x, k-2 j_{s}+x-1+\Delta_{0}\right.\),
                                    \(\left.k+2 j_{1}-x+1\right\}\)
else
        calculate \(r\) and \(\delta\)
        if \(r=0\) then \(L=1\)
        if \(r=1\) then
        if \(i_{1}=k-1\) then \(L=1+\Delta_{0}\)
        if \(1=i_{1} \neq k-1\) then \(L=3\)
        if \(1 \neq i_{1} \neq k-1\) then
            \(L=\min \left\{2 k-2 i_{1}-1+\Delta_{0}, 2 i_{1}+1\right\}\)
        if \(r \geq 2\) then
        \(L=\min \left\{k, 2 k-2 \delta, 2 k-2 i_{1}-1+\Delta_{0}, 2 i_{r}+1\right\}\)
output \(L\)
```

If we wish to output a shortest path then all we do is apply the algorithm DPillarMin but remember which shortest path corresponds to the final value of $L$ and output this shortest path (note that there may be more than one
shortest path; exactly which path one obtains depends upon how one implements checking the paths of $\Pi$ ). The time complexity of both algorithms is clearly $O(k)$; that is, linear in the number of columns. Henceforth, we assume that the algorithm DPillarMin outputs an actual shortest path.

It should be clear (using Lemma 2) that the different considerations for $r$ and $s$ exhaust all possibilities and that consequently the set of paths $\Pi$ considered by DPillarMin is such as to contain a shortest path. Hence, DPillarMin clearly outputs a shortest path from some source node to some destination node in DPillar $_{n, k}$. In summary, we have the following result.
Theorem 1. Suppose that $n, k \geq 2$ so that $n$ is even. The algorithm DPillarMin takes as input any two servers of DPillar $_{n, k}$, a source and a destination, and outputs a shortest path from the source server to the destination server; moreover, it computes this path with time complexity $O(k)$.

We can confirm that we have undertaken experiments so as to empirically check, using a breadth-first search, the correctness of DPillarMin on DPillar ${ }_{n, k}$ when $n$ and $k$ are relatively small. We undertook our experiments using our in-house simulator INRFlow [8].

### 6.4 The diameter of DPillar

We also compute the diameter of the DCN DPillar $n, k$, i.e., the maximum of the lengths of shortest paths joining any two distinct servers. All that was stated in [18] was that the diameter of the DCN DPillar ${ }_{n, k}$ is a 'linear function of $k$ '.
Theorem 2. If $k \in\{2,3\}$ then the DCN DPillar ${ }_{n, k}$ has diameter $k$; and if $k \geq 4$ then the DCN DPillar ${ }_{n, k}$ has diameter $k+\left\lfloor\frac{k}{2}\right\rfloor-2$.

Proof: Let src and dst be nodes of the digraph DPillar $_{n, k}$. W.l.o.g. we may assume that the column-index of $s r c$ is 0 and that of $d s t$ is $x$. We work in $G_{n, k}(0, x)$ and in the context of the algorithm DPillarMin.

We first note that for any $x$, the worst-case scenario is when all nodes of $G_{n, k}(0, x)$ are marked as a shortest path in this scenario yields a path in any other scenario (though not necessarily a shortest one). Hence, in what follows we assume that all nodes are marked.

Case (a): $k \geq 5$.
We consider first the case when $x \neq 0$. There are 5 different scenarios for $(r, s):(0, \geq 2) ;(1, \geq 2):(\geq 2, \geq 2) ;(\geq 2,1)$; and ( $\geq 2, \geq 2$ ).

Consider first when $r \geq 2$ and $s \geq 2$. By consideration of the algorithm DPillarMin, where we have $\delta=1, i_{1}=x+1$, $i_{r}=k-1, \epsilon=1, j_{s}=1, j_{1}=x-1, \Delta_{0}=1$ and $\Delta_{x}=1$, we immediately see that $L=\min \{k+x, 2 k-x, 2 k-2-$ $x, 2 k-2(x+1)+x, 2(k-1)-x+1, k-2+x, k-2+$ $x, k+2(x-1)-x+1\}=\min \{k+x-2,2 k-x-2\}$. We are trying to find a value of $x$ that maximizes this minimum value. If $k+x-2 \geq 2 k-x-2$ then $x \geq \frac{k}{2}$; so, in this situation this minimum value is maximized when $x=\left\lceil\frac{k}{2}\right\rceil$ and this minimum value is then $2 k-\left\lceil\frac{k}{2}\right\rceil-2=k+\left\lfloor\frac{k}{2}\right\rfloor-2$. If $k+x-2 \leq 2 k-x-2$ then $x \leq \frac{k}{2}$; so, in this situation this minimum value is maximized when $x=\left\lfloor\frac{k}{2}\right\rfloor$ and this minimum value is then $k+\left\lfloor\frac{k}{2}\right\rfloor-2$.

In each of the other 4 cases for $(r, s)$, where $x \in\{0,1, k-$ $2, k-1\}$, we have that the length of the path produced by DPillarMin is trivially less than $k+\left\lfloor\frac{k}{2}\right\rfloor-2$ (simply look at the initial minimization $L=\min \{k+x, 2 k-x\})$. Also, when $x=0$ the length of the path produced is trivially less than $k+\left\lfloor\frac{k}{2}\right\rfloor-2$. Hence, when $k \geq 5$ the dameter is $k+\left\lfloor\frac{k}{2}\right\rfloor-2$. Case (b) $2 \leq k \leq 4$.
It is trivial to see by hand that the diameter in this case is $k$. The result follows.

## 7 EXPERIMENTAL WORK

Whilst we have obtained an optimal single-path routing algorithm for DPillar (optimal in that our algorithm always outputs a shortest path), as yet we have no idea as to how often the single-path routing algorithm DPillarSP is suboptimal and the savings to be made by employing our optimal algorithm. To undertake a precise analytical evaluation of this question would be challenging; consequently, we proceed to evaluate empirically the most important performance metrics, namely path length, aggregate bottleneck throughput and transmission latency.

We undertake our evaluation using simulation. We use our own flow-based framework INRFlow [8]. The reason we adopt a simulation-based evaluation is as follows. Future DCNs are intended to incorporate hundreds of thousands, if not millions, of processors. Consequently, building a testbed of servers (bearing in mind realistic access to resources) would only yield a DCN with a handful of servers and there would be no grounds for believing that any such evaluation would scale up. For instance, in order to build even the smallest meaningful DPillar $_{n, k}$ would require that $n$ should be at least 6 and $k$ at least 3 which would result in a test-bed with 81 servers which is beyond our means. Not surprisingly, simulation is the standard evaluation mechanism in the literature. Of the DCNs mentioned in this paper, FiConn, MCube, HCN, BCN, SWKautz, SWCube, and SWdBruijn were all evaluated using simulation with only DCell, BCube, and CamCube evaluated using testbeds, incorporating 20,16 and 27 servers, respectively. In addition, the aspects of symmetry present in DCNs ameliorates the likelihood of 'random' aspects of the network topology having an unexpected impact upon performance when compared with more unstructured networks. Finally, as regards our evaluation of communication latency in Section 7.3, we have incorporated realistic measurements of protocol stack, propagation, data transmission, and routing latencies into our analysis.

### 7.1 Path Length

In order to obtain some idea of the practical significance of our algorithm DPillarMin in terms of path length, we undertook the following experiment. For specific values of $n$ and $k$, we measured the average length of the paths obtained by employing both DPillarMin and DPillarSP for every possible source-destination pair (node-symmetry means that we can actually fix a unique source node) as well as the cumulative frequencies of the lengths of paths arising. We also measured the number of such occasions when the path derived by DPillarSP is longer than the path derived by

DPillarMin; that is, the number of times DPillarSP produced a non-minimal path. Our results are shown in Table 2 and Table 3. In Table 2, the columns denote (in order): the parameters $n$ and $k$ of the particular $\operatorname{DPillar}_{n, k}$ that we are working with; the number of servers in that $\operatorname{DPillar}_{n, k}$; the average path lengths obtained from inputting every possible source-destination pair to the algorithms DPillarMin and DPillarSP; the improvement in terms of average path length obtained by employing DPillarMin as a percentage of the average path length obtained by employing DPillarSP; and the percentage of source-destination pairs where the optimal path length is shorter than that obtained by employing DPillarSP. In Table 3, for each chosen $n$ and $k$ we show the cumulative frequencies of the lengths of paths obtained by employing the two algorithms DPillarSP and DPillarMin. These cumulative frequencies are shown as percentages of the total number of pairs of (not necessarily distinct) servers and are rounded to the nearest $0.1 \%$ (in order to save space we do not show data relating to all pairs of $n$ and $k$; this omitted data is as might be expected).

TABLE 2
Average path lengths: DPillarMin vs. DPillarSP.

| DPillar $_{n, k}$ |  | \# of <br> servers | av. pth. len. <br> DPillarMin | av. pth. len. <br> DPillarSP | av. length <br> improve. | non-min. <br> paths |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ | spry |  |  |  |  |
| 16 | 3 | 1,536 | 2.72 | 3.86 | $29 \%$ | $66 \%$ |
| 16 | 4 | 16,384 | 3.74 | 5.36 | $30 \%$ | $73 \%$ |
| 16 | 5 | 163,840 | 4.77 | 6.86 | $30 \%$ | $78 \%$ |
| 32 | 3 | 12,288 | 2.86 | 3.93 | $27 \%$ | $67 \%$ |
| 32 | 4 | 262,144 | 3.87 | 5.43 | $28 \%$ | $74 \%$ |
| 48 | 3 | 41,472 | 2.9 | 3.96 | $26 \%$ | $67 \%$ |
| 64 | 3 | 98,304 | 2.93 | 3.97 | $26 \%$ | $67 \%$ |
| 80 | 3 | 192,000 | 2.94 | 3.97 | $25 \%$ | $67 \%$ |
| 128 | 3 | 786,432 | 2.96 | 3.98 | $25 \%$ | $67 \%$ |

TABLE 3
Cumulative frequencies of path lengths: DPillarMin vs. DPillarSP.

| DPillar $_{n, k}$ |  | rout. alg. | path lengths |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| 16 | 3 | SP | 0.1 | 0.6 | 4.8 | 38.0 | 70.8 | 100 | - | - | - | - |
| 16 | 3 | Min | 0.1 | 2.0 | 26.2 | 100 | - | - | - | - | - | - |
| 16 | 5 | SP | 0.0 | 0.0 | 0.0 | 0.4 | 2.9 | 22.9 | 42.9 | 62.8 | 82.5 | 100 |
| 16 | 5 | Min | 0.0 | 0.0 | 0.3 | 2.5 | 20.3 | 100 | - | - | - | - |
| 32 | 4 | SP | 0.0 | 0.0 | 0.1 | 1.7 | 26.7 | 51.7 | 76.6 | 100 | - | - |
| 32 | 4 | Min | 0.0 | 0.0 | 0.7 | 12.0 | 100 | - | - | - | - | - |
| 80 | 3 | SP | 0.0 | 0.0 | 0.0 | 33.3 | 67.4 | 100 | - | - | - | - |
| 80 | 3 | Min | 0.0 | 0.1 | 5.7 | 100 | - | - | - | - | - | - |
| 128 | 3 | SP | 0.0 | 0.0 | 0.5 | 33.9 | 67.2 | 100 | - | - | - | - |
| 128 | 3 | Min | 0.0 | 0.0 | 3.6 | 100 | - | - | - | - | - | - |

As can be seen from Table 2, using the algorithm DPillarMin yields a very significant improvement of between $25 \%$ and $30 \%$ in terms of the average path length. It is also worth highlighting that the number of non-optimal paths generated by DPillarSP is between $66 \%$ and $78 \%$ and increases significantly with $k$. Note that a reduction in path length does not only mean that the latency experienced by network traffic should be reduced (more on this later) but also that each flow will require less aggregate bandwidth to be transmitted and so the overall throughput of the network should also increase. As can be seen from Table 3, in each of the chosen scenarios DPillarMin yields significant cumulative improvements in path length. For example, when
$n=16$ and $k=5$, with DPillarSP only $22.9 \%$ of all paths have length at most 5 whereas with DPillarMin all paths do. We measure next the aggregate bottleneck throughput obtained through using the two different routing algorithms.

### 7.2 Aggregate Bottleneck Throughput

The aggregate bottleneck throughput, or simply $A B T$, is a metric introduced in [13] in order to estimate the throughput performance of a DCN. The reasoning behind ABT is that the performance of an all-to-all operation is limited by its slowest flow, i.e., the flow with the lowest throughput. The ABT is defined as the total number of flows times the throughput of the bottleneck flow, i.e., the link sustaining the most flows. In our experiments the bottleneck flow is determined experimentally using actual routing functions within our framework INRFlow. We assume an all-to-all communication pattern, so that there are $N(N-1)$ flows, and a bandwidth of 1 unit per directional link, where $N$ is the total number of servers. Since datacenters are most commonly used as stream processing platforms and are therefore bandwidth limited, this is an extremely relevant performance metric.

TABLE 4
Aggregate bottleneck throughput: DPillarMin vs. DPillarSP.

| DPillar $_{n, k}$ |  | $\begin{gathered} \text { \# of } \\ \text { servers } \end{gathered}$ | $\begin{gathered} \text { ABT } \\ \text { DPillarMin } \end{gathered}$ | $\begin{gathered} \text { ABT } \\ \text { DPillarSP } \end{gathered}$ | ABT improve. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ |  |  |  |  |
| 16 | 3 | 1,536 | 757.16 | 397.93 | 90\% |
| 16 | 4 | 16,384 | 6077.88 | 3056.72 | 99\% |
| 16 | 5 | 163,840 | 52953.26 | 23883.38 | 122\% |
| 32 | 3 | 12,288 | 5651.85 | 3126.72 | 81\% |
| 32 | 4 | 262,144 | 92102.69 | 48276.98 | 91\% |
| 48 | 3 | 41,472 | 18634.09 | 10472.73 | 78\% |
| 64 | 3 | 98,304 | 43653.56 | 24761.71 | 76\% |
| 80 | 3 | 192,000 | 84659.97 | 48362.72 | 75\% |
| 128 | 3 | 786,432 | 343097.99 | 197595.98 | 74\% |

Table 4 shows that DPillarMin is capable of offering much higher ABT than DPillarSP in all cases, with improvements of between $74 \%$ and $122 \%$ (the right-most is the improvement in ABT by using DPillarMin rather than DPillarSP divided by the ABT of DPillarSP). Informally, this means that bandwidth-limited applications such as, for example, Big Data analytics, running over a DCN using DPillarMin might be able to achieve nearly twice as much computational throughput as the same application running over a DCN using DPillarSP. This can provide significant savings in terms of running and maintenance costs associated with each application and thus will result in more competitive pricing for tenants. Furthermore, as applications run faster it will be possible to run more applications in a given time frame and so there is a huge potential for increasing the overall profit of the datacenter.

### 7.3 Communication Latency

Not all datacenter applications are bandwidth sensitive; indeed, many of them are more sensitive to latency, such as real-time operations or, more generally, any application interfacing with users. For this reason, it is important that we look at the transmission latency that we can expect from DPillarSP and DPillarMin. As there is no server-centric

DCN framework available that will enable us to perform testbench experiments (building one ourselves is not possible), we measure the latencies imposed by the different steps of the transmission, namely within the protocol stack, propagation latency, data transmission latency and routing at the servers, so as to obtain an estimate of how changing the routing algorithm would affect the overall performance. Our experiments were as follows.

- We measured the round trip time of both an empty frame (28 bytes for the headers) and a full frame (1,500 bytes, including the headers) sent to localhost so as to measure the latency imposed by going up and down the protocol stack. In both cases, the stack latency, $L_{s}$, was found to be $10 \mu$ s.
- We measured the round trip of an empty frame sent to a neighbouring server connected to the same Gigabit Ethernet switch. This was found to be $64 \mu \mathrm{~s}$; thus we can compute the one-way propagation latency, $L_{p}$, i.e., the time to go through the links and the switch, by dividing by two and removing the stack latency. This yields a propagation latency of $22 \mu \mathrm{~s}$.
- We measured the round trip time of a full-frame sent to the same neighbouring server. This was found to be $140 \mu \mathrm{~s}$; thus the one-way data transfer latency, $L_{d}$, can be calculated similarly by dividing by two and subtracting the stack latency as well as the propagation latency. This results in a data transfer latency of $38 \mu$ s (roughly 26 ns per byte).
- We measured the average routing latency, $L_{r}$, for both algorithms for a selection of the configurations above (those with between 8 and 40 thousand servers). Note that the code for the two algorithms is not optimised and that it includes some overheads imposed by our framework; so the running times for the algorithms can be considered as a worst case.
Consequently, for both DPillarSP and DPillarMin we obtain the per-hop latency $L_{h o p}=L_{s}+L_{p}+L_{d}+L_{r}$ along with the server-to-server latency $L_{\text {total }}=L_{\text {hop }} \times \bar{d}$, where $d$ is the average path length.

All the measurements were carried out under low load conditions in the same server: a 32-core AMD Opteron 6220 with 256 Gbytes of RAM and running an Ubuntu 14.04.1 SMP OS. Round-trip time measurements were carried out with the ping utility. The server and its neighbour are located within the same rack and are connected with short (at most 1 metre) electrical wires to a 24-port 1-Gbit Ethernet switch which does not support jumbo frames (we do not have 10-Gbit Ethernet hardware available). Note that the use of short wires is the best case for the propagation delay, as in a real scale-out datacenter wires will be much longer and so propagation delays will be larger (even if fibre connections are used [21]). Similarly, the measured latency of the protocol stack does not take into account any extra management/control inherent to the server-centric nature of the system; so, again, it can be considered a best case scenario. Increasing these delays will dilute the effects of the average routing latency in the total latency even more than in our preliminary estimate. (We remind the reader that a DPillar datacenter would be constructed out of COTS hardware and so our experimental set-up is reasonable).

TABLE 5
Average routing latencies: DPillarMin vs. DPillarSP.

| DPillar $_{n, k}$ |  | \# of <br> servers | $L_{r}$ <br> DPillarMin | $L_{r}$ <br> DPillarSP | $L_{r}$ <br> increase |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ | 16,384 | $5.964 \mu \mathrm{~s}$ | $1.349 \mu \mathrm{~s}$ | $442 \%$ |
| 16 | 4 | 12,288 | $3.325 \mu \mathrm{~s}$ | $0.960 \mu \mathrm{~s}$ | $346 \%$ |
| 32 | 3 | 12,28 |  |  |  |
| 48 | 3 | 41,472 | $3.328 \mu \mathrm{~s}$ | $0.859 \mu \mathrm{~s}$ | $387 \%$ |

TABLE 6
Per-hop and overall latencies: DPillarMin vs. DPillarSP.

| $\mathrm{DPillar}_{n, k}$ |  | $\begin{gathered} \hline L_{\text {hop }} \\ \text { DPillarMin } \end{gathered}$ | $\begin{gathered} L_{h o p} \\ \text { DPillarSP } \end{gathered}$ | $\begin{aligned} & L_{\text {hop }} \\ & \text { decl. } \end{aligned}$ | $\begin{gathered} L_{\text {total }} \\ \text { DPillarMin } \end{gathered}$ | $\begin{array}{c\|} \hline L_{\text {total }} \\ \text { DPillarSP } \end{array}$ | $\begin{gathered} L_{\text {total }} \\ \text { improve. } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ |  |  |  |  |  |  |
| 16 | 4 | 76.0 | 71.3 | 6\% | 284.1 | 382.2 | 26\% |
| 32 | 3 | 73.3 | 71.0 | 3\% | 209.5 | 279.1 | 25\% |
| 48 | 3 | 73.3 | 70.9 | 3\% | 212.9 | 280.4 | 24\% |

Table 5 shows the average routing latency $L_{r}$ for DPillarSP and DPillarMin, along with the increase in the average routing latency when using DPillarMin as opposed to DPillarSP (shown as a percentage of the average routing latency when using DPillarSP). Table 6 details the perhop and server-to-server latencies for both DPillarSP and DPillarMin. The very slight increase in the per-hop latency when using DPillarMin as opposed to DPillarSP is shown, as is the improvement in the server-to-server latency when using DPillarMin as opposed to DPillarSP (both are shown as a percentage of the corresponding value for DPillarSP).

It can be seen that the average routing latency for DPillarMin is between 3.4 and 4.5 times slower than that for DPillarSP, but of the order of only a few microseconds which is well below the other latencies measured in our experimental set-up. In consequence, the per-hop latencies of DPillarSP and DPillarMin are very similar; however, there is a significant reduction in server-to-server latency for DPillarMin over DPillarSP (between $24 \%$ and $26 \%$ ) when the reductions in average path-length are factored in.

Informal analytical modelling using the values above as a reference suggests that if jumbo frames were used then there would be negligible increase in per-hop latency so as to yield a significant overall improvement in server-toserver latency of up to $30 \%$. A similar analytic analysis using 10-Gbit Ethernet hardware suggests that while per-hop latency can increase by up to $12.5 \%$ when using DPillarMin as opposed to DPillarSP, the overall server-to-server latency improvement will still be in the range 19-23\%. Finally, the estimates with jumbo frame-enabled 10-Gbit Ethernet yield very similar results as the ones presented here. Full details are available in the supplemental material.

While the latency analysis performed here is rather simplistic and only covers zero-load latencies, our objective is not to provide highly accurate latency figures but to show that the impact of the routing algorithm DPillarMin on latency is insignificant, particularly when compared with the huge gains in terms of path length and throughput. Note that due to its less favourable throughput, the use of DPillarSP would lead to additional queuing in the servers which would in have a detrimental impact upon performance.

### 7.4 FiConn and DCell

There does not exist a proper comparative experimental evaluation of the numerous (dual-port) server-centric DCNs in the literature; comparative evaluations that have been undertaken so far are somewhat ad hoc, both in terms of the DCNs compared and the performance metrics evaluated. Of course, an extensive comparative evaluation will be a significant body of work and is well beyond the scope of this paper (where our focus has been on improving routing in DPillar). Moreover, we are fully aware that there are many different metrics for DCN evaluation, such as those relating to fault-tolerance, bisection bandwidth, load balancing, latency, throughput, scalability, and so on, and that the eventual success of a DCN will usually depend on its capacity to cope well across a range of such metrics. Nevertheless, we end our experimentation by including an interesting prelude to a fuller analysis of routing within server-centric DCNs: we briefly compare routing in DPillar with routing in the two DCNs DCell and FiConn.

We have chosen FiConn and DCell as they are widely regarded as benchmark server-centric DCNs. Like DPillar, FiConn is dual-port, whereas DCell is such that the number of server NIC ports is variable. The reader is referred to [16] and [12] for definitions of FiConn and DCell, respectively, but just as with DPillar, FiConn and DCell are families of DCNs parameterized by $n$, the number of switch-ports in a switch, and $k$, the depth of the recursive construction (actually, a server in DCell $n_{n, k}$ has $k+1$ NIC ports).

In Table 7, we have displayed the average path length and the ABT of (various instantiations of) DPillar with the routing algorithm DPillarMin, FiConn with the routing algorithm TOR (from [16]), and DCell with the routing algorithm DCellRouting (from [12]); we have chosen these instantiations so that the different DCNs can be compared on three different bases, namely them all having roughly $24 \mathrm{~K}, 117 \mathrm{~K}$ and 170 K servers, respectively (so, we have normalized against the number of servers). As usual, the data in Table 7 has been derived using our tool INRFlow.

TABLE 7
Average path lengths and ABT: DPillarMin vs. FiConn vs. DCell

| DPillar $_{\text {, }}$, |  | $\begin{gathered} \text { \# of } \\ \text { servers } \end{gathered}$ | av. pth. len. DPillarMin | ABTDPillarMin |
| :---: | :---: | :---: | :---: | :---: |
| $n$ | $k$ |  |  |  |
| 12 | 5 | 38,880 | 4.68 | 12805.63 |
| 16 | 5 | 163,840 | 4.77 | 52952.94 |
| 18 | 4 | 26,244 | 3.77 | 9616.46 |
| 26 | 4 | 114,244 | 3.84 | 40637.47 |
| 48 | 3 | 41,472 | 2.90 | 18633.64 |
| 64 | 3 | 98,304 | 2.93 | 43653.12 |
| FiConn $_{n, k}$ |  | $\begin{gathered} \text { \# of } \\ \text { servers } \end{gathered}$ | $\begin{aligned} & \text { av. pth. len. } \\ & \text { TOR } \end{aligned}$ | ABT |
| $n$ | $k$ |  |  | TOR |
| 10 | 3 | 116,160 | 12.97 | 13026.18 |
| 24 | 2 | 24,648 | 6.56 | 5005.47 |
| 36 | 2 | 117,648 | 6.71 | 23694.75 |
| 40 | 2 | 177,240 | 6.74 | 35650.59 |
| $\mathrm{DCell}_{n, k}$ |  | $\begin{gathered} \text { \# of } \\ \text { servers } \end{gathered}$ | av. pth. len. DCellRouting | ABT |
| $n$ | $k$ |  |  | DCellRouting |
| 3 | 3 | 24,492 | 10.18 | 5475.43 |
| 4 | 3 | 176,820 | 11.29 | 33582.97 |
| 12 | 2 | 24,492 | 6.34 | 6968.73 |
| 18 | 2 | 117,306 | 6.56 | 31937.10 |

As can readily be seen, DPillar compares extremely well with FiConn and DCell in terms of both average path length
and ABT (even though DCell would appear to have a natural advantage over the other two DCNs as it involves servers with more than two NIC ports).

We end with some comments on our very brief comparative evaluation. First, we reiterate that what is really required is an extensive evaluation involving a range of server-centric DCNs across a range of performance metrics. Second, we observe (in comparison with data in Tables 2 and 4) that the improvements made in using DPillarMin in the DCN DPillar, rather than DPillarSP, have resulted in moving DPillar from only comparable with DCell and FiConn to better than DCell and FiConn (at least in terms of average paths length and $A B T$ ). Third, there is no reason why a closer combinatorial scrutiny of both DCell and FiConn might not result in new and better routing algorithms than DCellRouting and TOR, respectively (just as we have improved routing within DPillar within this paper).

## 8 Conclusions

In this paper we have: developed an optimal and practical single-path routing algorithm DPillarMin for the DCN DPillar; shown that DPillar is a Cayley graph, and so node-symmetric; and provided an exact formulation of the diameter of DPillar. Our experimental results show not only that DPillarMin can significantly reduce the average path length of network traffic (up to $30 \%$ ), but also that this reduction results in a significant increase (more than $2 \times$ ) in terms of overall network throughput. Finally we showed that the computational overhead of DPillarMin is negligible and will barely affect the processing of network traffic: less than a $6 \%$ increase in per-hop latency, which is more than compensated by the reductions in path length.

In summary, we can claim that our proposed routing algorithm can unleash a massively improved performance to the DPillar DCN. Furthermore, we feel that there are other areas where efficiency gains might be made; in particular, with regard to multi-path routing. Of course, we reaffirm our statement above that what also needs to be undertaken is an holistic comparison of different (dual-port) servercentric DCNs, with their different routing algorithms and across a wide range of performance metrics, along with the combinatorial study of DCNs different to DPillar with a view to improving their routing algorithms.

## Acknowledgements

All of the authors are supported by the EPSRC grants EP/K015680/1 and EP/K015699/1 'Interconnection Networks: Practice unites with Theory (INPUT)'. Dr. Javier Navaridas is supported by the European Union's Horizon 2020 programme under grant agreement No. 671553 ‘ExaNeSt '. We are also grateful for the insightful comments of the reviewers which helped to significantly improve this paper.

## References

[1] D. Abts, M.R. Marty, P.M. Wells, P. Klausler and H. Liu, "Energy Proportional Datacenter Networks", Proc. of 37th Ann. Int. Symp. on Computer Architecture, 2010, pp. 338-347.
[2] H. Abu-Libdeh, P. Costa, A. Rowstron, G. OShea and A. Donnelly, "Symbiotic Routing in Future Data Centers", SIGCOMM Computer Communication Review, vol. 40, no. 4, 2010, pp. 51-62.
[3] J.H. Ahn, N. Binkert, A. Davis, M. McLaren and R.S. Schreiber, "HyperX: Topology, Routing, and Packaging of Efficient Largescale Networks", Proc. of Conf. on High Performance Computing Networking, Storage and Analysis, 2009, article no. 41.
[4] S. B. Akers and B. Krishnamurthy, "A Group-theoretic Model for Symmetric Interconnection Networks", IEEE Transactions on Computers, vol. 38, no. 4, 1989, pp. 555-566.
[5] M. Al-Fares, A. Loukissas and A. Vahdat, "A Scalable, Commodity Data Center Network Architecture", SIGCOMM Computer Communication Review, vol. 38, no. 4, 2008, pp. 63-74.
[6] C. Camarero, C. Martinez and R. Beivide, "Lattice Graphs for High-scale Interconnection Topologies", IEEE Transactions on Parallel and Distributed Systems, vol. 26, no. 9, 2015, pp. 2506-2519.
[7] W.J. Dally and B.P. Towles, Principles and Practices of Interconnection Networks, Morgan Kaufmann, 2004.
[8] A. Erickson, A. Kiasari, J. Pascual Saiz, J. Navaridas and I.A. Stewart, "Interconnection Networks Research Flow Evaluation Framework (INRFlow)", Feb. 16, 2016. [Software]. Available: https://bitbucket.org/alejandroerickson/inrflow. [Accessed: Feb. 22, 2016].
[9] A.W.-C. Fu and S.-C. Chau. "Cyclic-cubes: A New Family of Interconnection Networks of Even Fixed-degrees", IEEE Transactions on Parallel and Distributed Systems, vol. 9, no. 12, 1998, pp. 1253-1268.
[10] A. Greenberg, J.R. Hamilton, N. Jain, S. Kandula, C. Kim, P. Lahiri, D.A. Maltz, P. Patel and S. Sengupta, "VL2: A Scalable and Flexible Data Center Network", SIGCOMM Computer Communication Review, vol. 39, no. 4, pp. 51-62, 2009.
[11] D. Guo, T. Chen, D. Li, M. Li, Y. Liu and G. Chen, "Expandible and Cost-effective Network Structures for Data Centers using Dualport Servers", IEEE Transactions on Computers, vol. 62, no. 7, 2013, pp. 1303-1317.
[12] C. Guo, H. Wu, K. Tan, L. Shi, Y. Zhang and S. Lu, "DCell: A Scalable and Fault-tolerant Network Structure for Data Centers", SIGCOMM Computer Communication Review, vol. 38, no. 4, 2008, pp. 75-86.
[13] C. Guo, G. Lu, D. Li, H. Wu, X. Zhang, Y. Shi, C. Tian, Y. Zhang and S. Lu, "BCube: A High Performance, Server-centric Network Architecture for Modular Data Centers", SIGCOMM Computer Communication Review, vol. 39, no. 4, 2009, pp. 63-74.
[14] B. Heller, S. Seetharaman, P. Mahadevan, Y. Yiakoumis, P. Sharma, S. Banerjee and N. McKeown, "ElasticTree: Saving Energy in Data Center Networks", Proc. 7th USENIX Conf. on Networked Systems Design and Implementation", 2006, pp. 249-264.
[15] F.T. Leighton, Introduction to Parallel Algorithms and Architectures: Arrays. Trees. Hypercubes, Morgan Kaufmann, 1992.
[16] D. Li, C. Guo, H.Wu, K. Tan, Y. Zhang and S. Lu, "FiConn: Using Backup Port for Server Interconnection in Data Centers", Proc. of INFOCOM, 2009, pp. 2276-2285.
[17] D. Li and J. Wu, "On Data Center Network Architectures for Interconnecting Dual-port Servers", IEEE Transactions on Computers, vol. 64, no. 11, 2015, pp. 3210-3222.
[18] Y. Liao, J. Yin, D. Yin and L. Gao, "DPillar: Dual-port Server Interconnection Network for Large Scale Data Centers", Computer Networks, vol. 56, no. 8, 2012, pp. 2132-2147.
[19] Y. Liu, J.K. Muppala, M. Veeraraghavan, D. Lin and J. Katz, Data Centre Networks: Topologies, Architectures and Fault-Tolerance Characteristics, Springer, 2013.
[20] R.N. Mysore, A. Pamboris, N. Farrington, N. Huang, P. Miri, S. Radhakrishnan, V. Subramanya and A. Vahdat, "Portland: A Scalable Fault-tolerant Layer 2 Data Center Network Fabric", SIGCOMM Computer Communication Review, vol. 39, no. 4, 2009, pp. 39-50.
[21] L.L. Peterson and B.S. Davie, Computer Networks, Fifth Edition: A Systems Approach, Morgan Kaufmann, 2011.
[22] J.-Y. Shin, E.G. Sirer, H. Weatherspoon and D. Kirovski, "On the Feasibility of Completely Wireless Datacenters", IEEE/ACM Transactions on Networking, vol. 21, no. 5, 2013, pp. 1666-1679.
[23] C. Wang, C. Wang, Y. Yuan and Y. Wei, "MCube: A High Performance and Fault-tolerant Network Architecture for Data Centers", Proc. Int. Conf. on Computer Design and Applications, vol. 5, 2010, pp. V5-423-V5-427.
[24] W. Xiao and B. Parhami, "A Group Construction Method with Applications to Deriving Pruned Interconnection Networks", IEEE Transactions on Parallel and Distributed Systems, vol. 18, no. 5, 2007, pp. 637-643.


Alejandro Erickson is a Postdoctoral Research Associate at Durham University, UK, where he does research on various topological aspects of interconnection networks, with an emphasis on applications in data centre networks. He received his Ph.D. in Computer Science from the University of Victoria, Canada, in 2013, and his M.Math in Combinatorics and Optimization from the University of Waterloo, Canada, in 2008. Dr. Erickson has published in a broad range of topics, including data centre networks, computational geometry, graph and matroid theory, enumerative combinatorics, education, and mathematical art.


Abbas Eslami Kiasari received the BSc degree in Electrical Engineering from the Ferdowsi University of Mashhad, Iran, in 2003, the MSc degree in Computer Engineering from the Sharif University of Technology, Iran, in 2005, and the PhD degree in Electronic and Computer Systems from KTH Royal Institute of Technology, Sweden, in 2013. He is currently a Postdoctoral Research Associate at The University of Manchester, UK, where he does research on various aspects of interconnection networks. Dr. Kiasari received a guest scholarship from the Swedish Institute (SI) while a researcher at KTH in 2009. He served several journals and conferences as a referee, including IEEE Transactions on Parallel and Distributed Systems (TPDS), IEEE Transactions on Computers (TC), IEEE Transactions on Computer-Aided Design of Integrated Circuit and Systems (TCAD) and ACM Transactions on Embedded Computing Systems (TECS). His research interests include performance evaluation, interconnection networks, computer architecture, and queueing theory.


Javier Navaridas is a Lecturer in Computer Architecture in the Advanced Processors Technologies group at the University of Manchester, UK. He obtained his PhD in Computer Engineering in 2009 from the University of the Basque Country which was rewarded with an Extraordinary Doctorate Award (top 5\% theses). During that period he held a pre-doctoral and a postdoctoral grant with the Intelligent Systems Group led by Prof. J.A. Lozano. He joined the University of Manchester with a prestigious Newton International Fellowship in 2010. His research interests include interconnection networks, parallel and distributed systems, performance evaluation, simulation and modelling, computer architecture and engineering. Javier is currently leading the workpackage on interconnects of the ExaNeSt H2020 project, which aims to develop a novel architecture for Exascale computing systems.

lain A. Stewart received the MA in Mathematics from Oxford University, UK, in 1983 and the PhD in Mathematics from the University of London, UK, in 1986. He has been Professor of Computer Science at Durham University, UK, since 2002; he was formerly Professor of Computer Science at the University of Leicester, UK, from 19962002 (he has been Head of Department at both Leicester and Durham). His current research interests lie in interconnection networks for parallel and distributed computing but he has published in computational complexity, logic and finite model theory, algorithmic graph theory, theoretical aspects of artificial intelligence, and GPGPU computing.

# Supplemental Material for "An Optimal Single-Path Routing Algorithm in the Datacenter Network DPillar" 

Alejandro Erickson, Abbas Kiasari, Javier Navaridas and lain A. Stewart

## PROOF OF LEMMA 1

Lemma 1. The digraph DPillar ${ }_{n, k}$ is a Cayley graph.
Proof: We first define a set of elements and then a notion of multiplication on this set. Let $t_{0}, t_{1}, \ldots, t_{k-1}$ be distinct symbols and for each $i \in\{0,1, \ldots, k-1\}$, define

$$
\begin{aligned}
G_{i}= & \left\{t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}}\right. \\
& \left.: 0 \leq p_{j} \leq \frac{n}{2}-1, \text { for all } j \in\{0,1, \ldots, k-1\}\right\} .
\end{aligned}
$$

Define $G_{k}^{n}=\cup_{i=0}^{k-1} G_{i}$; so, note that $\left|G_{k}^{n}\right|=k\left(\frac{n}{2}\right)^{k}$. Define

$$
\begin{gathered}
S_{a}=\left\{t_{k-1}^{q} t_{0}^{0} t_{1}^{0} \ldots t_{k-2}^{0}: 0 \leq q \leq \frac{n}{2}-1\right\} ; \\
S_{b}=\left\{t_{0}^{q} t_{1}^{0} \ldots t_{k-1}^{0}: 0 \leq q \leq \frac{n}{2}-1\right\} ; \\
S_{c}=\left\{t_{1}^{0} t_{1}^{0} \ldots t_{k-1}^{0} t_{0}^{q}: 0 \leq q \leq \frac{n}{2}-1\right\} ; \\
S_{d}=\left\{t_{0}^{0} t_{1}^{0} \ldots t_{k-1}^{q}: 0 \leq q \leq \frac{n}{2}-1\right\} .
\end{gathered}
$$

Define a right-multiplication $\circ$ of the elements of $G_{k}^{n}$ by the elements of $S=S_{a} \cup S_{b} \cup S_{c} \cup S_{d}$ as follows:

$$
\begin{aligned}
& t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{k-1}^{q} t_{0}^{0} t_{1}^{0} \ldots t_{k-2}^{0} \\
& \quad=t_{i-1}^{p_{i-1}+q} t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-2}^{p_{i-2}} \\
& t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{0}^{q} t_{1}^{0} \ldots t_{k-1}^{0} \\
& \quad=t_{i}^{p_{i}+q_{1}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \\
& t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{1}^{0} t_{2}^{0} \ldots t_{k-1}^{0} t_{0}^{q} \\
& \quad=t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} t_{i}^{p_{i}+q} \\
& t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{0}^{0} t_{1}^{0} \ldots t_{k-1}^{q} \\
& \quad=t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}+q}
\end{aligned}
$$

with $i, p_{0}, p_{1}, \ldots, p_{k-1}$ and $q$ as appropriate and with addition on superscripts modulo $\frac{n}{2}$.

We now extend the multiplication we have just defined so that we make $G_{n}^{k}$ into a group with a generating set $S_{0}$ that is a subset of $S$. Let $\langle S\rangle$ be the set of all elements

- Abbas Kiasari and Javier Navaridas are with the School of Computer Science, University of Manchester, Oxford Road, Manchester M13 9PL, U.K.

E-mail: \{abbas.kiasari,javier.navaridas\}@manchester.ac.uk

- Alejandro Erickson and Iain Stewart are with the School of Engineering and Computing Sciences, Durham University, South Road, Durham DH1 3LE, U.K.
E-mail: $\{$ alejandro.erickson,i.a.stewart\}@durham.ac.uk
generated by right-multiplication by elements of $S$. It is trivial to show that this set is $G_{k}^{n}$; that is,

$$
\begin{aligned}
G_{k}^{n} & =\left\{\left(\left(\ldots\left(\left(s_{1} \circ s_{2}\right) \circ s_{3}\right) \ldots\right) \circ s_{i}\right)\right. \\
& \left.: i \geq 1, s_{j} \in S \text { for } j=1,2, \ldots, i\right\} .
\end{aligned}
$$

Extend the multiplication $\circ$ to $G_{k}^{n}$ by defining that no matter how a multiplication of elements of $S$ is bracketed, e.g., as $\left(s_{1} \circ\left(s_{2} \circ s_{3}\right)\right) \circ\left(s_{4} \circ s_{5}\right)$, the product is defined as that obtained by multiplying on the right, e.g., as $\left(\left(\left(s_{1} \circ s_{2}\right) \circ\right.\right.$ $\left.\left.\left.s_{3}\right) \circ s_{4}\right) \circ s_{5}\right)$. Consequently, we have now equipped $G_{k}^{n}$ with an associative multiplication $\circ$. It is trivial to check that there is an identity in $G_{k}^{n}$ (w.r.t. ०; it is $t_{0}^{0} t_{1}^{0} \ldots t_{k-1}^{0}$ ) and also that every element of $G_{k}^{n}$ has an inverse; furthermore, every element of $S$ has an inverse in $S$. Hence, $G_{k}^{n}$ is a group generated by the $2 n-2$ elements of $S_{0}=S \backslash\left\{t_{0}^{0} t_{1}^{0} \ldots t_{k-1}^{0}\right\}$ and $S_{0}$ is closed under inverses. Let $G_{k}^{n}(S)$ be the Cayley graph of $G_{k}^{n}$ w.r.t. the generating set $S_{0}$.

Finally, we prove that the Cayley graph $G_{k}^{n}\left(S_{0}\right)$ is exactly the same as DPillar $_{n, k}$. In what follows, by DPillar ${ }_{n, k}$ we mean the digraph DPillar $_{n, k}$. Define the mapping $\varphi$ from the nodes of $G_{k}^{n}\left(S_{0}\right)$ to the nodes of DPillar $_{n, k}$ by

$$
\varphi\left(t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}}\right)=\left(i, p_{k-1} p_{k-2} \ldots p_{0}\right)
$$

where $i, p_{0}, p_{1}, \ldots, p_{k-1}$ are as appropriate. As

$$
\begin{gathered}
t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{k-1}^{q} t_{0}^{0} t_{1}^{0} \ldots t_{k-2}^{0} \\
=t_{i-1}^{p_{i-1}+q} t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-2}^{p_{i-2}}
\end{gathered}
$$

this describes the a-edge of DPillar $_{n, k}$ from $\left(i, p_{k-1} p_{k-2} \ldots\right.$ $p_{0}$ ) to ( $\left.i-1, p_{k-1} p_{k-2} \ldots p_{i}\left(p_{i-1}+q\right) p_{i-2} \ldots p_{0}\right)$. As

$$
\begin{gathered}
t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{0}^{q} t_{1}^{0} \ldots t_{k-1}^{0} \\
=t_{i}^{p_{i}+q} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}}
\end{gathered}
$$

this describes the b-edge of DPillar ${ }_{n, k}$ from $\left(i, p_{k-1} p_{k-2} \ldots\right.$ $p_{0}$ ) to ( $\left.i, p_{k-1} p_{k-2} \ldots p_{i+1}\left(p_{i}+q\right) p_{i-1} \ldots p_{0}\right)$ when $q>0$. As

$$
\begin{gathered}
t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{1}^{0} t_{1}^{0} \ldots t_{k-1}^{0} t_{0}^{q} \\
\quad=t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} t_{i}^{p_{i}+q}
\end{gathered}
$$

this describes the c-edge of DPillar ${ }_{n, k}$ from $\left(i, p_{k-1} p_{k-2} \ldots\right.$ $\left.p_{0}\right)$ to $\left(i+1, p_{k-1} p_{k-2} \ldots p_{i+1}\left(p_{i}+q\right) p_{i-1} \ldots p_{0}\right)$. As

$$
\begin{gathered}
t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}} \circ t_{0}^{0} t_{1}^{0} \ldots t_{k-1}^{q} \\
=t_{i}^{p_{i}} t_{i+1}^{p_{i+1}} \ldots t_{k-1}^{p_{k-1}} t_{0}^{p_{0}} t_{1}^{p_{1}} \ldots t_{i-1}^{p_{i-1}+q}
\end{gathered}
$$

this describes the d-edge of DPillar $_{n, k}$ from $\left(i, p_{k-1} p_{k-2} \ldots\right.$ $p_{0}$ ) to ( $\left.i, p_{k-1} p_{k-2} \ldots p_{i}\left(p_{i-1}+q\right) p_{i-2} \ldots p_{0}\right)$ when $q>0$. Consequently, $\varphi$ is an isomorphism of $G_{k}^{n}\left(S_{0}\right)$ to DPillar ${ }_{n, k}$ and the result follows.

## Modelling other network configurations: JUMBO FRAMES AND $\mathbf{1 0 - G B I T}$ ETHERNET

While we were unable to carry out experiments with more advanced datacenter networking equipment, such as switches capable of dealing with jumbo frames or 10-Gbit Ethernet NICs or switches, it should be possible to extrapolate their performance from the statistics we captured from our experimental set-up. Having estimates for the latency expected from these configurations is useful as they can be seen as pathological cases in relation to the performance gains inherent to DPillarMin. Using jumbo frames (that is, frames with a payload of 9,000 bytes $^{1}$, rather than the standard 1,472 bytes) means that any routing algorithm is executed less often and that the protocol- and propagationinduced delays become less substantial when compared with the data transmission delay. In our case, this means that the overhead due to using DPillarMin becomes less significant; consequently, the overall delay will be even better than with standard frames. On the other hand, the higher bandwidth of 10 -Gbit ( $10 \times$ ) equipment means that the per-hop delay will be reduced which, in turn, means that the time taken to undertake routing computations may become dominant. However, according to our assessment this will not be the case.

We now explain how we extrapolate the per-hop latency and server-to-server latency for these technologies from the latencies we measured empirically in Section 7.3 (that is, $L_{s}$, $L_{p}, L_{d}$ and $L_{r}$ ).

- The stack latency, $L_{s}$, should not change as it is due to software executions at the server-side.
- The propagation latency, $L_{p}$, would barely be affected by the bandwidth of the links, or the size of the frames, but would be affected by the length of the links or the transmission media used (copper/fibre). For simplicity, we assume the propagation latency does not vary.
- The data transfer latency depends on the transmission bandwidth and the size of the frame. For simplicity, we assume perfect linear scaling of the perbyte delay: 26 ns per byte for 1-Gbit Ethernet and 2.6 ns per byte for 10-Gbit Ethernet, multiplied by either 1 standard frame ( 1,472 bytes) or 1 jumbo frame (9,000 bytes).
- There is no change to the average routing latency, $L_{r}$.

The extrapolation for 10 -Gbit Ethernet (see Table 1) suggests that, even though the per-hop delay might go up significantly with faster networks, the great improvement in path length achieved by DPillarMin still compensates for this and provides an improvement in terms of overall latency of between $20 \%$ and $23 \%$. The use of jumbo frames

[^0]alleviates the overhead incurred by using DPillarMin (see Tables 2 and 3) and raises the improvement in terms of overall latency up to $29 \%$ (1-Gbit Ethernet) and $24 \%$ (10Gbit Ethernet).

Further informal analysis using stack and propagation delays that were one order of magnitude smaller than the ones obtained in our empirical testing, suggested that with standard frames the overall latency will still be reduced by around 20 to $23 \%$ with 1-Gbit Ethernet and between $4 \%$ and $16 \%$ with 10 -Gbit Ethernet in most of the cases. If jumbo frames were considered then the stack and propagation delays barely affect the overall latency so the figures remain similar to those discussed above.

TABLE 1
Per-hop and overall latencies with 10-Gbit Ethernet and standard frames.

| DPillar $_{n, k}$ |  | $L_{\text {hop }}$ <br> DPillarMin | $L_{\text {hop }}$ <br> DPillarSP | $L_{\text {hop }}$ <br> decl. | $L_{\text {total }}$ <br> DPillarMin | $L_{\text {total }}$ <br> DPillarSP | $L_{\text {total }}$ <br> improve. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 16 | $k$ | 4 | 41.76 | 37.15 | $12 \%$ | 156.2 | 199.0 |
| $22 \%$ |  |  |  |  |  |  |  |
| 32 | 3 | 39.12 | 36.76 | $6 \%$ | 111.8 | 144.6 | $23 \%$ |
| 48 | 3 | 39.13 | 36.66 | $7 \%$ | 113.6 | 145.0 | $22 \%$ |

TABLE 2
Per-hop and overall latencies with 1-Gbit Ethernet and jumbo frames.

| DPillar $_{n, k}$ |  | $L_{\text {hop }}$ <br> DPillarMin | $L_{\text {hop }}$ <br> DPillarSP | $L_{\text {hop }}$ <br> decl. | $L_{\text {total }}$ <br> DPillarMin | $L_{\text {total }}$ <br> DPillarSP | $L_{\text {total }}$ <br> improve. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 16 | $k$ | 4 | 270.30 | 265.69 | $2 \%$ | 1011.0 | 1423.3 |
| $29 \%$ |  |  |  |  |  |  |  |
| 32 | 3 | 267.66 | 265.30 | $1 \%$ | 764.6 | 1043.5 | $27 \%$ |
| 48 | 3 | 267.67 | 265.20 | $1 \%$ | 777.3 | 1049.3 | $26 \%$ |

TABLE 3
Per-hop and overall latencies with 10-Gbit Ethernet and jumbo frames.

| DPillar $_{n, k}$ |  | $L_{h o p}$ <br> DPillarMin | $L_{\text {hop }}$ <br> DPillarSP | $L_{\text {hop }}$ <br> decl. | $L_{\text {total }}$ <br> DPillarMin | $L_{\text {total }}$ <br> DPillarSP | $L_{\text {total }}$ <br> improve. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 16 | $k$ | 4 | 61.20 | 56.58 | $8 \%$ | 228.9 | 303.1 |
| $24 \%$ |  |  |  |  |  |  |  |
| 32 | 3 | 58.56 | 56.19 | $4 \%$ | 167.3 | 221.0 | $24 \%$ |
| 48 | 3 | 58.56 | 56.09 | $4 \%$ | 170.1 | 221.9 | $23 \%$ |


[^0]:    1. Different networking equipment may have different frame length limits. For simplicity, we stick to a payload of 9,000 bytes, even though some devices can handle even larger jumbo frames, e.g., Cisco devices can typically handle up to 9,216 bytes.
