## Chapter 1

# Combinational Building Blocks (2.8)

## 1.1 K-maps

Graphical way to find simplified equations. The goal is to circle the largest groups of truth outputs. For each circle, create a sum of products equation where each term includes the products that change. For example:



## 1.2 Multiplexers (Mux)

Often called a mux, a multiplexer is a combinational circuit that chooses among several possible inputs with a select signal Below is a k-map and implementation of a Mux



### 1.3 Larger Multiplexers

Larger multiplexers can be used as well. We will need a *select* signal of  $\lg(n)$  for an n:1 input multiplexer



There are three ways to implement a mux: Two level logic, Tri-states, and hierarchical



Larger Multiplexers can also be used as lookup tables to perform any function and can be reprogrammed with different inputs. In general, a  $2^n$  input Multiplexer can be "reprogrammed" to perform any n-input logic function. In addition, one strategy for cutting the size in half. You do this by providing one of the literals of the logic function to the input of the Mux. This allows for  $2^{n-1}$  input Mux.

### 1.4 Decoders

A decorder is, in a sense, the opposite of a Mux. It has N inputs, and  $2^n$  outputs. The outputs are *one hot*. That is, only one is True / 1.



Decoders combined with OR gates can be used to create other logic functions. Since they are one-hot they represent a single min-term. It makes it easy to implement something like an XNOR.



## Chapter 2

# Arithmetic Circuits (5.2)

Arithmetic circuits are combinational logic functions that perform the typical arithmetic operations (addition, subtraction, multiplication, division). They are fundemental in modern computing.

#### 2.1 addition

#### 2.1.1 Half Adder

Adds two bits and has one *carry-out* bit to perform binary addition. There are 2 inputs for each singular bit and then two outputs. The output signal S represents the single bit output and the output signal  $C_{out}$  is for the Carry-bit for the next position / adder.

They can be made from an XOR gate and an AND gate. The  $C_{out}$  bit will be used when creating multi-bit adders from these single bit ones.



#### 2.1.2 Full Adder

Accepts a carry-in  $C_{in}$  bit from a Half-adder. It basically adds 3 1-bit inputs in order to output two bits



#### 2.1.3 Carry Propagate Adder (CPA)

These circuits can be put together to create a Carry Propagate Adder. This takes two N-bit inputs and a 1-bit  $C_{in}$  to produce a N-bit S, and a 1-bit  $C_{out}$ .

#### 2.1.4 Ripple Carry Adder

This is the simplest way to create a CPA. Here, you chain together full adders along with 1 Half-adder at the end.



The disadvantage with Ripple Carry Adders is that it becomes slow when N is large. The bits must wait for each bit to add before it.

This is the formula for the speed of a ripple carry adder, where  $t_{\rm FA}$  is the delay of the full adder:

$$t_{\text{ripple}} = Nt_{\text{FA}}$$

#### 2.1.5 Carry-Lookahead Adder

This is another type of CPA, which tries to fix the speed problem of Ripple-carry adders. It attempts to divide the adder into blocks and determines the  $C_{out}$  as soon as the  $C_{in}$  is known.

CLA's use G Generate and P Propagate signals to find the  $C_{out}$ . These signals do not depend on previous inputs

- 1. A  $G_i$  signal is made if both  $A_i$  and  $B_i$  are 1
- 2. A  $P_i$  if a carry if either  $A_i$  or  $B_i$  are 1

$$C_i = A_i B_i + (A_i + B_i) C_{i-1} = G_i + P_i C_{i-1}$$

In other words, there will be a carry if the  $i^{\rm th}$  column generates or is able to propagates a carry. We can rewrite this into blocks.

$$G_{3:0} = G_3 + P_3(G_2 + P_2(G_1 + P_1G_0))$$

$$P_{3:0} = P_3P_2P_1P_0$$

$$C_i = G_{i:j} + P_{i:j}C_j$$

The key is that the Generate and Propagate signals can be found immediately without waiting for the previous column



Where  $t_{pg}$  is the delay of the (P, G) gates.  $t_{pg\_block}$  is the delay to find the gen/prop signals. k is the bits per block and N is the number of blocks.

$$T_{\text{CLA}} = t_{\text{pg}} + t_{\text{pg-block}} + \left(\frac{N}{k} - 1\right) t_{\text{AND-OR}} + k t_{\text{FA}}$$

#### 2.1.6 Prefix Adders

These are the same as the Carry lookahead adders, however they calculate the  $G_i$  and  $P_i$  signals for each 2 columns, then every 4 columns etc.

$$S_i = (A_i \oplus B_i) \oplus C_{i-1}$$



The critical path of an N-bit prefix adder involves the combination of  $P_i$  and  $G_i$  followed by  $\lg N$  stages of black prefix cells

$$t_{PA} = t_{pg} + \lg N \left( t_{pg\text{-prefix}} \right) + t_{XOR}$$