

## Number systems and binary codes

- ↳ Binary
- ↳ Octal
- ↳ Decimal
- ↳ Hexadecimal

representation of numbers

signed      unsigned

$$+8 = 01000$$

$$8 = 1000 \text{ unsigned}$$

|    |         | MSB: 1 → -ve bits                        | $r^n - N$ → no               |
|----|---------|------------------------------------------|------------------------------|
|    |         | Sign magnitude form                      | 1's complement               |
| g  | 00 : +0 | $+x = +x$                                | $(r-1)'s \text{ complement}$ |
| 01 | +1      | $+x = +x$                                |                              |
| 10 | -0      | $-x = +x$                                |                              |
| 11 | -1      | $+x = 0101 = x$<br>$-x = 1010 = \bar{x}$ |                              |

Range:

$$-(2^{n-1} - 1) \text{ to } +(2^{n-1} - 1)$$



| binary | decimal |
|--------|---------|
| 000    | +0      |
| 001    | +1      |
| 010    | +2      |
| 011    | +3      |
| 100    | -3      |
| 101    | -2      |
| 110    | -1      |
| 111    | 0       |

Range:

$$-(2^{n-1} - 1) \text{ to } +(2^{n-1} - 1)$$

If  $a_3a_2a_1a_0 = N$  (2's complement)

$$a_3a_2a_3a_2a_1a_0 = N$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{+ve}}{\curvearrowleft} 2N$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{-ve}}{\curvearrowleft} 2N$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{+ve}}{\curvearrowleft} 2N+1$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{-ve}}{\curvearrowleft} 2N+1$$

If  $a_3a_2a_1a_0 = N$  (1's complement)

$$a_3a_2a_3a_2a_1a_0 = N$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{+ve}}{\curvearrowleft} 2N$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{-ve}}{\curvearrowleft} 2N+1$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{+ve}}{\curvearrowleft} 2N+1$$

$$\rightarrow a_3a_2a_1a_0 = \stackrel{\text{-ve}}{\curvearrowleft} 2N$$

BCD

defined from 0000 to 1001

BCD

→ weighted/non weighted

→ 8421, XS-3

BINARY CODES → self complementary / non self complementary

→ cyclic (Gray code)

conserves w/ 1-bit change

Types of weighted codes: 8421 / 2421 --

AK If sum of all weights = 9, self complementary code

$$(45.625)_{10} \rightarrow (?)_2$$

$$\begin{array}{r} 2 \\ \times 1 \end{array} \quad \begin{array}{r} 45 \\ 22 \\ 11 \\ 5 \\ 0 \\ 1 \\ 1 \end{array}$$

$$0.625 \times 2 = 1.250$$

$$0.250 \times 2 = 0.5$$

$$0.5 \times 2 = 1.0$$

$$\text{Ans: } (101101.101)_2$$

$$X = X_{\text{MSB}} \dots X_{\text{LSB}}$$

$$Y = Y_{\text{MSB}} \dots Y_{\text{LSB}}$$

$$Z = Z_{\text{MSB}} \dots Z_{\text{LSB}}$$

$$\text{Overflow: } \overline{X}_{\text{MSB}} \cdot Y_{\text{MSB}} \cdot Z_{\text{MSB}} \rightarrow \text{no overflow}$$

$$+ X_{\text{MSB}} \cdot Y_{\text{MSB}} \cdot \overline{Z}_{\text{MSB}}$$

↑ 1 overflow

Note  
need min 5 bit to represent  $\{-10\}$  in 1's complement

$$x = -4 \quad \begin{array}{r} 1 \\ 0 \\ 1 \\ 1 \end{array}$$

$$y = +3 \quad \begin{array}{r} 0 \\ 0 \\ 1 \\ 1 \end{array}$$

$$\text{MSB } 1 \rightarrow \text{-ve}$$

$$\text{Ans: } -(\begin{array}{r} 1 \\ 1 \\ 1 \\ 0 \end{array})$$

$$= -(0001)$$

$$= -1$$

$$x = +4 \quad \begin{array}{r} 0 \\ 1 \\ 0 \\ 0 \end{array}$$

$$y = -3 \quad \begin{array}{r} 1 \\ 1 \\ 0 \\ 0 \end{array}$$

$$\text{if carry generated} \quad \begin{array}{r} 1 \\ 0 \\ 0 \\ 0 \\ 0 \end{array} \rightarrow \begin{array}{r} 1 \\ 1 \\ 1 \\ 0 \\ 1 \end{array}$$

$$\text{Ans: } +1$$

$$(r-1)'s \quad \begin{array}{r} 9 \\ (62)_10 \end{array} \text{ complement} \quad \begin{array}{r} 99 \\ 62 \\ 34 \end{array}$$

OVERFLOW  
when 2+ve/2-ve nos. are added, and if the result is -ve or +ve, it means overflow has occurred

consider 5 bit as -9 represented in 5 bit

$$\begin{array}{r} -4 \\ -5 \\ = \end{array} \begin{array}{r} 11011 \\ 10111 \\ \hline 10111 \end{array}$$

Ans X because of OVERFLOW

$$\begin{array}{r} -4 \\ -5 \\ = \end{array} \begin{array}{r} 11100 \\ 11011 \\ \hline 11011 \end{array}$$

$$\text{Ans: } 10111 = -9$$

Same issue when

$$\begin{array}{r} +4 \\ +5 \\ = \end{array} \begin{array}{r} 00100 \\ 00101 \\ \hline 01001 \end{array}$$

$$+5 = 00101$$

$$01001 = +9$$

$$(r)'s \quad -x = \bar{x} + 1 = y$$

$$+\bar{x} = y - 1$$

$$x = y - 1$$

e.g. 10

$$+\bar{x} = 10 - 0 = 1$$

$$= 01$$

$$x = -(01) = -(10)$$

$$= -2$$

-3 = 101  
to represent 10 in 4 bits

$$-3 = 1101$$

A = +4 = 0100

$$B = -3 = 1101$$

$$A - B = 0001$$

carry neglected

$$A - B = 0001$$

final carry indicator

$$1 \rightarrow +ve \text{ flags}$$

$$0 \rightarrow -ve \text{ flags}$$

| Decimal | XS-3 |
|---------|------|
| 0       | 000  |
| 1       | 0100 |
| 2       | 0101 |
| 3       | 0110 |
| 4       | 0111 |
| 5       | 1000 |
| 6       | 1001 |
| 7       | 1010 |
| 8       | 1011 |
| 9       | 1100 |

$$(2)_{XS3} = (01000101)_2$$

29

$$\begin{array}{r} 0010 \\ 0111 \\ \hline 1001 \end{array}$$

0: +ve over flow

$$\rightarrow (000) \rightarrow 0111$$

### Gray code

| Dec | Code | Binary | Gray |
|-----|------|--------|------|
| 0   | 0000 | 000    | 000  |
| 1   | 0001 | 001    | 001  |
| 2   | 0011 | 010    | 011  |
| 3   | 0010 | 011    | 010  |
| 4   | 0110 | 100    | 110  |
| 5   | 0111 | 101    | 111  |
| 6   | 0101 | 110    | 101  |
| 7   | 0100 | 111    | 100  |
| 8   | 1100 |        |      |
| 9   | 1101 |        |      |
| 10  | 1111 |        |      |



even parity generator =  $x_1 \oplus x_2 \oplus x_3 \oplus x_4$ , checker =  $x_1 \oplus x_2 \oplus x_3 \oplus x_4 \oplus P_c \rightarrow 0$  no error  
 odd =  $\overline{x_1 \oplus x_2 \oplus x_3 \oplus x_4}$ , checker =  $\overline{x_1 \oplus x_2 \oplus x_3 \oplus x_4 \oplus P_b} \rightarrow 0$  no error

S code: even parity

↪  $\leq C_2$  ways.

|       |
|-------|
| 00011 |
| 00101 |
| 00110 |
| 01001 |
| 01010 |
| 01100 |
| 10001 |
| 10010 |
| 10100 |
| 11000 |

### MULTIPLICATION

hexadecimal

$$\begin{array}{r}
 36 \rightarrow 16(2)+4 \\
 33+2 \rightarrow 35 \\
 30+2 \rightarrow 32
 \end{array}
 \quad
 \begin{array}{r}
 \overset{2}{A} \overset{2}{B} C \\
 \times \overset{2}{2} \overset{2}{3} \\
 \hline
 \begin{array}{r}
 2034 \\
 15780 \\
 \hline
 177B4
 \end{array}
 \end{array}
 \quad
 \begin{array}{r}
 94 \\
 \times 12 \\
 \hline
 128 \\
 +940 \\
 \hline
 A68
 \end{array}$$

$$18 \rightarrow 16+2$$

## ANALOG VS DIGITAL

continuous  
takes ANY value within given limit

↳ minimizes the effect of noise (unwanted signal)

→ DTS (discrete time signal)

Independent axis ( $x$ ) is recorded @ values marked by lines, rest of it assumed.  
 $\Delta t = t_1 - t_0 = t_2 - t_1 = \dots$



analog to digital converter

Analog  $\xrightarrow[\text{in}]{\text{ADC}}$   $\text{DIGITAL SYSTEM}$   $\xrightarrow{\text{DAC}} \text{Analog out}$

## LOGIC GATES AND BOOLEAN ALGEBRA



### BUFFER

$2T_{pd}$  delay

### TRI STATE BUFFER



n variables:  $2^{(n-1)}$  Self duals

(logical expression)

No. of boolean functions for n-variables =  $2^{2^n}$

n: no. of levels  
m: no. of switch

$n = 2^m$   
(no. of min/max terms)

$$(A')' = A$$

$$\begin{aligned} A \cdot A &= A \\ A \cdot 0 &= 0 \\ A \cdot 1 &= A \\ A \cdot A' &= 0 \end{aligned}$$

$$\begin{aligned} A + A &= A \\ A + 0 &= A \\ A + 1 &= A \\ A + \bar{A} &= 1 \end{aligned}$$

POS

$$A + B \quad AB' \quad A'B' \quad A'B$$

|       | AB | CD |   |
|-------|----|----|---|
| A+B   | 00 | 00 | 0 |
| A+B'  | 01 | 01 | 1 |
| A'+B' | 11 | 11 | 1 |
| A'+B  | 10 | 10 | 0 |

| IP | f <sub>1</sub> | f <sub>2</sub> | f <sub>3</sub> | f <sub>4</sub> |
|----|----------------|----------------|----------------|----------------|
| 0  | 0              | 0              | 1              | 1              |
| 1  | 0              | 1              | 0              | 1              |
|    | ↓              | ↓              | ↓              | ↓              |
| 0  | X              | X              | X              | 1              |

NOT

$$x \rightarrow f = \bar{x}$$

BUFFER

$$x \rightarrow f = x$$

for propagation delay

$$x \rightarrow f = x$$

design of a buffer.

| enable | input | output |
|--------|-------|--------|
| 0      | 0     | High Z |
| 0      | 1     | High Z |
| 1      | 0     | 0      |
| 1      | 1     | 1      |

when enable = 1, it acts as a buffer  
enable = 0, no output

HIGH IMPEDANCE STATE

Duality

|                       | one times dual gives same expression |
|-----------------------|--------------------------------------|
| $x \cdot 0 = 0$       | $x+1 = 1$                            |
| $x \cdot \bar{x} = 0$ | $x+\bar{x} = 1$                      |
| $x+0 = x$             | $x \cdot 1 = x$                      |
|                       |                                      |

$$G = (A+B)(B+C)(A+C)$$

$$G = AB+AC+BC$$

$$G = AB+AC+BC$$

$$A+B = B+A \text{ dual}$$

$$A \cdot B = B \cdot A$$

$$(A+B)' = A' \cdot B'$$

$$(A \cdot B)' = A'+B'$$

$$(x+y)(x \cdot y) = 0 \Rightarrow x \cdot y + x \cdot y = 0$$

$$(x+y)+(z \cdot y) = 1 \Rightarrow (x+z+y) \cdot (x+y+\bar{y})$$

$$\Rightarrow (1+y) \cdot (1+x) = 1 \cdot 1 = 1.$$

## REDUNDANCY THEOREM

$$Y = AB + A'C + BC(A+B')$$

$$Y = AB + A'C$$

$$\begin{aligned} Y &= AB + A'C + BC(A+B') \\ &= AB + ABC + A'C + A'B'C \\ &= AB(1+C) + A'C(1+B) \\ &= AB + A'C. \end{aligned}$$

EPI: group of 1's (largest) w/ at least one 1 that CANNOT be paired/combined in any other way.

|    | $\bar{A}$ |                 |                 |                 | A               |    |    |                 |                 |                 |                 |
|----|-----------|-----------------|-----------------|-----------------|-----------------|----|----|-----------------|-----------------|-----------------|-----------------|
| BC | DE        | 00              | 01              | 11              | 10              | BC | DE | 00              | 01              | 11              | 10              |
| 00 | 00        | m <sub>0</sub>  | m <sub>1</sub>  | m <sub>3</sub>  | m <sub>2</sub>  | 00 | 00 | m <sub>16</sub> | m <sub>17</sub> | m <sub>19</sub> | m <sub>18</sub> |
| 01 | 01        | m <sub>4</sub>  | m <sub>5</sub>  | m <sub>7</sub>  | m <sub>6</sub>  | 01 | 01 | m <sub>20</sub> | m <sub>21</sub> | m <sub>23</sub> | m <sub>22</sub> |
| 11 | 11        | m <sub>12</sub> | m <sub>13</sub> | m <sub>15</sub> | m <sub>14</sub> | 11 | 11 | m <sub>28</sub> | m <sub>29</sub> | m <sub>31</sub> | m <sub>30</sub> |
| 10 | 10        | m <sub>8</sub>  | m <sub>9</sub>  | m <sub>11</sub> | m <sub>10</sub> | 10 | 10 | m <sub>24</sub> | m <sub>25</sub> | m <sub>27</sub> | m <sub>26</sub> |

## MINIMAL $\rightarrow$ CANONICAL

① no. of total variables

② identify the variables absent in each min term

③ use property  $1 = A + A'$ ,  $A \cdot 1 = 1$  to add missing min terms

SOP minterms

$$\text{eg. } Y = A + B'C$$

$$Y = A(B + B')(C + C') + (A + A')B'C$$

$$\begin{aligned} f(x, y, z) &= E(2, 6, 7) + \pi(1, 3, 6, 7) \\ &= E(2, 6, 7) + E(0, 2, 4, 5) \\ &= E(0, 2, 4, 5, 6, 7) \\ &= \pi(0, 1, 3) \end{aligned}$$

$$f_1 \Rightarrow f \Rightarrow g$$

$$f_1(x, y, z) = E(1, 2, 3, 4, 7)$$

$$f_2(x, y, z) = E(0, 1, 4, 6)$$

$$\therefore f = E(1, 4)$$

$$g = \pi(1, 4)$$

$$f_1 \Rightarrow f \Rightarrow g$$

$$f = E(0, 1, 2, 3, 4, 5, 7)$$

$$g = \pi(0, 1, 2, 3, 4, 6, 7)$$



$$\begin{aligned} A \oplus A &= 0 \\ A \oplus \bar{A} &= 1 \\ A \oplus 0 &= A \\ A \oplus 1 &= A' \\ A \oplus A \oplus A &= A \end{aligned}$$

$$\begin{aligned} A \oplus A \oplus \dots \oplus A &= A \quad n: \text{odd} \\ &\quad - 0 \quad n: \text{even} \end{aligned}$$

$$\begin{aligned} A \oplus A &= 1 \\ A \oplus \bar{A} &= 0 \\ A \oplus 0 &= A \\ A \oplus 1 &= A \\ A \oplus A \oplus A &= A \end{aligned}$$

$$A \oplus A \oplus \dots \oplus A = A \quad n: \text{odd}$$

$$\begin{aligned} \text{ODD NO of input} \\ \text{XOR} &= \text{XNOR} \\ \text{EVEN NO. complement} \end{aligned}$$

## Logic Gates using only NAND Gates



## Logic Gates using only NOR Gates



motherboard → subcircuit in → LOGIC  
 a chip                    GATES            circuit → transistor → transistor on  
 a chip

What does digital mean?

- Very simply, it means that the device or the system works with digits, numbers, discrete quantities.
- These numbers are usually, at least in the interior of the device, binary numbers—0s and 1s.
- We usually see the results as “people” numbers—decimal, most likely—and alphanumeric characters, including letters and digits and punctuation.

So what's the opposite of digital? Analog.

- This means that the range of values being processed is continuous.
- A good example is in your car. The speedometer is an analog device because the pointer can point absolutely anywhere on the scale (unless you happen to have a fully digital display as some cars do today).
- The odometer, on the other hand, is digital because it can display only numbers in a fixed range. Miles to the nearest integer, or perhaps to the nearest tenth. It can't display, say, 2783.9017 miles but instead displays 2783.9 or even 2783.

### Digital preferred

- Quality of service
- Maintenance
- Flexibility
- Upgradability
- Exponential vs Linear
- Delay
- Uses less bandwidth
- Higher efficiency for long distance transmission.
- Encryption: at transmission end we encrypt the intended data user decodes using proper key.



TRANSDUCER—converts non-electrical signal to electrical.

What is a signal?

- Function that represents variation of a physical quantity with a parameter.
- Function that is dependent (varies with respect to a parameter) on a parameter.
- In electrical/electronics signal represents variation of electrical quantity (voltage/current with time).



| Signal             | Analog                                                                                                            | Digital                                                                                                                                      | ← both parameters are discrete.<br>lower marked limit is constant.<br>e.g. 1,2,3 → assumed as 1 |
|--------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| Representation     | Analog signal is a continuous signal which represents physical measurements.                                      | Digital signals are discrete time signals generated by digital modulation.                                                                   |                                                                                                 |
| Technology         | Denoted by sine waves                                                                                             | Denoted by square waves                                                                                                                      |                                                                                                 |
| Data transmissions | Uses continuous range of values to represent information                                                          | Uses discrete or discontinuous values to represent information                                                                               |                                                                                                 |
| Response to Noise  | Human voice in air, analog electronic devices.                                                                    | Computers, CDs, DVDs, and other digital electronic devices.                                                                                  |                                                                                                 |
| Flexibility        | Analogue technology records waveforms as they are.                                                                | Samples analog waveforms into a limited set of numbers and records them.                                                                     |                                                                                                 |
| Uses               | Subjected to deterioration by noise during transmission and write/read cycle.                                     | Can be noise-immune without deterioration during transmission and write/read cycle.                                                          |                                                                                                 |
| Application        | More likely to get affected reducing accuracy                                                                     | Less affected since noise parameters are analog in nature                                                                                    |                                                                                                 |
| Bandwidth          | Analog hardware is not flexible.                                                                                  | Digital hardware is flexible in implementation.                                                                                              |                                                                                                 |
| Memory             | Can be used in analog devices only. Best suited for audio and video transmission.                                 | Best suited for computing and digital electronics.                                                                                           |                                                                                                 |
| Power              | Thermometer                                                                                                       | PCs, PDAs                                                                                                                                    |                                                                                                 |
| Errors             | Analog signal processing can be done in real time and consumes less bandwidth.                                    | There is no guarantee that digital signal processing can be done in real time and consumes more bandwidth to carry out the same information. |                                                                                                 |
|                    | Stored in the form of wave signal                                                                                 | Stored in the form of binary bit                                                                                                             |                                                                                                 |
|                    | Analog instrument draws large power                                                                               | Digital instrument draws only negligible power                                                                                               |                                                                                                 |
|                    | Analog instruments usually have a scale which is cramped at lower end and give considerable observational errors. | Digital instruments are free from observational errors like parallax and approximation errors.                                               |                                                                                                 |

## Top-down approach

- The top-down approach involves looking at the big picture and breaking that picture up into smaller constituents.
- Each of these smaller parts is a complete entity, which will combine with all these other parts to make the finished whole.
- But the smaller constituents may still be too large for one person or a small design team to handle.
- So we break them up again, getting even smaller constituents.
- Eventually, we'll have these constituents small enough that we can handle them, one by one, fairly easily.

## Bottom-up approach

- If we are careful to break the problem at clear boundaries between subsystems, we will find that we have small constituents whose integrity we can be sure of.
- Then we can test each constituent completely, making certain that it does its job 100% correctly.
- When these are assembled into the larger system they were broken out from, the larger system should also work correctly.

### WHAT'S A DIGITAL SYSTEM?

- A digital system is one that involves discrete quantities, most often binary digits – digits that are two valued viz. 0 and 1
- What we need to know now is what kinds of things we will find in digital systems.
- The basic units are gates, which are devices that combine binary signals in fixed, simple ways.
- Let us now look at some of the basic operations (gates) that we have.



When the truth table for any two or more networks are the same, then they are called as functionally equivalent networks.

- Ideally, we should use the network having lowest cost (say, no of gates, delay, area, power etc.)
- — —
- As you probably now know, combinational circuits are made up of gates and fancier circuits that contain just gates.
- Sequential circuits are made up of both combinational circuits and devices that can “remember” such as flip-flops.



## LOGIC CIRCUIT FAMILIES

- Logic circuits come in families.
- The members of a logic family are compatible to the nth degree, which is what the family is all about.
- All the members of a logic family have very similar characteristics.
- All require the same power supply voltages.
- All respond to the same logic signal levels.
- All produce the same signal levels. All of them operate at similar speeds.
- The members of a logic family are designed to work together simply.
- In most cases, a signal is moved from one member to another “just by running wires.” You don’t have to pay attention to signal levels, voltages, or drive currents.
- You do, however, have to consider timing, because a signal that arrives with too much delay may not cause the desired operation.
- Two families are quite common because they are simple, cheap, and versatile.
- They are also fairly forgiving of wiring errors.

### Logic Circuits and Binary Levels

Recognize at the input:



### Logic Circuits and Binary Levels

Available at the output:



### Logic Circuits and Binary Levels



TTL: Transistor Transistor Logic:



CMOS: Complimentary MOS Logic:



### TTL Family

- The transistor-transistor logic family (TTL) has been around for over 70 years. The two Ts in the name tell a little about the physical arrangement of the internal components.
- Part labels generally begin with a number, either 74 (commercial grade parts) or 54 (military grade).
- Within the TTL family are several subfamilies, separated by such characteristics as power consumption and speed.
- The particular subfamily is designated by letters after the initial number. Two examples are 74LS series (low-power Schottky), which are simple, require relatively small amounts of power, and operate at moderate speed, fast enough for many applications (such as vending machine logic).
- 74F series (fast), which are faster than the 74 LS series. These, and others that are even faster, may found in such systems as printers.
- The blank after the letters is filled in with two to four digits. But the digits are the same for standard circuits. For example, 74LS00 and 74F00 are both chips containing four two-input NAND gates.
- The TTL family typically requires a 5-volt power supply.

### CMOS Family

- The CMOS logic family (complementary metal-oxide semiconductor) is a very low- power family of chips.
- Typical power consumption when the chip isn't doing anything is in the microwatt range.
- The members of this family require essentially zero power except during switching, which means that their average power consumption depends on how many times the output switches per second. In other words, power consumption is proportional to frequency.
- There are three subfamilies here:
  - 40 series, which was the original family. Its devices are moderately fast.
  - 74HC series (high-speed CMOS), which is popular and has many different types of devices available. But it, like the 40 series, will not interface easily with the members of the TTL family. Yet we sometimes need to do this because the CMOS families do not have as many varieties of logic devices.
  - 74HCT (high-speed CMOS, TTL compatible), which resolves that problem. But here too, the variety is not very extensive.
- As with the TTL families, standard numbering is used. So a 4000, a 74HC 00, and a 74HCT 00 all have four NAND gates on one chip.
- CMOS has another advantage—lower power supply voltages. While 5 volts is still common, 3.3 volts, 3 volts, and even less than 3 volts are available.

- Product term is a term where the variables are connected by **and operators**, terms such as  $A \cdot B$ ,  $C \cdot D \cdot E$ , and even the simple term  $F$ .
- Sum term is a term where the variables are connected by **or operators**, terms such as  $A + B$ ,  $\bar{C} + D + E$ , and even the simple term  $F$ .
- Literal is any appearance of a variable in a term, whether primed or not. In the terms above, the literals are  $A, B, \bar{C}, D, E$ , and  $F$ . If the **variable appears both primed and unprimed**, as in  $G$  and  $\bar{G}$ , each is a literal.
- Sum-of-products** is an expression consisting of product terms linked by or operators  $A \cdot B + \bar{C} \cdot D \cdot E + F$ .
- Product-of-sums** is an expression consisting of sum terms linked by and operators  $(A + B) \cdot (\bar{C} + D + E) \cdot F$ .

| binary  | minterms |   |   | F |
|---------|----------|---|---|---|
|         | A        | B | C |   |
| 0 $m_0$ | 0        | 0 | 0 | 0 |
| 1 $m_1$ | 0        | 0 | 1 | 0 |
| 2 $m_2$ | 0        | 1 | 0 | 1 |
| 3 $m_3$ | 0        | 1 | 1 | 0 |
| 4 $m_4$ | 1        | 0 | 0 | 1 |
| 5 $m_5$ | 1        | 0 | 1 | 1 |
| 6 $m_6$ | 1        | 1 | 0 | 1 |
| 7 $m_7$ | 1        | 1 | 1 | 1 |

for when output is high

A: 1  
A': 0

$$\begin{aligned} & \rightarrow A' \cdot B \cdot C' \\ & \rightarrow A \cdot B' \cdot C' \\ & \rightarrow A \cdot B' \cdot C \\ & \rightarrow A \cdot B \cdot C' \\ & \rightarrow A \cdot B \cdot C \end{aligned}$$

$$F = A' \cdot B \cdot C' + A \cdot B' \cdot C' + A \cdot B \cdot C' + A \cdot B \cdot C \quad \{\text{CANONICAL/STANDARD SOP form}\}$$

$$\begin{aligned} F(A, B, C) &= m_2 + m_4 + m_5 + m_6 + m_7 \\ &= \sum m(2, 4, 5, 6, 7) \end{aligned}$$

$$F = A' \cdot B \cdot C' + A \cdot B' \cdot C' + A \cdot B \cdot C' + A \cdot B \cdot C \quad \text{CANONICAL}$$

$$F = A' \cdot B \cdot C' + A \cdot B' \cdot (C' + C) + A \cdot B \cdot (C' + C)$$

$$= A' \cdot B \cdot C' + A \cdot (B' + B)$$

$$= A' \cdot B \cdot C' + A$$

$$F = A + B \cdot C' \quad \{A + \bar{A} \cdot B = A + B\}$$

MINIMAL

| binary | A | B | Y |
|--------|---|---|---|
| $m_0$  | 0 | 0 | 0 |
| $m_1$  | 0 | 1 | 1 |
| $m_2$  | 1 | 0 | 0 |
| $m_3$  | 1 | 1 | 1 |

$$A' \cdot B$$

$$A \cdot B$$

$$\begin{aligned} Y &= A' \cdot B + A \cdot B \\ &= B \cdot (A' + A) \end{aligned}$$

$$Y = B$$

$$Y = \sum m(1, 3)$$



Total propagation delay =  $10\text{ ns}$

$$T = 20\text{ ns}$$

$$f = 1/20 \text{ ns}^{-1}$$

## PRODUCT OF SUM (POS)

for when output is low

| binary         | A | B | C | F |
|----------------|---|---|---|---|
| M <sub>0</sub> | 0 | 0 | 0 | 0 |
| M <sub>1</sub> | 0 | 0 | 1 | 0 |
| M <sub>2</sub> | 0 | 1 | 0 | 1 |
| M <sub>3</sub> | 0 | 1 | 1 | 0 |
| M <sub>4</sub> | 1 | 0 | 0 | 1 |
| M <sub>5</sub> | 1 | 0 | 1 | 1 |
| M <sub>6</sub> | 1 | 1 | 0 | 1 |
| M <sub>7</sub> | 1 | 1 | 1 | 1 |

$$\begin{array}{l} A = 0 \\ A' = 1 \end{array}$$

$$A + B + C$$

$$A + B + C'$$

1

$$A + B' + C'$$

1

1

1

1

derive POS from SOP  
↳ SOP for low

$$\begin{aligned} Y &= (A \cdot B \cdot C)' \cdot (A \cdot B' \cdot C)' \cdot (A' \cdot B \cdot C)' \\ &= (A+B+C) \cdot (A+B+C') \cdot (A+B'+C') \end{aligned}$$

$$Y = (A+B+C) \cdot (A+B+C') \cdot (A+B'+C')$$

$$Y = \pi M(0, 1, 3) \quad \{ \text{CANONICAL/STANDARD POS form} \}$$

$$Y = (A+B+C) \cdot (A+B+C') \cdot (A+B'+C')$$

$$(X+Y) \cdot (X+Z) = (X+Y \cdot Z)$$

$$Y = (A+B+C \cdot C') \cdot (A+B'+C)$$

$$= A+B \cdot (B'+C')$$

$$= A+B \cdot B'+B \cdot C'$$

$$Y = A+B \cdot C'$$

$$Y = (A+B) \cdot (A+C')$$

SOP form → no. of AND gates > OR  
POS form → no. of OR gates > AND

$$\{ \text{minimal POS form} \}$$

e.g. min terms

$$Y(A, B, C) = \Sigma m(0, 2, 3, 6, 7)$$

max terms

$$Y(A, B, C) = \Pi M(1, 4, 5)$$

$2^{(2^n)}$  self duals

$2^n$  = min/max terms ; n variables

$2^{(2^n)}$  = logical expression ; n variables

Self-dual  
→ for any logical expression two times dual gives same expression  
→ self dual : one time dual gives same expression

## POSITIVE and NEGATIVE LOGIC

- Higher voltage corresponds to logic 1
- Lower voltage corresponds to logic 0
- Higher voltage corresponds to logic 0
- Lower voltage corresponds to logic 1

### positive and negative logic AND gate

| A | B | Y |
|---|---|---|
| L | L | L |
| L | H | L |
| H | L | L |
| H | H | H |

### positive and negative logic OR gate

| A | B | Y |
|---|---|---|
| L | L | L |
| L | H | H |
| H | L | H |
| H | H | H |

### Observation

- pos logic AND gate = -ve logic OR gate
- pos logic OR gate = -ve logic AND gate

Definitions for Logic Synthesis:

- **Normal term:** Product or sum term in which no literal appears more than once, in any form.

$$F_1(x, y, z) = (x + y) + \bar{x} \cdot \bar{z}$$

- **Minterm:** For a function of n variables, minterm is a normal product term with n literals.

$$F_2(x, y, z) = \bar{x} \cdot \bar{y} \cdot z + \bar{x} \cdot y \cdot z + x \cdot \bar{y} \cdot \bar{z} + x \cdot \bar{y} \cdot z$$

- **Maxterm:** For a function of n variables, maxterm is a normal sum term with n literals.

$$F(x, y, z) = (x + y + z) \cdot (x + \bar{y} + z) \cdot (\bar{x} + \bar{y} + z) \cdot (\bar{x} + \bar{y} + \bar{z})$$

SOP  $\rightarrow$  CSOP

$$\begin{aligned} f(x, y, z) &= \bar{x} \cdot z + x \cdot \bar{y} \\ &= \bar{x} \cdot z(y + \bar{y}) + x \cdot \bar{y} \cdot (z + \bar{z}) \\ &= \bar{x} \cdot z \cdot y + \bar{x} \cdot \bar{y} \cdot \bar{z} + x \cdot \bar{y} \cdot z + x \cdot \bar{y} \cdot \bar{z} \end{aligned}$$

$$\begin{aligned} f(a, b, c) &= a + \bar{b} \cdot c \\ &= a \cdot (b + \bar{b}) \cdot (c + \bar{c}) + (a + \bar{a}) \bar{b} \cdot c \\ &= a \cdot b \cdot c + a \cdot b \cdot \bar{c} + a \cdot \bar{b} \cdot c + a \cdot \bar{b} \cdot \bar{c} + \bar{a} \cdot \bar{b} \cdot c \\ &= a \cdot b \cdot c + a \cdot b \cdot \bar{c} + a \cdot \bar{b} \cdot c + a \cdot \bar{b} \cdot \bar{c} + \bar{a} \cdot \bar{b} \cdot c \end{aligned}$$

POS  $\rightarrow$  CPPOS

$$\begin{aligned} f(x, y, z) &= (x + z) \cdot (\bar{x} + \bar{y}) \\ &= (x + z + y \cdot \bar{y}) \cdot (\bar{x} + \bar{y} + z \cdot \bar{z}) \\ &= (x + z + y) \cdot (x + z + \bar{y}) \cdot (\bar{x} + \bar{y} + z) \cdot (\bar{x} + \bar{y} + \bar{z}) \end{aligned}$$

$$\begin{aligned} f(a, b, c, d) &= a + d \\ &= a + d + b \cdot \bar{b} + c \cdot \bar{c} \\ &= (a + d + b \cdot \bar{b} + c) \cdot (a + d + b \cdot \bar{b} + \bar{c}) \\ &= (a + b + c + d) \cdot (a + \bar{b} + c + d) \cdot (a + b + \bar{c} + d) \cdot (a + \bar{b} + \bar{c} + d) \end{aligned}$$

COMPLEMENT

$$\bar{z}(C, B, A) = \Sigma_m(1, 3, 5, 6, 7) = \Pi_m(0, 2, 4)$$

$$\bar{z}(C, B, A) = \Sigma_m(0, 2, 4)$$

$$f(D, L, B, R) = \text{Em}(0, 4, 5, 6, 8, 9, 10, 11, 12, 13, 14)$$

| 00 | 01 | 11 | 10 |
|----|----|----|----|
| 00 | 1  |    |    |
| 01 | 1  | 1  | 1  |
| 11 | 1  | 1  | 1  |
| 10 | 1  | 1  | 1  |

$$\bar{B}\bar{A} + \bar{D}\bar{C} + \bar{B}C + \bar{A}C$$

$$f = \bar{B} \cdot \bar{A} + D \cdot \bar{C} + C \cdot \bar{B} + C \cdot \bar{A}$$

$$(f')' = [(A \cdot B)', (C \cdot D)', (B \cdot C)', (A \cdot C)']'$$



## Logic Synthesis

- Implement function using only NOR gates

$$f = (A + B)(C + \bar{B})(\bar{A} + C + D)$$

$$f = \overline{(A+B)(C+\bar{B})(\bar{A}+C+D)}$$

## Logic Synthesis:

- Implement function using NOT, OR and AND gates in POS

$$f(D, C, B, A) = \prod M(0, 2, 3, 4, 8, 10, 11, 12, 13, 15)$$

$$f(D, C, B, A) = (D + C + B + A) \cdot (D + C + \bar{B} + A) \cdot (D + C + \bar{B} + \bar{A}) \cdot (D + \bar{C} + B + A) \cdot \\ (\bar{D} + C + B + A) \cdot (\bar{D} + C + \bar{B} + A) \cdot (\bar{D} + C + \bar{B} + \bar{A}) \cdot (\bar{D} + \bar{C} + B + A) \cdot (\bar{D} + \bar{C} + \bar{B} + A) \cdot \\ (\bar{D} + \bar{C} + \bar{B} + \bar{A})$$

This reduces to  $f = (A + B)(C + \bar{B})(\bar{A} + C + D)$

Take over from here and carry out a process (like what we did for implementation using NOT, AND and OR gates) to implement using NOT, OR and AND gates



# Combinational logic circuits



A      B      Sum      Cout

|   |   |   |   |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

$$\text{Sum} = A \oplus B$$

$$\text{Cout} = A \cdot B$$



A      B      Cin      Sum      Cout

|   |   |   |   |   |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |

$$\text{Sum} = A \oplus B \oplus \text{Cin}$$

$$= A_0 B_0 \text{Cin}$$

$$\text{Cout} = AB + BC_{\text{in}} + AC_{\text{in}}$$

checkboard on KMAP.



$$\begin{aligned} &ABC_{\text{in}} + AB_{\text{in}} + AB(C_2 \text{in}) \\ &AB_{\text{in}} C_{\text{in}} + BC_{\text{in}} + ABC_{\text{in}} \\ &AC_{\text{in}} + ABC_{\text{in}} + BC_{\text{in}} + AC_{\text{in}} \\ &AC_{\text{in}} + AB + ABC_{\text{in}} + A B C_{\text{in}} \\ &AC_{\text{in}} + AB + BC_{\text{in}} \end{aligned}$$

$$\begin{aligned} \text{Sum delay} &= 2 \cdot \text{XOR} \\ \text{Carry delay} &= 3 \cdot \text{XOR} + 1 \cdot \text{AND} + 1 \cdot \text{OR} \end{aligned}$$

A - B



A      B      Diff      Borrow

|   |   |   |   |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |

$$\begin{aligned} \text{Diff} &= A \oplus B \\ \text{Borrow} &= \bar{A} \cdot B \end{aligned}$$



A      B      Cin      Diff      Borrow

|   |   |   |   |   |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 |



$$\begin{aligned} \text{Diff} &= A \oplus B \oplus \text{Cin} = AOB_{\text{Cin}} \\ \text{Borrow} &= \bar{A}B + \bar{A}\bar{C} + BC \end{aligned}$$



## Binary parallel adder



$$\begin{array}{r}
 & C_2 & C_1 & C_0 & C_{in} \\
 A: & A_3 & A_2 & A_1 & A_0 \\
 B: & B_3 & B_2 & B_1 & B_0 \\
 \hline
 C_3 & S_3 & S_2 & S_1 & S_0
 \end{array}$$



FA are identical  
 $\rightarrow PD(\text{sum}) = 10ns$   
 $\rightarrow PD(\text{carry}) = 5ns$

$$\text{worst case delay} = (n-1) \text{Carry delay} + \max_{(n-\text{bit})} (\underbrace{\text{CD}}_{\text{carry delay}}, \underbrace{\text{SD}}_{\text{sum delay}})$$



# DECIMAL ADDER (1 bit FA)

## BCD ADDER

1 dec digit = 0 to 9

2<sup>nd</sup> dec digit = 0 to 9

$$C_m = 0/1$$

$$\text{Max sum} = 19$$

TABLE 5-1  
Derivation of a BCD Adder

| K | Binary Sum |       |       |       | C | BCD Sum |       |       |       | Decimal |
|---|------------|-------|-------|-------|---|---------|-------|-------|-------|---------|
|   | $Z_8$      | $Z_4$ | $Z_2$ | $Z_1$ |   | $S_6$   | $S_4$ | $S_2$ | $S_1$ |         |
| 0 | 0          | 0     | 0     | 0     | 0 | 0       | 0     | 0     | 0     | 0       |
| 0 | 0          | 0     | 0     | 1     | 0 | 0       | 0     | 0     | 1     | 1       |
| 0 | 0          | 0     | 1     | 0     | 0 | 0       | 0     | 1     | 0     | 2       |
| 0 | 0          | 0     | 1     | 1     | 0 | 0       | 0     | 1     | 1     | 3       |
| 0 | 0          | 1     | 0     | 0     | 0 | 0       | 1     | 0     | 0     | 4       |
| 0 | 0          | 1     | 0     | 1     | 0 | 0       | 1     | 0     | 1     | 5       |
| 0 | 0          | 1     | 1     | 0     | 0 | 0       | 1     | 1     | 0     | 6       |
| 0 | 0          | 1     | 1     | 1     | 0 | 0       | 1     | 1     | 1     | 7       |
| 0 | 1          | 0     | 0     | 0     | 0 | 1       | 0     | 0     | 0     | 8       |
| 0 | 1          | 0     | 0     | 1     | 0 | 1       | 0     | 0     | 1     | 9       |
| 1 | 0          | 0     | 0     | 0     | 1 | 0       | 0     | 0     | 0     | 10      |
| 1 | 0          | 0     | 0     | 1     | 1 | 0       | 0     | 0     | 1     | 11      |
| 0 | 1          | 1     | 0     | 0     | 1 | 0       | 0     | 1     | 0     | 12      |
| 0 | 1          | 1     | 0     | 1     | 1 | 0       | 0     | 1     | 1     | 13      |
| 0 | 1          | 1     | 1     | 0     | 1 | 0       | 1     | 0     | 0     | 14      |
| 0 | 1          | 1     | 1     | 1     | 1 | 0       | 1     | 0     | 1     | 15      |
| 1 | 0          | 0     | 0     | 0     | 1 | 0       | 1     | 1     | 0     | 16      |
| 1 | 0          | 0     | 0     | 1     | 1 | 0       | 1     | 1     | 1     | 17      |
| 1 | 0          | 0     | 1     | 0     | 1 | 1       | 0     | 0     | 0     | 18      |
| 1 | 0          | 0     | 1     | 1     | 1 | 1       | 0     | 0     | 1     | 19      |

} binary sum, same as BCD





+ OR gate  $\rightarrow$  SOP

In one time, only one output in decoder circuit.  
 ↳ if that ONE output = 1  
 $z_{out} = 0$ , Active High.

If  $\bar{E}$  is used  $E=0$ : enable  
 $E=1$ : disable



### ACTIVE HIGH DECODER

www.electrical4you.com



| Inputs |   |   | Outputs        |                |                |                |
|--------|---|---|----------------|----------------|----------------|----------------|
| EN     | A | B | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |
| 0      | X | X | 0              | 0              | 0              | 0              |
| 1      | 0 | 0 | 0              | 0              | 0              | 1              |
| 1      | 0 | 1 | 0              | 0              | 1              | 0              |
| 1      | 1 | 0 | 0              | 1              | 0              | 0              |
| 1      | 1 | 1 | 1              | 0              | 0              | 0              |

### ACTIVE LOW DECODER



| E | A | B | Q <sub>0</sub> | Q <sub>1</sub> | Q <sub>2</sub> | Q <sub>3</sub> |
|---|---|---|----------------|----------------|----------------|----------------|
| 0 | 0 | 0 | 0              | 1              | 1              | 1              |
| 0 | 0 | 1 | 1              | 0              | 1              | 1              |
| 1 | 0 | 0 | 1              | 1              | 0              | 1              |
| 1 | 1 | 0 | 1              | 1              | 1              | 0              |
| 0 | x | x | 1              | 1              | 1              | 1              |

A 4-to-16 Binary Decoder Configuration



4-to-16 Line Decoder Implemented with two 3-to-8 Decoders

### 3x8 Decoder using 2x4 decoder

| A | B | C | D <sub>0</sub> |
|---|---|---|----------------|
| 0 | 0 | 0 | D <sub>0</sub> |
| 0 | 0 | 1 | D <sub>1</sub> |
| 0 | 1 | 0 | D <sub>2</sub> |
| 0 | 1 | 1 | D <sub>3</sub> |
| 1 | 0 | 0 | D <sub>4</sub> |
| 1 | 0 | 1 | D <sub>5</sub> |
| 1 | 1 | 0 | D <sub>6</sub> |
| 1 | 1 | 1 | D <sub>7</sub> |



MUX

$2^n \times 1$  MUX



$8 \times 1$  MUX implemented using  $4 \times 1$ .

$$\frac{8}{4} = 2$$

$$\frac{2}{4} = 0.5$$



$$F(A, B, C, D) = \Sigma m(1, 4, 5, 7, 9, 12, 13)$$

| $AB\backslash CD$ | $\bar{C}\bar{D}$ | $\bar{C}D$ | $C\bar{D}$ | $CD$ |
|-------------------|------------------|------------|------------|------|
| $\bar{A}\bar{B}$  | 00               | 1          |            |      |
| $\bar{A}B$        | 01               | 1          | 1          |      |
| $A\bar{B}$        | 10               | 1          |            |      |
| $AB$              | 11               |            |            |      |



| E | S <sub>1</sub> | S <sub>0</sub> | O/P            |
|---|----------------|----------------|----------------|
| 1 | 0              | 0              | $I_0$          |
| 1 | 0              | 1              | $I_1$          |
| 1 | 1              | 0              | $I_2$          |
| 0 | x              | x              | highz (no ans) |

$$f = (\bar{S}_1 \bar{S}_0 I_0 + \bar{S}_1 S_0 I_1 + S_1 \bar{S}_0 I_2 + S_1 S_0 I_3) \cdot En$$



## Encoder ( $n \rightarrow m$ line) $m = \log_2 n$

| En | $w_7$ | $w_6$ | $w_5$ | $w_4$ | $w_3$ | $w_2$ | $w_1$ | $w_0$ | $y_2$  | $y_1$ | $y_0$ |
|----|-------|-------|-------|-------|-------|-------|-------|-------|--------|-------|-------|
| 1  |       |       |       |       |       |       |       |       | 0      | 0     | 0     |
|    | 1     |       |       |       |       |       |       |       |        | 0     | 1     |
|    |       | 1     |       |       |       |       |       |       | 0      | 1     | 0     |
|    |       |       | 1     |       |       |       |       |       | 0      | 1     | 1     |
|    |       |       |       | 1     |       |       |       |       | 1      | 0     | 0     |
|    |       |       |       |       | 1     |       |       |       |        | 0     | 1     |
|    |       |       |       |       |       | 1     |       |       |        | 1     | 0     |
|    |       |       |       |       |       |       | 1     |       |        | 1     | 1     |
| 0  | x     | x     | x     | x     | x     | x     | x     | x     | high z |       |       |

Active high

Active low: singular zeros instead of 1s

## 10:4 Decimal-Binary Encoder:

$$m = \lceil \log_2 10 \rceil = \lceil 3.322 \rceil = 4$$

| $d_9$ | $d_8$ | $d_7$ | $d_6$ | $d_5$ | $d_4$ | $d_3$ | $d_2$ | $d_1$ | $d_0$ | D | C | B | A |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|---|---|---|---|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0 | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0 | 0 | 0 | 1 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0 | 0 | 1 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0 | 0 | 1 | 1 |
| 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0 | 1 | 0 | 0 |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0 | 1 | 0 | 0 |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 1 | 0 | 1 |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 1 | 1 | 0 |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 1 | 1 | 1 |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1 | 0 | 0 | 0 |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1 | 0 | 0 | 1 |



## Priority Encoders:

| $w_3$ | $w_2$ | $w_1$ | $w_0$ | $y_1$ | $y_0$ | $z$ |
|-------|-------|-------|-------|-------|-------|-----|
| 0     | 0     | 0     | 0     | d     | d     | 0   |
| 0     | 0     | 0     | 1     | 0     | 0     | 1   |
| 0     | 0     | 1     | φ     | 0     | 1     | 1   |
| 0     | 1     | φ     | φ     | 1     | 0     | 1   |
| 1     | φ     | φ     | φ     | 1     | 1     | 1   |

$z = w_3 + w_2 + w_1 + w_0$   
 $y_1 = w_3 + w_2$   
 $y_0 = w_3 + \overline{w_2}w_1$



# DEMUX

Demultiplexers:



$$y_0 = \overline{w_1} \cdot \overline{w_0} \cdot I$$

$$y_1 = \overline{w_1} \cdot w_0 \cdot I$$

$$y_2 = w_1 \cdot \overline{w_0} \cdot I$$

$$y_3 = w_1 \cdot w_0 \cdot I$$

| w <sub>1</sub> | w <sub>0</sub> | y <sub>0</sub> | y <sub>1</sub> | y <sub>2</sub> | y <sub>3</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | I              | 0              | 0              | 0              |
| 0              | 1              | 0              | I              | 0              | 0              |
| 1              | 0              | 0              | 0              | I              | 0              |
| 1              | 1              | 0              | 0              | 0              | I              |

Realizing Demultiplexer using a Decoder:



$$y_0 = \overline{w_1} \cdot \overline{w_0} \cdot E_n$$

$$y_1 = \overline{w_1} \cdot w_0 \cdot E_n$$

$$y_2 = w_1 \cdot \overline{w_0} \cdot E_n$$

$$y_3 = w_1 \cdot w_0 \cdot E_n$$



$$y_0 = \overline{w_1} \cdot \overline{w_0} \cdot I$$

$$y_1 = \overline{w_1} \cdot w_0 \cdot I$$

$$y_2 = w_1 \cdot \overline{w_0} \cdot I$$

$$y_3 = w_1 \cdot w_0 \cdot I$$

| A <sub>2</sub> , B <sub>2</sub> | A <sub>1</sub> , B <sub>1</sub> | A <sub>0</sub> , B <sub>0</sub> | A > B | A < B | A = B |
|---------------------------------|---------------------------------|---------------------------------|-------|-------|-------|
| A <sub>2</sub> > B <sub>2</sub> | X                               | X                               | 1     |       |       |
| A <sub>2</sub> < B <sub>2</sub> | X                               | X                               |       | 1     |       |
| A <sub>2</sub> = B <sub>2</sub> | A <sub>1</sub> > B <sub>1</sub> | X                               | 1     |       |       |
| A <sub>2</sub> = B <sub>2</sub> | A <sub>1</sub> < B <sub>1</sub> | X                               |       | 1     |       |
| A <sub>2</sub> = B <sub>2</sub> | A <sub>1</sub> = B <sub>1</sub> | A <sub>0</sub> > B <sub>0</sub> | 1     |       |       |
| A <sub>2</sub> = B <sub>2</sub> | A <sub>1</sub> = B <sub>1</sub> | A <sub>0</sub> < B <sub>0</sub> |       | 1     |       |
| A <sub>2</sub> = B <sub>2</sub> | A <sub>1</sub> = B <sub>1</sub> | A <sub>0</sub> = B <sub>0</sub> |       |       | 1     |

XNOR for A=B

| A | B | f |
|---|---|---|
| 0 | 0 | I |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | I |

$$\therefore f = (A_2 \odot B_2) \cdot (A_1 \odot B_1) \cdot (A_0 \odot B_0)$$

A > B

↳ A<sub>2</sub> > B<sub>2</sub> (OR) A<sub>2</sub> = B<sub>2</sub>, A<sub>1</sub> > B<sub>1</sub> (OR) A<sub>2</sub> = B<sub>2</sub>, A<sub>1</sub> = B<sub>1</sub>, A<sub>0</sub> > B<sub>0</sub>

$$f = (A_2 \cdot \overline{B_2}) + (A_2 \odot B_2) \cdot (A_1 \cdot \overline{B_1}) + (A_2 \odot B_2) \cdot (A_1 \odot B_1) \cdot (A_0 \cdot \overline{B_0})$$

A < B

A<sub>2</sub> < B<sub>2</sub> (OR) A<sub>2</sub> = B<sub>2</sub>, A<sub>1</sub> < B<sub>1</sub> (OR) A<sub>2</sub> = B<sub>2</sub>, A<sub>1</sub> = B<sub>1</sub>, A<sub>0</sub> < B<sub>0</sub>

$$f = (\overline{A_2} \cdot B_2) + (A_2 \odot B_2) \cdot (\overline{A_1} \cdot B_1) + (B_2 \odot A_2) \cdot (A_1 \odot B_1) \cdot (B_0 \cdot \overline{A_0})$$



# Sequential Circuits



combinational: present output depends only on present input

sequential: present output depends on present & previous input.

## Latch

### Structure



DC  $\rightarrow$  NOT gate  $\rightarrow$  NOT latch  
 $\downarrow$  NAND gate  $\rightarrow$  NAND latch  
 $\downarrow$  NOR gate  $\rightarrow$  NOR latch



### NOR latch



present output =  $Q_n$   
 next output =  $Q_{n+1}$   
 $R \rightarrow DC \rightarrow Q_n$   
 $S \rightarrow DC \rightarrow Q_n$

| A | B | C              | D                | Q <sub>n</sub> | Q <sub>n</sub> ' |
|---|---|----------------|------------------|----------------|------------------|
| 0 | 0 | Q <sub>n</sub> | Q <sub>n</sub> ' | memory         |                  |
| 0 | 1 | 1              | 0                | set            |                  |
| 1 | 0 | 0              | 1                | reset          |                  |
| 1 | 1 | 0              | 0                | FORBIDDEN      |                  |



| R | S | Q <sub>n</sub> | Q <sub>n+1</sub>   |
|---|---|----------------|--------------------|
| 0 | 0 | 0              | 0 { Q <sub>n</sub> |
| 0 | 0 | 1              | 1                  |
| 0 | 1 | 0              | 0 { Reset          |
| 0 | 1 | 1              | 0                  |
| 1 | 0 | 0              | 1 { Set            |
| 1 | 0 | 1              | 1                  |
| 1 | 1 | 0              | forbidden          |
| 1 | 1 | 1              | forbidden          |

### SR Latch

| S | R | Q <sub>n+1</sub> |
|---|---|------------------|
| 0 | 0 | 0                |
| 0 | 1 | 1                |

$$Q_{n+1} = S + \bar{R}Q_n$$

characteristic eq

### NAND latch (active low SR latch)



| S | R | Q <sub>n+1</sub>      |
|---|---|-----------------------|
| 0 | 0 | forbidden             |
| 0 | 1 | 1 set                 |
| 1 | 0 | 0 reset               |
| 1 | 1 | Q <sub>n</sub> memory |

### Active High SR latch



~NAND latch w/inverted input

S'  $\rightarrow$  DC - Q<sub>n</sub>  
 R'  $\rightarrow$  DC - Q<sub>n</sub>'

**Latch** → Asynchronous circuit (w/out time, w/out clock)

**Clocked Latch** → synchronous circuit (flip flop {FF})

CLOCKED S-R latch



S-R FF (flip flop)

ANOR + 2NAND

2NAND + 2NOT

Q<sub>n+1</sub>

1 0 0 0

memory

1 0 1 0

reset

1 1 0 1

set

1 1 1 X

forbidden

0 X X 0

memory

| S R |   | Q <sub>n</sub> | Q <sub>n+1</sub> | Q <sub>n+1</sub> |
|-----|---|----------------|------------------|------------------|
| 0   | 0 | 0              | 1                | 0                |
| 1   | 1 | 1              | 1                | X                |

CLK = 1

$$Q_{n+1} = S + \bar{R} Q_n \quad \{ \text{CLK} = 1 \}$$

$$Q_{n+1} = Q_n \quad \{ \text{CLK} = 0 \}$$



so1

so2

duty cycle = 50%

$$f_{clk} = 1/T_{clk}$$



CLK S R Q<sub>n</sub> Q<sub>n+1</sub>

1 0 0 0 0

1 0 0 1 1

1 0 1 0 0

1 0 1 1 0

1 1 0 0 1

1 1 0 1 1

1 1 1 0 X

1 1 1 1 X

0 X X 0 0

0 X X 1 1

| Q <sub>n</sub> | Q <sub>n+1</sub> | S | R |
|----------------|------------------|---|---|
| 0              | 0                | 0 | X |
| 0              | 1                | 1 | 0 |
| 1              | 0                | 0 | 1 |
| 1              | 1                | X | 0 |



| S | R | Preset | Clear | F/F operation       |
|---|---|--------|-------|---------------------|
| X | X | 0      | 0     | FORBIDDEN           |
| X | X | 1      | 1     | Q=1, FF set         |
| X | X | 1      | 0     | Q=0, FF clear       |
| S | R | 1      | 1     | Normal FF operation |

## J-K F/F



$$Q_{n+1} \mid_{S=R} = S + \bar{R} Q_n$$

$$\begin{aligned} Q_{n+1} &= J \bar{Q}_n + (K Q_n)^* Q_n \\ &= J \bar{Q}_n + (K' + Q_n) Q_n \end{aligned}$$

$$Q_{n+1} = J \bar{Q}_n + K' Q_n$$



Race around problem: in level triggered clock JK ff.

Excitation table

| $Q_n$ | $Q_{n+1}$ | $J$ | $K$ |
|-------|-----------|-----|-----|
| 0 0   | 0 x       |     |     |
| 0 1   | 1 x       |     |     |
| 1 0   | x 1       |     |     |
| 1 1   | x 0       |     |     |

| $clk$ | $J$ | $K$ | $Q_{n+1}$   |
|-------|-----|-----|-------------|
| 1     | 0   | 0   | $Q_n$       |
| 1     | 0   | 1   | 0           |
| 1     | 1   | 0   | 1           |
| 1     | 1   | 1   | $\bar{Q}_n$ |
| 0     | X   | X   | $Q_n$       |



TOGGLE



| $clk$ | $J$ | $K$ | $Q_n$ | $Q_{n+1}$       |
|-------|-----|-----|-------|-----------------|
| 1     | 1   | 1   | 0     | 1, 0, 1, 0, ... |
| 1     | 1   | 1   | 1     | 0, 1, 0, 1, ... |

EXPLANATION



RACE AROUND





+ve edge triggered clock/  
rising edge clock



Master-slave J-K/FF works as a -ve edge trigger FF



for const input in SR, edge & level have no diff

D/latch if clk (level)

D/FF if clk (edge)



# T F/F

Toggle flip flop



$$J = K = T$$

$$Q_{n+1} = J \bar{Q}_n + \bar{K} Q_n$$

$$Q_{n+1} = T \oplus Q_n$$

$$Q_{n+1} \oplus Q_n = T$$

$$Q_{n+1}|_{SR} = S + \bar{R} Q_n$$

$$Q_{n+1}|_{JK} = J \bar{Q}_n + \bar{K} Q_n \rightarrow$$

$$Q_{n+1}|_D = D \quad \rightarrow \text{to construct Register (memory element)}$$

$$Q_{n+1}|_T = T \oplus Q_n \quad \rightarrow \text{to implement counters}$$

frequency divide by  $2^n$



Design one FF using another

▷ F/F available

→ implement  $J/K$



$$D = f(J, K, Q_n)$$

$$\begin{aligned} Q_{n+1} &= J \bar{Q}_n + \bar{K} Q_n \\ S_{n+1} &= D \end{aligned}$$

$$D = J \bar{Q}_n + \bar{K} Q_n$$

|   | Q <sub>n</sub> | 00 | 01 | 11 | 10 |
|---|----------------|----|----|----|----|
| 0 | 0              | 0  | 0  | 0  | 0  |
| 1 | 0              | 0  | 0  | 0  | 0  |

$$D = (J + Q_n) \cdot (\bar{K} + \bar{Q}_n)$$

→ implement  $T$

$$D = T \oplus Q_n$$

→ implement SR

$$D = S + R Q_n$$

can't implement

SR: 11 are shown  
value-in approach.

$T \rightarrow D$

| $Q_n$ | $D$ | $Q_{n+1}$ | $T = Q_n \oplus D$ |
|-------|-----|-----------|--------------------|
| 0     | 0   | 0         | 0                  |
| 0     | 1   | 1         | 1                  |
| 1     | 0   | 0         | 1                  |
| 1     | 1   | 1         | 0                  |



$SR \rightarrow JK$

available: SR

required: JK

| $Q_n$ | $J$ | $K$ | $Q_{n+1}$ | $S$ | $R$ |
|-------|-----|-----|-----------|-----|-----|
| 0     | 0   | 0   | 0         | 0   | X   |
| 0     | 0   | 1   | 0         | X   | X   |
| 0     | 1   | 0   | 0         | X   | X   |
| 0     | 1   | 1   | 1         | 0   | 0   |
| 1     | 0   | 0   | 1         | X   | 0   |
| 1     | 0   | 1   | 0         | 0   | 1   |
| 1     | 1   | 0   | X         | 0   | X   |
| 1     | 1   | 1   | 0         | 0   | 1   |

| $Q_n$ | $Q_{n+1}$ | $S$ | $R$ |
|-------|-----------|-----|-----|
| 0     | 0         | 0   | X   |
| 0     | 1         | 1   | 0   |
| 1     | 0         | 0   | 1   |
| 1     | 1         | X   | 0   |

| $Q_n$ | $J$ | $K$ | $Q_{n+1}$ | $S$ |
|-------|-----|-----|-----------|-----|
| 0     | 0   | 0   | 1         | 1   |
| 1     | X   | 0   | 0         | X   |
| 0     | X   | 0   | 0         | X   |
| 1     | 0   | 1   | 1         | 0   |

  

| $Q_n$ | $K$ | $Q_{n+1}$ | $R$ |
|-------|-----|-----------|-----|
| 0     | 00  | 01        | 10  |
| 1     | X0  | 00        | 10  |
| 0     | X0  | 00        | 00  |
| 1     | 01  | 11        | 00  |

(S)  $S = \overline{Q_n} J$

(R)  $R = Q_n K$



$\rightarrow 4\text{F/F} : 4\text{-D/FF}$

Register: 4 bit Register

1F/F: store 1 bit binary info

: 1 bit memory, bistable multivibrator

monostable

astable

bistable



Trigger 1 ( $T_1$ )



$T_1$      $T_2$      $T_3$



$$M1 \quad Q_3 Q_2 Q_1 Q_0 = \times \times \times \times$$

preset en = 0

pull  $D_3 D_2 D_1 D_0 = 1111$

apply CLK

$Q_3 Q_2 Q_1 Q_0 = 1111$

$$M2 \quad \text{initial } Q_3 Q_2 Q_1 Q_0 = 0000 \text{ (clr)}$$

$D_3 D_2 D_1 D_0 = \times \times \times \times$

$I_3 I_2 I_1 I_0 = 1111$

pull en = 1111

$Q_3 Q_2 Q_1 Q_0 = 1111$

Shift Register  $\rightarrow$  left  
 $\rightarrow$  right



shift register

$\rightarrow$  /sel in //sel out

$\rightarrow$  //sel in serial out

$\rightarrow$  serial in //sel out  $\leftarrow$   $\begin{array}{c} \text{parallel input} \\ \downarrow \quad \downarrow \quad \downarrow \\ Q_3 \quad Q_2 \quad Q_1 \quad Q_0 \end{array} \leftarrow \text{serial in}$

$\rightarrow$  serial in serial out



parallel in, parallel out  
Register

$$D_3 D_2 D_1 D_0 = 1111$$

then apply clock

$$\rightarrow Q_3 Q_2 Q_1 Q_0 = 1111$$

$\downarrow$  stored until we give clock again

$$M2 \quad \text{initial } Q_3 Q_2 Q_1 Q_0 = 0000 \text{ (clr)}$$

$D_3 D_2 D_1 D_0 = \times \times \times \times$

$I_3 I_2 I_1 I_0 = 1111$

pull en = 1111

$Q_3 Q_2 Q_1 Q_0 = 1111$

parallel out  
Synchronous.



4 bit Shift Left Register

clear enable

preset enable

① parallel in, parallel out {0 clock is needed}

clear  $Q_3 Q_2 Q_1 Q_0 = 0000$   
input data @  $I_{Q2} I_{Q1} I_{Q0} = 1010$

② parallel in, serial out {n-1 clock is needed for n bit}

for output, only  $Q_3$  can be accessed

$Q_3 Q_2 Q_1 Q_0 = 1010$

|       |      |
|-------|------|
| clk 1 | 101x |
| 2     | 10x* |
| 3     | 1x*x |

③ serial in, // out {n clock needed}

1110  
 $Q_3 Q_2 Q_1 Q_0$

initial  $Q_3 Q_2 Q_1 Q_0$   
x x \* x

Put  $D_0=1$ ,  $clk=1$

1 x x x

$D_1=1$ ,  $clk=2$

1 1 x x

$D_2=1$ ,  $clk=3$

1 1 1 x

$D_3=1$ ,  $clk=4$

0 1 1 1

④ serial in, serial out {n+n-1 clocks}



## Application of shift register

- ① for parallel to serial data conversion
- ② for serial to parallel data conversion
- ③ used to multiply w/  $2^n$  {Shift Left Register}
- ④ used to divide w/  $2^n$  {Shift Right Register}
- ⑤ its a ring counter



serial output & input connected.

2-bit ring

00, 01, 10, 11

|                | $Q_1$ | $Q_0$ |       | $Q_1$ | $Q_0$ |               |
|----------------|-------|-------|-------|-------|-------|---------------|
| start          | 0     | 0     | start | 0     | 1     |               |
| clk1           | 0     | 0     | clk1  | 1     | 0     |               |
| only one state |       |       | clk2  | 0     | 1     |               |
|                |       |       |       |       |       | 2 diff states |
| start          | 1     | 1     |       |       |       |               |
| clk1           | 1     | 1     |       |       |       |               |

cannot be detected from all bits same

{ MAX possible count by  
n-bit ring counter  
→ n }

Johnson Counter (twisted ring counter) / (switchtail)  
↳ shift register application



max possible no of used states =  $2^n$ .

|         | $Q_1$ | $Q_0$ |
|---------|-------|-------|
| initial | 0     | 0     |
| clk 1   | 1     | 0     |
| 2       | 1     | 1     |
| 3       | 0     | 1     |
| 4       | 0     | 0     |



## FREQUENCY DIVIDER



## N-BIT ADDER USING SHIFT REGISTERS



## Shift Register as synchronous counter



|         | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |
|---------|-------|-------|-------|-------|
| initial | 1     | 1     | 1     | 1     |
| clk 1:  | 1     | 1     | 1     | 1     |

Synchronous: provided to only one F/F (LSB)

Counters ( $\uparrow$  F/F) → Asynchronous: simultaneously provided to all FF

→ Driven by clock signal, used to count no. of clock cycles. Also known as freq. divider circuit

$$f_{op} = \frac{f_{clk}}{N}$$

$\underbrace{\hspace{1cm}}$  any integer value



ASYNCHRONOUS Serial/Ripple



SYNCHRONOUS Parallel

UP → Start of  
0000  
1111

ASYNCHRONOUS



| $Q_1$ | $Q_0$ |
|-------|-------|
| 0     | 0     |
| 0     | 1     |
| 1     | 0     |
| 1     | 1     |

$$f_{op} = \frac{f_{clk}}{\text{no. of o/p states}}$$





### MOD-N counter

mod-5.  $0 \rightarrow 1 \rightarrow 2 \rightarrow 3 \rightarrow 4$



$f_{CLK} \geq PD\text{ of all the FF} = n \times PD\text{ of any one FF}$

$f_{CLK/\min} = PD\text{ of all FF}$

$$f_{CLK} \leq \frac{1}{PD\text{ of all the FF}}$$

$$f_{CLK/\max} = \frac{1}{n \times PD\text{ of any FF}}$$

$7 \rightarrow 6 \rightarrow 5 \rightarrow 4 \rightarrow 3 \rightarrow 2$



$$f_{Q_2} = f_{Q_1} = f_{Q_0} = \frac{f_{CLK}}{5}$$

diff waveform



# Synchronous Counter

$0 \rightarrow 1 \rightarrow 2 \rightarrow 3$



| $Q_1$ | $Q_0$ | $Q_1^+$ | $Q_0^+$ | $T_1$ | $T_0$ |
|-------|-------|---------|---------|-------|-------|
| 0     | 0     | 0       | 1       | 0     | 1     |
| 0     | 1     | 1       | 0       | 1     | 1     |
| 1     | 0     | 1       | 1       | 0     | 1     |
| 1     | 1     | 0       | 0       | 1     | 1     |

$$T_0 = 1$$

$$T_1 = Q_0$$



## VARIABLE LENGTH SYNCHRONOUS 3-BIT COUNTER

→ Initially, we design a 3-bit UP counter with memory :



DC Page 14



load

en

clk

## LIMING DELAY

→  $t_{\text{setup}}$ : Time taken for final output to see a change after the active clock edge is called ( $t_{\text{a}} - t_{\text{aw}}$ )



\*  $t_{\text{setup}} \approx \text{Propagation delay of Slave Latch } (T_s)$

→  $t_{\text{hold}}$ : Time for which  $D_m$  must remain high before active clock edge of slave latch (i.e.  $Q_m$  should be stable before slave's active clock edge)

e.g. For same Master-Slave FF above,

\*  $t_{\text{hold}} \geq \text{Propagation delay of master latch } (T_m)$

\* If input changes in the time period before setup, the output of slave latch is unpredictable

i.e. output could be of this value or previous value of input



→  $t_{\text{hold}}$ : When the clock signal switches value (for active edge), due to the rise time, there is a delay for the clock to change value; during this time, input must remain constant to avoid ambiguous output (current|prev value)



## Clock DISTRIBUTION





- \* For any node there were FFs at both ends, then the interconnect delay = t<sub>skew</sub> for FFs
- \* This is due to the interconnect having a finite resistance



Input needs to be  
red by 1st FF during this

Possible timing diagram of an arrangement of a combination of 2 FFs

\*  $t_{\text{max}}$  → Delay of combinational circuit connecting the 2 FFs

④ Also b/w the 2 FFs,  
there is a  $t_{\text{skew}} = t_2 - t_1$   
 $\Rightarrow t_{\text{skew}} > t_{\text{setup}} + t_{\text{hold}} + t_{\text{prop}}$   
 $+ t_{\text{skew}}$

\* This time constraint ensures before  $t_{\text{setup}}$  is up, the output of the first FF reaches the 2<sup>nd</sup> FF.

\* But this also limits the value of the frequency of the circuit  $\Rightarrow$  circuit can only operate at certain speed.

Maximum logit  
link constraint



- \* The delay seen in the change of output at 1<sup>st</sup> FF and propagation of output to input of 2<sup>nd</sup> FF through combinational circuit is due to non zero transition time.

- \* If  $t_{\text{start}} = t_{\text{pmax}} = 0$  then the value of  $D_2$  can change in the setup hold window, thus causing an unstable output.

\* To overcome this scenario,  
 $t_{ckout} + t_{pmin} \geq t_{hold} + t_{skew}$

Minimum logic delay constraint

To Incorporate clock delay

To incorporate clock delay

## FREQUENCY DIVISION

→ To build a frequency divider by  $n$ , use a mod- $n$  counter similar to how Johnson counter was dividing frequency by 6.



→ f/3 with Duty Cycle = 50%



Output of the  
circuit is  
for half the  
period of the  
input i.e.  $3T/2$   
 $T$   
Duty cycle = 50%



\* Similarly frequency dividers & phase shift can be created for any desired values by using Mod-n counters & taking combinations of input values.



## Mod 5

| $Q_2$ | $Q_1$ | $Q_0$ |
|-------|-------|-------|
| 0     | 0     | 0     |
| 0     | 0     | 1     |
| 0     | 1     | 0     |
| 0     | 1     | 1     |
| 1     | 0     | 0     |



**Mealey & Moore**  
o/p function of Present state only (PS)



## MEALEY

