# Digital Logic Design: a rigorous approach © Chapter 15: Addition Guy Even Moti Medina School of Electrical Engineering Tel-Aviv Univ. May 21, 2020 Book Homepage: http://www.eng.tau.ac.il/~guy/Even-Medina # Definition of a binary adder #### Definition ADDER(n) - a binary adder with input length n is a combinational circuit specified as follows. Input: $A[n-1:0], B[n-1:0] \in \{0,1\}^n$ , and $C[0] \in \{0,1\}$ . Output: $S[n-1:0] \in \{0,1\}^n$ and $C[n] \in \{0,1\}$ . Functionality: $$\langle \vec{S} \rangle + 2^n \cdot C[n] = \langle \vec{A} \rangle + \langle \vec{B} \rangle + C[0].$$ (1) Addition terminology: - addends: $\langle \vec{A} \rangle = \sum_{i=1}^{n-1} A[i] \cdot 2^i$ , and $\langle \vec{B} \rangle = \sum_{i=1}^{n-1} B[i] \cdot 2^i$ - carry-in bit : C[0] - sum: $\langle \vec{S} \rangle$ - carry-out bit: C[n] # binary adder definition (cont) #### Definition ADDER(n) - a binary adder with input length n is a combinational circuit specified as follows. Input: $A[n-1:0], B[n-1:0] \in \{0,1\}^n$ , and $C[0] \in \{0,1\}$ . Output: $S[n-1:0] \in \{0,1\}^n$ and $C[n] \in \{0,1\}$ . Functionality: $$\langle \vec{S} \rangle + 2^n \cdot C[n] = \langle \vec{A} \rangle + \langle \vec{B} \rangle + C[0].$$ (2) #### Claim (ADDER(n) is well defined) For every $A[n-1:0], B[n-1:0] \in \{0,1\}^n$ , and $C[0] \in \{0,1\}$ , there exist $S[n-1:0] \in \{0,1\}^n$ and $C[n] \in \{0,1\}$ such that $$\langle \vec{S} \rangle + 2^n \cdot C[n] = \langle \vec{A} \rangle + \langle \vec{B} \rangle + C[0]$$ adder (n) well defined 0 { (a) + (b) + c[0] { 2.(2^-1) + 1 $= 2^{n+1} - 1$ and SEN-1:0], CEN] can represent all numbers in the range $\{0,1,\ldots,2^{n+1}-1\}$ #### Full Adder An ADDER(1) is called a full adder. #### Definition (Full-Adder) FA - a Full-Adder is a combinational circuit with 3 inputs $x,y,z\in\{0,1\}$ and 2 outputs $c,s\in\{0,1\}$ that satisfies: $$2c + s = x + y + z.$$ Terminology: *s* -sum output, *c* -carry-out output. #### Claim $$(e \times erci \& e)$$ $$s = x \oplus y \oplus z,$$ $$c = (x \cdot y) \lor (y \cdot z) \lor (x \cdot z).$$ # Ripple Carry Adder RCA(n) - same addition algorithm that we use for adding numbers by hand. - row of *n* Full-Adders connected in a chain. - the weight of every signal is two to the power of its index. (Do not confuse weight here with Hamming weight. Weight means here the value in binary representation.) # Recursive definition of RCA(n) (want to prove that $$(\vec{5}) + 2^n \cdot (\vec{E}) = (\vec{A}) + (\vec{B}) + (\vec{0})$$ Basis: an RCA(1) is simply a Full-Adder. Reduction Step: ## RCA(n) - correctness #### Claim RCA(n) is a correct implementation of ADDER(n). ``` correctness of RCA(n) by ind. on n. basis: N=1 (FA is correct) hyp: RCA(n-1) is correct. Step: (A[n-1:0]) + (B[n-1:0]) + C[0] = 2^{n-1} \cdot (A[n-1] + B[n-1]) + \langle A[n-2:0] \rangle + \langle B[n-2:0] \rangle + \langle C_0| = 2^{n-1} \left( A[n-1] + B[n-1] + 2^{n-1} c[n-1] + \langle S[n-2:0] \rangle \right) = 2"-1 (A[n-1] + B[n-1] + C[n-1]) + (S[n-2:0]) =2^{n-1}\cdot(S[n-1]+2\cdot C[n])+(S[n-2:0]) = 27. C[n] + (S[n-1:0]> > ``` ## Delay and cost analysis The cost of an RCA(n) satisfies: $$c(\text{RCA}(n)) = n \cdot c(\text{FA}) = \Theta(n).$$ The delay of an RCA(n) satisfies $$d(\text{RCA}(n)) = n \cdot d(\text{FA}) = \Theta(n).$$ Clock rates in modern microprocessors correspond to the delay of 15-20 gates (in more aggressive designs, the critical paths are even shorter). Most microprocessors easily add 32-bit numbers within one clock cycle (high-end microprocessors even add 100-bit number in a cycle). Obviously, adders in such microprocessors are not Ripple Carry Adders. ## Carry bits We now define the carry bits associated with the addition $$\langle A[n-1:0] \rangle + \langle B[n-1:0] \rangle + C[0] = \langle S[n-1:0] \rangle + 2^n \cdot C[n]$$ #### Definition The carry bits C[n:0] are defined as the values of the stable signals C[n:0] in an RCA(n). This definition is well defined in light of the Simulation Theorem of combinational circuits. ## Cone of adder outputs The correctness proof of RCA(n) implies that, for every $0 \le i \le n-1$ , $$\langle A[i:0]\rangle + \langle B[i:0]\rangle + C[0] = 2^{i+1} \cdot C[i+1] + \langle S[i:0]\rangle.$$ Hence, for every $0 \le i \le n-1$ : $$C[i+1] = 1 \iff \langle A[i:0] \rangle + \langle B[i:0] \rangle + C[0] \ge 2^{i+1}$$ $$\langle S[i:0] \rangle = \operatorname{mod}(\langle A[i:0] \rangle + \langle B[i:0] \rangle + C[0], 2^{i+1}).$$ #### Claim For each $0 \le i \le n-1$ , the cone of Boolean functions corresponding to C[i+1] and S[i] consists of 2i+3 inputs corresponding to A[i:0], B[i:0], and C[0]. cone of addition proof that c[0] E cone (c[n]) (Similar proof shows that all inputs are in the cone of C[n] & S[n-1].) O CED 011.--1 100 ---- 0 (6) C[n] #### Lower bounds #### Claim \_ Let $\not$ denote a combinational circuit that implements an ADDER(n). If the fan-in in C is at most 2, then $$c(A) \ge 2n$$ , $d(A) \ge \log_2(2n+1)$ . Compare with the cost and delay of RCA(n). $$C(RCP(M)) = \Theta(N)$$ $C(RCP(M)) = \Theta(N)$ The rules are: -at the end we must know the sum. -it doesn't matter who has which sum bits. -communcation is costly, and -our goal is to compute the sum asap. # Conditional Sum Adder CSA(n) #### Claim The CSA(n) is a correct ADDER(n) design. ind. on n. we show the ind. step: Alice $C[K] = 2^{K} + \langle S[K-1:0] \rangle = \langle A[K-1:0] \rangle + \langle B[K+1:0] \rangle + c[v]$ $2^{N-K} \cdot C[n] + \langle S[n-1:K] \rangle = \langle A[n-1:K] \rangle + \langle B[n-1:K] \rangle + c[k] \rangle$ $2^{N-K} \cdot C[n] + \langle S[n:0] \rangle + c[k] \cdot 2^{K} = \langle A[n-1:0] \rangle + \langle B[n-1:0] \rangle + c[k] \cdot 2^{K} + c[n]$ M # Delay analysis To simplify the analysis we assume that $n=2^{\ell}$ . To optimize the delay, we use k=n/2. Let d(FA) denote the delay of a Full-Adder. The delay of a CSA(n) satisfies the following recurrence: $$d(\operatorname{CSA}(n)) = egin{cases} d(\operatorname{FA}) & \text{if } n = 1 \\ d(\operatorname{CSA}(n/2)) + d(\operatorname{MUX}) & \text{otherwise.} \end{cases}$$ Hence, the delay of a CSA(n) is $$d(CSA(n)) = \ell \cdot d(MUX) + d(FA)$$ = $\Theta(\log n)$ . # Cost analysis. Let c(FA) denote the cost of a Full-Adder. The cost of a CSA(n) satisfies the following recurrence: $$c(\mathrm{CSA}(n)) = egin{cases} c(\mathrm{FA}) & \text{if } n = 1 \\ 3 \cdot c(\mathrm{CSA}(n/2)) + (n/2 + 1) \cdot c(\mathrm{MUX}) & \text{otherwise.} \end{cases}$$ the solution of this recurrence is $c(CSA(n)) = \Theta(n^{\log_2 3})$ . - $\log_2 3 \approx 1.58$ , so a CSA(n) is costly. - but delay is logarithmic! - the CSA(n) design uses three half-size adders (easy to use). $$f(n) = 3 \cdot f(\frac{2}{n}) + \theta(n)$$ $$f(n) = \theta(n | 3^{2^{3}}) \approx \theta(n'.58)$$ # Compound Adder #### Definition COMP-ADDER(n) - a Compound Adder with input length n is a combinational circuit specified as follows. Input: $$A[n-1:0], B[n-1:0] \in \{0,1\}^n$$ . Output: $S[n:0], T[n:0] \in \{0,1\}^{n+1}$ . Functionality: $$\begin{split} \langle \vec{S} \rangle &= \langle \vec{A} \rangle + \langle \vec{B} \rangle + \bigcirc \\ \langle \vec{T} \rangle &= \langle \vec{A} \rangle + \langle \vec{B} \rangle + 1. \end{split}$$ Note that a Compound Adder does not have carry-in input. To simplify notation, the carry-out bits are denoted by S[n] for the sum and by T[n] for the incremented sum. ## COMP-ADDER(n) - Implementation **basis:** n = 1, we simply use a Full-Adder and a Half-Adder. **reduction step:** # COMP-ADDER(n) - example #### Example Consider a COMP-ADDER(4) with input A[3:0] = 0110 and B[3:0] = 1001. # COMP-ADDER(n) - example #### Claim The COMP-ADDER(n) design is a correct adder. comp-adder (n) correctness can be proved directly (see book) we will use a reduction to CSA(N). argue that compadder output same as CSA with C[0]=0. compadder output for T: argue that same as CSA with c[0]=1. # Delay analysis To simplify the analysis we assume that $n=2^{\ell}$ . To optimize the delay, we use k=n/2. The delay of a COMP-ADDER(n) satisfies the following recurrence: $$d(\text{COMP-ADDER}(n)) = egin{cases} d(\text{FA}) & \text{if } n = 1 \\ d(\text{COMP-ADDER}(n/2)) + d(\text{MUX}) & \text{otherwise.} \end{cases}$$ Hence, $$d(\text{COMP-ADDER}(n)) = \ell \cdot d(\text{MUX}) + d(\text{FA})$$ = $\Theta(\log n)$ . # Cost analysis The cost of a COMP-ADDER(n) satisfies the following recurrence: $$c(\text{COMP-ADDER}(n)) = egin{cases} c(\text{FA}) + c(\text{HA}) & & \\ 2 \cdot c(\text{COMP-ADDER}(n/2)) + (n/2+1) \cdot c(\text{MUX}) \end{cases}$$ Hence, $c(\text{COMP-ADDER}) = \Theta(n \log n)$ . $$n.bn$$ $\sim n^{b_2^3} \approx n^{1.58}$ SURPRISE!!! $c(\text{COMP-ADDER}(n)) \ll c(\text{CSA}(n))$ . $$f(n) = 2.f(\frac{2}{2}) + \theta(n)$$ $$f(n) = \theta(n | \leq n)$$ ## Reductions between sum and carry bits The correctness of RCA(n) implies that, for every $0 \le i \le n-1$ , $$C[i] \oplus S[i] \oplus A[i] \oplus B[i] \oplus C[i] \qquad \text{(3)}$$ $$\oplus C[i] \oplus S[i] \oplus S[i]$$ By xoring $C[i] \oplus S[i]$ to both sides, we obtain, $$C[i] = A[i] \oplus B[i] \oplus S[i] . \tag{4}$$ # Summary - defined binary addition. - Three adder designs: Ripple Carry Adder, Conditional Sum Adder, Compound Adder. - The problems of computing the sum bits and the carry bits are equivalent with respect to a constant-time linear-cost reduction. Since the cost of every adder is $\Omega(n)$ and the delay is $\Omega(\log n)$ , we regard the problems of computing the sum bits and the carry bits as equivalently hard. - Design methodology: divide & conquer. - Surprise! COMP-ADDER(n) is much cheaper asymptotically than a CSA(n). - Left to show: an adder with linear cost and logarithmic delay....