## EC 8392 - DIGITAL ELECTRONICS

## UNIT - III : SYNCHRONOUS SEQUENTIAL CIRCUITS

## CLASSIFICATION OF SYNCHRONOUS SEQUENTIAL CIRCUIT:

In synchronous or clocked sequential circuits, clocked Flip-Flops are used as memory elements, which change their individual states in synchronism with the periodic clock signal. Therefore, the change in states of Flip-Flop and change in state of the entire circuits occur at the transition of the clock signal.

The synchronous or clocked sequential networks are represented by two models.

Moore model: The output depends only on the present state of the Flip-Flops.
Mealy model: The output depends on both the present state of the Flip-Flops and on the inputs.

## Moore model:

In the Moore model, the outputs are a function of the present state of the Flip- Flops only. The output depends only on present state of Flip-Flops, it appears only after the clock pulse is applied, i.e., it varies in synchronism with the clock input.


## Mealy model:

In the Mealy model, the outputs are functions of both the present state of the Flip-Flops and inputs.


## Difference between Moore and Mealy model

| SI.No | Moore model | Mealy model |
| :--- | :--- | :--- |
| 1 | Its output is a function of <br> present <br> state only. | Its output is a function of present <br> state as well as present input. |
| 2 | Input changes does not affect <br> the <br> output. | Input changes may affect the <br> output <br> of the circuit. |
| 3 | It requires more number of <br> states <br> for implementing same <br> function. | It requires less number of states <br> for <br> implementing same function. |

## ANALYSIS OF SYNCHRONOUS SEQUENTIAL CIRCUIT:

The behavior of a sequential circuit is determined from the inputs, outputs and the state of its Flip-Flops. The outputs and the next state are both a function of the inputs and the present state. The analysis of a sequential circuit consists of
obtaining a table or diagram from the time sequence of inputs, outputs and internal states.

Before going to see the analysis and design examples, we first understand the state diagram, state table.

## State Diagram

## State diagram a pictorial representation of a behavior of a sequential is circuit.

In the state diagram, a state is represented by a circ e and the transition between states is indicated by directed lines connecting the circles.

- A directed line connecting a circle with circle with itself indicates that next state is same as present state.
- The binary number inside each circle identifies the state represented by the circle.

The directed lines are labeled with two binary numbers separated by a symbol ' $\varnothing$ '. The input value that causes the state transition is labeled first and the output value during the present state is labeled after the symbol ' 1 '.

In case of Moore circuit, the directed lines are labeled with only one binary
number representing the state of the input that causes the state transition. The
output state is indicated within the circle, below the present state because output state depends only on present state and not on the input.


State diagram for Mealy circuit


State diagram for Moore circuit

## State Table

## State table represents relationship between input, output and

## Flip-Flop states.

It consists of three sections labeled present state, next state and output.

- The present state designates the state of Flip-Flops before the occurrence of a clock pulse, and the output section gives the values of the output variables during the present state.
- Both the next state and output have two columns sections
representing two possible input conditions: $\mathrm{X}=0$ and $\mathrm{X}=1$.

| Prese <br> nt state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} X= \\ 1 \end{gathered}$ |
| AB | AB | AB | Y | Y |
| a | a | C | 0 | 0 |


| b | b | a | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| c | d | c | 0 | 1 |
| d | b | d | 0 | 0 |

- In case of Moore circuit, the output section has only one column since output does not depend on input.

\section*{$1 / \sqrt{\mid / 4}$| $c$ | $d$ | $c$ | 1 |
| :---: | :---: | :---: | :---: |
| $d$ | $b$ | $d$ | 0 |}

## State Equation

It is an algebraic expression that specifies the condition for a Flip-Flop state transition.

The Flip-Flops may be of any type and the logic diagram may or may not include combinational circuit gates.

## ANALYSIS PROCEDURE

The synchronous sequential circuit analysis is summarizes as given below:

1. Assign a state variable to each Flip-Flop in the synchronous sequential circuit.
2. Write the excitation input functions for each Flip-Flop and also write the Moore/ Mealy output equations.
3. Substitute the excitation input functions into the bistable equations for the Flip-Flops to obtain the next state output equations.
4. Obtain the state table and reduced form of the state table.
5. Draw the state diagram by using the second form of the state table.

## Analysis of Mealy Model

1.A sequential circuit has two JK Flip-Flops $A$ and $B$, one input $(x)$ and one output (y). the Flip-Flop input functions are,

| $J_{A}=B+x$ | $J_{B}=A^{\prime}+x^{\prime}$ |
| :--- | :--- |
| $K_{A}=1$ | $K_{B}=1$ |

and the circuit output function, $\mathbf{Y}=\mathbf{x A} \mathbf{A}^{\prime} \mathbf{B}$.
a) Draw the logic diagram of the Mealy circuit,
b) Tabulate the state table,
c) Draw the state diagram.

## Soln:

www.binils.com for Anna University | Polytechnic and schools


## State table:

To obtain the next-state values of a sequential circuit with JK FlipFlops, use the JK Flip-Flop characteristics table

| Present state |  | $\underset{t}{\text { Inpu }}$ | Flip-Flop Inputs |  |  |  | Next state |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | x | $\mathrm{J}_{\mathrm{A}}=\mathrm{B}+$ | $\begin{gathered} \mathrm{K}_{\mathrm{A}}= \\ 1 \end{gathered}$ | $\begin{aligned} & \mathrm{JB}=\mathrm{A}^{\prime}+ \\ & \mathbf{x}^{\prime} \end{aligned}$ | $\begin{gathered} \mathrm{K}_{\mathrm{B}}= \\ 1 \end{gathered}$ | $\underset{( }{A(t+1}$ | $\underset{\text { ) }}{\mathbf{B}(\mathrm{t}+1}$ | $\begin{gathered} Y= \\ \times A^{\prime} B \end{gathered}$ |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 |


| Prese <br> nt <br> state |  | Next state |  |  |  | Output |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} x= \\ 0 \end{gathered}$ |  | $\begin{gathered} x= \\ 1 \end{gathered}$ |  | $\begin{gathered} \mathrm{x}= \\ 0 \end{gathered}$ | $\begin{gathered} x= \\ 1 \end{gathered}$ |
| A | B | A | B | A | B | y | y |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |

Second form of state table

## State Diagram:



## State Diagram

2. A sequential circuit with two ' $D$ ' Flip-Flops $A$ and $B$, one input $(x)$ and one output (y). the Flip-Flop input functions are:

## $D_{A}=A x+B x$

$\mathbf{D}_{\mathrm{B}}=\mathbf{A}^{\prime} \mathbf{x}$ and the circuit output function is,
$Y=(A+B) x^{\prime}$.
(a) Draw the logic diagram of the circuit,
(b) Tabulate the state table,
(c) Draw the state diagram.

## Soln:



## State Table:



Second form of state table

## State Diagram:


3. Analyze the synchronous Mealy machine and obtain its state diagram.


## Soln:

The given synchronous Mealy machine consists of two D Flip-Flops, one inputs and one output.
The Flip-Flop input functions are,

$$
\begin{aligned}
& D A=Y 1^{\prime} Y 2 X^{\prime} \\
& D_{B}=X+Y_{1} Y_{2}
\end{aligned}
$$

The circuit output function is, $\mathbf{Z}=$

## $\mathrm{Y}_{1} \mathrm{Y}_{2} \mathrm{X}$ State Table:

| Present state |  | $\underset{t}{\operatorname{Inpu}}$ | Flip-Flop Inputs |  | Next state |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline Y \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{Y} \\ & 2 \end{aligned}$ | X | $\begin{gathered} \mathrm{DA}= \\ \mathrm{Y} 1 \text { 'Y2X' } \end{gathered}$ | $\begin{gathered} \hline \mathrm{D}_{\mathrm{B}}=\mathrm{X}_{+} \\ \mathrm{Y}_{1} \mathrm{Y}_{2} \end{gathered}$ | $\begin{gathered} Y_{1} \\ (t+1) \end{gathered}$ | $\begin{gathered} Y_{2} \\ (\mathbf{t}+1) \end{gathered}$ | $\begin{array}{r} \mathbf{Z}= \\ \mathbf{Y}_{1} \mathbf{Y}_{2} \mathbf{X} \end{array}$ |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\sqrt{0} 1$ |  | 0 1 |  |  |
| 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |


| Prese <br> nt <br> state |  | Next state |  |  |  | Output |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ |  | $X=1$ |  | $\mathrm{X}=0$ | $\begin{gathered} X= \\ 1 \end{gathered}$ |
| Y1 | Y2 | Y1 | Y2 | Y 1 | Y2 | Z | Z |


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

Second form of state table

State Diagram:

4. A sequential circuit has two JK Flop-Flops A and B, two inputs $x$ and $y$ and one output $z$. The Flip-Flop input equation and circuit output equations are $J_{A}=B x+B^{\prime} y^{\prime} \quad K_{A}=B^{\prime} x y^{\prime} J_{B}=A^{\prime} x \quad K_{B}=A+x y^{\prime}, \quad z=A x^{\prime} y^{\prime}+B x^{\prime} y^{\prime}$
(a) Draw the logic diagram of the circuit (b)

Tabulate the state table. (c) Derive
the state equation.

## State diagram:



## WWW

|  |  | Input |  | Flip-Flop <br> Inputs |  |  |  | Next | state | Outpu t |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | x | y | $\begin{gathered} \mathrm{J}_{\mathrm{A}}= \\ \mathrm{Bx}+\mathrm{B}^{\prime} \\ \mathrm{y}^{\prime} \end{gathered}$ | $\begin{gathered} \mathrm{K}_{\mathrm{A}}= \\ \mathrm{B}^{\prime} \mathrm{xy} \end{gathered}$ | $\begin{aligned} & \mathrm{J}_{\mathrm{B}}= \\ & \mathrm{A}^{\prime} \mathrm{X} \end{aligned}$ | $\begin{gathered} \mathrm{K}_{\mathrm{B}}= \\ \mathrm{A}+\mathrm{xy}, \end{gathered}$ | $A(t+1$ | $\begin{aligned} & \mathrm{B}(\mathrm{t}+1 \\ & \mathrm{l} \end{aligned}$ | z |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |


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

State Equation:

For A(t+1)

$A(t+1)=A x^{\prime}+A y+B x+A^{\prime} B^{\prime} y^{\prime}$

For B(t+1)

| $A B{ }^{x y}$ |  | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
| 00 | 0 | 0 | 1 | 1 |
| 01 | 0 | 0 | 1 | 1 |
| 11 | 0 | 0 | 0 | 0 |
| 10 | 0 | 0 | 0 | 0 |

$\mathrm{B}(\mathrm{t}+\mathbf{1})=\mathrm{A}^{\prime} \mathrm{x}$
5. A sequential circuit has two JK Flip-Flop A and B. the Flip-Flop input functions are: $\mathrm{J}_{\mathrm{A}}=\mathrm{B} \mathrm{J}_{\mathrm{B}}=\mathbf{x}^{\prime}$

$$
K_{A}=B x^{\prime} \quad K_{B}=A x .
$$

(a) Draw the logic diagram of the circuit,
(b) Tabulate the state table,
(c) Draw the state diagram.

## Logic diagram:



The output function is not given in the problem. The output of the Flip-
Flops may be considered as the output of the circuit.

## State table:

To obtain the next-state values of a sequential circuit with JK Flip-Flop, use the JK Flip-Flop characteristic table.

| Pre sta |  | Inpu t | Flip-Flop Inputs |  |  |  | Next state |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | x | $J_{A}=B$ | $\begin{aligned} & \mathrm{KA}= \\ & \mathrm{Bx}^{\prime} \end{aligned}$ | $\begin{aligned} & \mathrm{JB}= \\ & \mathbf{x}^{\prime} \end{aligned}$ | $\begin{gathered} K_{B}=A \\ X \end{gathered}$ | $\begin{gathered} \mathrm{A}(\mathrm{t}+1 \\ \mathrm{f} \end{gathered}$ | $\begin{gathered} \mathrm{B}(\mathrm{t}+1 \\ \mathrm{f} \end{gathered}$ |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 |



## Second form of state table

State

## Diagram:



## Analysis of Moore Model

6. Analyze the synchronous Moore circuit and obtain its state diagram.


## Soln:

Using the assigned variable $\mathrm{Y}_{1}$ and $\mathrm{Y}_{2}$ for the two JK Flip-Flops, we can write
the four excitation input equations and the Moore output equation as follows:
$J_{A}=Y_{2} X \quad ; \quad K_{A}=Y_{2}{ }^{\prime}$
$J_{B}=\mathbf{X} \quad ; \quad \mathbf{K B}=\mathbf{X} \quad$ and output function, $\mathbf{Z}=$

$$
Y_{1} Y_{2}
$$

## State table:

|  |  | Inpu | Flip-FIop <br> Inputs |  |  |  | Next state |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Y1 | Y2 | X | $\begin{aligned} & J_{A}= \\ & Y_{2} X \end{aligned}$ | $\mathrm{K}_{\mathrm{A}}=\mathrm{Y}_{2}{ }^{\prime}$ | $\mathrm{J}_{\mathrm{B}}=\mathbf{X}$ | $\begin{aligned} & \mathrm{KB}= \\ & \mathrm{X}^{\prime} \end{aligned}$ | $\begin{aligned} & \mathbf{Y}_{1} \\ & (\mathbf{t}+1) \end{aligned}$ | $\begin{aligned} & Y_{2} \\ & (t+1) \end{aligned}$ | $\begin{array}{r} \mathrm{Z}= \\ \mathrm{Y}_{1} \mathbf{Y}_{2} \end{array}$ |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 |


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


| Prese <br> nt <br> nt <br> state | Next state |  |  |  |  | Output |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{X = 0}$ |  |  | $\mathbf{X = 1}$ |  |  |
| $\mathbf{Y}$ | $\mathbf{Y}$ |  |  |  |  |  |
| $\mathbf{1}$ | $\mathbf{Y}$ | $\mathbf{Y 1}$ | $\mathbf{Y 2}$ | $\mathbf{Y}$ | $\mathbf{Y 2}$ |  |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | 0 |

Second form of state

## table State Diagram:

Here the output depends on the present state only and is independent of the input. The two values inside each circle separated by a slash are for the present state and output.
7. A sequential circuit has two $T$ Flip-Flop $A$ and $B$. The Flip-Flop input functions are:

$$
T_{A}=B x \quad T_{B}=x
$$

$$
y=A B
$$

(a) Draw the logic diagram of the circuit,
(b) Tabulate the state table,
(c) Draw the state diagram.

## Soln:

Logic diagram:


## State table



Second form of state table
State
Diagram:


## STATE REDUCTION/ MINIMIZATION

The state reduction is used to avoid the redundant states in the sequential circuits. The reduction in redundant states reduces the number of required Flip- Flops and logic gates, reducing the cost of the final circuit.

The two states are said to be redundant or equivalent, if every possible set of inputs generate exactly same output and same next state. When two states are equivalent, one of them can be removed without altering the inputoutput relationship.

Since ' $n$ ' Flip-Flops produced $2^{n}$ state, a reduction in the number of states may result in a reduction in the number of Flip-Flops.

The need for state reduction or state minimization is explained with one example.


## State diagram

Step 1: Determine the state table for given state diagram


| $\begin{gathered} \hline \text { Presen } \\ \mathbf{t} \\ \text { state } \\ \hline \end{gathered}$ | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ | $\mathrm{X}=$ | $\bar{X}=$ | $X=$ |
| a | b | C | 0 | 0 |
| b | $\mathrm{d}$ | e | 1 | 0 |
| c | c | d | 0 | 1 |
| d | a | d | 0 | 0 |
| e | c | d | 0 | 1 |

## Step 2: Find equivalent states

From the above state table cand e generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{c}$ and $\mathbf{e}$ go to next states $\mathbf{c}$ and $\mathbf{d}$ and have outputs 0 and 1 for $x=0$ and $x=1$ respectively. Therefore state $\mathbf{e}$ can be removed and replaced by $\mathbf{c}$. The final reduced state table is shown below.

| Presen <br> $t$ <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=0$ | $\mathrm{X}=1$ | $\mathrm{X}=0$ | $\mathrm{X}=1$ |


| a | b | c | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| b | d | c | 1 | 0 |
| c | c | d | 0 | 1 |
| d | a | d | 0 | 0 |

Reduced state table
The state diagram for the reduced table consists of only four states and is shown below.


## Reduced state diagram

1.Reduce the number of states in the following state table and tabulate the reduced state table.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | f | 0 | 1 |
| e | a | f | 0 | 1 |


| $f$ | $g$ | $f$ | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| $g$ | $a$ | $f$ | 0 | 1 |

Sol n:

From the above state table $\mathbf{e}$ and $\mathbf{g}$ generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{e}$ and $\mathbf{g}$ go to next states a and $\mathbf{f}$ and have outputs 0 and 1 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively.
Therefore state $\mathbf{g}$ can be removed and replaced by $\mathbf{e}$.
The reduced state table- 1 is shown below.

## WV

| Prese <br> nt | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | X= | X= | X= | X= |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | f | 0 | 1 |
| e | a | f | 0 | 1 |
| f | e | f | 0 | 1 |

Reduced state table-1
Now states $d$ and $f$ are equivalent. Both states go to the same next state (e, f) and have same output ( 0,1 ). Therefore one state can be removed; $\mathbf{f}$ is replaced by $\mathbf{d}$.

The final reduced state table-2 is shown below.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | d | 0 | 1 |
| e | a | d | 0 | 1 |

Reduced state table-
$\underline{2}$ Thus 7 states are reduced into 5 states.
2. Determine a minimal state table equivalent furnished below

| Presen <br> $\mathbf{t}$ <br> state | Next state <br> $\mathbf{0}$ |  |
| :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> $\mathbf{1}$ |  |
| 1 | 1,0 | 1,0 |
| 2 | 1,1 | 6,1 |
| 3 | 4,0 | 5,0 |
| 4 | 1,1 | 7,0 |
| 5 | 2,0 | 3,0 |
| 6 | 4,0 | 5,0 |
| 7 | 2,0 | 3,0 |

## Soln:

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |
| 1 | 1 | 1 | 0 | 0 |
| 2 | 1 | 6 | 1 | 1 |


| 3 | 4 | 5 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| 4 | 1 | 7 | 1 | 0 |
| 5 | 2 | 3 | 0 | 0 |
| 6 | 4 | 5 | 0 | 0 |
| 7 | 2 | 3 | 0 | 0 |

From the above state table, $\mathbf{5}$ and $\mathbf{7}$ generate exactly same next state and same output for every possible set of inputs. The state 5 and 7 go to next states 2 and 3 and have outputs 0 and 0 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore state 7 can be removed and replaced by 5 .

Similarly, $\mathbf{3}$ and 6 generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{3}$ and $\mathbf{6}$ go to next states $\mathbf{4}$ and $\mathbf{5}$ and have outputs 0 and 0 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore state 6 can be removed and replaced by 3.

The final reduced state table is shown below.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ |
| 1 | 1 | 1 | 0 | 0 |
| 2 | 1 | 3 | 1 | 1 |
| 3 | 4 | 5 | 0 | 0 |
| 4 | 1 | 5 | 1 | 0 |
| 5 | 2 | 3 | 0 | 0 |

Reduced state
tableThus 7 states are reduced into 5 states.
3.Minimize the following state table.

| Prese <br> nt <br> state | Next state |  |
| :---: | :---: | :---: |
|  | X= <br> $\mathbf{0}$ | X= <br> $\mathbf{1}$ |
| A | D, 0 | C, 1 |
| B | E, 1 | A, 1 |
| C | H, 1 | D, 1 |
| D | D, 0 | C, 1 |
| E | B, 0 | G, 1 |
| F | H, 1 | D, 1 |
| G | A, 0 | F, 1 |
| H | C, 0 | A, 1 |
| I | G, 1 | H,1 |

## Soln:

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> A | $\mathrm{X}=$ <br> $\mathbf{1}$ | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ |
| B | E | A | 1 | 1 |
| C | H | D | 1 | 1 |
| D | D | C | 0 | 1 |
| E | B | G | 0 | 1 |
| F | H | D | 1 | 1 |
| G | A | F | 0 | 1 |


| H | C | A | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| I | G | H | 1 | 1 |

From the above state table, $\mathbf{A}$ and $\mathbf{D}$ generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{A}$ and $\mathbf{D}$ go to next states $\mathbf{D}$ and $\mathbf{C}$ and have outputs 0 and 1 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore state $\mathbf{D}$ can be removed and replaced by A. Similarly, C and F generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{C}$ and $\mathbf{F}$ go to next states $\mathbf{H}$ and $\mathbf{D}$ and have outputs 1 and 1 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore state F can be removed and replaced by $\mathbf{C}$.

The reduced state table-1 is shown below.

| Prese <br> nt <br> state | Next state <br> $\mathbf{0}$ |  | Output <br> $\mathbf{1}$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}_{=}$ | $\mathbf{0}$ | $\mathbf{X}=$ |  |
| A | A | C | 0 | 1 |
| B | E | A | 1 | 1 |
| C | H | A | 1 | 1 |
| E | B | G | 0 | 1 |
| G | A | C | 0 | 1 |
| H | C | A | 0 | 1 |
| I | G | H | 1 | 1 |

Reduced state table-1
From the above reduced state table-1, $\mathbf{A}$ and $\mathbf{G}$ generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{A}$ and $\mathbf{G}$ go to next states $\mathbf{A}$ and $\mathbf{C}$ and have outputs 0 and 1 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore
state $\mathbf{G}$ can be removed and replaced by $\mathbf{A}$. The final reduced state table-2 is shown below.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 1 \end{gathered}$ |
| A | A | C | 0 | 1 |
| B | E | A | 1 | 1 |
| C | H | A | 1 | 1 |
| E | B | A | 0 | 1 |
| H | C | A | 0 | 1 |
| 1 | A | H | 1 | 1 |

Reduced state table-
$\underline{2}$ Thus 9 states are reduced into 6
states. 4.Reduce the following state diagram.


## Soln:

| Prese nt state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{X}= \\ 0 \end{gathered}$ | $\begin{gathered} X= \\ 1 \end{gathered}$ |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | f | 0 | 1 |
| e | a | f | 0 | 1 |
| f | g | f | 0 | 1 |
| g | a | f | 0 | 1 |

## State table

From the above state table $\mathbf{e}$ and $\mathbf{g}$ generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{e}$ and $\mathbf{g}$ go to next states a and $\mathbf{f}$ and have outputs 0 and 1 for $x=0$ and $x=1$ respectively. Therefore state $\mathbf{g}$ can be removed and replaced by $\mathbf{e}$. The reduced state table-1 is shown below.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | X= <br> $\mathbf{0}$ | X= <br> $\mathbf{1}$ | X= <br> $\mathbf{0}$ | X= <br> $\mathbf{1}$ |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | f | 0 | 1 |
| e | a | f | 0 | 1 |
| f | e | f | 0 | 1 |

Reduced state table-1

Now states $d$ and $f$ are equivalent. Both states go to the same next state (e, f) and have same output ( 0,1 ). Therefore one state can be removed; $\mathbf{f}$ is replaced by $\mathbf{d}$.
The final reduced state table-2 is shown below.

| $\begin{gathered} \hline \text { Presen } \\ \mathbf{t} \\ \text { state } \\ \hline \end{gathered}$ | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $X=$ | $X=$ | $X=$ | $X=$ |
| a | a | b | 0 | 0 |
| b | c | d | 0 | 0 |
| c | a | d | 0 | 0 |
| d | e | d | 0 | 1 |
| e | a | d | 0 | 1 |

## Reduced state table-2

Thus 7 states are reduced into 5 states.
The state diagram for the reduced state table-2 is,


## DESIGN OF SYNCHRONOUS SEQUENTIAL CIRCUITS:

A synchronous sequential circuit is made up of number of Flip-Flops and combinational gates. The design of circuit consists of choosing the FlipFlops and then finding a combinational gate structure together with the FlipFlops. The number of Flip-Flops is determined from the number of states needed in the circuit. The combinational circuit is derived from the state table.

## Design procedure:

1. The given problem is determined with a state diagram.
2. From the state diagram, obtain the state table.
3. The number of states may be reduced by state reduction methods (if applicable).
4. Assign binary values to each state (Binary Assignment) if the state table contains letter symbols.
5. Determine the number of Flip-Flops and assign a letter symbol (A, B, C, ...) to each.
6. Choose the type of Flip-Flop (SR, JK, D, T) to be used.
7. From the state table, circuit excitation and output tables.
8. Using K-map or any other simplification method, derive the circuit output functions and the Flip-Flop input functions.
9. Draw the logic diagram.


The type of Flip-Flop to be used may be included in the design specifications or may depend what is available to the designer. Many digital systems are constructed with JK Flip-Flops because they are the most versatile available. The selection of inputs is given as follows.

| Flip-Flop | Applicatio <br> $\mathbf{n}$ |
| :---: | :--- |
| J | General Applications <br> K <br> Applications requiring transfer <br> of data <br> (Ex: Shift Registers) <br> Application involving <br> complementation |
| T | (Ex: Binary Counters) |

Before going to the design examples for the clocked synchronous sequential circuits we revise Flip-Flop excitation tables.

| Prese <br> nt <br> State | Next <br> State |  | Inputs |  |
| :---: | :---: | :---: | :---: | :---: |
| Qn | Qn+ <br> 1 | $\mathbf{S}$ | $\mathbf{R}$ |  |
| 0 | 0 | 0 | $x$ |  |
| 0 | 1 | 1 | 0 |  |
| 1 | 0 | 0 | 1 |  |
| 1 | 1 | $x$ | 0 |  |

Excitation table for SR Flip-Flop

| Prese <br> nt <br> State | Next <br> State |  | Inputs |  |
| :---: | :---: | :---: | :---: | :---: |
| Qn | Qn+ <br> 1 | J | K |  |
| 0 | 0 | 0 | x |  |
| 0 | 1 | 1 | x |  |
| 1 | 0 | x | 1 |  |
| 1 | 1 | x | 0 |  |


| Prese <br> nt <br> State | Next <br> State | Input |
| :---: | :---: | :---: |
| Qn | Qn+ <br> $\mathbf{1}$ | $\mathbf{T}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |


| Prese <br> $\mathbf{n t}$ <br> State | Next <br> State | Inpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: |
| $\mathbf{Q n}$ | $\mathbf{Q n +}$ <br> $\mathbf{1}$ | $\mathbf{D}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

## Excitation table for D Flip-Flop

1.A sequential circuit has one input and one output. The state diagram is shown below. Design the sequential circuit with a) D-Flip-Flops, b) T Flip-Flops, c) RS Flip-Flops and d) JK Flip-Flops.


## Solution:

## State Table:

The state table for the state diagram is,

| Present <br> state |  | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=1$ | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |  |
| A | B | AB | AB | Y | Y |
| 0 | 0 | 00 | 10 | 0 | 1 |
| 0 | 1 | 11 | 00 | 0 | 0 |
| 1 | 0 | 10 | 01 | 1 | 0 |
| 1 | 1 | 00 | 10 | 1 | 0 |

## State reduction:

As seen from the state table there is no equivalent states. Therefore, no reduction in the state diagram.

The state table shows that circuit goes through four states, therefore we require 2 Flip-Flops (number of states $=2^{m}$, where $m=$ number of FlipFlops). Since two Flip-Flops are required first is denoted as A and second is denoted as B.
i) Design using D Flip-Flops:

## Excitation table:

Using the excitation table for T Flip-Flop, we can determine the excitation table for the
given circuit as,

| Presen <br> $\mathbf{t}$ <br> State | Next <br> State | Input |
| :---: | :---: | :---: |
| $\mathbf{Q n}$ | Qn+ <br> 1 | $\mathbf{D}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

## Excitation table for D Flip-Flop

| Present <br> state |  | Inpu <br> $\mathbf{t}$ |  | Next state |  | Flip-Flop <br> Inputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | $\mathbf{X}$ | A | B | D <br> $\mathbf{t}$ |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 |

## Circuit excitation table

## K-map

 Simplification:

With these Flip-Flop input functions and circuit output function we can draw the logic diagram as follows.

ii) Design using T Flip-Flops:

| Using the <br> excitation | Presen <br> $\mathbf{t}$ <br> State | Next <br> State | Inpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: |
|  | Qn determine the |  |  |
| 0 | Qn+ <br> $\mathbf{1}$ | $\mathbf{T}$ |  |
| 0 | 0 | 0 |  |
| 1 | 1 | 1 |  |
| 1 | 1 | 0 |  |

## Excitation table for T Flip-Flop

| Present <br> state | Inpu <br> $\mathbf{t}$ | Next state |  | Flip-Flop <br> Inputs |  | Outpu <br> $\mathbf{t}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | $\mathbf{X}$ | A | B | TA | TB | Y |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 |

## Circuit excitation table

## K-map Simplification:

|  | ar F |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 0 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 |

$\mathrm{T}_{\mathrm{A}}=\mathrm{B} \oplus \mathrm{x}$

$\mathrm{T}_{\mathrm{B}}=\mathrm{AB}+\mathrm{AX}+\mathrm{BX}$

For Output

$\mathrm{Y}=\mathrm{A}^{\prime} \mathrm{B}^{\prime} \mathrm{X}+\mathrm{AX} \mathrm{X}^{\prime}$

Therefore, input functions for,

## $T_{A}=B x$ and

## $T_{B}=\mathbf{A B}+\mathbf{A X}+\mathbf{B X}$

Circuit output function, $\mathbf{Y}=\mathbf{X A} \mathbf{A}^{\prime}+\mathbf{X}^{\prime} \mathbf{A}$
With these Flip-Flop input functions and circuit output function we can draw the logic diagram as follows.


| Present <br> State | Next <br> State | Inputs |  |
| :---: | :---: | :---: | :---: |
| Q | Qn+ <br> $\mathbf{n}$ | S | R |
| 0 | 0 | 0 | x |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | $x$ | 0 |

Excitation table for SR Flip-Flop

| Prese <br> $\mathbf{n t}$ <br> state | Inpu <br> $\mathbf{t}$ | Next state |  | lip-Flop <br> nputs |  |  |  |  | Outpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A}$ | $\mathbf{B}$ | $\mathbf{X}$ | $\mathbf{A}$ | $\mathbf{B}$ | $\mathbf{S}$ | $\mathbf{R}$ | $\mathbf{S}$ | $\mathbf{R}$ | $\mathbf{Y}$ |
| 0 | 0 | 0 | 0 | 0 | 0 | $x$ | 0 | $x$ | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | $x$ | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | $x$ | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | $x$ | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 | 0 | $x$ | 0 | 0 | $x$ | 1 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 | $x$ | 0 | 0 | 1 | 0 |

Circuit excitation

## K-map

For Flip-flop A

| $A{ }^{B X}$ | Fors $\mathrm{S}_{\text {A }}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 0 | 0 | (1) | 0 | (1) |
| 1 | x | 0 | x | 0 |
|  |  | B'X |  |  |


$\mathrm{R}_{\mathrm{A}}=\mathrm{ABX}{ }^{\prime}+\mathrm{AB}^{\prime} \mathrm{X}^{\prime}$

For Output

$\mathrm{Y}=\mathrm{A}^{\prime} \mathrm{B}^{\prime} \mathrm{X}+\mathrm{AX}^{\prime}$

## For Flip-flop B


$\mathrm{S}_{\mathrm{B}}=\mathrm{AB}^{\prime} \mathrm{X}$

$\mathrm{R}_{\mathrm{B}}=\mathrm{AB}+\mathrm{BX}$

With these Flip-Flop input functions and circuit output function we can draw


## iii Design using JK Flip-

Using the excitation table for JK Flip-Flop, we can determine the excitation table for the given circuit as,

| Prese <br> $\mathbf{n t}$ <br> State | Next <br> State | Inputs |  |
| :---: | :---: | :---: | :---: |
| $\mathbf{Q n}$ | Qn+ <br> $\mathbf{1}$ | J | K |
| 0 | 0 | 0 | x |
| 0 | 1 | 1 | x |
| 1 | 0 | x | 1 |
| 1 | 1 | x | 0 |


| Prese <br> nt <br> state |  | Inpu t |  | tate | Flip-Flop <br> Inputs |  |  |  | Outpu t |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | X | A | B | JA | $\begin{aligned} & \hline \mathbf{K} \\ & \mathbf{A} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathbf{J} \\ & \mathbf{B} \end{aligned}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~B} \end{aligned}$ | Y |
| 0 | 0 | 0 | 0 | 0 | 0 | X | 0 | X | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | x | 0 | x | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | X | X | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | X | X | 1 | 0 |
| 1 | 0 | 0 | 1 | 0 | X | 0 | 0 | X | 1 |
| 1 | 0 | 1 | 0 | 1 | X | 1 | 1 | x | 0 |
| 1 | 1 | 0 | 0 | 0 | X | 1 | X | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 | X | 0 | X | 1 | 0 |

## Circuit excitation table

## K-map Simplification:

With these Flip-Flop input functions and circuit output function we can draw the logic diagram as follows.

For Flip-flop A


The input functions

## $J_{A}=B X^{\prime}+$ B'X

$K_{A}=B X^{\prime}+$
$\mathrm{K}_{\mathrm{B}}=\mathrm{A}+$
B'X
$\mathrm{J}_{\mathrm{B}}=$
——.

Circuit output function, $\mathbf{Y}=\mathbf{A X}{ }^{\prime}+$


## Logic diagram of given sequential circuit using JK FlipFlop

2. Design a clocked sequential machine using JK Flip-Flops for the state diagram
chnum in the finuire I lce ctate redustinn if noccihle Make nrnner ctate


Soln:
State

| Presen <br> $\mathbf{t}$ | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> 1 | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |
| a | a | b | 0 | 0 |
| b | c | b | 0 | 0 |
| c | a | b | 0 | 1 |
| d | a | b | 0 | 0 |

From the above state table a and d generate exactly same next state and same output for every possible set of inputs. The state $\mathbf{a}$ and $\mathbf{d}$ go to next states $\mathbf{a}$ and $\mathbf{b}$ and have outputs 0 and 0 for $\mathrm{x}=0$ and $\mathrm{x}=1$ respectively. Therefore state $\mathbf{d}$ can be removed and replaced by $\mathbf{a}$. The final reduced state table is shown below.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 | $\mathrm{X}=$ <br> 0 | $\mathrm{X}=$ <br> 1 |
| a | a | b | 0 | 0 |
| b | c | b | 0 | 0 |
| c | a | b | 0 | 1 |

## Binary Assignment:

Now each state is assigned with binary values. Since there are three states, number of Flip-Flops required is two and 2 binary numbers are assigned to the states.
$a=00 ; b=0$; and $c=10$
The reduced state diagram is drawn as,


Reduced State Diagram

## Excitation Table:

| Prese <br> nt <br> State | Next <br> State | Inputs <br> $\mathbf{Q n}$ |  |
| :---: | :---: | :---: | :---: |
| Qn+ <br> $\mathbf{1}$ | J | K |  |
| 0 | 0 | 0 | x |
| 0 | 1 | 1 | x |
| 1 | 0 | x | 1 |
| 1 | 1 | x | 0 |


| Inpu <br> $\mathbf{t}$ | Prese <br> nt <br> state | Next state |  | Flip-Flop <br> nputs |  |  |  |  | Outpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | A B | B | A | B | J <br> A | K <br> A | JB | K | Y |
| 0 | 0 | 0 | 0 | 0 | 0 | $x$ | 0 | $x$ | 0 |
| 1 | 0 | 0 | 0 | 1 | 0 | $x$ | 1 | $x$ | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | $x$ | $x$ | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 | 0 | $x$ | $x$ | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 | $x$ | 1 | 0 | $x$ | 0 |
| 1 | 1 | 0 | 0 | 1 | $x$ | 1 | 1 | $x$ | 1 |
| 0 | 1 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ |

## K-map Simplification:

www.binils.com for Anna University | Polytechnic and schools

## For Flip-flop A


$\mathrm{J}_{\mathrm{A}}=\mathrm{X}^{\prime} \mathrm{B}$

$\mathrm{K}_{\mathrm{A}}=1$

For Output

$\mathrm{Y}=\mathrm{XA}$

## For Flip-flop B

| $A{ }^{B X}$ | For $\mathrm{J}_{\mathrm{B}}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 0 | 0 | x | x | 0 |
| 1 | (1 | X | x | 1 |
|  | $=$ |  |  |  |


| $A)^{B X}$ | For K ${ }_{\text {B }}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 0 | $x$ | 1 | X | x |
| 1 | x | 0 | x | x |

With these Flip-Flop input functions and circuit output function we can draw the logic diagram as follows.

3. Design a clocked sequential machine using T Flip-Flops for the following state diagram. Use state reduction if possible. Also use straight binary state assignment.


## Soln:

## State Table:

State table for the given state diagram is,

| Presen $t$ <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} X= \\ 0 \end{gathered}$ | $\begin{gathered} X= \\ 1 \end{gathered}$ | $\begin{gathered} X= \\ 0 \end{gathered}$ | $\begin{gathered} X= \\ 1 \end{gathered}$ |
| a | a | b | 0 | 0 |
| b | d | C | 0 | 0 |
| C | a | b | 1 | 0 |
| d | b | a | 1 | 1 |

Even though a and c are having same next states for input $\mathrm{X}=0$ and $X=1$, as the outputs are not same state reduction is not possible.

## State Assignment:

Use straight binary assignments as $a=00, b=01, c=10$ and $d=11$, the transition table is,

| Inpu <br> $\mathbf{t}$ | Present <br> state |  | Next state |  | Flip-Flop <br> Inputs |  | Outpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | A | $\mathbf{B}$ | $\mathbf{A}$ | $\mathbf{B}$ | $\mathbf{T}$ | TB | $\mathbf{Y}$ |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 |

## K-map simplification:

For Flip-flop A


For Flip-flop B

$\mathrm{T}_{\mathrm{B}}=\mathrm{X}$

$\mathrm{Z}=\mathrm{AB}+\mathrm{X}^{\prime} \mathrm{A}$

## Logic Diagram:



## STATE ASSIGNMENT:

In sequential circuits, the behavior of the circuit is defined in terms of its inputs, present states, next states and outputs. To generate desired next state at particular present state and inputs, it is necessary to have specific Flip-Flop inputs. These Flip-Flop inputs are described by a set of Boolean functions called Flip-Flop input functions.

To determine the Flip-Flop functions, it is necessary to represent states in the state diagram using binary values instead of alphabets. This procedure is known as state assignment.


## Reduced state diagram with binary states

## Rules for state assignments

There are two basic rules for making state assignments.

## Rule 1:

States having the same NEXT STATES for a given input condition should have assignments which can be grouped into logically adjacent cells in a K-map.

## Rule 2:

States that are the NEXT STATES of a single state should have assignment which can be grouped into logically adjacent cells in a K-map.

| Prese <br> nt <br> state | Next state |  | Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ | $\mathrm{X}=$ <br> $\mathbf{0}$ | $\mathrm{X}=$ <br> $\mathbf{1}$ |
| 00 | 01 | 10 | 0 | 0 |
| 01 | 11 | 10 | 1 | 0 |
| 10 | 10 | 11 | 0 | 1 |


| 11 | 00 | 11 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- |

## State table with assignment states

## State Assignment Problem:

1. Design a sequential circuit for a state diagram shown below. Use state assignment rules for assigning states and compare the required combinational circuit with random state assignment.


Using random state assignment we assign, $a=000, b=001, c=010, d=011$ and $e=100$.
The excitation table with these assignments is given as,

| Present te <br> st <br> a |  |  | Input | Next <br> stat <br> e |  |  | Outpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| An | B | C | X | An+1 | $\mathbf{B n + 1}$ | $\mathbf{C n + 1}$ | $\mathbf{Z}$ |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 |

www.binils.com for Anna University | Polytechnic and schools

| 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | $x$ | $x$ | $x$ | $x$ |
| 1 | 0 | 1 | 1 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 0 | 0 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 0 | 1 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 1 | 0 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 1 | $x$ | $x$ | $x$ | $x$ |  |

K-map Simplification:

| $A_{n} B_{n}{ }^{C_{n} X}$ | $00$ | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 0 | 0 | 1 | 0 |
| 01 | 1 | 0 | 0 | 0 |
| 11 | X | X | X | X |
| 10 | 0 | 0 | X | X |


| $A_{n} B_{n}{ }^{C_{n} X}$ |  | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 0 | 1 | 0 | 1 |
| 01 | 0 | 1 | 0 | 0 |
| 11 | X | X | X | X |
| 10 | 0 | 0 | X | x |


| $A_{n} B_{n} C_{n}$ |  | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 1 | 0 | 0 | 1 |
| 01 | 0 | 1 | 0 | 0 |
| 11 | X | X | X | X |
| 10 | 0 | 0 | X | X |
| $\mathrm{D}_{\mathrm{C}}=\bar{A}_{\mathrm{A}} \bar{B}_{\mathrm{B}} \overline{\mathrm{X}}+\mathrm{B}_{\mathrm{n}} \bar{C}_{\mathrm{n}} \mathbf{X}$ |  |  |  |  |


| $A_{n} B_{n}{ }^{C_{n}}$ |  | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 0 | 0 | 0 | 0 |
| 01 | 0 | 0 | 1 | 0 |
| 11 | x | x | x | X |
| 10 | 1 | 0 | X | x |
| $\mathbf{Z}=\mathrm{B}_{\mathrm{n}} \mathrm{C}_{\mathrm{n}} \mathbf{X}+\mathrm{A}_{\mathrm{n}} \overline{\mathrm{X}}$ |  |  |  |  |

The random assignments require:
7 three input AND
functions 1 two input AND
function
4 two input OR functions

## 12 gates with 31 inputs

Now, we will apply the state assignment rules and compare the results.


State diagram after applying Rules 1 and 2
Rule 1 says that: $\quad e$ and d must be adjacent, and $b$ and $c$ must be adjacent. Rule 2 says that: $\quad e$ and $d$ must be adjacent, and $b$ and c must be adjacent.

Applying Rule 1, Rule 2 to the state diagram we get the state assignment as,

| Present state |  |  | Inpu <br> $\mathbf{t}$ | Next state |  |  | Outpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| An | B <br> $\mathbf{n}$ | Cn | $\mathbf{X}$ | An+ <br> $\mathbf{1}$ | Bn+ <br> $\mathbf{1}$ | $\mathbf{C n +}$ <br> $\mathbf{1}$ | $\mathbf{Z}$ |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 |
| 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | $x$ | $x$ | $x$ | $x$ |
| 0 | 1 | 0 | 1 | $x$ | $x$ | $x$ | $x$ |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |
| 1 | 0 | 0 | 0 | $x$ | $x$ | $x$ | $x$ |
| 1 | 0 | 0 | 1 | $x$ | $x$ | $x$ | $x$ |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 0 | 1 | $x$ | $x$ | $x$ | $x$ |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

[^0]www.binils.com for Anna University | Polytechnic and schools

| $A_{n} B_{n}{ }^{C_{n}}$ |  | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 0 | 0 | 1 | 1 |
| 01 | X | X | 1 | 1 |
| 11 | X | X | 0 | 0 |
| 10 | X | X | 0 | 0 |

$\mathrm{A}_{\mathrm{n}+1}=\mathrm{D}_{\mathrm{A}}=\overline{\mathbf{A}}_{\mathrm{n}} \mathrm{C}_{\mathrm{n}}$


| $A_{n} B_{n}{ }^{C_{n} X}$ | $00$ | 01 | 11 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 0 | 1 | 1 | 0 |
| 01 | X | X | 0 | 1 |
| 11 | x | X | 0 | 0 |
| 10 | X | X | 0 | 0 |



The state assignments using Rule 1 and 2
require: 4 three input AND
functions
1 two input AND function
.---- 2 two input OR functions

7 gates with 18 inputs

Thus by simply applying Rules 1 and 2 good results have been achieved.

## EC 8392 - DIGITAL ELECTRONICS

## UNIT - III : SYNCHRONOUS SEQUENTIAL CIRCUITS

## SYNCHRONOUS COUNTERS

Flip-Flops can be connected together to perform counting operations. Such a group of Flip- Flops is counter. The number of Flip- used and the way in a Flops
which they are connected determine the number of states (called the modulus) and
also the specific sequence of states that the counter through during each goes complete cycle.

Counters are classified into two broad categories according to the way they are clocked:


In asynchronous (ripple) counters, the first Flip-Flop is clocked by the external clock pulse and then each successive Flip-Flop is clocked by the output of the preceding Flip-Flop.

In synchronous counters, the clock input is connected to all of the FlipFlops so that they are clocked simultaneously. Within each of these two categories, counters
are classified primarily by the type of sequence, the number of states, or the
number of Flip-Flops in the counter.
The term 'synchronous' refers to events that have a fixed time relationship with each other. In synchronous counter, the clock pulses are applied to all Flip- Flops simultaneously. Hence there is minimum propagation delay.

Table : 3.3 - Difference between Asynchronous and synchronous Counter

| S.N <br> $\mathbf{0}$ | Asynchronous (ripple) <br> counter | Synchronous counter |
| :---: | :--- | :--- |
| $\mathbf{1}$ | All the Flip-Flops are not <br> clocked simultaneously. | All the Flip-Flops are clocked <br> simultaneously. |
| 2 | The delay times of <br> all Flip- Flops are <br> added. Therefore <br> there is <br> considerable <br> propagation delay. | There is minimum propagation <br> delay. |
| 3 | Speed of operation is low | Speed of operation is high. |
| 4 | Logic circuit is very simple <br> even for more number of <br> states. | Design involves complex logic <br> circuit |
| 5 | Minimum numbers of logic <br> devices are needed. | The number of logic devices is <br> more <br> than ripple counters. |
| 6 | Cheaper than synchronous <br> counters. | Costlier than ripple counters. |

## Bit Synchronous Binary Counter

In this counter the clock signal is connected in parallel to clock inputs of both the Flip-Flops ( $\mathrm{FF}_{0}$ and $\mathrm{FF}_{1}$ ). The output of $\mathrm{FF}_{0}$ is connected to $\mathrm{J}_{1}$ and $\mathrm{K}_{1}$ inputs of the second Flip-Flop $\left(\mathrm{FF}_{1}\right)$.


Fig : 3.34-2-Bit Synchronous Binary Counter

Assume that the counter is initially in the binary 0 state: i.e., both FlipFlops are RESET. When the positive edge of the first clock pulse is applied, FFo will toggle because $\mathrm{J}_{0}=\mathrm{k}_{0}=1$, whereas $\mathrm{FF}_{1}$ output will remain 0 because $J_{1}=k_{1}=0$. After the first clock pulse $Q_{0}=1$ and $Q_{1}=0$.

When the leading edge of CLK2 occurs, $\mathrm{FF}_{0}$ will toggle and $\mathrm{Q}_{0}$ will go LOW. Since $F F_{1}$ has a $\operatorname{HIGH}\left(Q_{0}=1\right)$ on its $J_{1}$ and $K_{1}$ inputs at the triggering edge of this clock pulse, the Flip-Flop toggles and Q1 goes HIGH. Thus, after CLK2,
$Q_{0}=0$ and $Q_{1}=1$.
When the leading edge of CLK3 occurs, $\mathrm{FF}_{0}$ again toggles to the SET state $\left(Q_{0}=1\right)$, and $F_{1}$ remains SET $\left(Q_{1}=1\right)$ because its $J_{1}$ and $K_{1}$ inputs are both LOW $\left(\mathrm{Q}_{0}=0\right)$.
After this triggering edge, $Q_{0}=1$ and $Q_{1}=1$.
Finally, at the leading edge of CLK4, $Q_{0}$ and $Q_{1}$ go LOW because they both have a toggle condition on their $J_{1}$ and $K_{1}$ inputs. The counter has now recycled to its original state, $Q_{0}=Q_{1}=0$.


Fig : 3.35 - Timing diagram

## 3- Bit Synchronous Binary Counter

A 3 bit synchronous binary counter is constructed with three JK FlipFlops and an AND gate. The output of $\mathrm{FF}_{0}\left(\mathrm{Q}_{0}\right)$ changes on each clock pulse as the counter progresses from its original state to its final state and then back to its original state. To produce this operation, $\mathrm{FF}_{0}$ must be held in the toggle mode by constant HIGH, on its $J_{0}$ and Koinputs.


Fig : 3.36-3-Bit Synchronous Binary Counter

The output of $\mathrm{FF}_{1}\left(\mathrm{Q}_{1}\right)$ goes to the opposite state following each time $\mathrm{Q}_{0}=$ 1.

This change occurs at CLK2, CLK4, CLK6, and CLK8. The CLK8 pulse causes the counter to recycle. To produce this operation, $Q_{0}$ is connected to the $\mathrm{J}_{1}$ and $\mathrm{K}_{1}$ inputs
of $\mathrm{FF}_{1}$. When $\mathrm{Q}_{0}=1$ and a clock pulse occurs, $\mathrm{FF}_{1}$ is in the toggle mode and therefore changes state. When $\mathrm{Q}_{0}=0, \mathrm{FF}_{1}$ is in the no-change mode and remains in its present state.

The output of $\mathrm{FF}_{2}\left(\mathrm{Q}_{2}\right)$ changes state both times; it is preceded by the unique condition in which both $\mathrm{Q}_{0}$ and $\mathrm{Q}_{1}$ are HIGH. This condition is detected by the AND gate and applied to the $\mathrm{J}_{2}$ and $\mathrm{K}_{2}$ inputs of $\mathrm{FF}_{3}$.
Whenever both outputs $Q_{0}=Q_{1}=1$, the output of the AND gate makes the $\mathrm{J}_{2}=\mathrm{K}_{2}=1$ and FF 2 toggles on the following clock pulse. Otherwise, the $\mathrm{J}_{2}$ and $\mathrm{K}_{2}$ inputs of FF 2 are held LOW by the AND gate output, $\mathrm{FF}_{2}$ does not change state.

| CLOCK Pulse | Q2 | Q1 | Q0 |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Initiall | 0 | 0 | 0 |
| $y$ | 1 | 0 | 0 | 1 |
| 2 | 0 | 1 | 0 |  |
| 3 | 0 | 1 | 1 |  |
| 4 | 1 | 0 | 0 |  |
| 5 | 1 | 0 | 1 |  |
| 6 | 1 | 1 | 0 |  |
| 7 | 1 | 1 | 1 |  |
| 8 | 0 | 0 | 0 |  |
| (recycles |  |  |  |  |



Fig : 3.37-Timing diagram

## 4- Bit Synchronous Binary Counter

This particular counter is implemented with negative edge-triggered Flip- Flops. The reasoning behind the $J$ and $K$ input control for the first three Flip- Flops is the same as previously discussed for the 3-bit counter. For the fourth stage, the Flip- Flop has to change the state when $Q_{0}=Q_{1}=Q_{2}=1$. This condition is decoded by AND gate $\mathrm{G}_{3}$.


Fig : 3.38-4-Bit Synchronous Binary Counter
Therefore, when $Q_{0}=Q_{1}=Q_{2}=1$, Flip-Flop $F_{3}$ toggles and for all other times it is in a no-change condition. Points where the AND gate outputs are HIGH are indicated by the shaded areas.


Fig : 3.39 - Timing
state

## 4-Bit Synchronous Decade Counter: (BCD Counter):

BCD decade counter has a sequence from 0000 to 1001 (9).
After 1001 it must recycle back to 0000 state. This counter requires four Flip-Flops and AND/OR logic as shown below.


| CLOCK Pulse | Q3 | Q2 | Q1 | Q0 |
| :---: | :---: | :---: | :---: | :---: |
| Initiall | 0 | 0 | 0 | 0 |
| y 1 | 0 | 0 | 0 | 1 |
| 2 | 0 | 0 | 1 | 0 |
| 3 | 0 | 0 | 1 | 1 |
| 4 | 0 | 1 | 0 | 0 |
| 5 | 0 | 1 | 0 | 1 |
| 6 | 0 | 1 | 1 | 0 |
| 7 | 0 | 1 | 1 | 1 |
| 8 | 1 | 0 | 0 | 0 |
| 9 | 1 | 0 | 0 | 1 |
| 10 (recycles | 0 | 0 | 0 | 0 |
| $)$ |  |  |  |  |

xFirst, notice that $F F_{0}\left(Q_{0}\right)$ toggles on each clock pulse, so the logic equation for its $J_{0}$ and $K_{0}$ inputs is

$$
J_{0}=K_{0}=1
$$

This equation is implemented by connecting $\mathrm{J}_{0}$ and $\mathrm{K}_{0}$ to a constant HIGH level. xNext, notice from table, that $\mathrm{FF}_{1}\left(\mathrm{Q}_{1}\right)$ changes on the next clock pulse each time $\mathrm{Q} 0=1$ and $\mathrm{Q} 3=0$, so the logic equation for the $J_{1}$ and $K_{1}$ inputs is

$$
J_{1}=K_{1}=Q_{0} Q_{3}{ }^{\prime}
$$

This equation is implemented by ANDing $Q_{0}$ and $Q_{3}$ and connecting the gate output to the $\mathrm{J}_{1}$ and $\mathrm{K}_{1}$ inputs of $\mathrm{FF}_{\text {I }}$.
$x$ Flip-Flop $2\left(Q_{2}\right)$ changes on the next clock pulse each time both $Q_{0}=Q_{1}=1$.
This requires an input logic equation as follows:

$$
\mathrm{J} 2=\mathrm{K} 2=\mathrm{Q} 0 \mathrm{Q} 1
$$

This equation is implemented by ANDing $Q_{0}$ and $Q_{1}$ and connecting the gate output to the $\mathrm{J}_{2}$ and $\mathrm{K}_{2}$ inputs of $\mathrm{FF}_{3}$.
$x$ Finally, $\mathrm{FF}_{3}\left(\mathrm{Q}_{3}\right)$ changes to the opposite state on the next clock pulse each time
$Q_{0}=1, Q_{1}=1$, and $Q_{2}=1$ (state 7 ), or when $Q_{0}=1$ and $Q_{1}=1$
(state 9). The equation for this is as follows:

$$
\mathrm{J} 3=\mathrm{K} 3=\text { Q0Q1Q2+ Q0Q3 }
$$

This function is implemented with the AND/OR logic connected to the $J_{3}$ and $\mathrm{K}_{3}$ inputs of $\mathrm{FF}_{3}$.


Fig : 3.40-Timing diagram

## Synchronous UP/DOWN Counter

An up/down counter is a bidirectional counter, capable of progressing in either direction through a certain sequence. A 3-bit binary counter that advances upward through its sequence ( $0,1,2,3,4,5,6,7$ ) and then can be reversed so that
it goes through the sequence in the opposite direction ( $7,6,5,4,3,2,1,0$ ) is an illustration of up/down sequential operation.

The complete up/down sequence for a 3-bit binary counter is shown in table below. The arrows indicate the state-to-state movement of the counter for both its UP and its DOWN modes of operation. An examination of $Q_{0}$ for both the up and down sequences shows that $\mathrm{FF}_{0}$ toggles on each clock pulse. Thus, the $\mathrm{J}_{0}$ and $\mathrm{K}_{0}$ inputs of $\mathrm{FF}_{0}$ are,

$$
J_{0}=K_{0}=1
$$



To form a synchronous UP/DOWN counter, the control input (UP/DOWN) is used to allow either the normal output or the inverted output of one Flip-Flop to the J and K inputs of the next Flip-Flop. When UP/DOWN= 1, the MOD 8 counter will count from 000 to 111 and UP/DOWN=0, it will count from 111 to 000.

When UP/DOWN $=1$, it will enable AND gates 1 and 3 and disable AND gates 2 and 4. This allows the Q0 and Q1 outputs through the AND gates to the J and K inputs of the following Flip-Flops, so the counter counts up as pulses are applied. When UP/DOWN $=0$, the reverse action takes place.

$$
\begin{aligned}
& J_{1}=K_{1}=\left(Q_{0} \cdot U P\right)+\left(Q_{0}{ }^{\prime} \cdot D O W N\right) \\
& J_{2}=K_{2}=\left(Q_{0 .} Q_{1} \cdot U P\right)+\left(Q_{0^{\prime}} \cdot Q_{1}^{\prime} \cdot D O W N\right)
\end{aligned}
$$

Fig : 3.41-3-bit UP/DOWN Synchronous Counter

## MODULUS-N-COUNTERS

The counter with ' $n$ ' Flip-Flops has maximum MOD number 2 '. Find the number of Flip-Flops ( n ) required for the desired MOD number ( N ) using the equation,
$2 \mathrm{n} \geq \mathrm{N}$
(i) For example, a 3 bit binary counter is a MOD 8 counter. The basic counter can be modified to produce MOD numbers less than $2^{n}$ by allowing the counter to skin those are normally part of counting sequence.

$$
\begin{aligned}
& n=3 N=82^{n}= \\
& 2^{3}=8=N
\end{aligned}
$$

## (ii) MOD 5 Counter:

$$
\begin{aligned}
& 2^{n}=N \\
& 2^{n}=5
\end{aligned}
$$

$2^{2}=4$ less than $N$.
$2^{3}=8>N(5)$ Therefore, 3 Flip-
Flops are required.
(iii) MOD 10 Counter:

$$
2^{n}=N=102^{3}=8 \text { less }
$$

than N .
$2^{4}=16>N(10)$. To construct any MOD-N counter, the following methods can be used.

1. Find the number of Flip-Flops $(\mathrm{n})$ required for the desired MOD number $(\mathrm{N})$ using the equation,

$$
2^{n} \geq N
$$

2. Connect all the Flip-Flops as a required counter.
3. Find the binary number for $N$.
4. Connect all Flip-Flop outputs for which $\mathrm{Q}=1$ when the count is N , as inputs to NAND gate.
5. Connect the NAND gate output to the CLR input of each Flip-Flop.

When the counter reaches $\mathrm{N}^{\text {th }}$ state, the output of the NAND gate goes LOW, resetting all Flip-Flops to 0 . Therefore the counter counts from 0 through $\mathrm{N}-1$.

For example, MOD-10 counter reaches state 10 (1010). i.e., $\mathrm{Q}_{3} \mathrm{Q}_{2} \mathrm{Q}_{1} \mathrm{Q}_{0}=1$ 010 . The outputs $Q_{3}$ and $Q_{1}$ are connected to the NAND gate and the output of the NAND gate goes LOW and resetting all Flip-Flops to zero. Therefore MOD-10 counter counts from 0000 to 1001. And then recycles to the zero value.

The MOD-10 counter circuit is shown below.


Fig : 3.42-MOD-10 (Decade)
WWW.binils.com

## EC 8392 - DIGITAL ELECTRONICS UNIT - III : SYNCHRONOUS SEQUENTIAL CIRCUITS

## INTRODUCTION

In combinational logic circuits, the outputs at any instant of time depend only on the input signals present at that time. For a change in input, the output occurs immediately.


Fig : 3.1-Combinational Circuit- Block Diagram
In sequential logic circuits, it consists of combinational circuits to which storage elements are connected to form a feedback path. The storage elements are devices capable of storing binary information either 1 or 0 .

The information stored in the memory elements at any given time defines the present state of the sequential circuit. The present state and the external circuit determine the output and the next state of sequential circuits.


Fig : 3.2-Sequential Circuit- Block Diagram

Thus in sequential circuits, the output variables depend not only on the present input variables but also on the past history of input variables.

The rotary channel selected knob on an old-fashioned TV is like a combinational. Its output selects a channel based only on its current input - the
position of the knob. The channel-up and channel-down push buttons on a TV is like a sequential circuit. The channel selection depends on the past sequence of up/down pushes.

Table: 3.1-The comparison between combinational and sequential circuits

| S.N <br> $\mathbf{0}$ | Combinational logic | Sequential logic |
| :---: | :--- | :--- |
| $\mathbf{1}$ | The output variable, at all <br> times depends on the <br> combination of input <br> variables. | The output variable depends not <br> only on the present input but also <br> depend upon the past history of <br> inputs. |
| 2 | Memory unit is not required | Memory unit is required to store <br> the <br> past history of input variables. |
| 3 | Faster in speed | Slower than combinational circuits. |
| 4 | Easy to design | Comparatively harder to design. |
| 5 | Eg. Parallel adder | Eg. Serial adder |

## Classification of Logic Circuits



Fig : 3.3 - Classification of sequential Circuits

The sequential circuits can be classified depending on the timing of their signals:

- Synchronous sequential circuits
- Asynchronous sequential circuits.

In synchronous sequential circuits, signals can affect the memory elements only at discrete instants of time. In asynchronous sequential circuits change in input signals can affect memory element at any instant of time. The memory elements used in both circuits are Flip-Flops, which are capable of storing 1-bit information.

Table: 3.2 - The comparison between Synchronous and asynchronous sequential circuits

| S.N <br> $\mathbf{0}$ | Synchronous sequential <br> circuits | Asynchronous sequential <br> circuits |
| :--- | :--- | :--- |
| $\mathbf{1}$ | Memory elements are <br> clocked Flip-Flops | Memory elements are either <br> unclocked Flip-Flops or time delay <br> elements. |
| $\mathbf{2}$ | The change in input signals <br> can affect memory element <br> upon activation of clock <br> signal. | The change in input signals can <br> affect <br> memory element at any instant of <br> time. |
| $\mathbf{3}$ | The maximum operating <br> speed of clock depends on <br> time delays involved. | Because of the absence of clock, <br> it can <br> operate faster <br> synchronous circuits. |
| 4 | Easier to design | More difficult to design |

## LATCHES:

Latches and Flip-Flops are the basic building blocks of the most sequential circuits. Latches are used for a sequential device that checks all of its inputs continuously and changes its outputs accordingly at any time independent of clocking signal. Enable signal is provided with the latch. When enable signal is active output changes occur as the input changes. But when enable signal is not activated input changes do not affect the output.

Flip-Flop is used for a sequential device that normally samples its inputs and changes its outputs only at times determined by clocking signal.

## SR Latch:

The simplest type of latch is the set-reset (SR) latch. It can be constructed from either two NOR gates or two NAND gates.

## SR latch using NOR gates:

The two NOR gates are cross-coupled so that the output of NOR gate 1 is connected to one of the inputs of NOR gate 2 and vice versa. The latch has two outputs Q and Q' and two inputs, set and reset.


Fig : 3.4-SR latch using NOR gates

Before going to analyse the SR latch, we recall that a logic 1 at any input of a NOR gate forces its output to a logic 0 . Let us understand the operation of this circuit for various input/ output possibilities.

## Case 1: $S=0$ and $R=0$

Initially, Q= 1 and Q'= 0
Let us assume that initially $Q=1$ and $Q^{\prime}=0$. With $Q^{\prime}=0$, both inputs to NOR gate 1 are at logic 0 . So, its output, $Q$ is at logic 1 . With $Q=1$, one input of NOR gate 2 is at logic

1. Hence its output, $Q$ ' is at logic 0 . This shows that when $S$ and $R$ both are low, the output does not change.


Initially, Q=0 and Q'= 1
With $Q^{\prime}=1$, one input of NOR gate 1 is at logic 1 , hence its output, $Q$ is at logic 0 . With $Q=0$, both inputs to NOR gate 2 are at logic 0 . So, its output $Q$ ' is at logic 1. In this case also there is no change in the output state.


## Case 2: $\mathrm{S}=0$ and $\mathrm{R}=1$

In this case, $R$ input of the NOR gate 1 is at logic 1 , hence its output, $Q$ is at logic 0.

Both inputs to NOR gate 2 are now at logic 0 . So that its output, $Q^{\prime}$ is at logic 1 .


## Case 3: $\mathrm{S}=1$ and $\mathrm{R}=0$

In this case, $S$ input of the NOR gate 2 is at logic 1, hence its output, $Q$ is at logic 0 . Both inputs to NOR gate 1 are now at logic 0 . So that its output, Q is at logic 1.


Case 4: $S=1$ and $R=1$
When $R$ and $S$ both are at logic 1, they force the outputs of both NOR gates to the low state, i.e., ( $\mathrm{Q}=0$ and $\mathrm{Q}^{\prime}=0$ ). So, we call this an indeterminate or prohibited state, and represent this condition in the truth table as an asterisk (*). This condition also violates the basic definition of a latch that requires $Q$ to be complement of $\mathrm{Q}^{\prime}$.

Thus in normal operation this condition must be avoided by making sure that 1's are not applied to both the inputs simultaneously.

We can summarize the operation of SR latch as follows:
$x W h e n S=0$ and $R=0$, the output, $Q_{n+1}$ remains in its present state, $Q_{n}$. $x W$ hen $S=0$ and $R=1$, the latch is reset to 0 . $x W$ hen $S=1$ and $R=0$, the latch is set to 1 .
$x$ When $S=1$ and $R=1$, the output of both gates will produce 0. i.e., $\mathbf{Q n + 1}=\mathbf{Q n + 1}=\mathbf{0}$.

The truth table of NOR based SR latch is shown below.
WWI

| $\mathbf{S}$ | $\mathbf{R}$ | $\mathbf{Q n}$ | $\mathbf{Q n +}$ <br> $\mathbf{1}$ | State |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | No Change |
| 0 | 0 | 1 | 1 | $(\mathrm{NC})$ |
| 0 | 1 | 0 | 0 | Reset |
| 0 | 1 | 1 | 0 |  |
| 1 | 0 | 0 | 1 | Set |
| 1 | 0 | 1 | 1 |  |
| 1 | 1 | 0 | $\times x$ | Indeterminat <br> $e$ <br> 1 |
| 1 | 1 |  | $*$ |  |

## SR latch using NAND gates:

The SR latch can also be implemented using NAND gates. The inputs of this Latch are $S$ and $R$. To understand how this circuit functions, recall that a low on any input to a NAND gate forces its output high.


Fig : 3.5-SR latch using NAND gates


Fig : 3.6-Logic Symbol
We can summarize the operation of SR latch as

## follows:

$x W h e n S=0$ and $R=0$, the output of both gates will produce

$$
\text { 0. i.e., } Q n+1=Q n+1^{\prime}=1 \text {. }
$$

$x W$ hen $S=0$ and $R=1$, the latch is reset to 0 . $x$ When $S=1$ and $R=0$, the latch is set to 1 . $x W$ hen $S=1$ and $R=1$, the output, $Q_{n+1}$ remains in its present state, $\mathrm{Q}_{\mathrm{n}}$.

The truth table of NAND based SR latch is shown below.

| $\mathbf{S}$ | $\mathbf{R}$ | $\mathbf{Q n}$ | Qn+ <br> $\mathbf{1}$ | State |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\times x$ | Indeterminat <br> $e$ |
| 0 | 0 | 1 |  | $*$ |
| 0 | 1 | 0 | 1 | Set |
| 0 | 1 | 1 | 1 |  |
| 1 | 0 | 0 | 0 | Reset |
| 1 | 0 | 1 | 0 |  |


| 1 | 1 | 0 | 0 | No Change |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 1 | $(\mathrm{NC})$ |

## Gated SR Latch:

In the SR latch, the output changes occur immediately after the input changes i.e, the latch is sensitive to its $S$ and $R$ inputs all the time.

A latch that is sensitive to the inputs only when an enable input is active. Such a latch with enable input is known as gated SR latch.
$x$ The circuit behaves like $S R$ latch when $E N=1$. It retains its previous state



Fig: 3.6-SR Latch with enable input using NAND gates Fig:3.7 Logic Symbol The truth table of gated SR latch is show below.

| EN | $\mathbf{S}$ | $\mathbf{R}$ | Qn | Qn+1 | State |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | No Change |
| 1 | 0 | 0 | 1 | 1 | (NC) |
| 1 | 0 | 1 | 0 | 0 | Reset |
| 1 | 0 | 1 | 1 | 0 |  |


| 1 | 1 | 0 | 0 | 1 | Set |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 1 | 1 |  |
| 1 | 1 | 1 | 0 | xx | Indeterminate |
| 1 | 1 | 1 | 1 |  | $*$ |
| 0 | xx | xx | 0 | 0 | No Change |
| 0 |  |  | 1 | 1 | (NC) |

When $S$ is HIGH and $R$ is LOW, a HIGH on the EN input sets the latch. When S is LOW and R is HIGH, a HIGH on the EN input resets the latch.


Fig : 3.8 - Timing diagram

## D

Latch
In SR latch, when both inputs are same (00 or 11), the output either does not
change or it is invalid. In many practical applications, these input conditions are not required. These input conditions can be avoided by making them complement of each other. This modified SR latch is known as D latch.


Fig : 3.9-D Latch


Fig : 3.10 - Logic Symbol

As shown in the figure, $D$ input goes directly to the $S$ input, and its complement is applied to the R input. Therefore, only two input conditions exists, either $S=0$ and $R=1$ or $S=1$ and $R=0$. The truth table for $D$ latch is shown below.

| EN | $\mathbf{D}$ | $\mathbf{Q}$ <br> $\mathbf{n}$ | $\mathbf{Q n +}$ <br> $\mathbf{1}$ | State |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | $x$ | 0 | Reset |
| 1 | 1 | $x$ | 1 | Set |
| 0 | $x$ | $x$ | Qn | No Change <br> (NC) |

As shown in the truth table, the Q output follows the D input. For this reason, D latch is called transparent latch.

When D is HIGH and EN is HIGH. Q goes HIGH. When D is LOW and EN is HIGH, Q goes LOW. When EN is LOW, the state of the latch is not affected by the D input.


Fig : 3.11 - Timing diagram

## EC 8392 - DIGITAL ELECTRONICS

## UNIT - IV : ASYNCHRONOUS SEQUENTIAL CIRCUITS

## ANALYSIS EXAMPLE

Asynchronous sequential circuits can be constructed with the use of SR latches with or without external feedback paths. Of course, there is always a feedback loop within the latch itself. The analysis of a circuit with latches will be demonstrated by means of a specific example from which it will be possible to generalize the procedural steps necessary to analyze other, similar circuits.


Fig: 4.8 - Examples of a circuit with SR latches Image source from Digital Design by Moris Mano (Page No. 428)

There are two inputs, $\mathrm{x}_{1}$ and $\mathrm{x}_{2}$, and two external feedback loops giving rise to the secondary variables, $\mathrm{y}_{1}$ and $\mathrm{y}_{2}$. Note that this circuit resembles a conventional sequential circuit with latches behaving like flip-flops without clock pulses. The analysis of the circuit requires that we first obtain the Boolean function for the $S$ and R inputs in each latch:

$$
\begin{array}{ll}
S_{1}=x_{1} y_{2} & S_{2}=x_{1} \cdot x_{2} \\
R_{1}=x_{1}^{\prime} x_{2}^{\prime} & R_{2}=x_{2}^{\prime} y_{1}
\end{array}
$$

We then check whether the condition $\mathrm{SR}=0$ is satisfied to ensure proper operation of the circuit:

$$
\begin{aligned}
& S_{1} R_{1}=x_{1} y_{2} x_{1}^{\prime} x_{2}^{\prime}=0 \\
& S_{2} R_{2}=x_{1} x_{2} x_{2}^{\prime} y_{1}=0
\end{aligned}
$$

## WWW

Fig: 4.9- Transition table


Image source from Digital Design by Moris Mano (Page No. 429)

The procedure for analyzing an asynchronous sequential circuit with SR latches can be summarized as follows:

1. Label each latch output with $Y_{i}$ and its external feedback path (if any) with Yi for i
$=1$,
$2, \ldots k$.
2. Derive the Boolean functions for the $S_{i}$ and $R_{i}$ inputs in each latch.
3. Check whether $S R=0$ for each $N O R$ latch or whether $S^{\prime} R^{\prime}=0$ for each NAND latch. If either of these conditions is not satisfied, there is a possibility that the circuit may not operate properly.
4. Evaluate $Y=S+R^{\prime} y$ for each NOR latch or $Y=S^{\prime}+R y$ for each NAND latch.
5. Consruct a map, with the y's representing the rows and the $x$ inputs representing the colwnns.
6. Plot the value of $Y=Y_{1} Y_{2} \ldots . . Y_{K}$ in the map.
7. Circle all stable states such that $Y=y$. The resulting map is then the transition table.


## W A Fig: 4.10 - Derivation of a Latch Circuit fromTransition table Image source from Digital Design by Moris Mano (Page No. 431) <br> DESIGN PROCEDURE

The design of an asynchronous sequential circuit starts from the statement of the problem and culminates in a logic diagram. There are a number of design steps that must be carried out in order to minimize the complexity of the circuit and to produce a stable circuit without critical races. Briefly, the design steps are as follows: A primitive flow table is obtained from the design specifications. The flow table is then reduced to a minimum number of states. Next, the states are given a binary assignment from which we obtain the transition table. Finally, from the transition table, we derive the logic diagram as a combinational circuit with feedback or as a circuit with SR latches.

## DESIGN EXAMPLE

It is necessary to design a gated latch circuit with two inputs $G$ (gate) and D (data) and one output Q. Binary information present at the D input is transferred to the $Q$ output when $G$ is equal to 1 . The $Q$ output will follow the $D$ input as long as $G=1$. When $G$ goes to 0 , the information that was present at the $D$ input at the time the transition occurred is retained at the Q output. The gated latch is a memory element that accepts the value of $D$ when $G=1$ and retains this value after $G$ goes to 0 . Once $G=0$, a change in $D$ does not change the value of the output Q.

## Primitive Flow Table

A primitive flow table is a flow table with only one stable total state in each row. Remember that a total stale consists of the internal state combined with the input. The derivation of the primitive flow table can be facilitated if we first form a table with all possible total states in the system.


Fig: 4.10 - Primitive flow table Image source from Digital Design by Moris Mano (Page No. 434)

The primitive flow table for the gated latch has one row for each state and one column for each input combination. First, we fill in one square in each row belonging to the stable state in that row. These entries are determined from Table. For example, Slate Q is stable and the output is 0 when the input is 01 . This information is entered into the flow table in the first row and second column. Similarly, the other five stable stales together with their output are entered into the corresponding input columns. Next, we note that since both inputs are not allowed to change simultaneously, we can enter dash marks in each row that differs in two or more variables from the input variables associated with the stable state. For example, the first row in the flow table shows a stable state with an input of 01 . Since only one input can change at any given time, it can change to 00 or 11, but not to 10. Therefore, we enter two dashes in the 10 column of row a. This will eventually result in a don't-care condition for the next state and output in this square. Following the same procedure, we fill in a second square in each row of the primitive flow table.

Next, it is necessary to find values for two more squares in each row. The comments listed in Table may help in deriving the necessary information. For example, state c is associated with input 00 and is reached after a change in input from state a or d. Therefore, an unstable state c is shown in column 00 and rows a and d in the flow table. The output is marked with a dash to indicate a don't-care condition. The interpretation of this situation is that if the circuit is in stable state a and the input changes from 01 to 00 , the circuit first goes to an unstable next state c . which changes
the present-slate value from a to c , causing a transition to the third row and first column of the table. The unstable state values for the other square $s$ are determined in a similar manner. All outputs associated with unstable states are marked with a dash to indicate don't -care conditions.

## Reduction of the Primitive flow table

The primitive flow table has only one stable state in each row. The table can be reduced to a smaller number of rows if two or more stable states are placed in the same row. The grouping of stable states from separate rows into one common row is called merging. Merging a number of stable states in the same row means that the binary state variable ultimately assigned to the merged row will not change when the input variable changes. This is because, in a primitive flow table, the stale variable changes every time the input changes, but in a reduced flow table, a change of input will not cause a change in the state variable if the next stable state is in the same row.

Two or more rows in the primitive flow table can be merged into one row if there are non conflicting stales and outputs in each of the columns. Whenever one state symbol and don't -care entries are encountered in the same column, the state is listed in the merged row.

Moreover, if the stale is circled in one of the rows, it is also circled in the merged row. The output value is included with each stable slate in the merged row. Because the merged stales have the same output, the state cannot be distinguished on the basis of the output.


Fig: 4.11 - Reduction of primitive flow tables Image source from Digital Design by Moris Mano (Page No. 436)

## Transition table and Logic Diagram

In order to obtain the circuit described by the reduced flow table, it is necessary to assign a distinct binary value to each state. This assignment converts the flow table into a transition table. In the general case, a binary state assignment must be made to ensure that the circuit will be free of critical races. Fortunately, there can be no critical races in a two-row flow table; therefore, we can finish the design of the gated latch prior to studying that section.Assigning 0 to state a and 1 to state $b$ in the reduced flow table of Fig. (b), we obtain the transition table of Fig. (a). The transition table is, in effect, a map for the excitation variable Y. The simplified Boolean function for Y is then obtained from the map as

$$
Y=D C+C^{\prime} y
$$



Fig: 4.12 - Transition table and output map for a gated latch Image source from Digital Design by Moris Mano (Page No. 437)

Fig. Transition Table and output amp for gated latch
N F Fig: 4.13: Gated-latch logic diagram


Image source from Digital Design by Moris Mano (Page No. 437)

## Assigning outputs to unstable states

The procedure for making the assignment to outputs associated with unstable states can be summarized as follows:

1. Assign a 0 to an output variable associated with an unstable state which is a transient state between two stab le states that have a 0 in the corresponding output variable.
2. Assign a 1 to an output variable associated with an unstable state which is a transient state between two stable states that have a 1 in the corresponding output variable.
3. Assign a don' t-care condition to an output variable associated with an unstable state which is a transient state between two stable states that have different value s (0 and 1, or 1 and 0 ) in the corresponding output variable .

## WWW $\square$ $\square ?$


(a) Maps for $S$ and $R$

(b) Logic diagram

Fig 4.14 - Circuit with SR Latches
Image source from Digital Design by Moris Mano (Page No. 438)

(a) Flow table

| 0 | 0 |
| :---: | :---: |
| X | 0 |
| 1 | 1 |
| X | 1 |

(b) Output assignment

Fig 4.15 - Assigning output values to unstable states Image source from Digital Design by Moris Mano (Page No. 438)

## EC 8392 - DIGITAL ELECTRONICS <br> UNIT - III : SYNCHRONOUS SEQUENTIAL CIRCUITS

## SHIFT REGISTERS:

A register is simply 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 instance, a register used to store an 8-bit binary number must have 8 Flip-Flops.

The Flip-Flops must be connected such that the binary number can be entered (shifted) into the register and possibly shifted out. A group of FlipFlops connected to provide either or both of these functions is called a shift register.

The bits in a binary number (data) can be removed 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 most significant bit (MSB) or the least significant bit (LSB). This technique is referred to as serial shifting. The second method involves shifting all the data bits simultaneously and is referred to as parallel shifting. There are two ways to shift into a register (serial or parallel) and similarly two ways to shift the data out of the register. This leads to the construction of four basic register types-
i. Serial in- serial out,
ii. Serial in- parallel out,
iii. Parallel in- serial out, iv. Parallel in- parallel out.

(i) Serial in- serial out
(iii) Parallel in- serial out


(iv) Parallel in- parallel out

Fig : 3.43 - Various types of Shift Registers

## Serial-In Serial-Out Shift Register:

The serial in/serial out shift register accepts data serially, i.e., one bit at a time on a single line. It produces the stored information on its output also in serial form.


The entry of the four bits 1010 into the register is illustrated below, beginning with the right-most bit. The register is initially clear. The 0 is put onto the data input line, making $\mathrm{D}=0$ for $\mathrm{FF}_{0}$. When the first clock pulse is applied, $\mathrm{FF}_{0}$ is reset, thus storing the 0 .

Next the second bit, which is a 1 , is applied to the data input, making $D=1$ for $F F_{0}$ and $D=0$ for $F F_{1}$ because the $D$ input of $F F_{1}$ is connected to the $Q_{0}$ output. When
the second clock pulse occurs, the 1 on the data input is shifted into FFO, causing FFO to set; and the 0 that was in FFO is shifted into FFI.

The third bit, a 0 , is now put onto the data-input line, and a clock pulse is applied. The 0 is entered into $F F_{0}$, the 1 stored in $F F_{0}$ is shifted into $F F_{1}$, and the 0 stored in $\mathrm{FF}_{1}$ is shifted into $\mathrm{FF}_{2}$.

The last bit, a 1, is now applied to the data input, and a clock pulse is applied.
This time the 1 is entered into FFO, the 0 stored in FFO is shifted into FFI, the 1 stored in FF1 is shifted into FF2, and the 0 stored in FF2 is shifted into FF3. This completes the serial entry of the four bits into the shift register, where they can be stored for any length of time as long as the Flip-Flops have dc power.



Fig : 3.45 - Four bits (1010) being entered serially into the register To get the data out of the register, the bits must be shifted out serially and taken off the Q3 output. After CLK4, the right-most bit, 0, appears on the Q3 output.

When clock pulse CLK5 is applied, the second bit appears on the Q3 output. Clock pulse CLK6 shifts the third bit to the output, and CLK7 shifts the fourth bit to the output. While the original four bits are being shifted out, more bits can be shifted in. All zeros are shown being shifted out, more bits can be shifted in.
www.binils.com for Anna University | Polytechnic and schools


Fig : 3.46 - Four bits (1010) being entered serially-shifted out of the register and replaced by all zeros

## Serial-In Parallel-Out Shift Register:

In this shift register, data bits are entered into the register in the same as serial-in serial-out shift register. But the output is taken in parallel. Once the data are stored, each bit appears on its respective output line and all bits are available simultaneously instead of on a bit-by-bit.


Fig : 3.47-Serial-In parallel-Out Shift Register



Fig : 3.47- Four bits (1111) being serially entered into the register

## Parallel-In Serial-Out Shift Register:

In this type, the bits are entered in parallel i.e., simultaneously into their respective stages on parallel lines.

A 4-bit parallel-in serial-out shift register is illustrated below. There are four data input lines, $X_{0}, X_{1}, X_{2}$ and $X_{3}$ for entering data in parallel into the register.
SHIFT/ LOAD input is the control input, which allows four bits of data to load in parallel into the register.

When SHIFT/LOAD is LOW, gates $G_{1}, G_{2}, G_{3}$ and $G_{4}$ are enabled, allowing each data bit to be applied to the D input of its respective Flip-Flop. When a clock pulse is
applied, the Flip-Flops with $D=1$ will set and those with $D=0$ will reset, thereby storing all four bits simultaneously.


When SHIFT/LOAD is HIGH, gates $\mathrm{G}_{1}, \mathrm{G}_{2}, \mathrm{G}_{3}$ and $\mathrm{G}_{4}$ are disabled and gates $\mathrm{G}_{5}$,
$\mathrm{G}_{6}$ and $\mathrm{G}_{7}$ are enabled, allowing the data bits to shift right from one stage to the next. The OR gates allow either the normal shifting operation or the parallel data- entry operation, depending on which AND gates are enabled by the level on the SHIFT/LOAD input.

## Parallel-In Parallel-Out Shift Register:

In this type, there is simultaneous entry of all data bits and the bits appear on
parallel outputs simultaneously.


Fig : 3.49 - Parallel-In Parallel-Out Shift Register

## UNIVERSAL SHIFT REGISTERS

If the register has shift and parallel load capabilities, then it is called a shift register with parallel load or universal shift register. Shift register can be used for converting serial data to parallel data, and vice-versa. If a parallel load capability is added to a shift register, the data entered in parallel can be taken out in serial fashion by shifting the data stored in the register.

The functions of universal shift register are:

1. A clear control to clear the register to 0 .
2. A clock input to synchronize the operations.
3. A shift-right control to enable the shift right operation and the serial input and output lines associated with the shift right.
4. A shift-left control to enable the shift left operation and the serial input and output lines associated with the shift left.
5. A parallel-load control to enable a parallel transfer and the n input lines associated with the parallel transfer.
6. ' $n$ ' parallel output lines.
7. A control line that leaves the information in the register unchanged even though the clock pulses re continuously applied.

It consists of four D-Flip-Flops and four 4 input multiplexers (MUX). So
selection inputs are used to select one of the four inputs of each multiplexer.

The input 0 in each MUX is selected when $S_{1} S_{0}=00$ and input 1 is selected when $S_{1} S_{0}=01$. Similarly inputs 2 and 3 are selected when $\mathrm{S}_{1} \mathrm{~S}_{0}=10$ and $\mathrm{S}_{1} \mathrm{~S}_{0}=11$ respectively. The inputs S 1 and S 0 control the mode of the operation of the register

Parallel outputs

and $S_{1}$ are the two selection inputs connected to all the four multiplexers.
These two
Fig : 3.50-4-Bit Universal Shift Register

When $\mathrm{S}_{1} \mathrm{~S}_{0}=00$, the present value of the register is applied to the D -inputs of the Flip-Flops. This is done by connecting the output of each Flip-Flop to the 0 input of the respective multiplexer. The next clock pulse transfers into each Flip-Flop, the binary value is held previously, and hence no change of state occurs.

When $\mathrm{S}_{1} \mathrm{~S}_{0}=01$, terminal 1 of the multiplexer inputs has a path to the D inputs of the Flip-Flops. This causes a shift-right operation with the lefter serial input transferred into Flip-Flop $\mathrm{FF}_{3}$.

When $S_{1} S_{0}=10$, a shift-left operation results with the right serial input going into Flip-Flop $\mathrm{FF}_{1}$.

Finally when $S_{1} S_{0}=11$, the binary information on the parallel input lines $\left(I_{1}, I_{2}, I_{3}\right.$ and $\left.I_{4}\right)$ are transferred into the register simultaneously during the next clock pulse.

The function table of bi-directional shift register with parallel inputs and parallel outputs is shown below.

| Mode Control |  | Operation |
| :---: | :---: | :---: |
| S | S |  |
| 1 | 0 |  |
| 0 | 0 | No change |
| 0 | 1 | Shift-right |
| 1 | 0 | Shift-left |
| 1 | 1 | Parallel <br> load |

## BI-DIRECTION SHIFT REGISTERS:

A bidirectional shift register is one in which the data can be shifted either left or right. It can be implemented by using gating logic that enables the transfer of a
data bit from one stage to the next stage to the right or to the left depending on the level of a control line.

A 4-bit bidirectional shift register is shown below. A HIGH on the RIGHT/LEFT control input allows data bits inside the register to be shifted to the right, and a LOW enables data bits inside the register to be shifted to the left.

When the RIGHT/LEFT control input is HIGH, gates $\mathrm{G}_{1}, \mathrm{G}_{2}, \mathrm{G}_{3}$ and $\mathrm{G}_{4}$ are enabled, and the state of the Q output of each Flip-Flop is passed through to the D input of the following Flip-Flop. When a clock pulse occurs, the data bits are shifted one place to the right.

When the RIGHT/LEFT control input is LOW, gates $\mathrm{G}_{5}, \mathrm{G}_{6}, \mathrm{G}_{7}$ and $\mathrm{G}_{8}$ are enabled, and the Q output of each Flip-Flop is passed through to the D input of the preceding Flip-Flop. When a clock pulse occurs, the data bits are then shifted one place to the left.


Fig : 3.51-4-bit bi-directional shift register

## EC 8392 - DIGITAL ELECTRONICS

## UNIT - III : SYNCHRONOUS SEQUENTIAL CIRCUITS

## TRIGGERING OF FLIP-FLOPS

The state of a Flip-Flop is switched by a momentary change in the input signal. This momentary change is called a trigger and the transition it causes is said to trigger the Flip-Flop. Clocked Flip-Flops are triggered by pulses. A clock pulse starts from an initial value of 0 , goes momentarily to 1 and after a short time, returns to its initial 0 value.

Latches are controlled by enable signal, and they are level triggered, either positive level triggered or negative level triggered. The output is free to change according to the $S$ and $R$ input values, when active level is maintained at the enable input.

Flip-Flops are different from latches. Flip-Flops are pulse or clock edge triggered instead of level triggered.


Fig : 3.12 - Various types of triggering

## EDGE TRIGGERED FLIP-FLOPS

Flip-Flops are synchronous bistable devices (has two outputs $Q$ and Q'). In this case, the term synchronous means that the output changes state only at a specified point on the triggering input called the clock (CLK), i.e., changes in the output occur in synchronization with the clock.

An edge-triggered Flip-Flop changes state either at the positive edge (rising edge) or at the negative edge (falling edge) of the clock pulse and is sensitive to its inputs only at this transition of the clock. The different types of edge-triggered Flip- Flops are-xS-R Flip-Flop, xJ-K Flip-Flop, xD Flip-Flop, xT Flip- Flop.

Although the S-R Flip-Flop is not available in IC form, it is the basis for the D and J-K Flip-Flops. Each type can be either positive edgetriggered (no bubble at C input) or negative edge-triggered (bubble at C input). The key to identifying an edge- triggered Flip-Flop by its logic symbol is the small triangle inside the block at the clock (C) input. This triangle is called the dynamic input indicator.

## S-R Flip-Flop

The $S$ and $R$ inputs of the S-R Flip-Flop are called synchronous inputs because data on these inputs are transferred to the Flip-Flop's output only on the triggering edge of the clock pulse. The circuit is similar to SR latch except enable signal is replaced by clock pulse (CLK). On the positive edge of the clock pulse, the circuit responds to the $S$ and $R$ inputs.


Fig : 3.13-SR Flip-Flop

When $S$ is HIGH and $R$ is LOW, the $Q$ output goes HIGH on the triggering edge of the clock pulse, and the Flip-Flop is SET. When $S$ is LOW and R is HIGH, the Q output goes LOW on the triggering edge of the clock pulse, and the Flip- Flop is RESET. When both S and R are LOW, the output does not change from its prior state.

An invalid condition exists when both $S$ and $R$ are HIGH.


Truth table for SR Flip-Flop


Fig : 3.14 - Input and output waveforms of SR Flip-Flop

## J-K Flip-Flop:

JK means Jack Kilby, Texas Instrument (TI) Engineer, who invented IC in 1958. JK Flip-Flop has two inputs J(set) and K(reset). A JK Flip-Flop can be obtained from the clocked SR Flip-Flop by augmenting two AND gates as shown below.


Fig : 3.15- JK Flip Flop
The data input $J$ and the output $Q^{\prime}$ are applied o the first AND gate and its output (JQ') is applied to the $S$ input of SR Flip-Flop. Similarly, the data input $K$ and the output $Q$ are applied to the second AND gate and its output (KQ) is applied to the $R$ input of SR Flip-Flop.

(a) Using SR flipflop

(b) Graphic symbol

Fig : 3.16-JK Flipflop using SR Flipflop

## $\mathrm{J}=\mathrm{K}=\mathbf{0}$

When $\mathrm{J}=\mathrm{K}=0$, both AND gates are disabled. Therefore clock pulse have no effect, hence the Flip-Flop output is same as the previous output. $\mathrm{J}=0, \mathrm{~K}=1$

When $\mathrm{J}=0$ and $\mathrm{K}=1$, AND gate 1 is disabled i.e., $\mathrm{S}=0$ and $\mathrm{R}=1$. This condition will reset the Flip-Flop to 0 .

$$
\mathrm{J}=1, \mathrm{~K}=0
$$

When $J=1$ and $K=0$, AND gate 2 is disabled i.e., $S=1$ and $R=0$.
Therefore the Flip-Flop will set on the application of a clock pulse. $\mathrm{J}=\mathrm{K}=0$

When $\mathrm{J}=\mathrm{K}=1$, it is possible to set or reset the Flip-Flop. If Q is High, AND gate 2 passes on a reset pulse to the next clock. When $Q$ is low, AND gate 1 passes on a set pulse to the next clock. Eitherway, Q changes to the complement of the last state i.e., toggle. Toggle means to switch to the opposite state.

The truth table of JK Flip-Flop is given below.

| CLK | Inputs |  | Outpu <br> $\mathbf{t}$ | State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{J}$ | $\mathbf{K}$ | $\mathbf{Q n + 1}$ |  |  |
| 1 | 0 | 0 | Qn | No <br> Change |  |
| 1 | 0 | 1 | 0 | Reset |  |



Fig : 3.17-Input and output waveforms of JK Flip-Flop

## Characteristic table and Characteristic equation:

The characteristic table for JK Flip-Flop is shown in the table below. From the table, K-map for the next state transition $\left(Q_{n+1}\right)$ can be drawn and the simplified logic expression which represents the characteristic equation of JK Flip-Flop can be found.

| $\mathbf{Q}$ | $\mathbf{J}$ | $\mathbf{K}$ | $\mathbf{Q n +}$ <br> $\mathbf{n}$ |
| :---: | :---: | :---: | :---: |
| 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 | 0 |

## Characteristic table

## K-map Simplification:

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

Characteristic equation: $\mathbf{Q}_{\mathrm{n}+1}=\mathbf{J Q} \mathbf{\prime}+$ K'Q $^{\prime}$.

## D Flip-Flop:

Like in D latch, in D Flip-Flop the basic SR Flip-Flop is used with complemented inputs. The D Flip-Flop is similar to D-latch except clock pulse is used instead of enable input.

Fig : 3.18 - D Flip-Flop

WV


To eliminate the undesirable condition of the indeterminate state in the RS Flip-Flop is to ensure that inputs $S$ and $R$ are never equal to 1 at the same time. This is done by D Flip-Flop. The D (delay) Flip-Flop has one input called delay input and clock pulse input. The D Flip-Flop using SR Flip-Flop is shown below.

(a) Using SR flipflop

(b) Graphic symbol

Fig : 3.19 - D Flipflop using SR
Flipflop The truth table of D Flip-Flop is given below.

| Cloc <br> $\mathbf{k}$ | $\mathbf{D}$ | Qn+ <br> $\mathbf{1}$ | State |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | Reset |
| 1 | 1 | 1 | Set <br> 0 |
| $x$ | Qn | No <br> Change |  |

Truth table for D Flip-Flop


Fig : 3.20-Input and output waveforms of clocked D Flip-Flop

Looking at the truth table for D Flip-Flop we can realize that $Q_{n+1}$ function follows the $D$ input at the positive going edges of the clock pulses.

## Characteristic table and Characteristic equation:

The characteristic table for D Flip-Flop shows that the next state of the Flip- Flop is independent of the present state since $Q_{n+1}$ is equal to $D$. This means that an input pulse will transfer the value of input $D$ into the output of the Flip-

Flop independent of the value of the output before the pulse was applied. The characteristic equation is derived from K-map.

| $\mathbf{Q}$ | $\mathbf{D}$ | $\mathbf{Q n +}$ |
| :---: | :---: | :---: |
| $\mathbf{n}$ |  | $\mathbf{1}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

## Characteristic table

K-map simplification


Characteristic equation: $\mathbf{Q}_{\mathbf{n + 1}}=$

## D. T Flip-Flop

The T (Toggle) Flip-Flop is a modification of the JK Flip-Flop. It is obtained from JK Flip-Flop by connecting both inputs J and K together, i.e., single input.

Regardless of the present state, the Flip-Flop complements its output when the clock pulse occurs while input $\mathrm{T}=1$.


When $T=0, Q_{n+1}=Q_{n}$, ie., the next state is the sameas the present state and no change occurs. When $T=1, Q n+1=Q n$, ie., the next state is the complement of the present state.


Fig : 3.22 - T flipflop using JK
Flipflop The truth table of T Flip-Flop is given below.

## www

| $\mathbf{T}$ | $\mathbf{Q n + 1}$ | State |
| :---: | :---: | :---: |
| 0 | Qn | No |
| 1 | Qn' | Change |
|  |  |  |

## Truth table for T Flip-Flop

Characteristic table and Characteristic equation:
The characteristic table for T Flip-Flop is shown below and characteristic equation is derived using K-map.

| $\mathbf{Q}$ | $\mathbf{T}$ | $\mathbf{Q n +}$ |
| :---: | :---: | :---: |
| $\mathbf{n}$ |  | $\mathbf{1}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

## K-map Simplification:



Characteristic equation: $\mathbf{Q}_{\mathrm{n}+1}=\mathbf{T} \mathbf{Q}_{\mathbf{n}}{ }^{\prime}+\mathrm{T}^{\prime} \mathbf{Q}_{\mathrm{n}}$.

## Master-Slave JK Flip-Flop

A master-slave Flip-Flop is constructed using two separate JK Flip-Flops. The first Flip-Flop is called the master. It is driven by the positive edge of the clock pulse. The second Flip-Flop is called the slave. It is driven by the negative edge of the clock pulse. The logic diagram of a master-slave JK Flip-Flop is shown below.


Fig : 3.32 - Logic diagram
When the clock pulse has a positive edge, the master acts according to its $\mathrm{J}-\mathrm{K}$ inputs, but the slave does not respond, since it requires a negative edge at the clock input.

When the clock input has a negative edge, the slave Flip-Flop copies the master outputs. But the master does not respond since it requires a positive edge at its clock input. The clocked master-slave J-K Flip-Flop using NAND gates is shown below.


Fig : 3.33 - Master-Slave JK Flip-Flop

## APPLICATION TABLE (OR) EXCITATION TABLE:

The characteristic table is useful for analysis and for defining the operation of the Flip-Flop. It specifies the next state $\left(Q_{n+1}\right)$ when the inputs and present state are known.

The excitation or application table is useful for design process. It is used to find the Flip-Flop input conditions that will cause the required transition, when the present state $\left(Q_{n}\right)$ and the next state $\left(\mathrm{Q}_{\mathrm{n}+1}\right)$ are known.

## SR Flip-Flop:

| Presen <br> $\mathbf{t}$ <br> State | Inputs | Next <br> State |  |
| :---: | :---: | :---: | :---: |
| $\mathbf{Q}$ | $\mathbf{S}$ | $\mathbf{R}$ | Qn+ <br> $\mathbf{1}$ |
| $\mathbf{n}$ | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | x |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | $x$ |

## Characteristic Table

| Presen <br> $\mathbf{t}$ <br> State | Next <br> State |  | Inputs |  |
| :---: | :---: | :---: | :---: | :---: |
| Qn | Qn+ <br> 1 | $\mathbf{S}$ | $R$ |  |
| 0 | 0 | 0 | x |  |
| 0 | 1 | 1 | 0 |  |
| 1 | 0 | 0 | 1 |  |
| 1 | 1 | x | 0 |  |

Excitation Table

The above table presents the excitation table for SR Flip-Flop. It consists of present state $\left(Q_{n}\right)$, next state $\left(Q_{n+1}\right)$ and a column for each input to show how the required transition is achieved.

There are 4 possible transitions from present state to next state. The required Input conditions for each of the four transitions are derived from the information available in the characteristic table. The symbol ' $x$ ' denotes the don't care condition, it does not matter whether the input is 0 or 1.

## JK Flip-Flop:

| Presen <br> $\mathbf{t}$ <br> State | Inputs |  | Next <br> State |
| :---: | :---: | :---: | :---: |
| $\mathbf{Q}$ <br> $\mathbf{n}$ | $\mathbf{J}$ | $\mathbf{K}$ | $\mathbf{Q n +}$ <br> $\mathbf{1}$ |
| 0 | 0 | 0 | 0 |
| $\mathbf{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 | 0 |

Characteristic Table

| Presen <br> $\mathbf{t}$ <br> State | Next <br> State | Inputs |  | Inputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{Q}$ <br> $\mathbf{n}$ | Qn+ <br> $\mathbf{1}$ | $\mathbf{J}$ | K | J | K |
| 0 | 0 | 0 | 0 | 0 | x |
| 0 | 0 | 0 | 1 |  |  |
| 0 | 1 | 1 | 0 | 1 | x |
| 0 | 1 | 1 | 1 |  |  |
| 1 | 0 | 0 | 1 | $x$ | 1 |
| 1 | 0 | 1 | 1 |  |  |
| 1 | 1 | 0 | 0 | $x$ | 0 |
| 1 | 1 | 1 | 0 |  |  |
|  |  |  |  |  |  |

Modified Table

| Presen <br> t <br> State | Next <br> State | Inputs |  |
| :---: | :---: | :---: | :---: |
| Qn | Qn+ <br> 1 | J | K |
| 0 | 0 | 0 | x |
| 0 | 1 | 1 | x |
| 1 | 0 | x | 1 |
| 1 | 1 | x | 0 |

## Excitation Table

## D Flip-Flop

| Presen <br> $\mathbf{t}$ | Inpu <br> $\mathbf{t}$ | Next <br> State |
| :---: | :---: | :---: |
| $\mathbf{Q}$ | $\mathbf{D}$ | $\mathbf{Q n + 1}$ |
| $\mathbf{n}$ |  |  |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Characteristic Table

| Presen <br> $\mathbf{t}$ <br> State | Next <br> State | Inpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: |
| Qn | Qn+ <br> $\mathbf{1}$ | $\mathbf{D}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Excitation Table

## T Flip-Flop

| Presen State | Inpu t | Next <br> State |
| :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{Q} \\ & \mathrm{n} \end{aligned}$ | T | $\begin{gathered} \mathrm{Qn}_{+} \\ 1 \end{gathered}$ |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 |  |  |
| Characteristic Table |  |  |


| Presen <br> $\mathbf{t}$ <br> State | Next <br> State | Inpu <br> $\mathbf{t}$ |
| :---: | :---: | :---: |
| $\mathbf{Q}$ | $\mathbf{Q n + 1}$ | $\mathbf{T}$ |
| $\mathbf{n}$ | 0 | 0 |
| 0 | 1 | 1 |
| 0 | 0 | 1 |
| 1 | 1 | 0 |
| $\mathbf{1}$ |  |  |

## Modified Table

## REALIZATION OF ONE FLIP-FLOP USING OTHER FLIP-FLOPS

It is possible to convert one Flip-Flop into another Flip-Flop with some additional gates or simply doing some extra connection. The realization of one Flip- Flop using other Flip-Flops is implemented by the use of characteristic tables and excitation tables. Let us see few conversions among Flip-Flops.

SR Flip-Flop to D Flip-
Flop SR Flip-Flop to JK
Flip-Flop SR Flip-Flop to
T Flip-Flop JK Flip-Flop
to T Flip-Flop JK Flip-
Flop to D Flip-Flop D
Flip-Flop to T Flip-Flop

W
T Flip-Flop to D Flip-Flop

## SR Flip-Flop to D Flip-Flop:

1. Write the characteristic table for required Flip-Flop (D Flip-Flop). $x$ Write the excitation table for given Flip-Flop (SR Flip-Flop).
2. Determine the expression for the given Flip-Flop inputs ( S and R ) by using K- map.
3. Draw the Flip-Flop conversion logic diagram to obtain the required Flip- Flop (D Flip-Flop) by using the above obtained expression. The excitation table for the above conversion is

| Required Flip-Flop (D) |  |  | Given Flip- <br> Flop <br> (SR) |  |
| :---: | :---: | :---: | :---: | :---: |
| Inpu <br> t | Present <br> state | Next <br> state | Flip-Flop Inputs |  |
| D | Qn | Qn+1 | S | R |
| 0 | 0 | 0 | 0 | $x$ |
| 0 | 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 1 | $x$ | 0 |
| K-map simplification |  | Logic diagram |  |  |

For S
For R

$\mathrm{S}=\mathrm{D}$

$\mathrm{R}=\overline{\mathrm{D}}$


CP

SR Flip-Flop to JK Flip-Flop
The excitation table for the above conversion is,

| Inputs |  | Present <br> state | Next <br> state | Flip- <br> Flop <br> Input |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{J}$ | $\mathbf{K}$ | $\mathbf{Q n}$ | Qn+1 | $\mathbf{S}$ | $\mathbf{R}$ |
| 0 | 0 | 0 | 0 | 0 | x |
| 0 | 0 | 1 | 1 | x | 0 |
| 0 | 1 | 0 | 0 | 0 | x |
| 0 | 1 | 1 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 1 | x | 0 |


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

K-map simplification
For $S$

| KQ ${ }_{\text {n }}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 0 | 0 | x | 0 | 0 |
| 1 | $1)$ | x | 0 | 1 |


| $\mathrm{K}_{\mathrm{n}}$ |  | For R |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
|  | 00 | 01 | 11 | 10 |
| 0 | x | 0 | 1 | x |
| 1 | 0 | 0 | 1 | 0 |

$\mathrm{S}=\mathrm{J} \overline{\mathrm{Q}}_{\mathrm{n}}$
$R=K Q_{n}$
Logic diagram


## SR Flip-Flop to T Flip-Flop

The excitation table for the above conversion is

| Inpu <br> $\mathbf{t}$ | Present <br> state | Next <br> state | Flip-Flop <br> Inputs |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{T}$ | $\mathbf{Q n}$ | $\mathbf{Q n + 1}$ | $\mathbf{S}$ | $\mathbf{R}$ |
| 0 | 0 | 0 | 0 | $x$ |
| 0 | 1 | 1 | $x$ | 0 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 0 | 1 |

K-map simplification


$$
\mathrm{S}=\mathrm{T} \overline{\mathrm{Q}}_{\mathrm{n}}
$$


$\mathrm{R}=\mathrm{T} \mathrm{Q}_{\mathrm{n}}$

Logic diagram


## JK Flip-Flop to T Flip-Flop

The excitation table for the above conversion is


K-map simplification
For J

$\mathrm{J}=\mathrm{T}$

$K=T$


## JK Flip-Flop to D Flip-Flop

The excitation table for the above conversion is

| In <br> pu <br> t | Present <br> state | Next <br> state | Flip- <br> Flop <br> Inputs |  |
| :---: | :---: | :---: | :---: | :---: |
| D | Qn | Qn+1 | J | K |
| 0 | 0 | 0 | 0 | $x$ |
| 0 | 1 | 0 | $x$ | 1 |
| 1 | 0 | 1 | 1 | $x$ |
| 1 | 1 | 1 | $x$ | 0 |

## WWW

K -map simplification



Logic diagram


## D Flip-Flop to T Flip-Flop

The excitation table for the above conversion is

## wWW. <br> binils s com

| Inp <br> ut | Present <br> state | Next <br> state | Flip- <br> Flop <br> Input |
| :---: | :---: | :---: | :---: |
| T | Qn | Qn+1 | D |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |

> K-map simplification

Logic diagram


## $\mathrm{D}=\overline{\mathrm{T}} \mathrm{Q}_{\mathrm{n}}+\mathrm{T} \overline{\mathrm{Q}}_{\mathrm{n}}$ <br> $=\mathrm{T} \oplus \mathrm{Q}_{\mathrm{n}}$ <br> WWW

## T Flip-Flop to D Flip-Flop

The excitation table for the above conversion is

| Inpu <br> $\mathbf{t}$ | Present <br> state | Next <br> state | Flip- <br> Flop <br> Input |
| :---: | :---: | :---: | :---: |
| $\mathbf{D}$ | Qn | Qn+1 | T |


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

K -map simplification


$$
\begin{aligned}
\mathrm{T} & =\mathrm{D} \overline{\mathrm{Q}}_{\mathrm{n}}+\overline{\mathrm{D}} \mathrm{Q}_{\mathrm{n}} \\
& =\mathrm{D} \oplus \mathrm{Q}_{\mathrm{n}}
\end{aligned}
$$

Logic diagram


## WWW.binis


[^0]:    K-map Simplification:

