# Chapter 3 – Boolean Algebra and Digital Logic

CS 271 Computer Architecture Purdue University Fort Wayne

### Objectives

- □ Understand the relationship between Boolean logic and digital computer circuits.
- ☐ Learn how to design simple logic circuits.
- Understand how digital circuits work together to form complex computer systems.

### Introduction

- In the latter 19<sup>th</sup> century, George Boole suggested that logical thought could be represented through mathematical equations.
- □ Boolean algebra is everywhere
- https://www.google.com/doodles/george-booles-200th-birthday



### Application of Boolean Algebra

- Digital circuit
- Google search
- □ Database (SQL)
- Programming
- ......

# An Example on Programming

```
while (((A && B) || (A && !B)) || !A)
{
     // do something
}
```

### 3.2 Boolean Algebra

- Boolean algebra is a mathematical system for manipulating variables that can have one of two values.
  - In formal logic, these values are "true" and "false"
  - In digital systems, these values are "on"/"off," "high"/"low," or "1"/"0".
  - So, it is perfect for binary number systems
- □ Boolean expressions are created to operate Boolean variables.
  - Common Boolean operators include AND, OR, and NOT.

### Boolean Algebra

- □ The function of Boolean operator can be completely described using a *Truth Table*.
- The truth tables of the Boolean operators AND and OR are shown on the right.
- ☐ The AND operator is also known as the *Boolean product* ".". The OR operator is the *Boolean sum* "+".

#### X AND Y

| Y | XY          |
|---|-------------|
| 0 | 0           |
| 1 | 0           |
| 0 | 0           |
| 1 | 1           |
|   | 0<br>1<br>0 |

#### X OR Y

| Х | Y | X+Y |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 1   |

### Boolean NOT

- ☐ The truth table of the Boolean NOT operator is shown on the right.
- □ The NOT operation is most often designated by an overbar "-".
  - Some books use the prime mark (\') or the "elbow" (\'), for instead.



### **Boolean Function**

- ☐ A Boolean function has:
  - At least one Boolean variable,
  - At least one Boolean operator, and
  - At least one input from the set of {0,1}.
- □ It produces an output that is a member of the set {0,1} Either 0 or 1.

Now you know why the binary numbering system is so handy for digital systems.

### Boolean Algebra

□ Let's look at a truth table for the following Boolean function shown on the right. :

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

☐ To valuate the Boolean function easier, the truth table contains a extra columns (shaded) to hold the evaluations of partial function.

|   | $F(x,y,z) = x\overline{z} + y$ |   |   |    |                   |
|---|--------------------------------|---|---|----|-------------------|
| x | У                              | z | z | χΞ | x <del>z</del> +y |
| 0 | 0                              | 0 | 1 | 0  | 0                 |
| 0 | 0                              | 1 | 0 | 0  | 0                 |
| 0 | 1                              | 0 | 1 | 0  | 1                 |
| 0 | 1                              | 1 | 0 | 0  | 1                 |
| 1 | 0                              | 0 | 1 | 1  | 1                 |
| 1 | 0                              | 1 | 0 | 0  | 0                 |
| 1 | 1                              | 0 | 1 | 1  | 1                 |
| 1 | 1                              | 1 | 0 | 0  | 1                 |

### Rules Of Precedence

- Arithmetic has its rules of precedence
  - Like arithmetic, Boolean operations follow the rules of precedence (priority):
  - NOT operator > AND operator > OR operator .
- ☐ This explains why we chose the shaded partial function in that order in the table.





Rules Of Precedence

# Use Boolean Algebra in Circuit Design

- Digital circuit designer always like achieve the following goals:
  - Cheaper to produce
  - Consume less power
  - run faster
- ☐ How to do it? -- We know that:
  - Computers contain circuits that implement Boolean functions → Boolean functions can express circuits
  - If we can simplify a Boolean function, that express a circuit, we can archive the above goals
- □ We always can reduce a Boolean function to its <u>simplest</u> form by using a number of Boolean laws can help us do so.
  12

### Boolean Algebra Laws

- Most Boolean algebra laws have either an AND (product) form or an OR (sum) form. We give the laws with both forms.
  - Since the laws are always true, so X (and Y) could be either 0 or 1

| Identity                                         | AND                                            | OR                                                         |
|--------------------------------------------------|------------------------------------------------|------------------------------------------------------------|
| Name                                             | Form                                           | Form                                                       |
| Identity Law Null Law Idempotent Law Inverse Law | $1x = x$ $0x = 0$ $xx = x$ $x\overline{x} = 0$ | $0 + x = x$ $1 + x = 1$ $x + x = x$ $x + \overline{x} = 1$ |

### Boolean Algebra Laws ('Cont)

☐ The second group of Boolean laws should be familiar to you from your study of algebra:

| Identity                                               | AND                                            | OR                                               |
|--------------------------------------------------------|------------------------------------------------|--------------------------------------------------|
| Name                                                   | Form                                           | Form                                             |
| Commutative Law<br>Associative Law<br>Distributive Law | xy = yx $(xy) z = x (yz)$ $x+yz = (x+y) (x+z)$ | x+y = y+x $(x+y)+z = x + (y+z)$ $x(y+z) = xy+xz$ |

# Boolean Algebra Laws ('Cont)

- □ The last group of Boolean laws are perhaps the most useful.
  - If you have studied set theory or formal logic, these laws should be familiar to you.

| Identity<br>Name                 | AND<br>Form                                                  | OR<br>Form                                                 |
|----------------------------------|--------------------------------------------------------------|------------------------------------------------------------|
| Absorption Law<br>DeMorgan's Law | $x(x+y) = x$ $(\overline{xy}) = \overline{x} + \overline{y}$ | $x + xy = x$ $\overline{(x+y)} = \overline{x}\overline{y}$ |
| Double Complement Law            | $(\overline{x})$                                             |                                                            |

# DeMorgan's law

- DeMorgan's law provides an easy way of finding the negation (complement) of a Boolean function.
- □ DeMorgan's law states:

$$(\overline{xy}) = \overline{x} + \overline{y}$$
 and  $(\overline{x+y}) = \overline{x}\overline{y}$ 



Example

More Examples?

- I will come to school tomorrow if
  - (A) my car is working, and
  - □ (B) it won't be snowing
- I won't come to school tomorrow if
  - (A) my car is not working, or
  - □ (B) it will snowing



# DeMorgan's Law

- □ DeMorgan's law can be extended to any number of variables.
  - Replace each variable by its negation (complement)
  - Change all ANDs to ORs and all ORs to ANDs.
- $\square$  Let's say F (X, Y, Z) is the following, what is  $\overline{F}$ ?

$$F(X, Y, Z) = (XY) + (XY) + (XZ)$$

### Simplify Boolean function

□ Let's use Boolean laws to simplify:

as follows:

$$F(X,Y,Z) = (X+Y)(X+Y)(XZ)$$

```
(X + Y) (X + \overline{Y}) (X\overline{Z})
 (X + Y) (X + \overline{Y}) (\overline{X} + Z)
                                       DeMorgan's Law
                                       Double complement Law
 (XX + X\overline{Y} + YX + Y\overline{Y})(\overline{X} + \overline{Z})
                                       Distributive Law
((X + YY) + X(Y + Y))(X + Z)
                                       Commutative and Distributive Laws
((X + 0) + X(1))(X + Z)
                                       Inverse Law
  X(X + Z)
                                       Idempotent and Identity Laws
 x\overline{x} + xz
                                       Distributive Law
  0 + XZ
                                       Inverse Law
  XZ
                                       Identity Law
```

# Logic simplification steps

- Apply De Morgan's theorems
- Expanding out parenthesis
- □ Find the common factors
- □ Popular rules used:

$$X+XY=X$$
  $X+X=X$ ,  $XX=X$ 

$$XY+XY=X$$
  $X+0=X, X+1=1$ 

$$X+\overline{X}Y=X+Y$$
  $X0=0$   $X1=X$ 





# Example (1)

Apply De Morgan's theorem

$$\overline{W+X+Y+Z}$$



#### PURDUE UNIVERSITY FORT WAYNE

### Example (2)

 $\blacksquare (A\overline{B}(C+BD)+\overline{A}\overline{B})C$ 





### Example (3)

■ ĀBC+ABC+ĀBC+ABC



#### PURDUE UNIVERSITY FORT WAYNE

# Example (4)

$$\blacksquare$$
  $(\overline{AB+AC})+\overline{AB}C$ 





### Example (5)

■ AC+ABC+ABCD+ABD



#### PURDUE UNIVERSITY FORT WAYNE

# Example (6)

$$(\overline{A} + \overline{B} + \overline{C})(\overline{B} + C)(A + \overline{B})$$

### An Example on Programming

```
while (((A && B) || (A && !B)) || !A)
     // do something
while (1)
    // do something
```

### Boolean Algebra

- □ Through our exercises in simplifying Boolean expressions, we see that there are 1+ ways of stating the same Boolean expression.
  - These "synonymous" forms are logically equivalent.
  - Logically equivalent expressions could produce confusions

$$(X+Y) (X+\overline{Y}) (\overline{XZ}) = XZ$$

In order to eliminate the confusion, designers express Boolean express in unified and standardized form, called canonical form.

### Boolean Algebra

- ☐ There are two canonical forms for Boolean expressions: sum-of-products and product-of-sums.
  - Boolean product (x) → AND → logical conjunction operator
  - Boolean sum (+) → OR → logical conjunction operator
- □ In the sum-of-products form, ANDed variables are ORed together.
  - For example: F(x, y, z) = xy + xz + yz
- In the product-of-sums form, ORed variables are ANDed together.
  - For example: F(x, y, z) = (x+y)(x+z)(y+z)

### Minterm and Maxterm

- □ Some books uses <u>sum-of-minterms</u> form and <u>product-of-maxterms</u> form
  - A <u>minterm</u> is a logical expression of n variables that employs only the complement operator and the product operator.
    - □ For example, abc, ab'c and abc' are 3 minterms for a Boolean function of the three variables a, b, and c.
  - A <u>maxterm</u> is a logical expression of n variables that employs only the complement operator and the sum operator.

# Create Canonical Form Via Truth Table

- □ It is easy to convert a function to sum-of-products form from its truth table.
- □ We only interested in the production of the inputs which yields TRUE (=1).
  - We first *highlight* the lines that result in 1.
  - Then, we group them together with OR.

| E | $F(x,y,z) = x\overline{z} + y$ |   |   |      |  |
|---|--------------------------------|---|---|------|--|
|   | x                              | У | z | xz+y |  |
| Г | 0                              | 0 | 0 | 0    |  |
|   | 0                              | 0 | 1 | 0    |  |
|   | 0                              | 1 | 0 | 1    |  |
|   | 0                              | 1 | 1 | 1_   |  |
|   | 1                              | 0 | 0 | 1    |  |
|   | 1                              | 0 | 1 | 0    |  |
|   | 1                              | 1 | 0 | 1    |  |
|   | 1                              | 1 | 1 | 1    |  |
| L |                                |   |   |      |  |

# Create Canonical Form Via Truth Table ('Cont)

(xyz

■ Look at this example:

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

$$= (\overline{x}y\overline{z}) + (\overline{x}yz) + (x\overline{y}z)$$

$$+ (xy\overline{z}) + (xyz)$$

(xyz It may not the simplest form. But, it is the standard sum-of-products canonical

form

|          | $F(x,y,z) = x\overline{z}+y$ |   |   |      |  |  |
|----------|------------------------------|---|---|------|--|--|
|          | x                            | У | z | xz+y |  |  |
|          | 0                            | 0 | 0 | 0    |  |  |
|          | 0                            | 0 | 1 | 0    |  |  |
| )        | 0                            | 1 | 0 | 1    |  |  |
| Ì        | 0                            | 1 | 1 | 1_   |  |  |
| <b>'</b> | 1                            | 0 | 0 | 1    |  |  |
| )        | 1                            | 0 | 1 | 0    |  |  |
| )        | 1                            | 1 | 0 | 1    |  |  |
| ,<br>)   | 1                            | 1 | 1 | 1    |  |  |
| ,        |                              |   |   |      |  |  |

### Exercise

Convert ABC+A'BC+AB'C+A'B'C+ABC' to its simplest form

```
ABC+A'BC+AB'C+A'B'C+ABC'= BC(A+A') + B'C(A+A') + ABC'

= BC1 +B'C1 + ABC'

= C(B+B') + ABC'

= C + ABC'

= C + AB
```

### Exercise

□ Convert AB + C to the sum-of-products form

```
AB
                AB 1
                                By Th4
            (C + C')
        AΒ
                       By Th 15
        ABC + ABC'
                        By distributive law
        CBA + C'BA
                        By associative law
                                              By Th4
C
       C (A + A')
                                      By Th15
       CA + CA'
                                      By distributive law
        CA 1 + CA'1
                                      By Th4
        CA (B + B') + CA' (B + B') By Th15
        CAB + CAB' + CA'B + CA'B'
                                      By distributive law
        CBA + CBA' + CB'A + CB'A'
                                      By associative law
AB+C
        = (CBA + C'BA) + (CBA + CBA' + CB'A + CB'A')
= CBA + CBA' + CB'A + CB'A' + C'BA
```

### 3.3 Logic Gates

- □ We've seen Boolean functions in abstract terms.
- You may still ask:
  - How could Boolean function be used in computer?
- In reality, Boolean functions are implemented as digital circuits, which called *Logic Gates*.
- □ A logic gate is an electronic device that produces a result based on input values.
  - A logic gate may contain multiple transistors, but, we think them as one integrated unit.
  - Integrated circuits (IC) contain collections of gates, for a particular purpose.

### AND, OR, and NOT Gates

☐ Three simplest gates are the AND, OR, and NOT gates.

"inversion bubble"



Their symbol and their truth tables are listed above.

### NAND and NOR Gates

- NAND and NOR are two additional gates.
  - Their symbols and truth tables are shown on the right.
- □ NAND = NOT AND
- $\square$  NOR = NOT OR



# The Application of NAND and NOR Gates

- □ NAND and NOR are known as <u>universal</u>
   <u>gates!</u> <u>gates of all</u>
   <u>gates</u>
  - They are inexpensive to produce
- More important: Any Boolean function can be constructed using only NAND or only NOR gates.



# Multiple Inputs and Outputs of Gates

- The gates could have multiple inputs and/or multiple outputs.
  - The second output can be provided as the complement of the first output.
  - We'll see more integrated circuits, which have multiple inputs/outputs.



#### **XOR Gates**

- Another very useful gate is the *Exclusive OR* (XOR) gate.
- ☐ The output of the XOR operation is true (1) only when the values of inputs are different.



 $\square$  The symbol for XOR is  $\bigoplus$ 

### Parity generator / checker

- ☐ Electrical noise in the transmission of binary information can cause errors
- ☐ Parity can detect these types of errors
- □ Parity systems
  - Odd parity
  - Even parity
- Add a bit to the binary information

#### Even parity check

- ☐ Even parity check
- □ Example: input: A(7...0), Output: even\_parity bit
  - If there are even numbers of 1 in A, even\_parity = '0',
  - If there are odd numbers of 1 in A, even\_parity = '1'

```
e.g., A = "10100001",

even_parity = '1'

A = "10100011",

even_parity = '0'
```

### Odd parity check

- □ Odd parity check
- Example: input: A(7...0), Output: odd\_parity bit
  - If there are odd numbers of 1 in A, odd\_parity = `0',
  - If there are even numbers of 1 in A, odd\_parity = '1'

```
e.g., A = "10100001",
odd_parity = '0'
A = "10100011",
```

odd\_parity = '1'

# Odd-parity generator/checker system



#### Error detection

- ☐ Transmitting end: The parity generator creates the parity bit.
- □ Receiving end: The parity checker determines if the parity is correct.
- □ e.g., odd-parity check of 8-bit data
  - Data send: 10111101 + 1
  - Data received: 101011011
  - odd-parity check: The number of 1 is even  $\rightarrow$  *error*

### Discussion point

- □ What are disadvantages of even parity (or odd parity) check to detect transmission errors? Consider the following case:
  - Protocol: 8-bit plus one even parity bit
  - Information sent: 11011100 + 1
  - Information received: 10010100 + 1
- □ The parity generator/checker system detects only errors that occur to 1 bit.

## Parity check using XOR

- □ N-1 XOR gates can be cascaded to form a circuit with N inputs and a single output
  - even-parity circuit.
  - Example: N=8, Inputs=10111101, even-parity output
    - $=((1\oplus 0)\oplus (1\oplus 1))\oplus ((1\oplus 1)\oplus (0\oplus 1))=0$
- □ Odd-parity check circuit: even-parity check circuit → Inverted → Odd-parity check
  - Example: N=8, Inputs=10111101, odd-parity output
    - $= \mathsf{NOT}(((1\oplus 0)\oplus (1\oplus 1))\oplus ((1\oplus 1)\oplus (0\oplus 1))) = 1$

### Binary comparators

A one-bit comparator is the same as the XOR



♦ A *n*-bit comparator determines if two *n*-bit signal vectors are equal:

$$EQ(X[1:n],Y[1:n])=(X1=Y1)(X2=Y2)....(Xn=Yn)$$

### Two Types of Logic Circuits

- ☐ Combinational Logic Circuit (CLC)
  - Good at designing <u>computational</u> components in the CPU, such as ALU
- ☐ Sequential Logic Circuit (*SLC*)
  - Good at designing memory components, such as registers and memory

### Logic Gates

- □ We use the combination of gates to implement Boolean functions.
- ☐ The circuit below implements the Boolean function:

$$F(X,Y,Z) = X + \overline{Y}Z$$



# 3.5 Combinational Circuits



☐ The circuit implements the Boolean function:

$$F(X,Y,Z) = X+YZ$$

- □ The major characteristics of this kind of circuits:
  - The circuit produces an output almost immediately after the inputs are given.
- This kind of circuits are called combinational logic circuit (CLC).
  - In a later section, we will explore circuits where this is not the case.

# Simplify *CLC via* Boolean Algebra

- □ As I have mentioned previously:
  - The simpler that we can express a Boolean function, the smaller the circuit will be constructed.
  - Simpler circuits are cheaper → consume less power → run faster than complex circuits.
- We always want to reduce a Boolean function to its simplest form.
- It is important to simplify combinational logic circuit via Boolean algebra laws

# Simplify *CLC via* Boo Algebra

Can we simplify this circuit? If yes, then how?

Look at this example



# Steps to Simplify a Complex Circuit

- From this example, we know that the basic steps to simplify a complex circuit is the following:
  - Step1: Express a logical circuit into a Boolean expression
  - Step2: Simplify the Boolean expression as much as possible
  - Step3: Re-express the simplified expression back to a circuit.

☐ Simplify the following circuit



Step1: Express a logical circuit into a Boolean expression



Step2: Simplify the Boolean expression as much as possible



Step3: Re-express the simplified expression back to a circuit



Obviously, the simplified circuit is much <u>simpler</u> than the original one

# Combinational Circuits: *Half Adder*

- Combinational logic circuits can be used to create many useful devices.
- ☐ *Half Adder*. Compute the sum of two bits.
- Let's gain some insight of how to construct a half adder by looking at its truth table on the right.

| Inputs |             | Outputs            |  |
|--------|-------------|--------------------|--|
| Y      | Sum         | Carry              |  |
| 0      | 0           | 0                  |  |
| 1      | 1           | 0                  |  |
| 0      | 1           | 0                  |  |
| 1      | 0           | 1                  |  |
|        | Y<br>0<br>1 | Y Sum  0 0 1 1 0 1 |  |

#### Combinational Circuits: Half

### Adder ('Cont)

- ☐ It consists two gates:
  - a XOR gate -- the sum bit
  - a AND gate -- the carry bit

| х -<br>ч - | Sum   |
|------------|-------|
| 1 -        |       |
|            |       |
| _          | Carry |

| Inputs |   | Outputs |       |  |
|--------|---|---------|-------|--|
| x      | Y | Sum     | Carry |  |
| 0      | 0 | 0       | 0     |  |
| 0      | 1 | 1       | 0     |  |
| 1      | 0 | 1       | 0     |  |
| 1      | 1 | 0       | 1     |  |

# Combinational Circuits: *Full Adder*

- We can extend the half adder to a full adder, which includes an additional carry bit (Carry In)
- The truth table for a full adder is shown on the right.

|   | Inputs |             |     | Outputs      |  |
|---|--------|-------------|-----|--------------|--|
| X | Y      | Carry<br>In | Sum | Carry<br>Out |  |
| 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            |  |

#### Half Adder → Full Adder ?

☐ How can we extend the half adder to a full adder?



|   | Inputs |             |     | Outputs      |  |  |
|---|--------|-------------|-----|--------------|--|--|
| x | Y      | Carry<br>In | Sum | Carry<br>Out |  |  |
| 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            |  |  |

☐ Hint: First calculate X + Y by a half adder, then the sum adds the carry in bit, then.....

#### The Full Adder



## Ripple-carry Adder

- Just as we combined half adders to construct a full adder, full adders can be connected in series.
- The carry bit "ripples" from one adder to the next. This configuration is called a *ripple-carry adder*.



This is the full adder for two 16 bits!

#### Decoder

- Decoder is another important combinational circuit.
- □ It is used to select a memory location according a address in binary form
  - Application: given a memory address → Obtain its memory content.
- $\square$  Address decoder with <u>n inputs</u> can select one out of <u>2<sup>n</sup> locations</u>.



### Decoder



#### A 2-to-4 Decoder

☐ This is a 2-to-4 decoder:





74138 as a memory address decoder

## Multiplexer

- A multiplexer works just the opposite to a decoder.
- It selects a single value from multiple inputs.
- The chosen input for output is determined by the value of the multiplexer's control lines.
- □ To select from n inputs,
   log₂n control lines are required.



## A four-line multiplexer



Data select control input determines which data input is connected to the output

**Table 8–5** Data Select Input Codes for Figure 8–30

|                  | Select<br>l Inputs | Doto Input             |
|------------------|--------------------|------------------------|
| $\overline{S_1}$ | $S_0$              | Data Input<br>Selected |
| 0                | 0                  | $D_0$                  |
| 0                | 1                  | $D_1$                  |
| 1                | 0                  | $D_2$                  |
| 1                | 1                  | $D_3$                  |

What is the logic equation for the output Y =?

#### Combinational Circuits

☐ This is a 4-to-1 multiplexer.





A Simple Two-Bit ALU

# 3.6 Sequential Logic Circuits (*SLC*)

- □ Combinational logic circuits are perfect for those applications when a Boolean function be immediately evaluated, given the current inputs.
  - Examples: multiplexer, ripple-carry adder, shifter, etc.
- However, sometimes, we need a kind of circuits that change value by considering the current inputs and its current state.
  - Memory is such an example that requires to remember the current state
  - The circuits need to "remember" their states.
- Sequential logic circuits (SLC) provide this functionality.

#### How to "remember"?

- Think about the states in your own life-time
  - 1 years old, blabla...
  - 2 years old, blabla...
  - 3 years old, blabla...



# Essential Component of Sequential Circuits: Clocks

- □ As the name implies, sequential logic circuits require a means by which events can be sequenced.
- ☐ The change of states is triggered by the clock.
  - The "clock" is a special circuit that sends electrical pulses to a sequential logic circuit.
- ☐ Clocks produce electrical waveforms constantly, such as the one shown below.



#### When Change Its State?

- ☐ State changes occur in sequential circuits, *only when* the clock ticks.
- ☐ A sequential logic circuits could changes it state
  - Either, at the <u>rising/falling edge</u> of the clock pulse,
  - Or, when the clock pulse reaches its <u>highest/lowest level</u>.



# Edge-triggered Or Level-triggered?

- □ SLC that changes its state at the rising edge, or the falling edge of the clock pulse is called *Edge-triggered SLC*.
- □ SLC that changes its state when the clock voltage reaches to its highest or lowest level are called Level-triggered SLC.



#### Latch And Flip-flop

- latch and flip-flop are two kinds of SLCs, which are used to construct memory
  - A latch is level-triggered
  - A flip-flop is edge-triggered
- □ Which one depends on the length of the clock pulse?
  - Latch, or
  - flip-flop?

# Essential Component Of Sequential Circuits: *Feedback*

- ☐ The most important design mechanism of SLC is **Feedback** 
  - Feedback can retain the state of sequential circuits
- ☐ Feedback in digital circuits occurs when an output is *looped back* as an input.
- A simple example of this concept is shown below.
  - If Q is 0 it will always be 0, if it is 1, it will always be 1. --- The motivation of Memory!



#### SR Flip-flop

- You can see how feedback works by examining the most basic sequential logic components, the SR flip-flop.
  - The "SR" stands for set/reset.
- ☐ The internals of an SR flip-flop are shown below, along with its block diagram. Clock Driven



#### Behavior Of An SR Flip-flop

- The behavior of an SR flip-flop is illustrated in the following truth table.
  - Let's denote Q(t) as the value of the output at time t, and
  - Denote Q(t+1) is the value of Q at time t+1.



| s | R | Q(t+1)           |
|---|---|------------------|
| 0 | 0 | Q(t) (no change) |
| 0 | 1 | 0 (reset to 0)   |
| 1 | 0 | 1 (set to 1)     |
| 1 | 1 | undefined        |

Retain its original value

Change its value

### SR Flip-flop Truth Table

- □ We consider Q(t), its current output, as the third input for SR flipflop, besides S and R.
- ☐ The truth table for this circuit, as shown on the right.
- □ When both S and R are1, the SR flip-flop is in forbidden state



#### Clocked SR Flip-flop



#### JK Flip-flop

- One limitation of SR flip-flop is that, when S and R are both 1, the output is *undefined*.
  - This is not nice because it wastes a state
- ☐ Therefore, SR flip-flop can be modified to provide a stable state when both S and R inputs are 1.
- This modified flip-flop is called a JK flip-flop, shown on the right.
  - The "JK" is in honor of Jack Kilby.



#### 3.6 Sequential Circuits

- On the right, we see how an SR flip-flop can be modified to create a JK flip-flop.
- The truth table indicates that the flip-flop is stable for all inputs.
  - When J and K are both 1,  $Q(t+1) = \neg Q(t)$



| J | K | Q(t+1)           |
|---|---|------------------|
| 0 | 0 | Q(t) (no change) |
| 0 | 1 | 0 (reset to 0)   |
| 1 | 0 | 1 (set to 1)     |
| 1 | 1 | Q(t)             |

#### An Example

- ☐ Let's say a JK flip-flop is <u>rising-edge</u> triggered
- $\square$  At t0, Q(t) = 0. What will be the changes of the value of Q over time?



JK flip-flop

 Any time other than the rising edge won't trigger this JK flip-flop to change its state

| J | K | Q(t+1)           |
|---|---|------------------|
| 0 | 0 | Q(t) (no change) |
| 0 | 1 | 0 (reset to 0)   |
| 1 | 0 | 1 (set to 1)     |
| 1 | 1 | Q(t) 88          |

#### D Flip-flop

- Another modification of the SR flip-flop is the D flip-flop, shown below with its truth table.
- You will notice that the output of the flip-flop remains the same during subsequent clock pulses. The output changes only when the value of D changes.



| D | Q(t+1) |
|---|--------|
| 0 | 0      |
| 1 | 1      |

#### D Flip-flop

- ☐ The D flip-flop is the fundamental circuit of computer memory.
  - D flip-flop and its truth table are illustrated as below.



| D | Q(t+1) |
|---|--------|
| 0 | 0      |
| 1 | 1      |

#### 3.6 Sequential Circuits

- Sequential circuits are used anytime that we need to design a "stateful" application.
  - A stateful application is one where the next state of the machine depends on the current state of the machine and the input.
- A stateful application requires both combinational and sequential logic.
- ☐ The following slides provide several examples of circuits that fall into this category.

Can you think of others?

#### 3.6 Sequential Circuits

This illustration shows a 4-bit register consisting of D flip-flops. You will usually see its block diagram (below) instead.



A larger memory configuration is shown on the next slide.



## 3.6 4X3 Memory



#### 3.6 Sequential Circuits

- A binary counter is another example of a sequential circuit.
- The low-order bit is complemented at each clock pulse.
- □ Whenever it changes from 0 to 1, the next bit is complemented, and so on through the other flip-flops.



#### 3.7 Designing Circuits

- Digital designers rely on specialized software to create efficient circuits.
  - Thus, software is an enabler for the construction of better hardware.
- Of course, software is in reality a collection of algorithms that could just as well be implemented in hardware.
  - Recall the Principle of Equivalence of Hardware and Software.

#### **Designing Circuits**

- □ When we need to implement a simple, specialized algorithm and its execution speed must be as fast as possible, a hardware solution is often preferred.
- □ This is the idea behind *embedded systems*, which are small special-purpose computers that we find in many everyday things.
- □ Embedded systems require special programming that demands an understanding of the operation of digital circuits, the basics of which you have learned in this chapter.

#### Chapter 3 Conclusion

- Computers are implementations of Boolean logic.
- Boolean functions are completely described by truth tables.
- Logic gates are small circuits that implement Boolean operators.
- □ The basic gates are AND, OR, and NOT.
  - The XOR gate is very useful in parity checkers and adders.
- ☐ The "universal gates" are NOR and NAND.

#### Chapter 3 Conclusion

- Computer circuits consist of combinational logic circuits and sequential logic circuits.
- Combinational circuits produce outputs almost immediately when their inputs change.
- Sequential circuits require clocks to control their changes of state.
- □ The basic sequential circuit unit is the flip-flop: The behaviors of the SR, JK, and D flip-flops are the most important to know.

#### End of Chapter 3