

# Energy Consumption of VLSI Decoders

Christopher Blake and Frank R. Kschischang  
 Department of Electrical & Computer Engineering  
 University of Toronto

christopher.blake@mail.utoronto.ca frank@comm.utoronto.ca

## Abstract

Thompson's model of VLSI computation relates the energy of a computation to the product of the circuit area and the number of clock cycles needed to carry out the computation. It is shown that for any family of circuits implemented according to this model, using any algorithm that performs decoding of a codeword passed through a binary erasure channel, as the block length approaches infinity either (a) the probability of block error is asymptotically lower bounded by  $\frac{1}{2}$  or (b) the energy of the computation scales at least as  $\Omega(n\sqrt{\log n})$ , and so the energy of successful decoding, per decoded bit, must scale at least as  $\Omega(\sqrt{\log n})$ . This implies that the average energy per decoded bit must approach infinity for any sequence of codes that approaches capacity. The analysis techniques used are then extended to the case of serial computation, showing that if a circuit is restricted to serial computation, then as block length approaches infinity, either the block error probability is lower bounded by  $\frac{1}{2}$  or the energy scales at least as fast as  $\Omega(n \log n)$ . In a very general case that allows for the number of output pins to vary with block length, it is shown that the average energy per decoded bit must scale as  $\Omega(n(\log n)^{\frac{1}{5}})$ . A simple example is provided of a class of circuits performing low-density parity-check decoding whose energy complexity scales as  $O(n^2 \log \log n)$ .

## I. INTRODUCTION

**S**INCE the work of Shannon [1], information theory has sought to determine how much information can be communicated over a noisy channel; modern coding theory has sought ways to achieve this capacity using error control codes. A standard channel model is the additive white Gaussian noise (AWGN) channel, for which the maximum rate of information that can be reliably communicated (known as the capacity) is known and depends on the transmission power. This model does not, however, consider the energy it takes to encode and decode; a full understanding of energy use in a communication system requires taking into account these encoding and decoding energies, along with the transmission energy. Currently there has been very little work done in seeking a fundamental understanding of the energy required to execute an error control coding algorithm.

Early work in relating the area of circuits and number of clock cycles in circuits that perform decoding algorithms was presented by El Gamal *et al.* in [2]. More recent work in trying to find fundamental limits on the energy of decoding can be attributed to Grover *et al.* in [3]. In this work, the authors consider decoding schemes that are implemented using a VLSI model attributed to Thompson [4] (which we will describe later), and they are able to show that for any code, using any decoding algorithm, as the required block error probability approaches 0, the sum of the transmission, encoding, and decoding energy, per bit, must approach infinity at a rate of  $\Omega(\sqrt[3]{\frac{1}{\log P_e^{\text{blk}}}})$ , where  $P_e^{\text{blk}}$  is the block error probability of the code. This result is useful to the extent that it suggests how to judge the energy complexity of low error probability codes; however, it does not suggest how the energy complexity of decoding scales as capacity is approached.

The result of this paper uses a similar approach to Grover *et al.*, but we generalize the computation model to both parallel and serial computation, and show how the energy of low block error rate decoders



Fig. 1. Diagram of a possible VLSI circuit. The circuit is laid out on a grid of squares and the squares of the grid that are filled in fully represent computational nodes and the thinner lines represent wires. Also present is a wire-crossing in one of the grid squares. The area of this circuit is proportional to the number of grid-squares that contain either a computational node, a wire, or a wire crossing.

must scale with block length  $n$ . We believe that this approach can guide the development of codes and decoding circuits that are optimal from an energy standpoint.

In this paper, in Section II we will describe the VLSI model that will be used to derive our bounds on decoding energy. Our results apply to a decoder for a standard binary erasure channel, which will be formally defined in Section III. In Section IV we will describe some terminology and some key lemmas used in our paper. The main contribution of this paper will be given in Section V where we describe a scaling rule for codes with long block length that have asymptotic error probability less than  $\frac{1}{2}$ . The approach used in this section is extended in Section VI to find a scaling rule for serial computation. Then, in Section VII we extend the approaches of the previous sections to derive a non-trivial super-linear lower bound on circuit energy complexity for a series of decoders in which the number of output pins can vary with increasing block length. These results are applied to find a scaling rule for the energy of capacity approaching decoders as a function of fraction of capacity in Section VIII. We then give a simple example in Section IX showing how an LDPC decoder can be implemented with at most  $O(n^2 \log \log n)$  energy, providing an upper bound to complement our fundamental lower bound.

*Notation:* To aid our discussion of scaling laws, we use standard Big-Oh and Big-Omega asymptotic notation, which is well discussed in [5]. We say that a function  $f(x) = O(g(x))$  if and only if there is some  $M$  and some  $x_0$  such that for all  $x \geq x_0$ ,  $f(x) \leq Mg(x)$ . Similarly, we say that  $f(x) = \Omega(g(x))$  if and only if  $g(x) = O(f(x))$ . Intuitively, this means that the function  $f(x)$  grows at least as fast (in an order sense) as  $g(x)$  and hence we use it with lower bounds. In the following, a sequence of values  $b_1, b_2, \dots, b_k$  is denoted  $b_1^k$ . Random variables are denoted with upper case letters; values in their sample spaces are denoted with lower-case letters.

## II. VLSI MODEL

### A. Description of Model

The VLSI model that we will use is based on the work of Thompson [6], and was used by El Gamal in [2] and Grover *et al.* in [3]. The model consists of a basic set of axioms that describe what is meant by a VLSI circuit and a computation. The model then relates two parameters of the circuit and computation, namely the number of clock cycles used for the computation and the area of the circuit, to the energy used in the computation. Thompson used this model to compute fundamental bounds on the energy required to compute the discrete Fourier transform, as well as other standard computational problems, including sorting. The results in this paper apply to any circuit implemented in a way that is consistent with these axioms, listed as follows:

- A circuit consists of two types of components: wires and nodes. In such a circuit, wires carry binary messages and nodes can perform simple computations (*e.g.*, AND, XOR), all laid out on a

grid of squares. Wires carry information from one node to another node. Wires are assumed to be bi-directional (at least for the purpose of lower bounds). In each clock cycle, each node sends one bit to each of the nodes it is connected to over the wire. We in general allow a node to perform a random function on its inputs. In a deterministic function, the output of the function is determined fully by its inputs. By a random function we mean that the outputs of a particular node, conditioned on the inputs being some element from the set of possible inputs, is a distribution  $p_{Y|X}(\cdot|\cdot)$  where  $Y$  is a random variable representing the possible outputs of the node and  $X$  a random variable representing the inputs of a node. In the particular case of a node with 4 input wires (and thus 4 output wires because of our bidirectional assumption on the wires) the random variables  $X$  and  $Y$  can take on values from  $\{0, 1\}^4$ .

- A VLSI circuit is a set of computational nodes connected to each other using finite-width bi-directional wires. At each clock cycle, nodes communicate with the other nodes to which they are connected. Computation terminates at a pre-determined number,  $\tau$ , of clock cycles.
- Wires run along edges and cross at grid points. There is only one wire per edge. Each grid point contains a logic element, a wire crossing, a wire connection, or an input/output pin. Grid points can be empty. A computational node is a grid point that is either a logic element, a wire-connection, or an input/output pin.
- The circuit is planar, and each node has at most 4 wires leading from it.
- Inputs of computation are stored in source nodes and outputs are stored in output nodes. The same node can be a source node and an output node. Each input can enter the circuit only at the corresponding source node.
- Each wire has width  $\lambda_w$ . Any two wires are separated by at least the wire-width. Any grid points are separated by distance at least  $\lambda_w$ . Each node is assumed to require at least  $\lambda_w^2$  wire area (length and width at least  $\lambda_w$ ).
- Processing is done in “batches,” in which a set of inputs is processed and outputs released before the next set of inputs arrive.
- Energy consumed in a computation is proportional to  $A_c \tau$  where  $A_c$  is the area occupied by the wires and nodes of the circuit and  $\tau$  is the number of clock cycles required to execute the computation. Precisely, the energy is assumed to be  $\frac{1}{2}C_{\text{circuit}}V_{\text{DD}}^2\tau$  where  $C_{\text{circuit}} = C_{\text{unit-area}}A_c$ , where  $C_{\text{unit-area}}$  is the capacitance per unit wired area of the circuit, and  $V_{\text{DD}}$  is the voltage used to drive the circuit. The quantity  $\frac{1}{2}C_{\text{unit-area}}V_{\text{DD}}^2$  is denoted by  $\xi_{\text{tech}}$ , which is the “energy parameter” of the circuit. Processing energy for computation,  $E_{\text{proc}}$ , is thus given by  $E_{\text{proc}} = \xi_{\text{tech}}A_c\tau$ . Since energy of a computation in our model and the area time complexity are essentially the same, in this paper we use the terms “energy complexity” and “Area-Time” complexity interchangeably.

## B. Discussion of Model

The circuit model described above allows us to consider a circuit as a graph in which the computational nodes correspond to the nodes of a graph and the wires correspond to edges.

The last assumption of our model, which relates the area and number of clock cycles to energy consumed in a circuit, assumes that a VLSI circuit is fully charged and then discharged to ground during each clock cycle. Since the wires in a circuit are made of conducting material and are laid out essentially flat, the circuit will have a capacitance proportional to the area of the wires. Assuming that all the wires will need to be charged at each clock cycle, there must be  $\frac{1}{2}C_{\text{circuit}}V_{\text{DD}}^2$  energy supplied to the circuit. For now, we do not consider what will happen if at each clock cycle the state of some of the wires does not change. In the literature (see [7] and [8]) this model is often used to understand power consumption in a digital circuit so we do not attempt to alter these assumptions for the purposes of this paper. Sometimes leakage current of the circuit is factored into such models; we also neglect this as we assume the frequency of computation is high enough so that the power used in computation dominates.

There has been some work to understand the tradeoff between computational complexity and code performance. One such example is [9], in which the complexity of a Gallager Decoding Algorithm B was

optimized subject to some coding parameters. This however does not correspond to the energy of such algorithms.

In [6] it was proven that the Area-Time complexity of any circuit implemented according to this VLSI model that computes a Discrete Fourier Transform must scale as  $\Omega(n^{1.5} \log n)$ . However, there exist algorithms that compute in  $O(n \log n)$  operations (for example, see [10]); Thompson's results thus imply that, for at least some algorithms, energy consumption is *not* merely proportional to the computational complexity of an algorithm.

In the field of coding theory, Grover *et al.* in [3] provided an example of two algorithms with the same computational complexity but different computational energies. The authors looked at the girth of the Tanner graph of an LDPC code. The girth is defined as the minimum length cycle in the Tanner graph that represents the code. They showed, using a concrete example, that for (3, 4)-regular LDPC codes of girth 6 and 8 decoded using the Gallager-A decoding algorithm, the decoders for girth 8 codes can consume up to 36% more energy than those for girth 6 codes. The girth of a code does not necessarily make the decoding algorithm require more computations (*i.e.*, it does not increase computational complexity), but, for this example, it *does* increase the energy complexity. This is because codes with greater girth require the interconnection between nodes to be more complex, even though the same number of computational nodes and clock cycles may be required. This drives up the area required to make these interconnections, and thus drives up the energy requirements. Also in the field of coding theory, the work of Thorpe [11] has shown that a measure of wiring complexity of an LDPC decoder can be traded off with decoding performance.

Thus, current research suggests that in decoding algorithms there appears to be a fundamental trade-off between code performance and interconnect complexity. This paper attempts to find an analytical characterization of this trade-off.

Our paper considers a generic model of computation, but of course it does not completely reflect all methods of implementing a circuit. We discuss some circuit design techniques that our model does not directly consider below.

1) *Multiple Layer VLSI Circuits:* Modern VLSI circuits differ from the Thompson model in that the number of VLSI layers is not one (or two if one counts a wire crossing as another layer). Modern VLSI circuits allow multiple layers. Fortunately, it is known that if  $L$  layers are allowed, then this can decrease the total area by at most a factor of  $L^2$  (see, for example, [4] or [12]). For the purposes of our lower bounds, if the number of layers remains constant as  $n$  increases, we can modify our energy lower bound results by dividing the lower bounds by  $L^2$ . If, however, the number of layers can grow with  $n$  our results may no longer hold. Note also that this only holds for the purpose of lower bound. It may not be possible to implement a circuit with an area that decreases by a factor of  $L^2$ , and so the upper bounds of Section IX cannot be similarly modified.

2) *Adiabatic Computing:* The model used in this paper assumes that after every clock cycle the circuit is entirely discharged and the energy used to charge the circuit is lost. There exists extensive research into circuit designs in which this is not the case (for an overview of this type of computing, called adiabatic computing, see [13]). Our results do not apply to such circuit designs.

3) *Using Memory Elements in Circuit Computation:* The Thompson model does not allow for the use of special memory nodes in computation that can hold information and compute the special function of loading and unloading from memory. Such a circuit can be created using the Thompson model, but it may be that a strategic use of a lower energy memory element can decrease the total energy of a computation. Intuitively, however, the use of a memory element to communicate information within a circuit should still be proportional to the distance that information is communicated. Grover in [14] proposed a ‘bit-meters’ model of energy computation and derives scaling rules similar to our results, suggesting that, at least in an order sense, the circuit model we use is general enough to understand the scaling of high block length codes even if lower energy memory is used. Understanding precisely what kind of gain the use of a memory element can provide in energy complexity is beyond the scope of this paper.

### III. CHANNEL MODEL

We will consider a noisy channel model that is similar to the model used by Grover *et al.* in [3]. An information sequence of  $k$  independent fair coin flips  $b_1^k \in \{0, 1\}^k$  is encoded into  $2^{nR}$  binary-alphabet codewords  $x_1^n \in \{0, 1\}^n$ ; and thus this code has rate  $R = k/n$  bits/channel use. The sequence  $x_1^n$  is passed through a binary erasure channel with erasure probability  $\epsilon$ , resulting in a received vector  $y_1^n \in \{0, 1, ?\}^n$ , where the ? symbol corresponds to the erasure event.

The decoder estimates the input sequence  $\hat{b}_1^k \in \{0, 1\}^k$  by computing a function of the received vector  $y_1^n$ . The outputs of the noisy channel thus become inputs into the decoder circuit. In our most general model of computation, it is required that these channel outputs are eventually input into an input node of the circuit. In a parallel implementation model used for Theorem 1, each of these  $n$  decoder input symbols are input, at the beginning of the computation, into the  $n$  input nodes of the decoder. In a more general computational model used in Theorems 2 and 3, it is assumed that each of these symbols are input into the input nodes of the decoder during some clock cycle in the computation. Note that we allow each of the  $n$  symbols to be inserted into the circuit at any input node location during any clock cycle, but we also require, according to our model, that each input is injected only once into the circuit. Thus, our model does not subsume circuit implementations that, at no cost, allow the same input symbol to be inserted into the circuit in multiple places.

The probability of block error is defined as

$$P_e^{\text{blk}} = \Pr \left( \hat{b}_1^k \neq b_1^k \right).$$

The lower bounds used in our result are valid for a binary erasure channel, but also for any channel that can result from a degraded version of a binary erasure channel. Hence, if we let  $\epsilon = 2p_{\text{ch}}$  then our results apply to lower bounds on decoders for binary symmetric channels with crossover probability  $p_{\text{ch}}$ .

### IV. DEFINITIONS AND MAIN LEMMAS

The main theorems in this paper rely on the evaluation of a particular limit, which we present as a lemma below.

*Lemma 1.* For any constant  $c$ ,  $0 < c < 1$ , and any constant  $c' > 0$ :

$$\lim_{n \rightarrow \infty} (1 - \exp(-c \log n))^{\frac{c'n}{\log n}} = 0. \quad (1)$$

*Proof:* This result follows simply from taking the logarithm of the expression in (1) and using L'Hôpital's rule to show that the logarithm approaches  $-\infty$ . ■

#### A. Relation Between Energy and Bits Communicated

Grover *et al.* in [3] used a nested bisection technique, involving subdividing circuits, to derive the two key lemmas used in this paper. A circuit created according to the Thompson model can be considered a graph in which the computational nodes correspond to graph vertices and the wires are graph edges. To understand these lemmas we must first understand what is meant by (a) a minimum bisection of a circuit and (b) a nested bisection of a circuit. Informally, a bisection of a graph is a set of edges whose removal results in at least two graphs of essentially the same size that are unconnected to each other. A bisection can also be defined in terms of separating a particular subset of vertices. A formal definition is given below.

*Definition 1.* Let  $G = (V, E)$  be a graph. Let  $S \subseteq V$  be a subset of the vertices, and  $E_s \subseteq E$  be a subset of the edges. Then  $E_s$  bisects  $S$  in  $G$  if deletion of the edges in  $E_s$  from the graph cuts  $V$  into disconnected sets  $V_1$  and  $V_2$ , with  $V_1 \cup V_2 = V$ , and  $S$  into sets  $S_1 \subseteq V_1$  and  $S_2 \subseteq V_2$  such that  $|S_1| - |S_2| \leq 1$ . A bisection of  $V$  in  $G$  is called a bisection of  $G$ .



Fig. 2. Example of two graphs with a minimum bisection labelled. Nodes are represented by circles and edges by lines joining the circles. A dotted line crosses the edges of each graph that form a minimum bisection.

A minimal bisection is a bisection of a graph whose size is minimal over all bisections. The *minimum bisection width* is the size of a minimal bisection. For a general graph, finding a minimum bisection is a difficult problem (in fact, it is NP-Complete [15]), but all that is required for the results we will use is that a minimum bisection exists for every graph. Fig. 2 shows minimal bisections of a few simple graphs.

Note that the definition of a minimum bisection also applies to subsets of the vertices of a graph. A circuit has both input nodes and output nodes. The input (resp. output) nodes of the graph corresponding to a circuit are those nodes of the graph that correspond to the input (resp. output) nodes of the circuit. For the purposes of the results in this paper, we will consider bisections of the graph that bisect the output nodes.

We will also be using some other terms throughout the paper which we define below.

If one performs a minimum bisection on the output nodes of the graph corresponding to the interconnection graph of a circuit, this results in 2 disconnected subcircuits. The output nodes of these two (now disconnected) subcircuits can thus each be minimally-bisected again, resulting in 4 subcircuits.

*Definition 2.* This process, when repeated  $r$  times, is said to perform an  $r$ -stage nested minimum bisection. Note that this divides the graph into  $2^r$  disconnected components, which we will refer to as *subcircuits*.

When a circuit is viewed as a graph, a subcircuit can be viewed as a subgraph induced by a nested minimum bisection. When viewed as a circuit according to the Thompson model, it is a collection of computational nodes joined by wires laid out on a grid pattern. An example of a mesh-like circuit with 16 nodes undergoing two stages of nested minimum bisections is shown in Fig. 3.

After a circuit undergoes  $r$ -stages of nested minimum bisections, label each of the  $2^r$  subcircuits with a unique integer  $i$  in which  $1 \leq i \leq 2^r$ . Consider a particular subcircuit  $i$ . During the  $r$ -stages of nested minimum bisections, a number of edges  $f_i$  are removed that are incident on the graph corresponding to subcircuit  $i$  (we can think of this as the “fan-out” of this subcircuit).

*Definition 3.* During the course of the computation, the number of bits communicated to subcircuit  $i$  is  $b_i = \tau f_i$ , where  $\tau$  is the number of clock cycles, and we refer to  $b_i$  as the *bits communicated to subcircuit  $i$  during a computation*.

The quantity  $b_i$  is associated with a particular subcircuit induced by a particular  $r$ -stage nested minimum bisection. When discussed, this quantity’s association with a particular  $r$ -stage nested minimum bisection is implicit.

*Definition 4.* The quantity  $B_r = \sum_{i=1}^{2^r} b_i$  denotes the *number of bits communicated across all edges deleted in an  $r$ -stage nested minimum bisection*. Note that this is a quantity associated with a particular  $r$ -stage nested minimum bisection.

The quantity  $B_r$  will be important in the proofs of the theorems in the paper. Specifically, it can be shown that if a decoding circuit (which we will define below) has a large  $B_r$  for a particular  $r$ -stage nested minimum bisection, then the energy expended during a computation by this circuit must be high. As well, it can be shown that if this quantity is low, then the probability that the circuit makes an error is high.

The above definitions are general and can apply to the computation of any function. However, for our bounds we will be finding lower bounds on the energy complexity of decoding circuits.

*Definition 5.* An  $(n, k)$  parallel decoding circuit is a circuit that has  $n$  input nodes (accepting symbols in  $\{0, 1, ?\}$ ) and  $k$  output nodes (producing symbols in  $\{0, 1\}$ ). The  $n$  input nodes are to receive the outputs of a noisy channel (which for the purposes of lower bound we assume to be a binary erasure channel with erasure probability  $\epsilon$ ). At the end of the computation the decoder is to output the estimate of the original codeword. Note that this circuit decodes a rate  $R = k/n$  code.

Note that in the Thompson model it is assumed that all inputs are binary. For the purposes of lower bound, we allow for the inputs into the computation to be either 0, 1 or ?, where ? is the erasure symbol. At every clock cycle, we allow input nodes to perform a function on their input symbol, as well as the bits input into the node at the clock cycle. These nodes may then output any function of these inputs along the wires leading from the node.

This definition will be generalized to serial computation models in the discussions preceding Theorem 2. Note also that our model of a decoding circuit allows for an input to be an erasure symbol, which is a slight relaxation of the Thompson circuit model. However, in our theorems, the key point will be that, if in a particular subcircuit all the  $n_i$  input nodes of that subcircuit are erased, then, *conditioned on this event*, the distribution of the possible original inputs to the channel of the  $k_i$  bits that a subcircuit  $i$  is to estimate remains uniform. This is a result of the symmetric nature of a binary erasure channel, and this will allow us to directly apply Lemma 2 to form lower bounds on probability of error.

After a decoding circuit undergoes  $r$ -stages of nested minimum bisections, each subcircuit will have roughly an equal number of output nodes, but the number of input nodes may vary (the actual number of input nodes in each subcircuit in general will be a function of the particular graph structure of the circuit, and the particular  $r$ -level nested minimum bisection performed).

*Definition 6.* We refer to this quantity as the *number of input nodes in subcircuit  $i$*  and denote it  $n_i$ .

Note that this quantity is determined by the particular  $r$ -stage nested minimum bisection, but for notational convenience we will consider the relation of this quantity to the particular structure of the  $r$ -stage nested minimum bisection to be implicit.

*Definition 7.* A particular  $i$ th subcircuit formed by an  $r$ -stage nested minimum bisection will have a certain number of output nodes, which we denote  $k_i$ . This quantity is referred to as the *number of output nodes in subcircuit  $i$* .

In a fully parallel computation model (which we will employ in Theorem 1), at the end of the computation, these output nodes are to hold a vector  $\hat{k}_i \in \{0, 1\}^{k_i}$ , where the vector to be estimated is a vector  $k_i \in \{0, 1\}^{k_i}$  which is produced by a series of fair coin flips as described in Section III. Since at the end of the computation these output nodes are to hold an estimate of a vector of length  $k_i$  it is said that in this case  $k_i$  is the *number of bits responsible for decoding by subcircuit  $i$* . The probability of error for a subcircuit is precisely the probability that, after the end of the computation,  $\hat{K}_i \neq K_i$ .

*Lemma 2.* Suppose that  $X$ ,  $Y$ , and  $\hat{X}$  are random variables that form a Markov chain  $X \rightarrow Y \rightarrow \hat{X}$ . Suppose furthermore that  $X$  takes on values from a finite alphabet  $\mathcal{X}$  with a uniform distribution (i.e.,  $P(X = x) = \frac{1}{|\mathcal{X}|}$  for any  $x \in \mathcal{X}$ ) and  $Y$  takes on values from an alphabet  $\mathcal{Y}$ . Suppose furthermore that  $\hat{X}$  takes on values from a set  $\hat{\mathcal{X}}$  such that  $\mathcal{X} \subseteq \hat{\mathcal{X}}$ . Then,

$$P(\hat{X} = X) \leq \frac{|\mathcal{Y}|}{|\mathcal{X}|}.$$

*Remark 1.* This general lemma is meant to make rigorous a fundamental notion that will be used in this paper. As applied to our decoding problem, the random variable  $X$  can be thought of as the input to a binary erasure channel, and  $Y$  can be any inputs into a subcircuit of a computation, and  $\hat{X}$  can be thought of as a subcircuit's estimate of  $X$ . This lemma makes rigorous the notion that if a subcircuit has fewer bits input into it than it is responsible for decoding, then the decoder must guess at least 1 bit, and

makes an error with probability at least  $\frac{1}{2}$ . This scenario is actually a special case of this lemma in which  $|\mathcal{Y}| = 2^m$  and  $|\mathcal{X}| = 2^k$  for integers  $k$  and  $m$ , where  $m < k$ .

*Proof:* Clearly, by the law of total probability,

$$\begin{aligned} P(X = \hat{X}) &= \sum_{x \in \mathcal{X}} \sum_{y \in \mathcal{Y}} P_{X,Y,\hat{X}}(x, y, x) \\ &= \sum_{x \in \mathcal{X}} \sum_{y \in \mathcal{Y}} P_X(x) P_{Y|X}(y|x) P_{\hat{X}|Y}(x|y) \end{aligned}$$

where we simply expand the term in the summation according to the definition of a Markov chain. Using  $P_X(x) = \frac{1}{|\mathcal{X}|}$  we get:

$$P(X = \hat{X}) = \frac{1}{|\mathcal{X}|} \sum_{x \in \mathcal{X}} \sum_{y \in \mathcal{Y}} P_{Y|X}(y|x) P_{\hat{X}|Y}(x|y)$$

and using  $P_{Y|X}(y|x) < 1$  because it is a probability, and changing the order of summation gives us:

$$P(X = \hat{X}) \leq \frac{1}{|\mathcal{X}|} \sum_{y \in \mathcal{Y}} \sum_{x \in \mathcal{X}} P_{\hat{X}|Y}(x|y).$$

Since  $\sum_{x \in \mathcal{X}} P_{\hat{X}|Y}(x|y) \leq 1$  (as we are summing over a subset of values that  $\hat{X}$  can take on), we get:

$$P(X = \hat{X}) \leq \frac{1}{|\mathcal{X}|} \sum_{y \in \mathcal{Y}} 1 = \frac{|\mathcal{Y}|}{|\mathcal{X}|}.$$

■

In the proofs of the theorems in this paper, we will be dividing a circuit up into pieces and then we will let  $n$  grow larger. Technically, a circuit can only be divided into an integer fraction of pieces. However, in most cases this does not matter. To make this notion rigorous, we will need to use the following lemma:

*Lemma 3.* Let  $h : \mathbb{R} \rightarrow \mathbb{R}$  be a function such that  $|h(x) - x| \leq a$  for sufficiently large  $x$  and some positive constant  $a$ . If there are functions  $f, g : \mathbb{R} \rightarrow \mathbb{R}$ , and  $g$  is continuous for sufficiently large  $x$ , and if  $\lim_{x \rightarrow \infty} f(g(x)) = c$  for some constant  $c \in \mathbb{R}$ , and if  $\lim_{x \rightarrow \infty} g(x) = \infty$  then  $\lim_{x \rightarrow \infty} f(h(g(x))) = c$ .

*Proof:* Suppose

$$\lim_{x \rightarrow \infty} f(g(x)) = c.$$

To show that  $\lim_{x \rightarrow \infty} f(h(g(x))) = c$  we need to construct, given some  $\epsilon$ , a particular  $x_0$  such that for all  $x > x_0$ ,  $|f(h(g(x))) - c| < \epsilon$ . Since  $g$  grows unbounded, and is continuous for sufficiently large  $x$ , then there must be a particular value of  $x$  (call it  $x'$ ) such that  $g(x)$  takes on all values greater than  $g(x')$  for some  $x > x'$ . As well, for any  $\epsilon > 0$  there exists some  $x''$  such that for all  $x > x''$ ,  $|f(g(x)) - c| < \epsilon$ . In particular this is true for some  $x'' > x'$ . Thus, choose  $x_0$  to be the least number greater than  $x''$  in which  $g(x_0) = g(x'') + a$  (this must exist because  $g$  takes on all values greater than  $g(x'')$ ). Thus, for  $x > x_0$   $h(g(x))$  only takes on values greater than  $g(x'')$  (because  $|h(x) - x| \leq a$ ). Since  $|f(g(x)) - c| < \epsilon$  for all  $x > x''$ , thus  $|f(h(g(x))) - c| < \epsilon$  for all  $x > x_0$ , since  $h(g(x))$  can only take on values that  $g(x)$  takes on for  $x > x''$ . ■

*Corollary 1.* This result applies when  $h(\cdot)$  is the floor function, denoted  $\lfloor \cdot \rfloor$ , since  $|\lfloor x \rfloor - x| \leq 1$ .

We will need to make one observation that will be used in the three main theorems of this paper, which we present in the lemma below.

*Lemma 4.* If  $\epsilon > 0$  and  $n_1, n_2, \dots, n_m$  are positive integers subject to the restriction that  $\sum_{i=1}^m n_i \leq n$  then:

$$\prod_{i=1}^m (1 - \epsilon^{n_i}) \leq \left(1 - \epsilon^{\frac{n}{m}}\right)^m$$



Fig. 3. Example of a possible circuit undergoing two stages of nested minimum bisections. The dotted line down the middle is a first nested bisection, and the other two horizontal dotted lines are the bisections that divide the two subcircuits that resulted from the first stage of the nested bisections, resulting in four subcircuits. We are concerned with the number of bits communicated across  $r$ -stages of nested minimum bisections. In these two stages of nested minimum bisections, we see that 8 wires are cut. Because we assume wires are bidirectional, and thus two bits are communicated across these wires every clock cycle, in the case of this circuit we have  $B_r = 8 \times 2 \times \tau$ , where  $\tau$  is the number of clock cycles. It will not be important how to actually do these nested bisections, rather it is important only to know that any circuit can undergo these nested bisections.

*Proof:* The proof follows from a simple convex optimization argument. ■

Grover *et al.* in [3] uses a nested bisection technique to prove a relation between energy consumed in a circuit computation and bits communicated across the  $r$ -stages of nested bisections which we present as a series of two lemmas, the second which we will use directly in our results.

**Lemma 5.** For a circuit undergoing  $r$ -stages of nested bisections, in which the total number of bits communicated across all  $r$ -stages of nested bisections is  $B_r$ , then

$$A\tau^2 \geq \frac{(\sqrt{2} - 1)^2}{16} \frac{B_r^2}{2^{r+1}} \lambda^2$$

where  $A$  is the area of the circuit and  $\tau$  is the number of clock cycles during the computation.

*Proof:* See [3] for a detailed proof. Here we provide a sketch. To accomplish this proof,  $r$ -stages of nested minimum bisections on a circuit are performed and then a principle due to Thompson [6] is applied that states that the area of a circuit is at least proportional to the square of the minimum bisection width of the circuit. Also, the number of bits communicated to a subcircuit cannot exceed the number of wires entering that subcircuit multiplied by the number of clock cycles. The area of the circuit (related to the size of the minimum bisections performed) and the number of clock cycles (more clock cycles allow more bits communicated across cuts) are then related to the number of bits communicated across all the edges deleted during the  $r$ -stages of nested bisections. ■

**Lemma 6.** If a circuit as described in Lemma 5 in addition has at least  $\beta$  nodes, then the  $A\tau$  complexity of such a computation is lower bounded by:

$$A\tau \geq \frac{\sqrt{2} - 1}{4\sqrt{2}} \sqrt{\frac{\beta}{2^r}} B_r \lambda_w^2$$

*Proof:* Following the same arguments of Grover *et al.* in [3] (which we reproduce to get the more general result we will need), note that if there are at least  $\beta$  computational nodes, then

$$A \geq \beta \lambda_w^2$$

which, when combined with Lemma 5 results in:

$$A^2 \tau^2 \geq \frac{(\sqrt{2} - 1)^2}{16} \frac{B_r^2}{2^{r+1}} \beta \lambda_w^4$$

which yields the statement of the Lemma upon taking the square root. ■

*Remark 2.* In terms of our energy notation, the result of Lemma 6 implies that for such a circuit with at least  $\beta$  computational nodes, the energy complexity is lower bounded by:

$$E_{\text{proc}} \geq \xi_{\text{tech}} \lambda_w^2 \frac{\sqrt{2} - 1}{4\sqrt{2}} \sqrt{\frac{\beta}{2^r}} B_r = K_{\text{tech}} \sqrt{\frac{\beta}{2^r}} B_r$$

where  $K_{\text{tech}} = \xi_{\text{tech}} \lambda_w^2 \frac{\sqrt{2} - 1}{4\sqrt{2}}$ .

### B. Bound on Block Error Probability

The key lemma that will be used in the first theorem of this paper is due to Grover *et al.* [3]. We modify the lemma slightly.

*Lemma 7.* For any code implemented using the VLSI model for an erasure channel with erasure probability  $\epsilon$ , for any  $r < \log_2 \left(\frac{k}{2}\right)$ ,

$$\text{either } P_e^{blk} \geq \frac{1}{2} - \left(1 - \epsilon^{\frac{n_i}{2^{r-1}}}\right)^{2^{r-1}} \text{ or } B_r \geq \frac{k}{2}.$$

The proof uses the same approach as Grover *et al.* in [3] but we modify it slightly to ease the use of our lemma for our theorem and to conveniently deal with the possibility that a decoder can guess an output of a computation.

Let  $s_i$  be the number of input bits erased in the  $i$ th subcircuit after  $r$ -stages of nested bisections. Furthermore, recall from Definition 3 that  $b_i$  is the number of bits injected into the  $i$ th subcircuit during the computation. Also, recall from Definition 6 that  $n_i$  is the number of input nodes located within the  $i$ th subcircuit. We use the principle that if

$$\frac{k}{2^r} < n_i - s_i + b_i$$

for any subcircuit then the probability of block error is at least  $\frac{1}{2}$ . This is a very intuitive idea; if the number of bits that are not erased, plus the number of bits injected into a circuit is less than the number of bits the circuit is responsible for decoding, the circuit must at least guess 1 bit. This argument will be made formal in the proof that follows.

*Proof:* (of Lemma 7) Suppose that all the  $n_i$  input bits injected into the  $i$ th subcircuit are the erasure symbol. Then, conditioned on this event, the distribution of the  $k_i$  bits that this subcircuit is to estimate is uniform (owing to the symmetric nature of the binary erasure channel). Furthermore, if  $b_i < \frac{k}{2^r}$  then the number of bits injected into the subcircuit is less than the number of bits the subcircuit is responsible for decoding. Combining these two facts allows us to apply Lemma 2 directly to conclude that, in the event all the inputs bits of a subcircuit are erased, and the number of bits injected into the subcircuit is less than  $\frac{k}{2^r}$ , then the subcircuit makes an error with probability at least  $\frac{1}{2}$ . Denote the event that all inputs bits in subcircuit  $i$  are erased as  $W_i^r$ . The probability of this event is given by

$$P(W_i^r) = \epsilon^{n_i}.$$

Suppose that  $B_r < k/2$  (where we recall from Definition 4 that  $B_r$  is the total number of bits communicated across all edges cut in  $r$ -stages of nested minimum bisections). Let  $S = \{i : b_i < \frac{k}{2^r}\}$  be the set of indices  $i$  in which  $b_i$  (the bits communicated to the  $i$ th subcircuit) is smaller than  $\frac{k}{2^r}$ . We first claim that  $|S| > 2^{r-1}$ . To prove this claim, let  $\bar{S} = \{i : b_i \geq \frac{k}{2^r}\}$  and note that  $\frac{k}{2} > B_r = \sum b_i \geq \sum_{i \in \bar{S}} \frac{k}{2^r} = |\bar{S}| \frac{k}{2^r}$ , from which it follows that  $|\bar{S}| < 2^{r-1}$ . Since  $|S| + |\bar{S}| = 2^r$ , the claim follows.

Hence, in the case that  $B_r \leq k/2$ , because of the law of total probability:

$$\begin{aligned} P(\text{correct}) &= P(\cap_{i \in S} \bar{W}_i^r) P(\text{correct} | \cap_{i \in S} \bar{W}_i^r) + P(\cup_{i \in S} W_i^r) P(\text{correct} | \cup_{i \in S} W_i^r) \\ &\leq \prod_{i \in S} (1 - \epsilon^{n_i}) + \frac{1}{2} \end{aligned} \tag{2}$$

where the event  $\cap_{i \in S} \bar{W}_i^r$  is the event that each of the subcircuits indexed in  $S$ , after  $r$ -stages of nested bisections, do not have all their  $n_i$  input bits erased. We then note that, in this case, the probability of the circuit being decoded correctly is at most 1. For the second term, we note that conditioned on the event that at least one of the subcircuits indexed in  $S$  has all their input bits erased, since the circuit must at least guess 1 bit, the probability of the circuit decoding successfully is at most  $\frac{1}{2}$ , by Lemma 2.

Since  $\sum_{i \in S} n_i \leq \sum_{i=1}^{2^r} n_i = n$ , subject to this restriction, Lemma 4 shows the expression in (2) is maximized when  $n_i = \frac{n}{|S|}$  for each subcircuit in  $S$ . Hence,

$$P(\text{correct}) \leq \left(1 - \epsilon^{\frac{n}{|S|}}\right)^{|S|} + \frac{1}{2}.$$

Thus, either  $B_r \leq \frac{k}{2}$  or  $|S| \geq 2^{r-1}$  which implies

$$P(\text{correct}) \leq \left(1 - \epsilon^{\frac{n}{2^{r-1}}}\right)^{2^{r-1}} + \frac{1}{2}$$

and so

$$\begin{aligned} P_e^{\text{blk}} &= 1 - P(\text{correct}) \\ &\geq \frac{1}{2} - \left(1 - \epsilon^{\frac{n}{2^{r-1}}}\right)^{2^{r-1}}. \end{aligned}$$

■

## V. KEY RESULT: A FUNDAMENTAL SCALING RULE FOR ENERGY OF LOW BLOCK ERROR PROBABILITY DECODERS

We define a coding scheme as a sequence of codes of fixed rate together with decoding circuits, in which the block length of each successive code increases. We define  $P_e^{\text{blk},n}$  as the block error probability for the decoder of block length  $n$  in this scheme. An example of a coding scheme would be a series of regular LDPC codes together with LDPC decoding circuits in which the block length  $n$  doubles for each decoder in the sequence. Our results are general and would apply to any particular coding scheme using any circuit implementation and any decoding algorithm. The key result of this paper is given in the following theorem:

*Theorem 1.* For every coding scheme in which  $\lim_{n \rightarrow \infty} P_e^{\text{blk},n} < \frac{1}{2}$ , there exists some  $n_0$  such that for all  $n > n_0$ , for any circuit implemented according to the VLSI model with parameters  $\xi_{\text{tech}}$  and  $\lambda_w$ ,

$$E_{\text{dec}} > K_{\text{tech}} \sqrt{\frac{(\log_2 n)}{\log_2 \left(\frac{1}{\epsilon}\right)} \frac{Rn}{2}} \quad (3)$$

where  $E_{\text{dec}}$  is the energy used in the decoding and  $K_{\text{tech}} = \xi_{\text{tech}} \lambda_w^2 \frac{(\sqrt{2}-1)}{4\sqrt{2}}$  is a constant that depends on circuit technology parameters that we defined before.

*Remark 3.* The requirement that  $\lim_{n \rightarrow \infty} P_e^{\text{blk},n} < \frac{1}{2}$  for our bound in (3) though reasonable, is not necessary for a good design. Typical block error probability requirements may be on the order of  $10^{-5}$  or  $10^{-6}$ , although if the block error probabilities are lower bounded by  $\frac{1}{2}$  for a series of decoding schemes, this is not necessarily a bad design. The individual bit error probabilities (the probability that a randomly selected output bit of the decoder is decoded correctly) may indeed be acceptably low. However, our results do not consider such schemes. It is also not necessary for a decoding scheme to have a block length that gets arbitrarily large. However, a capacity-approaching code must have block length that approaches infinity and our result can be used to understand how the energy complexity of such decoding algorithms approach infinity.

*Proof:* The theorem follows from an appropriate choice for  $r$ , the number of nested bisections we perform. We can choose any nonnegative integer  $r$  so that  $r < \log_2 \left(\frac{k}{2}\right)$ . Note that  $k = nR$  is the number of

bits the decoder is responsible for decoding. As  $k$  gets large, we can thus choose any  $r$  so that  $1 \leq 2^r \leq \frac{k}{2}$ . Thus, we choose an  $r$  so that, approximately,  $2^r = \frac{2 \log(\frac{1}{\epsilon})n}{K \log n}$ , for a value of  $K$  which we will choose later. In particular, we will choose  $r = \left\lfloor \log_2 \left( \frac{2 \log(\frac{1}{\epsilon})n}{K \log n} \right) \right\rfloor$ .

This is valid so long as  $n$  is sufficiently large, for some  $0 < K < 1$ . Note that  $\log \frac{1}{\epsilon} > 0$  since  $0 < \epsilon < 1$ . Since  $\frac{k}{2} = \frac{Rn}{2}$ , this is a valid choice for  $r$  so long as

$$\frac{2 \log \left( \frac{1}{\epsilon} \right) n}{K \log n} < \frac{R}{2}$$

which must occur as the left side of the inequality approaches 0 as  $n$  gets large. We can plug this value for  $r$  into Lemma 7, but we will simplify the expression by neglecting the floor function, as application of Lemma 2 will show that this does not alter the evaluation of the limit that we will compute, as we can see our choice for  $r$  grows unbounded with  $n$ . Thus, either

$$P_e^{\text{blk},n} \geq \frac{1}{2} - (1 - \exp(-K \log n))^{\frac{1}{K} \frac{\log(\frac{1}{\epsilon})n}{\log n}} \quad (4)$$

or, applying Lemma 6 by recognizing that there are at least  $\beta = n$  nodes,

$$E_{\text{dec}} > K_{\text{tech}} \sqrt{\frac{(K \log n)}{\log(\frac{1}{\epsilon})} \frac{Rn}{2}}. \quad (5)$$

By a direct application of Lemma 1, so long as  $K < 1$ , the bound in (4) approaches  $\frac{1}{2}$  which we can see as follows:

$$\begin{aligned} \lim_{n \rightarrow \infty} P_e^{\text{blk},n} &\geq \frac{1}{2} - \lim_{n \rightarrow \infty} (1 - \exp(-K \log n))^{\frac{Kn}{\log n}} \\ &= \frac{1}{2}. \end{aligned}$$

This implies that, in the limit of large block sizes, the probability of block error must be lower bounded by  $\frac{1}{2}$ , unless  $B_r \geq \frac{k}{2}$ . But then by (5), it must be that

$$E_{\text{dec}} > K_{\text{tech}} \sqrt{\frac{(\log n)}{\log(\frac{1}{\epsilon})} \frac{Rn}{2}} \quad (6)$$

which is the result we are seeking to prove. ■

The following corollary is immediate.

*Corollary 2.* If a sequence of decoding schemes in which in the limit of large  $n$   $P_e^{\text{blk},n} < \frac{1}{2}$ , the average decoding energy, per decoded bit (which we denote  $E_{\text{dec,avg}}$ ) is bounded as:

$$E_{\text{dec,avg}} > K_{\text{tech}} \sqrt{\frac{(\log_2 n)}{\log_2(\frac{1}{\epsilon})}}. \quad (7)$$

*Proof:* The proof follows simply by dividing (6) by  $nR$ , the number of bits such a code is responsible for decoding. ■

## VI. SERIAL COMPUTATION

Our result in Section V applies to decoders implemented entirely in parallel; however, this does not necessarily reflect the state of modern decoder implementations. Below we provide a modified version of the Thompson VLSI model that allows for the source of the computation to be input serially and the outputs to be computed serially.

In this modified model, we assume that the circuit computes a function of  $n$  inputs and  $k$  outputs. However, instead of having  $n$  input nodes and  $k$  output nodes, the circuit has  $p$  input nodes and  $j$  output nodes. The computation terminates after a set  $\tau$  number of clock cycles, and during the  $\tau$  clock cycles, the inputs to the computation may be input into the  $p$  input nodes (where  $p$  bits at most can be input during a single clock cycle), and the outputs of the computation must appear in the output nodes during specified clock cycles of the computation.

*Remark 4.* The number of clock cycles  $\tau$  must at least be enough to output all the bits. If there are  $j$  output nodes and  $k$  outputs to the function being computed, then there must be at least  $\frac{k}{j}$  clock cycles. If all the inputs into the computation are being used, then there must also be at least  $\frac{n}{p}$  clock cycles, though it is technically possible for some functions to have inputs that “don’t matter” so this is not a strict bound for all functions.

Hence, a lower bound on the energy complexity for this computation is:

$$E_{\text{proc}} \geq \xi_{\text{tech}} A_c \frac{k}{j}$$

where  $A_c$  is the area of the circuit.

*Theorem 2.* Suppose there is a sequence codes together with decoding schemes with rate  $R$  and block length  $n$  approaching infinity. We label the block error probability of the length  $n$  decoder as  $P_e^{\text{blk},n}$ . Also suppose that the number of output pins remains a constant  $j$ . Then either (a)  $\lim_{n \rightarrow \infty} P_e^{\text{blk},n} \geq \frac{1}{2}$  or (b) there exists some  $n_0$  such that for all  $n$  greater than  $n_0$

$$E_{\text{dec}} \geq \frac{\xi_{\text{tech}} \lambda_w^2 R^2 n}{j \log\left(\frac{1}{\epsilon}\right)} (\log n - j) = \Omega(n \log n).$$

To prove this theorem, instead of dividing the circuit into subcircuits, we will divide the computation conceptually in time, by dividing the computation into epochs. More precisely, consider dividing the computation outputs into chunks of size  $m$  (with the exception of possibly one chunk if  $m$  does not evenly divide  $k$ ), meaning that there are  $\lceil \frac{k}{m} \rceil$  such chunks. Hence, the outputs, which can be labeled  $(k_1, k_2, \dots, k_k)$  can be divided into groups, or a collection of subvectors  $(K_1, K_2, \dots, K_{\lceil \frac{k}{m} \rceil})$  in which  $K_1 = (k_1, k_2, \dots, k_m)$ ,  $K_2 = (k_{m+1}, k_{m+2}, \dots, k_{2m})$  and so on, until  $K_{\lceil \frac{k}{m} \rceil} = (k_{m\lfloor \frac{k}{m} \rfloor}, k_{m\lfloor \frac{k}{m} \rfloor + 1}, \dots, k_k)$ .

*Definition 8.* The set of clock cycles in the computation in which the bits in  $K_i$  are output is considered to be the  $i$ th epoch.

In our analysis, we are interested in analyzing the decoding problem for chunks of the output as defined above for an  $m$  that we will choose later for the convenience of our theorem. We are also interested in another set of quantities: the input bits injected into the circuit between the time when the last of the bits in  $K_i$  are output and the first of the bits in  $K_{i+1}$  bits are output. Label the collection of these bits as  $(N_1, N_2, \dots, N_{\lceil \frac{k}{m} \rceil})$ . Label the size of each of these of these subvectors as  $(n_1, n_2, \dots, n_{\lceil \frac{k}{m} \rceil})$ , so that the number of bits injected before all of the bits in  $K_1$  are computed is  $n_1$ , and the number of those injected after the first  $n_1$  bits are injected and until the clock cycle when the last of the bits in  $K_2$  are output is  $n_2$ , and so on. Let  $s_i$  be the number of erasures that are injected into the circuit during the  $i$ th epoch. Note that by Lemma 2 an error occurs when

$$m \leq n_i + \bar{A} - s_i$$

where  $\bar{A} = \frac{A_c}{\lambda_w^2}$  is the maximum number of bits that can be stored in the circuit, remembering that according to the computation model the maximum number of bits that can be stored in a circuit must be proportional to the area of the circuit, as each wire in the circuit at any given time in the computation can hold only the value 1 or 0.

*Proof:* (of Theorem 2) Suppose we divide the circuit into chunks each of size  $\bar{A} + j$ ,  $j$  more than the normalized circuit area. Then, if all the bits  $n_i$  are erased, the probability that at least one of the bits of  $K_i$  is not decoded must at least be  $\frac{1}{2}$ , because there are simply not enough non-erased inputs for the circuit to infer the  $m$  bits it is responsible for decoding in that window of time. Note that we choose  $m = \bar{A} + j$  so that an error event occurs with probability at least  $\frac{1}{2}$  when all the  $n_i$  bits are erased, because it is technically possible that in a clock cycle that outputs the last of the bits of  $K_i$ ,  $j - 1$  bits of  $K_{i+1}$  are output. Then, the number of bits required to be computed for the next chunk of outputs is at least  $k_{i+1} - j + 1$ . Let the size of each  $K_i$  (except possibly  $K_{\lceil \frac{k}{m} \rceil}$ ) be  $\bar{A} + j$ . Similar to what we did for in Section IV-B, denote the event that all input bits in  $N_i$  are erased as  $W_i$ . Thus:

$$\begin{aligned} P(\text{correct}) &= P\left(\bigcap_{i=1}^{\lfloor \frac{k}{m} \rfloor} \bar{W}_i\right) P\left(\text{correct} \mid \bigcap_{i=1}^{\lfloor \frac{k}{m} \rfloor} \bar{W}_i\right) + P\left(\bigcup_{i=1}^{\lfloor \frac{k}{m} \rfloor} W_i\right) P\left(\text{correct} \mid \bigcup_{i=1}^{\lfloor \frac{k}{m} \rfloor} W_i\right) \\ &\leq \prod_{i=1}^{\lfloor \frac{k}{m} \rfloor} (1 - \epsilon^{n_i}) + \frac{1}{2}. \end{aligned}$$

The first term is simplified by recognizing the independence of erasure events in the channel and the second term is simplified by the fact that, conditioned on the event that at least one subcircuit has input nodes being all erasure symbols, Lemma 2 applies and at least one subcircuit must make an error with probability at least  $\frac{1}{2}$ . Thus:

$$\begin{aligned} P_e^{blk,n} &= 1 - P(\text{correct}) \\ &\geq 1 - \prod_{i=1}^{\lfloor \frac{k}{m} \rfloor} (1 - \epsilon^{n_i}). \end{aligned} \tag{8}$$

It must be that  $\sum_{i=1}^{\lfloor \frac{k}{m} \rfloor} n_i = n$ , and thus  $\sum_{i=1}^{\lfloor \frac{k}{m} \rfloor} n_i \leq n$ , where again  $n$  is the total number of inputs.

We can apply Lemma 4 to show that the product term in (8) is maximized when each  $n_i$  is equal to  $n_i = \frac{n}{\lfloor \frac{k}{m} \rfloor}$ . Thus, we show that:

$$P_e^{blk} \geq 1 - \left(1 - \epsilon^{\frac{n}{\lfloor \frac{k}{m} \rfloor}}\right)^{\lfloor \frac{k}{m} \rfloor}.$$

For the sake of the convenience of calculation, we replace  $\lfloor \frac{k}{m} \rfloor$  with  $\frac{k}{m}$ , which will not alter the evaluation of the limit by Lemma 3, giving us:

$$P_e^{blk,n} \geq 1 - \left(1 - \epsilon^{\frac{mn}{k}}\right)^{\frac{k}{m}} \tag{9}$$

Since we have assumed  $m = \bar{A} + j$ , suppose that  $\bar{A} \leq \frac{cR}{\log \frac{1}{\epsilon}} \log n - j$ , and recognizing that  $k = Rn$ , and that  $m = \bar{A} + j$ , substituting into (9) and simplifying gives us:

$$P_e^{blk} \geq \frac{1}{2} - (1 - \exp(-c \log n))^{\frac{\log(\frac{1}{\epsilon}) R n}{\log n}}$$

Thus, if  $c < 1$  and applying Lemma 1:

$$\lim_{n \rightarrow \infty} P_e^{blk} \geq \frac{1}{2} - \lim_{n \rightarrow \infty} (1 - \exp(-c \log n))^{\frac{\log(\frac{1}{\epsilon}) R n}{\log n}} = \frac{1}{2}$$

Hence, either in the limit block error probability is at least  $\frac{1}{2}$ , or  $\bar{A} > \frac{cR}{\log \frac{1}{\epsilon}} \log n - j$  and thus

$$E_{\text{dec}} \geq \xi_{\text{tech}} \lambda_w^2 \bar{A} \frac{k}{j} \geq \frac{\xi_{\text{tech}} \lambda_w^2 R^2 n}{j \log \left( \frac{1}{\epsilon} \right)} (\log n - j) = \Omega(n \log n),$$

where we have used the fact that the number of clock cycles is at least  $\frac{k}{j}$  as well as our bound on  $\bar{A}$ . ■

## VII. A GENERAL CASE: ALLOWING THE NUMBER OF OUTPUT PINS TO VARY WITH INCREASING BLOCK LENGTH

The results in Sections V and VI show that in the case of fully parallel implementations, the Area-Time complexity of decoders that asymptotically have a low block error probability must asymptotically have a super-linear lower bound. Technically, however, it may be possible to make a series of circuits with increasing block length, and have the number of output pins increase with increasing block length. We can show that, in this case, a super-linear lower bound exists as well where we require only weak assumptions on the circuit layout. This proof applies the main principle of this paper: namely that if a subcircuit has all its inputs erased, then that subcircuit must somehow have communicated to it other bits from outside this circuit, or it must, with high probability, make an error. In Theorem 1, we recognize that in a fully parallel computation these bits must be injected to it from another part of the circuit, resulting in some energy cost. In Theorem 2, we divide the circuit into epochs, and recognize that if all the input bits injected into the circuit during that epoch are erased then the circuit must have bits injected to it from before that epoch. But the number of bits that can be carried forward after each epoch is limited by the area of the circuit. In the general case in which the number of output pins can vary with block length, we divide the circuit into subcircuits and epochs (in essence, dividing the circuit in both time and space) and apply these two fundamental ideas.

To accomplish this lower bound, we will need this simplifying assumption: for any decoder with  $j$  output pins, each output pin is responsible for, before the end of the computation, outputting between  $\left\lfloor \frac{k}{j} \right\rfloor$  and  $\left\lceil \frac{k}{j} \right\rceil$  bits. Furthermore, we assume that each output bit produces an output at the same time. We call this assumption an *output regularity assumption*. This assumption allows us to divide the circuit into subcircuits and then epochs, and thus with this assumption each subcircuit can be divided into *subcircuit epochs*. The main structure of the proof will be this: if the energy of a computation is not high, then there will be many subcircuit epochs that do not have enough bits injected into them to overcome the case of one of them having all of their input bits erased. The task is thus to choose a correct number of divisions of the circuit into subcircuits and epochs, so that the probability of this event (that a subcircuit epoch makes an error) is high unless the area-time complexity of the computation is high.

*Theorem 3.* For a sequence of codes and circuit implementations of decoding algorithms in which block length  $n$  gets large, and where the number of output pins  $j$  can vary with block length  $n$ , and the computation performed by the decoders is consistent with the output regularity assumption, then, in the limit as  $n$  approaches infinity, either (a)  $\lim_{n \rightarrow \infty} P_e^{blk,n} \geq \frac{1}{2}$  or (b) for a sufficiently large  $n$ ,  $E_{\text{dec}} \geq \Omega(n (\log n)^{\frac{1}{5}})$ .

*Proof:* The proof is given in Appendix A. ■

## VIII. CONSEQUENCES

A direct consequence of our work is that as code rates approach capacity, the average energy of decoding, per bit, must approach infinity. It is well known from [16] and [17] and further studied in [18] that as a function of fraction of capacity  $\eta = \frac{R}{C}$ , the minimum block length scales approximately as

$$n \approx \frac{c}{(1 - \eta)^2}$$

for a constant  $c$  that depends on the channel and target probabilities of error. We are not concerned about the value of this constant, but rather the dependence of this approximation on  $\eta$ . Plugging this result into (7) implies:

$$E_{\text{dec,avg}} \gtrsim K_{\text{tech}} \sqrt{\frac{\left(\log_2 \frac{c}{(1-\eta)^2}\right)}{\log_2 \left(\frac{1}{\epsilon}\right)}} = \Omega\left(\sqrt{\log\left(\frac{1}{1-\eta}\right)}\right).$$

This result implies that not only must the total energy of a decoding algorithm approach infinity as capacity is approached (this is a trivial consequence of the fact that block length must approach infinity as capacity is approached), but also the energy *per bit* must approach infinity as capacity is approached. Thus, if the total energy per bit is to be optimized, a rate strictly less than capacity must be used. We cannot get arbitrarily close to optimal energy per bit by getting arbitrarily close to capacity, which would be the case if there were linear energy complexity algorithms with block error probability that stay less than  $\frac{1}{2}$ .

The result of Theorem 2 can also be extended to find a fundamental lower bound on the average energy per bit of serially decoded, capacity-approaching codes. For the same reason as in the fully parallel case, we can see that as a function of gap to capacity, the average energy per bit for a decoder must scale as

$$E_{\text{dec,avg}} \geq \frac{2\lambda_w^2 R}{j \log\left(\frac{1}{\epsilon}\right)} \left(\log\left(\frac{1}{1-\eta}\right) - j\right) = \Omega\left(\log\left(\frac{1}{1-\eta}\right)\right).$$

Finally, it can be shown from Theorem 3 that in circuits in which the output pins can grow arbitrarily, and the regular output rate condition is satisfied, the average energy per bit as a function of gap to capacity must scale as

$$E_{\text{dec,avg}} \geq \Omega\left(\log\left(\frac{1}{1-\eta}\right)^{\frac{1}{5}}\right).$$

## IX. UPPER BOUND ON ENERGY OF REGULAR LDPC CODE

We have shown that for any code and decoding circuit with block error probability that is below  $\frac{1}{2}$ , the Area-Time complexity must scale at least as fast as  $\Omega(n\sqrt{\log n})$ . We provide here an example of a particular circuit layout that achieves  $O(n^2)$  complexity. Low density parity check (LDPC) codes are standard codes first described by Gallager in [19]. There have been a number of papers that have sought to find very energy-efficient implementations of LDPC decoders; for example [20]. The reference [21] gives an overview of various techniques used to create actual VLSI implementations of LDPC decoders. However, these papers have not sought to view how the energy per bit of these decoders scales with block length; they show a method to optimize an LDPC decoder of a particular block length and show that their implementation method improves over a previous implementation. Our goal is to provide an understanding of how a particular implementation of LDPC codes should scale with block length  $n$ .

We provide a simple circuit placement algorithm that results in a circuit whose area scales no faster than  $O(|E|^2)$  where  $|E|$  is the number of edges in the circuit. For a regular LDPC code with constant node degrees, this implies that the area scales as  $O(n^2)$ .

The placement algorithm proposed involves actually instantiating the Tanner Graph of the LDPC code with wires, where each edge of the Tanner graph corresponds to a wire connected to  $n$  subcircuits that perform variable node computations and the  $n-k$  subcircuits that perform check node computations. Our concern is not about the implementation of the variable and check nodes in this circuit. In the diagram, we treat these as merely a “black box” whose area is no greater than proportional to the square of the degree of the node. Of course, the actual area of these nodes is implementation specific, but the important point is that the area of each node should only depend on the particular node degree and not on the block length of the entire code. Our concern is actually regarding how the area of the interconnecting wires scales. The wires leading out of each of these check and variable node subcircuits correspond to edges that leave the corresponding check or variable node of the Tanner graph. The challenge is then to connect the variable nodes with the check nodes with wires as they are connected in the Tanner graph in a way

consistent with our circuit axioms. We lay out all the variable nodes on the left side of the circuit, and all the subcircuits corresponding to a check node on the right side of the circuit, and place the outputs of each of these subcircuits in a unique row of the circuit grid (see Fig. 4). Note that the number of outputs for each variable and check node subcircuit will be equal to the degree of that corresponding node in the Tanner graph of the code. The height of this alignment of nodes will be  $2|E|$ , twice the number of edges in the corresponding Tanner graph (as there must be a unique row for each of the  $|E|$  edges of the variable nodes and also for the  $|E|$  edges leading from the check nodes).

The distance between these columns of check and variable nodes is  $|E|$ . Each output of the variable nodes is assigned a unique grid column that will not be occupied by any other wire (except in the case of a crossing, which according to our model is allowed). A horizontal wire is drawn until this column is reached, and then the wire is drawn up or down along this column until it reaches the row corresponding to the variable node to which it is to be attached. A diagram of the procedure to draw such a circuit for a case of 6 edges is shown in Fig. 4. Since each output of the variable and check node ‘‘black boxes’’ takes up a unique row, and each wire has a unique column, no two wires in drawing this circuit can ever run along the same edge; they can only cross, which is permitted in our model.

The total area of this circuit is thus bounded by:  $A_c \leq A_{\text{nodes}} + A_w$ , where  $A_{\text{nodes}}$  is the area of the nodes and  $A_w$  is the area of the wires. Now it is sufficient that there is a grid row for each output of the variable nodes and the check nodes, and that there is a column for each edge. Hence

$$A_w \leq 2|E| \cdot |E| = 2|E|^2.$$

We assume that the area of the subcircuits that perform the computational node operations can complete their operation in one clock cycle and take up area proportional to the square of their degree. Hence we suppose that  $A_{\text{nodes}} \leq d_v^2 n + d_c^2 (n - k)$ , where  $d_v$  is the degree of the variable nodes and  $d_c$  the degree of the check nodes. We then conclude that:

$$A_c \leq 2|E|^2 + d_v^2 n + d_c^2 (n - k).$$

The total energy for the computation will depend on the number of iterations performed. Since each iteration requires sending information for the variables nodes to the check nodes and back again, this can be performed in 2 clock cycles. Hence,  $\tau = 2N$ , where  $N$  is the number of iterations performed, and of course  $\tau$  is the number of clock cycles in the computation.

Thus, the total energy of this implementation of an LDPC code is upper bounded by

$$E_{\text{dec}} \leq 2N (2|E|^2 + d_v^2 n + d_c^2 (n - k)).$$

The work of Lentmaier *et al.* [22] has shown that for an LDPC decoder, for asymptotically low block error probability,  $\tau = O(\log \log n)$  iterations are sufficient if the node degrees are high enough. This then results in an upper bound on the energy of

$$E_{\text{dec}} \leq 2N (2(nd_v)^2 + d_v^2 n + d_c^2 (n - k)) = O(n^2 \log \log n).$$

## X. CONCLUSION

This work expands on previous work in [3] by providing a standard to which decoding algorithms together with circuit implementations can be compared. Earlier work on the energy used in decoding (for example, [20]) have involved trying to optimize a circuit that implements a particular code; they have not sought to understand how the energy scales with the length of the code.

Some work has provided an analysis of the energy requirements for specific types of codes. The work in [23] has provided a way to analyze the energy requirements for an LDPC decoder. The result of our paper is more general: it applies to any decoding algorithm. Further investigations should compare the results in this paper to existing results relating energy per bit with parameters like block error probability.



Fig. 4. An example of an implementation of an LDPC code Tanner graph. There are  $|E|$  edges that correspond to interconnections that must be made. Going left to right, starting at the top left circuit, the six parts of this diagram show the progressive addition of each additional “edge” in the circuit implementation of the Tanner Graph. Each wire has a unique column that it is allowed to run along, and each output has a unique row, ensuring that no two wires ever need to run along the same section. The only time when the wires need to intersect is during a wire crossing, which is explicitly allowed by our circuit axioms. This method can be used to draw any arbitrary bipartite graph with  $|E|$  edges.

Finally, this paper should also be used to guide the development of new codes that attempt to approach this fundamental lower bound. There may be some modifications of some types of codes, for example LDPC codes, whose Area-Time complexity is chosen to be  $O(n\sqrt{\log n})$  (for example, by choosing the neighbors of the nodes in the Tanner graph representation of such a code to limit the area of the code, or by limiting the number of iterations). Most analyses of LDPC codes assume a random Tanner graph. If the interconnections of the LDPC code are restricted to limit the area of the implementation (and thus violating the assumptions of most LDPC code analyses) will the decoder still have a good performance? The work of [11] suggests there is some kind of trade-off.

## APPENDIX

### A. Proof Of Theorem 3

To accomplish this super-linear lower bound, we divide how the number of output pins  $j$  scales with  $n$ , the block length, into cases. We suppose that  $j \geq \sqrt{\log k}$ . If not, using our result from Theorem 2, for codes with asymptotic block error probability less than  $\frac{1}{2}$ ,

$$E_{\text{dec}} \geq \frac{\lambda_w^2 R^2 n}{\log(\frac{1}{\epsilon})} \left( \frac{\log n}{j} - 1 \right),$$

if  $j < \sqrt{\log k}$  then we can show that

$$A\tau \geq \frac{\lambda_w^2 R^2 n}{\log(\frac{1}{\epsilon})} \left( \sqrt{\log k} - 1 \right) = \Omega(n\sqrt{\log n}) \geq \Omega(n(\log n)^{\frac{1}{5}})$$

and we are done.

*Remark 5.* Technically, the statement that either  $j \geq \sqrt{\log k}$  or  $j < \sqrt{\log k}$  does not fully specify all possible sequences of output pins. However, for any sequence, we can divide the sequences into separate subsequences, specifically the sequences of codes in which  $j \geq \sqrt{\log k}$  and in which  $j < \sqrt{\log k}$ . For each of those subsequences we can prove our lower bound.

Let  $\bar{A} = \frac{A}{\lambda^2}$  be the normalized circuit area. Suppose also that  $\frac{\bar{A}}{j} \leq \log^{0.9} n$ . Otherwise, if  $\frac{\bar{A}}{j} > \log^{0.9} n$  and from our simple bound in Remark 4, we can see that

$$\bar{A}\tau \geq \bar{A}\frac{k}{j} > k \log^{0.9} n \geq \Omega\left(n(\log n)^{\frac{1}{5}}\right)$$

and we are done.

Note again that, just as in Remark 5, if the area alternates between  $\log^{0.9} n$  with increasing block length, we can simply divide the sequence of decoders into two subsequences and prove that the necessary scaling law holds for each subsequence.

Hence, we consider the case that we have a sequence of serial decoding algorithms in which the area of the circuit grows with the block length  $n$  and the number of output nodes on the circuit grows with  $n$ . We consider the case in which

$$\frac{\bar{A}}{j} \leq \log^{0.9} n \tag{10}$$

and

$$j \geq \sqrt{\log k} \tag{11}$$

We will now choose a way to divide the computation into  $M$  epochs and  $N$  subcircuits.

For each of the  $M$  epochs we want the number of bits responsible on average for each decoder to decode to be four times the area. This will mean that, even if we optimistically assume that before the beginning of each epoch a circuit had already computed the future outputs, a typical subcircuit can only store a fraction of the bits it is responsible for decoding in the next epoch. Note that the number of bits that a subcircuit is responsible for in total over the entire computation must be  $\frac{k}{N}$  and hence, if the computation is to be divided into  $M$  epochs, during each epoch, an average subcircuit must be responsible for decoding  $\frac{k}{MN}$  bits. We seek to choose an  $M$  such that

$$\frac{k}{MN} \geq 4\bar{A}_{\text{subckt,avg}}$$

where  $\bar{A}_{\text{subckt,avg}}$  is the average normalized area of a subcircuit. This will be true if  $\frac{k}{MN} \geq 4\bar{A}$  or equivalently if  $M \leq \frac{k}{4\bar{A}}$  so we choose

$$M = \frac{k}{4\bar{A}}$$

We also want  $NM = \frac{cn}{\log n}$  for a constant  $c$  which we will choose later, so we choose

$$N = \frac{cn4\bar{A}}{k \log n} = \frac{c4\bar{A}}{R \log n}.$$

We need to show that this is a valid choice for  $N$ . The restriction on the choice of  $N$  is that  $N \leq j$  (we can't subdivide the circuit into more subcircuits than there are output pins). By applying the assumption on the scaling of the area of the circuit in (10) we can see that

$$\frac{4\bar{A}}{R \log n} \leq \frac{4cj \log^{0.9} n}{R \log n} = j \left( \frac{4c}{R} \right) \frac{\log^{0.9} n}{\log n}$$

is asymptotically less than  $j$ , and hence this choice of  $N$  is valid. Our choice of  $M$  is  $\frac{k}{4\bar{A}}$ . The restriction on the choice of  $M$  is that  $M \leq \frac{k}{j}$  (there must be at least one output per pin per epoch). Thus  $\frac{k}{4\bar{A}} \leq \frac{k}{j}$ ,

which will be true when  $j \leq 4A$ . But since the  $j$  output pins form part of the area of the circuit, this must always be satisfied.

On a minor technical note, we can only choose integer values of  $M$ . Hence, we can decide to choose the floor of  $M$ . But, as argued in Lemma 3 if the function for choosing  $M$  grows with  $n$  then the evaluation of a limit where we neglect this floor function is the same. So, our other requirement, that  $\lim_{n \rightarrow \infty} \frac{A}{n} = 0$  means that our choice for  $M$  grows as  $n$  increases. We consider the case when area of the computation remains proportional to  $n$  at the end of this section.

Let the number of bits injected into the  $i$ th subcircuit during the  $q$ th epoch from other parts of the circuit be  $b_{i,q}$ . Now, the average subcircuit has area  $\frac{\bar{A}}{N}$ , so we consider the set of subcircuits that have area less than  $2\frac{\bar{A}}{N}$ . This number must be at least  $\frac{1}{2}$  the subcircuits, otherwise the total area of all these subcircuits would exceed the total circuit area. Denote the set of indices of subcircuits with area less than  $2\frac{\bar{A}}{N}$  as  $T$ . Note that  $|T| \geq \frac{N}{2}$ .

Consider a specific  $q$ th epoch. Suppose that the total number of bits injected into the subcircuits indexed by  $T$  after  $r$ -stages of nested bisections during this epoch is less than  $\frac{j}{2}$ . If this is true, then there must be at least half of the subcircuits in  $T$  that have fewer than  $\frac{2j}{N}$  bits injected into them. Otherwise, the total number of bits injected into these subcircuits is at least  $\frac{|T|}{2} \frac{2j}{N} \geq \frac{N}{4} \frac{2j}{N} = \frac{j}{2}$ , which we assumed is not the case.

Thus, with our assumptions, at the  $q$ th epoch, either the total number of bits injected across  $r$ -stages of nested minimum bisections is at least  $\frac{j}{2}$ , or there are at least  $\frac{N}{4}$  subcircuits with area less than  $2\bar{A}$  that have less than  $\frac{j}{2N}$  bits injected into them. Denote the set of indices of these low area subcircuits with a low number of bits injected into them during the  $q$ th epoch as  $S_q$ . The size of  $S_q$  we have assumed to be at least  $\frac{N}{4}$ , so for the sake of simplicity define  $S_q^*$  as a subset of  $S_q$  with size exactly  $\frac{N}{4}$ . Now, consider the number of epochs during which there are less than  $\frac{j}{2}$  bits injected across all the bisections. Either this number is less than  $\frac{M}{2}$  or greater than or equal to  $\frac{M}{2}$ . Suppose that it is greater than or equal to  $\frac{M}{2}$ . Denote the set of indices denoting the epochs in which the number of bits injected across all the bisections during that epoch is less than  $\frac{j}{2}$  as  $Q$ , and a particular set of size exactly  $\frac{M}{2}$  as  $Q^*$  (chosen for simplicity of computation).

We now apply the key principle used for all the theorems in this paper. Consider a particular  $q$ th epoch where  $q \in Q^*$ , an epoch with less than  $\frac{j}{2}$  bits communicated across all the bisections. During this epoch the subcircuits in  $S_q$  are those with less than  $\frac{2j}{N}$  bits injected into them, and they have area at most  $\frac{2\bar{A}}{N}$ , and are responsible for decoding  $\frac{4\bar{A}}{N}$  bits. Let the number of input bits injected into the circuit for such a particular subcircuit be  $n_{i,q}$ . If all of these inputs are erased, then, by applying Lemma 2 the circuit must guess at least 1 output, and the probability of error is at least  $\frac{1}{2}$ , because in this case they only have  $B_{i,q} + \frac{2\bar{A}}{N} \leq \frac{2j}{N} + \frac{2\bar{A}}{N} \leq \frac{4\bar{A}}{N}$  bits to use. Using the same argument as in Theorems 2 and 1, we can show that if, for all the subcircuits in  $S_q^*$ , where  $q \in Q^*$ , in the event that for any of these subcircuits all of their  $n_{i,q}$  input bits are erased, then an error occurs with probability  $\frac{1}{2}$ . Applying this principle gives us:

$$P_e^{blk} \geq \frac{1}{2} - \prod_{q=Q^*} \prod_{i \in S_q^*} (1 - \epsilon^{n_{i,q}}) \quad (12)$$

where we note as well that

$$\sum_{q=1}^{\frac{M}{2}} \sum_{i=1}^{\frac{N}{4}} n_{i,q} \leq n.$$

Subject to those restrictions, Lemma 4 implies that the expression in (12) is minimized when each of

the  $n_{i,q}$  are equal to  $\frac{8n}{NM}$ . Hence

$$\begin{aligned} P_{e,blk} &\geq \frac{1}{2} - \left(1 - \epsilon^{\frac{8n}{NM}}\right)^{\frac{NM}{8}} \\ &\geq \frac{1}{2} - (1 - \epsilon^{8c \log n})^{\frac{\log n}{8n}}, \end{aligned}$$

which, by applying Lemma 1, can easily be shown to approach  $\frac{1}{2}$  when  $n$  gets larger, if  $c$  is chosen to be  $\frac{\log \frac{1}{\epsilon}}{8}$ . Hence, either in the limit block error probability approaches  $\frac{1}{2}$  or the size of  $Q$  is greater than  $\frac{M}{2}$ , and there are many bits communicated in the circuit for many epochs.

From Lemma 6, by recognizing that for the circuit under consideration there are at least  $j$  nodes, if there are  $B_r$  bits injected across all the  $r$ -stages of nested minimum bisections, then

$$\bar{A}\tau \geq K' B_r \sqrt{\frac{j}{2^r}}$$

where  $K' = \frac{\sqrt{2}-1}{4\sqrt{2}}$  and  $2^r = N$ , the number of subcircuits into which the circuit was divided. Thus, combining this bound with our choice for  $N$  and the assumption that there are at least  $\frac{j}{2}$  bits injected across all the bisections for epochs in  $Q^*$ , we get that either

$$\bar{A}\tau_i \geq K' \frac{j}{2} \sqrt{\frac{j}{N}}$$

for at least  $\frac{M}{2}$  epochs, or  $\lim_{n \rightarrow \infty} P_e^{blk,n} \geq \frac{1}{2}$ . Hence, in total,

$$\begin{aligned} \bar{A}\tau &\geq K' \frac{j}{2} \sqrt{\frac{j}{N}} \frac{M}{2} \\ &= K' \frac{j}{2} \sqrt{\frac{j}{N}} \frac{k}{8\bar{A}} \\ &= K' \frac{j^{1.5}}{2} \sqrt{\frac{R \log n}{4c\bar{A}}} \frac{k}{8\bar{A}} \\ \bar{A}^{2.5}\tau &\geq \frac{K'}{32} k j^{1.5} \sqrt{\frac{R \log n}{c}} \end{aligned} \tag{13}$$

We also have the bound from Remark 4:

$$\begin{aligned} \tau &\geq \frac{k}{j}, \text{ which implies} \\ \tau^{1.5} &\geq \frac{k^{1.5}}{j^{1.5}} \end{aligned}$$

and hence, combining this with (13), we get

$$\begin{aligned} \bar{A}^{2.5}\tau^{2.5} &\geq \frac{K'}{32} k^{2.5} \sqrt{\frac{R \log n}{c}} \\ \bar{A}\tau &\geq \frac{(K')^{\frac{2}{5}}}{4} k \left( \frac{8R \log n}{\log(\frac{1}{\epsilon})} \right)^{\frac{1}{5}} = \Omega\left(k (\log n)^{\frac{1}{5}}\right). \end{aligned}$$

Finally, we must consider a case when the area of the circuit scales with  $n$ . This must be treated separately because in this case our choice for  $M$  in the above argument does not necessarily grow with

$n$  and so we can't assume that our rounding approximation is valid. Thus, suppose that  $A = cn$ . Suppose also that  $j \leq \frac{k}{(\log n)^{0.9}}$ . Then

$$\tau \geq \frac{k}{j} \geq (\log n)^{0.9}$$

from Remark 4, and therefore the total Area-Time complexity of such a sequence of decoders scales as

$$A\tau \geq cn (\log n)^{0.9} = \Omega(n (\log n)^{0.9}).$$

In the other case, when  $j \geq \frac{k}{(\log n)^{0.9}}$  then we can subdivide the circuit into  $\frac{n}{\log n}$  pieces, and make the same argument that has been made in Theorem 1 that the number of bits communicated across all cuts during the course of the computation must be proportional to  $k/2$ . Recognizing that we have assumed there are at least  $cn$  nodes in the circuit and applying Lemma 6, and also substituting  $2^r = \frac{\log \frac{1}{\epsilon} n}{\log n}$  we get:

$$\bar{A}\tau \geq \frac{\sqrt{2}-1}{8\sqrt{2}} \sqrt{\frac{cR \log n}{\log(\frac{1}{\epsilon})}} n = \Omega(n \sqrt{\log n})$$

which of course is asymptotically faster than  $\Omega(n (\log n)^{\frac{1}{5}})$ .

## REFERENCES

- [1] C. E. Shannon, "A mathematical theory of communication," *Bell Sys. Techn. J.*, vol. 27, no. 3, pp. 379–423 & 623–656, 1948.
- [2] A. El Gamal, J. Greene, and K. Pang, "VLSI complexity of coding," *The MIT Conf. on Adv. Research in VLSI*, 1984.
- [3] P. Grover, A. Goldsmith, and A. Sahai, "Fundamental limits on the power consumption of encoding and decoding," in *Proc. 2012 IEEE Int. Symp. Info. Theory*, 2012, pp. 2716–2720.
- [4] C. D. Thompson, "A complexity theory for VLSI," Ph.D. Thesis, Carnegie-Mellon, 1980.
- [5] D. E. Knuth, "Big omicron and big omega and big theta," *ACM SIGACT News*, vol. 8, no. 2, 1976.
- [6] C. D. Thompson, "Area-time complexity for VLSI," *Proc. 11th Ann. ACM Symp. Theory of Comput.*, pp. 81–88, 1979.
- [7] S. L. Howard, C. Schlegel, and K. Iniewski, "Error control coding in low-power wireless sensor networks: When is ECC energy-efficient?" *EURASIP J. on Wireless Commun. and Netw.*, pp. 1–14, 2006.
- [8] J. Rabaey, A. Chandrakasan, and B. Nikolic, *Digital Integrated Circuits*. Englewood Cliffs, NJ, USA: Prentice Hall, 2003.
- [9] W. Yu, M. Ardashani, B. Smith, and F. R. Kschischang, "Complexity-optimized low-density parity-check codes for Gallager decoding algorithm B," in *Proc. 2005 IEEE Int. Symp. on Info. Theory*, 2005, pp. 1488–1492.
- [10] J. Cooley and J. W. Tukey, "An algorithm for the machine calculation of complex Fourier series," *Math. Comput.*, 1965.
- [11] J. Thorpe, "Design of LDPC graphs for hardware implementation," in *Proceedings of 2002 IEEE International Symposium on Information Theory*, 2002, p. 483.
- [12] C.-H. Yeh, E. Varvarigos, and B. Parhami, "Multilayer VLSI layout for interconnection networks," in *Proc. Intl Conf. Parallel Processing*, 2000, pp. 33–40.
- [13] J. S. Denker, "A review of adiabatic computing," in *1994 IEEE Symposium on Low Power Electronics*, 1994, pp. 94–97.
- [14] P. Grover, "'Information-friction' and its implications on minimum energy required for communication," *CoRR*, vol. abs/1401.1059, 2014. [Online]. Available: <http://arxiv.org/abs/1401.1059>
- [15] M. Garey, D. Johnson, and L. Stockmeyer, "Some simplified NP-complete graph problems," *Theoretical Computer Science*, vol. 1, no. 3, pp. 237 – 267, 1976. [Online]. Available: <http://www.sciencedirect.com/science/article/pii/0304397576900591>
- [16] V. Strassen, "Asymptotische abschätzungen in Shannons Informationstheorie," in *in Transactions of the 3rd Prague Conference on Information Theory, Statistical Decision Functions, Random Processes*. Prague: Pub. House of the Czechoslovak Academy of Sciences, 1962, pp. 689–723.
- [17] R. G. Gallager, *Information Theory and Reliable Communication*. New York, NY, USA: John Wiley & Sons, Inc., 1968.
- [18] Y. Polyanskiy, "Channel coding: non-asymptotic fundamental limits," Ph.D. dissertation, Princeton University, Nov. 2010.
- [19] R. Gallager, "Low-density parity-check codes," *Information Theory, IRE Transactions on*, vol. 8, no. 1, pp. 21–28, 1962.
- [20] A. Darabiha, A. Chan Carusone, and F. R. Kschischang, "Power reduction techniques for LDPC decoders," *IEEE J. of Solid-State Circuits*, vol. 43, no. 8, pp. 1835–1845, Aug. 2008.
- [21] C. Roth, A. Cevrero, C. Studer, Y. Leblebici, and A. Burg, "Area, throughput, and energy-efficiency trade-offs in the VLSI implementation of LDPC decoders," in *2011 IEEE International Symposium on Circuits and Systems (ISCAS)*, May 2011, pp. 1772–1775.
- [22] M. Lentmaier, D. Truhachev, K. Zigangirov, and D. Costello, "An analysis of the block error probability performance of iterative decoding," *IEEE Transactions on Information Theory*, vol. 51, no. 11, pp. 3834–3855, Nov 2005.
- [23] M. Korb and T. G. Noll, "LDPC decoder area, timing, and energy models for early quantitative hardware cost estimates," in *2010 Int. Symp. System on Chip*, Sep. 2010, pp. 169–172.