

## Module V

### ⇒ Registers and Counters

A register is a group of flip-flops that can be used to store a binary number.

There must be one flip-flop for each bit in the binary number. For example, a register used to store 8 bit binary number must have 8 flip-flops.

The flip-flops must be connected such that the binary number can be entered or shifted into the register & possibly shifted out. A group of flip-flops connected to provide either or both of these functions is called a shift register.

#### Types of Shift registers:

- 1 Serial In Serial Out
- 2 Serial In Parallel Out
- 3 Parallel In Serial Out
- 4 Parallel In Parallel Out

#### a SERIAL IN SERIAL OUT



#### b SERIAL IN PARALLEL OUT



## C PARALLEL IN SERIAL OUT



## d Parallel in Parallel out

Parallel data inputs.

Parallel  
data  
outputs

- The bits in a binary number can be moved from one place to another in either of two ways.
- The first method involves shifting the data one bit at a time in a serial fashion, beginning with either the MSB or LSB - This technique is referred as serial shifting.
- The second method involves shifting all the data bits simultaneously - This technique is referred as parallel shifting.
- There are two ways to shift data into a register, serial or parallel & similarly two ways to shift the data out of the register - This leads to the construction of 4 basic register type as shown in above figure.

(3)

## 1 SERIAL IN SERIAL OUT (SISO)

→ Design 4 bit SISO Shift Register using JK flipflops

Logic diagram



Block diagram



## Timing diagram



→ Show how a number 0100 is entered serially in a shift register using state table.

State table.

| Clock | SI | Q | R | S | T |
|-------|----|---|---|---|---|
| 0     | 0  | 0 | 0 | 0 | 0 |
| 1     | 1  | 0 | 0 | 0 | 0 |
| 2     | 0  | 1 | 0 | 0 | 0 |
| 3     | 0  | 0 | 1 | 0 | 0 |
| 4     | 0  | 0 | 0 | 1 | 0 |

(5)

⇒ Design 4 bit SISO left shift register using

D flip-flop (Negative edge triggered).

Initial contents of the register is 0011  
( $Q_0, Q_1, Q_2, Q_3$ )

Logic Diagram



Block diagram



Timing diagram



State table

| Clk | SI | $Q_0$ | $Q_1$ | $Q_2$ | $Q_3$ | Next |
|-----|----|-------|-------|-------|-------|------|
| 0   | 0  | 0     | 0     | 1     | 1     |      |
| 1   | 1  | 0     | 0     | 0     | 1     |      |
| 2   | L  | 1     | 0     | 0     | 0     |      |
| 3   | 0  | 1     | 1     | 0     | 0     |      |
| 4   |    | 0     | 1     | 1     | 0     |      |

⇒

a) Block diagram

7

b) Logic diagram



c) Timing diagram



$\Rightarrow$  Parallel In Parallel out Right Shift Register

$\Rightarrow$

Block diagram



Shift Register Operation

| Inputs | Outputs                         | Action |
|--------|---------------------------------|--------|
| sh L   | $Q_3^+$ $Q_2^+$ $Q_1^+$ $Q_0^+$ |        |
| 0 0    | $Q_3$ $Q_2$ $Q_1$ $Q_0$         | NC     |
| 0 1    | $D_3$ $D_2$ $D_1$ $D_0$         | Load   |
| 1 X    | SI $Q_3$ $Q_2$ $Q_1$            | Shift  |

Logic diagram

9

Timing diagramApplications of Registers

~~APP of Register~~ → Johnson counter or twisted ring counters.

Logic diagram

## Transition Graph or state diagram



## Timing diagram



### Counter definition:

A circuit that cycles through a fixed sequence of states is called a counter.

### Johnson Counter definition:

A shift register with inverted feedback is called a Johnson counter or a twisted ring counter.

## Applications of Registers

App of register

⇒ Ring counter



1 ⇒ If the data in flipflops is 000 or 111 then all the states will be similar i.e., 000 or 111  
 ↳ we can use this for application which is repeatedly produce a same state.

⇒ State or transition diagram



2. If the data in flipflops is 011, then



Timing assuming data in a register at 011



A shift register with non inverted feedback is called a ring counter.

⇒ 4-bit D-flipflop register with data, load, clear & clock inputs.

CE: clock enable

when load is 1  
it works



- When load is equal to zero, the register is not clocked & holds its present value.
- When load is equal to one, the clock is transmitted to the flipflop & the data applied to D inputs will be loaded into the flipflops on the falling edge of the clock. For example: if the Q outputs  $Q_3, Q_2, Q_1, Q_0$  is 0000 & the data inputs  $D_3, D_2, D_1, D_0$  is 1101. After the falling edge of the clock, Q will change from

0000 to 1101

→ the  $\text{clrN}$  is a asynchronous input, the bubble at the clear input indicates that the logic '0' is required to clear the flipflop.

⇒ Data transfer between the register



Register A = FF  $A_1 \& A_2$

Register B = FF  $B_1 \& B_2$

Register Q = FF  $Q_1 + Q_2$

→ 8-bit register with tristate output  
Logic diagram



Block diagram



- The above figure shows an integrated circuit register that contains 8 D Flipflops with the tristate buffers at flipflop outputs.
- The buffers are enabled when  $E_n = 0$ . The second figure shows the block diagram for 8 bit register.

## ⇒ Data Transfer using the tristate bus



- The above figure shows how data can be transferred from one of the four 8-bit registers into one of two other registers.
- The operation can be summarized as follows
  - i If  $EF = 00$ , then 'A' is stored in 'G' or 'H'
  - ii If  $EF = 01$ , then 'B' is stored in 'G' or 'H'
  - iii If  $EF = 10$ , then 'C' is stored in 'G' or 'H'
  - iv If  $EF = 11$ , then 'D' is stored in 'G' or 'H'

## Parallel Adder with Accumulation



- In computer circuits, it is frequently desirable to store one number in a register of flipflops (called an accumulator) and add a second number to it, leaving the result stored in the accumulator.
- Suppose that the number  $X = x_n \dots x_2 x_1$  is stored in the accumulator. Then, the number  $Y = y_n \dots y_2 y_1$  is applied to the full adder inputs, and after the carry has propagated through the adders, the sum of  $X$  and  $Y$  appears at the adder outputs.
- An add signal (Ad) is used to load the adder outputs into the accumulator flip-flops on the rising clock edge.
- If  $s_i = 1$ , the next state of flip-flop  $x_i$  will be 1. If  $s_i = 0$ , the next state of flip-flop  $x_i$  will be 0. Thus,  $x_i^+ = s_i$ , and if  $Ad = 1$ , the number  $X$  in the accumulator is replaced with the sum of  $X$  and  $Y$  following the rising edge of the clock.

(17)

$\Rightarrow$  Design of irregular counter (counter for other sequence)

$\Rightarrow$  i) Design an upcounter for given state diagram using T flip-flop.



(Q2)

$$0 \rightarrow 4 \rightarrow 7 \rightarrow 2 \rightarrow 3$$

i)  $T \rightarrow 111 \Rightarrow 3 \text{ FF}$  we need

ii) T-FF

iii) Excitation table for T Flip Flop

| $Q_n$ | $Q_{n+1}$ | T |
|-------|-----------|---|
| 0     | 0         | 0 |
| 0     | 1         | 1 |
| 1     | 0         | 1 |
| 1     | 1         | 0 |

iv) Next state table.

| $Q_C$ | $Q_B$ | $Q_A$ | $Q_{C+1}$ | $Q_{B+1}$ | $Q_{A+1}$ | $T_C$ | $T_B$ | $T_A$ |
|-------|-------|-------|-----------|-----------|-----------|-------|-------|-------|
| 0     | 0     | 0     | 1         | 0         | 0         | 1     | 0     | 0     |
| 0     | 0     | 1     | x         | x         | x         | x     | x     | x     |
| 0     | 1     | 0     | 0         | 1         | 1         | 0     | 0     | 1     |
| 0     | 1     | 1     | 0         | 0         | 0         | 0     | 1     | 1     |
| 1     | 0     | 0     | 1         | 1         | 1         | 0     | 1     | 1     |
| 1     | 0     | 1     | x         | x         | x         | x     | x     | x     |
| 1     | 1     | 0     | x         | x         | x         | x     | x     | x     |
| 1     | 1     | 1     | 0         | 1         | 0         | 1     | 0     | 1     |

K-map

|             |             | $Q_B Q_A$             |                 |                 |           |
|-------------|-------------|-----------------------|-----------------|-----------------|-----------|
|             |             | $\bar{Q}_B \bar{Q}_A$ | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ |
| $\bar{Q}_C$ | $\bar{Q}_C$ | 1                     | x               | 0               | 0         |
|             | $Q_C$       | 0                     | (x)             | (1)             | x         |

Timing diagram



$$T_C = Q'_C Q'_B + Q_C Q_B$$

|             |             | $Q_B Q_A$             |                 |                 |           |
|-------------|-------------|-----------------------|-----------------|-----------------|-----------|
|             |             | $\bar{Q}_B \bar{Q}_A$ | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ |
| $\bar{Q}_C$ | $\bar{Q}_C$ | 0                     | x               | 1               | 0         |
|             | $Q_C$       | 1                     | x               | 0               | x         |

$$T_B = Q'_C Q_A + Q_C Q'_B$$

|             |             | $Q_B Q_A$             |                 |                 |           |
|-------------|-------------|-----------------------|-----------------|-----------------|-----------|
|             |             | $\bar{Q}_B \bar{Q}_A$ | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ |
| $\bar{Q}_C$ | $\bar{Q}_C$ | 0                     | x               | 1               | 1         |
|             | $Q_C$       | 1                     | x               | 1               | x         |

$$T_A = Q_C + Q_B$$



→ 2. Design an upcounter for given state diagram using D flip-flop.



i)  $D \rightarrow 10 \Rightarrow 2\text{FF}$

ii) D-FF

2D

iii) Excitation table for D-Flip Flop.

| $Q_n$ | $Q_{n+1}$ | D |
|-------|-----------|---|
| 0     | 0         | 0 |
| 0     | 1         | 1 |
| 1     | 0         | 0 |
| 1     | 1         | 1 |

iv) Next state table

| $Q_B$ | $Q_A$ | $Q_{B+1}$ | $Q_{A+1}$ | $D_B$ | $D_A$ |
|-------|-------|-----------|-----------|-------|-------|
| 0     | 0     | 1         | 1         | 1     | 1     |
| 0     | 1     | 1         | 1         | 1     | 1     |
| 1     | 0     | 0         | 0         | 0     | 0     |
| 1     | 1     | 1         | 0         | 1     | 0     |

K-map:

| $\bar{Q}_B$ | $Q_A$ | $\bar{Q}_A$ | $Q_{A+1}$ |
|-------------|-------|-------------|-----------|
| $\bar{Q}_B$ | 1     | 1           |           |
| $Q_B$       | 0     | 1           |           |

$$D_B = \bar{Q}_B + Q_A$$

| $\bar{Q}_A$ | $\bar{Q}_B$ | $Q_A$ | $Q_{A+1}$ |
|-------------|-------------|-------|-----------|
| $\bar{Q}_A$ | 1           | 1     |           |
| $Q_B$       | 0           | 0     |           |

$$D_A = \bar{Q}_B$$

21



→ Design irregular counter using JK Flip Flop for the following sequence:



i) JK - 110 - 3FF

ii) JK Flip-Flop

iii) Excitation table for JK Flip Flop.

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

## Next state table

| $Q_C$ | $Q_B$ | $Q_A$ | $Q_{C+1}$ | $Q_{B+1}$ | $Q_{A+1}$ | $J_C$ | $K_C$ | $J_B$ | $K_B$ | $J_A$ | $K_A$ |
|-------|-------|-------|-----------|-----------|-----------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0         | 1         | 1         | 0     | x     | 1     | x     | 1     | x     |
| 0     | 0     | 1     | x         | x         | x         | x     | x     | x     | x     | x     | x     |
| 0     | 1     | 0     | 0         | 0         | 0         | 0     | x     | x     | 1     | 0     | x     |
| 0     | 1     | 1     | 1         | 1         | 0         | 1     | x     | x     | 0     | x     | 1     |
| 1     | 0     | 0     | 0         | 1         | 0         | x     | 1     | 1     | x     | 0     | x     |
| 1     | 0     | 1     | x         | x         | x         | x     | x     | x     | x     | x     | x     |
| 1     | 1     | 0     | 1         | 0         | 0         | 0     | x     | 0     | x     | 1     | 0     |
| 1     | 1     | 1     | x         | x         | x         | x     | x     | x     | x     | x     | x     |

## K-Map

| $Q_B Q_A$             |   |                 |                 |           |                       |
|-----------------------|---|-----------------|-----------------|-----------|-----------------------|
| $\bar{Q}_B \bar{Q}_A$ |   | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ | $\bar{Q}_B \bar{Q}_A$ |
| $\bar{Q}_C$           | 0 | x               | 1               | 0         |                       |
| $\bar{Q}_C$           | x | x               | x               | x         |                       |

$$J_C = Q_A$$

| $Q_B Q_A$             |   |                 |                 |           |                       |
|-----------------------|---|-----------------|-----------------|-----------|-----------------------|
| $\bar{Q}_B \bar{Q}_A$ |   | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ | $\bar{Q}_B \bar{Q}_A$ |
| $\bar{Q}_C$           | 0 | x               | x               | x         | x                     |
| $\bar{Q}_C$           | 1 | x               | x               | x         | 0                     |

$$K_C = \bar{Q}_B$$

| $Q_B Q_A$             |   |                 |                 |           |                       |
|-----------------------|---|-----------------|-----------------|-----------|-----------------------|
| $\bar{Q}_B \bar{Q}_A$ |   | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ | $\bar{Q}_B \bar{Q}_A$ |
| $\bar{Q}_C$           | 1 | x               | x               | x         | x                     |
| $\bar{Q}_C$           | 1 | x               | x               | x         | x                     |

$$J_B = 1$$

| $Q_B Q_A$             |   |                 |                 |           |                       |
|-----------------------|---|-----------------|-----------------|-----------|-----------------------|
| $\bar{Q}_B \bar{Q}_A$ |   | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ | $\bar{Q}_B \bar{Q}_A$ |
| $\bar{Q}_C$           | x | x               | 0               | 1         |                       |
| $\bar{Q}_C$           | x | x               | 0               | 1         |                       |

$$K_B = \bar{Q}_A$$

| $Q_B Q_A$             |   |                 |                 |           |                       |
|-----------------------|---|-----------------|-----------------|-----------|-----------------------|
| $\bar{Q}_B \bar{Q}_A$ |   | $\bar{Q}_B Q_A$ | $Q_B \bar{Q}_A$ | $Q_B Q_A$ | $\bar{Q}_B \bar{Q}_A$ |
| $\bar{Q}_C$           | 1 | x               | x               | 0         |                       |
| $\bar{Q}_C$           | 0 | x               | x               | 0         |                       |

$$J_A = \bar{Q}_C \bar{Q}_B$$

$$K_A = 1$$



→ Design Mod 6 downcounter using SR flip flop where all unused state must lead to 000

$5 \rightarrow 0$

$101 \rightarrow 000$

3 SR Flip Flops.



Excitation table for SR Flip Flop

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

Next State table.

| $Q_C$ | $Q_B$ | $Q_A$ | $Q_{C+1}$ | $Q_{B+1}$ | $Q_{A+1}$ | $S_C$ | $R_C$ | $S_B$ | $R_B$ | $S_A$ | $R_A$ |
|-------|-------|-------|-----------|-----------|-----------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 1         | 0         | 1         | 1     | 0     | 0     | X     | 1     | 0     |
| 0     | 0     | 1     | 0         | 0         | 0         | 0     | X     | 0     | X     | 0     | 1     |
| 0     | 1     | 0     | 0         | 0         | 1         | 0     | X     | 0     | 1     | 1     | 0     |
| 0     | 1     | 1     | 0         | 1         | 0         | 0     | X     | X     | 0     | 0     | 1     |
| 1     | 0     | 0     | 0         | 1         | 1         | 0     | 1     | 1     | 0     | 1     | 0     |
| 1     | 0     | 1     | 1         | 0         | 0         | X     | 0     | 0     | X     | 0     | 1     |
| 1     | 1     | 0     | 0         | 0         | 0         | 0     | 1     | 0     | 1     | 0     | X     |
| 1     | 1     | 1     | 0         | 0         | 0         | 0     | 0     | 1     | 0     | 1     | 0     |

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | (1) 0 0 0                                                       | $\bar{Q}_C$ | 0 X X X                                                         |

  

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | (1) 0 0 0                                                       | $\bar{Q}_C$ | X X 0 (1)                                                       |

$$S_C = \bar{Q}_A \bar{Q}_B \bar{Q}_C$$

$$R_C = Q_B + Q_C \bar{Q}_A$$

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | (1) 0 0 X 0                                                     | $\bar{Q}_C$ | X X 0 (1)                                                       |

  

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | (1) 0 0 0 0                                                     | $\bar{Q}_C$ | 0 X (1) 1                                                       |

$$S_B = Q_C \bar{Q}_B \bar{Q}_A$$

$$R_B = Q_C Q_B + Q_B \bar{Q}_A$$

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | (1) 0 0 1                                                       | $\bar{Q}_C$ | 0 1 1 0                                                         |

  

| $\bar{Q}_C$ | $Q_B Q_A$                                                       | $\bar{Q}_C$ | $Q_B Q_A$                                                       |
|-------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------|
| $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ | $\bar{Q}_C$ | $\bar{Q}_B \bar{Q}_A$ $\bar{Q}_B Q_A$ $Q_B \bar{Q}_A$ $Q_B Q_A$ |
| $Q_C$       | 1 0 0 0                                                         | $\bar{Q}_C$ | 0 1 1 X                                                         |

$$S_A = \bar{Q}_B \bar{Q}_A + \bar{Q} \bar{Q}_A$$

$$R_A = Q_A$$



$\Rightarrow$  A sequential parity checker

i) Block diagram for parity checker



ii) State Graph for parity checker



iii) State & Transition Table.

a) State table

| Present state  | Next state     |                | Present O/p |
|----------------|----------------|----------------|-------------|
|                | X=0            | X=1            |             |
| S <sub>0</sub> | S <sub>0</sub> | S <sub>1</sub> | 0           |
| S <sub>1</sub> | S <sub>1</sub> | S <sub>0</sub> | 1           |

b) Transition table using T flip flop

| Q | Q <sup>+</sup> |       | T |
|---|----------------|-------|---|
|   | X = 0          | X = 1 |   |
| 0 | 0              | 1     | 0 |
| 1 | 1              | 0     | 1 |

iv

## sequential parity checker using T FLIPFLOP



Parity - No of 1's

- odd parity → 0110001 → odd no of 1's
- Even parity → 0111100 → Even no of 1's

Parity Generator

ODD

0110000  1

0110001  0

Parity checker

ODD → 0110000

EVEN

0110000  0

0110001  1

**Application of parity checker and generator.**

→ one bit error detection in data transmission



## A Sequential Parity Checker

- When binary data is transmitted or stored, an extra bit (called a parity bit) is frequently added for purposes of error detection.
- For example, if data is being transmitted in groups of 7 bits, an eighth bit can be added to each group of 7 bits to make the total number of 1's in each block of 8 bits an odd number.
- When the total number of 1 bits in the block (including the parity bit) is odd, we say that the parity is odd.
- Alternatively, the parity bit could be chosen such that the total number of 1's in the block is even, in which case we would have even parity.



- If any single bit in the 8-bit word is changed from 0 to 1 or from 1 to 0, the parity is no longer odd.
- Thus, if any single bit error occurs in transmission of a word with odd parity, the presence of this error can be detected because the number of 1 bits in the word has been changed from odd to even.

## ⇒ State Graph for Parity checker [Explanation].

- We will start the design by constructing a state graph.
- The sequential circuit must "remember" whether the total number of 1 inputs received is even or odd, therefore, only two states are required.
- We will designate these states as  $S_0$  and  $S_1$ , corresponding respectively to an even number of 1's received and an odd number of 1's received.
- We will start the circuit in state  $S_0$  because initially zero 1's have been received, and zero is an even number.
- As indicated in the figure, if the circuit is in state  $S_0$  (even number of 1's received) and  $X=0$  is received, the circuit must stay in  $S_0$  because the number of 1's received is still even. However, if  $X=1$  is received, the circuit goes to state  $S_1$ , because the number of 1's received is then odd.
- Similarly, if the circuit is in state  $S_1$  (odd number of 1's received) a 0 input causes no state change, but a 1 causes a change to  $S_0$  because the number of 1's received is then even.
- The output  $Z$  should be 1 whenever the circuit is in state  $S_1$  (odd number of 1's received). The output is listed below the state on the state graph.

## ⇒ State Tables and Graphs

### → Rules

The following method can be used to construct the transition table:

1. Determine the flip-flop input equations and the output equations from the circuit.
2. Derive the next-state equation for each flip-flop from its input equations, using one of the following relations:

$$D \text{ flip-flop} \quad Q^+ = D$$

$$D\text{-}CE \text{ flip-flop} \quad Q^+ = D \cdot CE + Q \cdot CE'$$

$$T \text{ flip-flop} \quad Q^+ = T \oplus Q$$

$$S\text{-}R \text{ flip-flop} \quad Q^+ = S + R'Q$$

$$J\text{-}K \text{ flip-flop} \quad Q^+ = JQ' + K'Q$$

3. Plot a next-state map for each flip-flop.

4. Combine these maps to form the transition table. Such a transition table, which gives the next state of the flip-flops as a function of their present state and the circuit inputs.

### Example

#### Moore State Machine



(30)

1) The flip-flop input equations and output equation are

$$DA = X \oplus B' \quad DB = X + A \quad Z = A \oplus B$$

2) The next-state equations for the flip-flops are

$$A^+ = X \oplus B' \quad B^+ = X + A$$

3) The corresponding maps are

|    |   | X |   | AB |    | X  |    |
|----|---|---|---|----|----|----|----|
|    |   | 0 | 1 | 00 | 01 | 00 | 01 |
| 00 | 1 | 0 |   |    |    | 0  | 1  |
| 01 | 0 | 1 |   |    |    | 0  | 1  |
| 11 | 0 | 1 |   |    |    | 1  | 1  |
| 10 | 1 | 0 |   |    |    | 1  | 1  |

$A^+$        $B^+$

(a)

| AB | $A^+ B^+$ |     | Z |
|----|-----------|-----|---|
|    | X=0       | X=1 |   |
| 00 | 10        | 01  | 0 |
| 01 | 00        | 11  | 1 |
| 11 | 01        | 11  | 0 |
| 10 | 11        | 01  | 1 |

(b)

| Present State  | Next State     |                | Present Output(z) |
|----------------|----------------|----------------|-------------------|
|                | X=0            | X=1            |                   |
| S <sub>0</sub> | S <sub>3</sub> | S <sub>1</sub> | 0                 |
| S <sub>1</sub> | S <sub>0</sub> | S <sub>2</sub> | 1                 |
| S <sub>2</sub> | S <sub>1</sub> | S <sub>3</sub> | 0                 |
| S <sub>3</sub> | S <sub>2</sub> | S <sub>0</sub> | 1                 |

## Moore State Graph



## 2. Mealy State Machine



$$A^+ = J_A A' + K_A' A = XBA' + X'A.$$

$$B^+ = J_B B' + K_B' B = XB' + (AX)'B = XB' + X'B + A'B.$$

$$Z = X'A'B + XB' + XA.$$

|    | X |   | AB |    | X  |    | AB |    | X  |    | AB |    |
|----|---|---|----|----|----|----|----|----|----|----|----|----|
|    | 0 | 1 | 00 | 01 | 00 | 01 | 00 | 01 | 00 | 01 | 00 | 01 |
| 00 | 0 | 0 | 00 | 01 | 00 | 01 | 00 | 01 | 00 | 01 | 00 | 01 |
| 01 | 0 | 1 | 01 | 11 | 01 | 11 | 01 | 11 | 01 | 11 | 01 | 11 |
| 11 | 1 | 0 | 11 | 10 | 11 | 10 | 11 | 10 | 11 | 10 | 11 | 10 |
| 10 | 1 | 0 | 10 | 01 | 10 | 01 | 10 | 01 | 10 | 01 | 10 | 01 |

$A^+$        $B^+$        $Z$

(a)

|      | $A^+ B^+$ |     | $Z$   |     |
|------|-----------|-----|-------|-----|
| $AB$ | $X=0$     | $1$ | $X=0$ | $1$ |
| 00   | 00        | 01  | 0     | 1   |
| 01   | 01        | 11  | 1     | 0   |
| 11   | 11        | 00  | 0     | 1   |
| 10   | 10        | 01  | 0     | 1   |

(b)

| Present State | Next State |       | Present Output |     |
|---------------|------------|-------|----------------|-----|
|               | $X=0$      | $1$   | $X=0$          | $1$ |
| $S_0$         | $S_0$      | $S_1$ | 0              | 1   |
| $S_1$         | $S_1$      | $S_2$ | 1              | 0   |
| $S_2$         | $S_2$      | $S_0$ | 0              | 1   |
| $S_3$         | $S_3$      | $S_1$ | 0              | 1   |

Mealy State Graph.



$\Rightarrow$  Serial Adder

(a) with D Flip-flop



(b) Truth Table

|  | $x_i$ | $y_i$ | $c_i$ | $c_{i+1}$ | $s_i$ |
|--|-------|-------|-------|-----------|-------|
|  | 0     | 0     | 0     | 0         | 0     |
|  | 0     | 0     | 1     | 0         | 1     |
|  | 0     | 1     | 0     | 0         | 1     |
|  | 0     | 1     | 1     | 1         | 0     |
|  | 1     | 0     | 0     | 0         | 1     |
|  | 1     | 0     | 1     | 1         | 0     |
|  | 1     | 1     | 0     | 1         | 0     |
|  | 1     | 1     | 1     | 1         | 1     |

Timing diagram for Serial Adder.State Graph for Serial Adder.

- We can construct a state graph for the serial adder. The serial adder is a Mealy machine with inputs  $x_i$  and  $y_i$  and output  $s_i$ .
- The two states represent a carry ( $c_i$ ) of 0 and 1, respectively.
- From the table,  $c_i$  is the present state of the sequential circuit, and  $c_{i+1}$  is the next state.
- If we start in  $s_0$  (no carry), and  $x_i, y_i = 11$ , the output is  $s_i = 0$  and the next state is  $s_1$ . This is indicated by the arrow going from state  $s_0$  to  $s_1$ .

⇒ Asynchronous counters

→ Asynchronous UP Counters



Truth table

| Negative<br>clock<br>transitions | C | B | A | State<br>or<br>count |
|----------------------------------|---|---|---|----------------------|
| -                                | 0 | 0 | 0 | 0                    |
| a                                | 0 | 0 | 1 | 1                    |
| b                                | 0 | 1 | 0 | 2                    |
| c                                | 0 | 1 | 1 | 3                    |
| d                                | 1 | 0 | 0 | 4                    |
| e                                | 1 | 0 | 1 | 5                    |
| f                                | 1 | 1 | 0 | 6                    |
| g                                | 1 | 1 | 1 | 7                    |
| h                                | 0 | 0 | 0 | 0                    |

Waveforms

Time

a b c d e f g h i j

Clock.

A

B

C

→ Asynchronous Down counter

## Truth Table

| Count | C | B | A |
|-------|---|---|---|
| 7     | 1 | 1 | 1 |
| 6     | 1 | 1 | 0 |
| 5     | 1 | 0 | 1 |
| 4     | 1 | 0 | 0 |
| 3     | 0 | 1 | 1 |
| 2     | 0 | 1 | 0 |
| 1     | 0 | 0 | 1 |
| 0     | 0 | 0 | 0 |
| 7     | 1 | 1 | 1 |

## Timing diagram / Waveforms

