# **Electronics Engineering**

# **Advanced Electronics**

Comprehensive Theory with Solved Examples and Practice Questions





#### **MADE EASY Publications**

Corporate Office: 44-A/4, Kalu Sarai (Near Hauz Khas Metro Station), New Delhi-110016

E-mail: infomep@madeeasy.in Contact: 011-45124660, 8860378007

Visit us at: www.madeeasypublications.org

## **Advanced Electronics**

© Copyright, by MADE EASY Publications.

All rights are reserved. No part of this publication may be reproduced, stored in or introduced into a retrieval system, or transmitted in any form or by any means (electronic, mechanical, photo-copying, recording or otherwise), without the prior written permission of the above mentioned publisher of this book.

First Edition: 2017 Second Edition: 2018 Third Edition: 2019 Fourth Edition: 2020

# **Contents**

# **Advanced Electronics**

| Ch   | apter 1                                    | Cl       | napter 4                                       |                |
|------|--------------------------------------------|----------|------------------------------------------------|----------------|
| Inte | egrated Circuits Fabrication               | VL       | .SI Testing                                    | 48             |
|      | :hnology1                                  | 4.1      | Stages of Testing                              | 48             |
|      |                                            | 4.2      | Importance of Testing                          | 48             |
| 1.1  | Crystal Growth1                            | 4.3      | Testing During the VLSI Life Cycle             | 49             |
| 1.2  | Doping and Impurities2                     | 4.4      | Challenges in VLSI Testing                     | 50             |
| 1.3  | Growth and Deposition of Dielectric Films8 | 4.5      | Test Principles                                | 50             |
| 1.4  | Masking and Photolithography9              | 4.6      | Design for Testability (DFT)                   | 53             |
|      |                                            | 4.7      | Design Economics                               | 59             |
| 1.5  | Metallization10                            | 4.8      | Yield and Reject Rate                          | 59             |
| 1.6  | Technological Advantages of Silicon11      |          | Student's Assignments                          | 6 <sup>2</sup> |
|      | Student's Assignments12                    |          |                                                |                |
| Ch   | apter 2                                    | Cl       | napter 5                                       |                |
| VLS  | SI Design14                                | Sy<br>Se | nthesis of Synchronous quential Circuits       | 62             |
| 2.1  | Chip Developing Process14                  | 5.1      | Finite State Machine (FSM)                     | 62             |
| 2.2  | VLSI Circuit Design Process14              |          | Design of a Sequential Circuit or Finite State |                |
| 2.3  | Design Flow17                              |          | Student's Assignments                          |                |
| 2.4  | Design Styles22                            |          | Statent's Assignments                          |                |
|      | Student's Assignments25                    | Cl       | napter 6                                       |                |
| Ch   | apter 3                                    |          | ogrammable Logic Devices                       |                |
| Pin  | elining27                                  | an       | d Memories                                     | 97             |
| -    |                                            | 6.1      | Programmable Logic Devices                     | 98             |
|      | Instruction Pipeline28                     | 6.2      | Semiconductor Memories                         | 11             |
|      | Pipeline Hazards                           |          | Student's Assignments                          |                |
|      | ·                                          |          | Jiuuchi s Assigninenis                         | 110            |
|      | Pipeline Performance Analysis              |          |                                                |                |
| 3.5  | Arithmetic Pipeline39                      |          |                                                |                |

Student's Assignments ......46

CHAPTER 5

# Synthesis of Synchronous Sequential Circuits

# Introduction

## State Diagram (State graph)

It is a pictorial representation of the relationships between the present state, the input, the next state and the output of a sequential circuit, i.e. the state diagram is a pictorial representation of the behaviour of a sequential circuit.

## State table

The state table is a tabular representation of the state diagram. Even though the behaviour of a sequential circuit can be conveniently described using a state diagram, for its implementation the information of the state diagram is to be translated into a state table. Both the state diagram and the state table contain the same information.

# **5.1** Finite State Machine (FSM)

- Finite state machines are sequential circuits whose past histories can affect their future behaviour in only a finite number of ways, i.e. they are machines with a fixed number of states.
- A sequential circuit is referred to as a finite state machine (FSM).
- Finite state machines are of two types. They differ in the way the output is generated. They are
  - 1. Mealy type model 2. Moore type model

# 5.1.1 Mealy Machine

In this model, the output depends on both the present state of the circuit and the present inputs.

NS = F(PS, X)

Output = G(PS, X)

F and G are some logic functions.

PS = Present state

NS = Next state

X =Present inputs

Input changes may affect the output of the logic circuit.



It requires less number of states for implementing a function than that of Moore model.



State diagram and state table for a Mealy circuit are given below.



| <b>DO</b> | NS output |       |  |  |
|-----------|-----------|-------|--|--|
| PS        | X = 0     | X = 1 |  |  |
| а         | a, 0      | b, 1  |  |  |
| b         | b, 1      | c, 0  |  |  |
| С         | d, 0      | c, 1  |  |  |
| d         | d, 0      | a, 1  |  |  |

State diagram

Stable table



X =Input and Y =Output

In the Mealy model, the output depends on the present input. Hence both input, output are represented on the directed lines.

#### 5.1.2 **Moore Machine**

In this model, the output depends only on the present state of the circuit.

$$NS = F(PS, X)$$
  
Output =  $G(PS)$ 

F and G are some logic functions.

PS = Present state

NS = Next state

X =Present inputs

Input changes do not affect the output of the logic circuit.

It requires more number of states for implementing a function than that of Mealy model.





State diagram and state table for a Moore circuit are given below.



|    | NS Input |       | Present |
|----|----------|-------|---------|
| PS | X = 0    | X = 1 | output  |
| а  | а        | b     | 0       |
| b  | b        | С     | 0       |
| С  | d        | С     | 1       |
| d  | а        | d     | 0       |

State diagram

State table





In the Moore model, the output depends only on the present state of the circuit and it is independent of the input applied. Hence, the present output is represented inside the circle belongs to the present state and input is represented on the directed line.

# Example - 5.1

Draw the equivalent Moore state diagram for the following Mealy state diagram.



## **Solution:**

In a Moore state diagram, each state is associated with a fixed output.

States for the Moore state diagram, corresponding to the given Mealy state diagram, can be assigned as shown below.

| Mealy State      | Equivalent Moore State |
|------------------|------------------------|
| a, with output 0 | a <sub>0</sub>         |
| a, with output 1 | a <sub>1</sub>         |
| b, with output 0 | $b_0$                  |
| b, with output 1 | <i>b</i> <sub>1</sub>  |
| c, with output 0 | $c_0$                  |

In the given Mealy state diagram, there no transition that produces next state as "c" with output "1". Hence, there is no need a state equivalent to "c" with output "1", i.e.  $c_1$  in Moore model.



The state table and state diagram of the required Moore model can be given as,

| Present state         | Next state (output)       |                           |  |  |
|-----------------------|---------------------------|---------------------------|--|--|
| Fresent state         | X = 0                     | X = 1                     |  |  |
| a <sub>0</sub>        | a <sub>0</sub> (0)        | <i>b</i> <sub>0</sub> (0) |  |  |
| a <sub>1</sub>        | a <sub>0</sub> (0)        | <i>b</i> <sub>0</sub> (0) |  |  |
| $b_0$                 | <i>b</i> <sub>1</sub> (1) | c <sub>0</sub> (0)        |  |  |
| <i>b</i> <sub>1</sub> | b <sub>1</sub> (1)        | c <sub>0</sub> (0)        |  |  |
| $c_0$                 | b <sub>0</sub> (0)        | a <sub>1</sub> (1)        |  |  |



State table

State diagram

#### Example - 5.2

Draw the equivalent Mealy state diagram for the following Moore state diagram.



#### **Solution:**

Same state notations can be followed in the corresponding Mealy state diagram of the given Moore state diagram.

The state table and state diagram of the required Mealy model can be given as,

| Present state | Next  | state | Output |       |
|---------------|-------|-------|--------|-------|
| Fresent state | X = 0 | X = 1 | X = 0  | X = 1 |
| а             | а     | ь     | 0      | 1     |
| b             | b     | d     | 1      | 1     |
| С             | а     | b     | 0      | 1     |
| d             | С     | а     | 0      | 0     |

State table



State diagram

## **State Reduction**

- The state reduction technique basically avoids the introduction of redundant states.
- The reduction in redundant states reduces the number of flip-flops and logic gates, reducing the cost of the final circuit.
- Two states are said to be equivalent if every possible set of inputs generate exactly the same output and the same next state.
- When two state are equivalent, one of them can be removed without altering the input-output relationship.
- Let us illustrate the reduction technique with an example.





#### Develop a state diagram for the logic circuit shown in the figure below. Example - 5.3



#### **Solution:**

 $T_1 = X \text{ and } T_0 = Q_1 X$ Excitations of the flip flops are,  $Y = Q_1Q_0 \Rightarrow$  Moore circuit Output signal,

The state table and state diagram of the given sequential circuit can be developed as shown below.

| Present state  |       | Input | Excitations           |       | Next state                  |         | Output |
|----------------|-------|-------|-----------------------|-------|-----------------------------|---------|--------|
| Q <sub>1</sub> | $Q_0$ | X     | <i>T</i> <sub>1</sub> | $T_0$ | Q <sub>1</sub> <sup>+</sup> | $Q_0^+$ | Υ      |
| 0              | 0     | 0     | 0                     | 0     | 0                           | 0       | 0      |
| 0              | 0     | 1     | 1                     | 0     | 1                           | 0       | 0      |
| 0              | 1     | 0     | 0                     | 0     | 0                           | 1       | 0      |
| 0              | 1     | 1     | 1                     | 0     | 1                           | 1       | 1      |
| 1              | 0     | 0     | 0                     | 0     | 1                           | 0       | 0      |
| 1              | 0     | 1     | 1                     | 1     | 0                           | 1       | 0      |
| 1              | 1     | 0     | 0                     | 0     | 1                           | 1       | 1      |
| 1              | 1     | 1     | 1                     | 1     | 0                           | 0       | 0      |



# Example - 5.4

# Reduce the following state diagram:



# **Solution:**

The state table of the given state diagram is,

| -  | N     |       | Out   | tput  |
|----|-------|-------|-------|-------|
| PS | X = 0 | X = 1 | X = 0 | X = 1 |
| а  | b     | d     | 0     | 1     |
| b  | е     | f     | 0     | 1     |
| С  | b     | d     | 0     | 1     |
| d  | е     | b     | 0     | 1     |
| е  | е     | f     | 0     | 1     |
| f  | f     | С     | 0     | 0     |



"b" and "e" are said to be equivalent states. So, remove "e" and replace it with "b".

"a" and "c" are said to be equivalent states. So, remove "c" and replace it with "a".

So, the reduced state table is,

|    | _NS_  |              | Out   | tput         |
|----|-------|--------------|-------|--------------|
| PS | X = 0 | <i>X</i> = 1 | X = 0 | <i>X</i> = 1 |
| а  | b     | d            | 0     | 1            |
| b  | b     | f            | 0     | 1            |
| d  | b     | b            | 0     | 1            |
| f  | f     | а            | 0     | 0            |

No further equivalent states are found. So, it is not possible to reduce further.

Now, the reduced state diagram can be drawn from the reduced state table as shown below:



# Example - 5.5

# Reduce the following state diagram:



# **Solution:**

The state table of the given state diagram is,

|    | N     | S     | Out   | put   |
|----|-------|-------|-------|-------|
| PS | X = 0 | X = 1 | X = 0 | X = 1 |
| а  | С     | b     | 1     | 1     |
| b  | d     | С     | 0     | 0     |
| С  | g     | d     | 0     | 1     |
| d  | е     | f     | 1     | 0     |
| е  | а     | f     | 1     | 0     |
| f  | g     | f     | 1     | 0     |
| g  | а     | f     | 1     | 0     |

"g" and "e" are said to be equivalent states. So, remove "g" and replace it with "e".



The reduced state table is,

| PS | $\frac{NS}{X=0  X=1}$ |   | X = 0 | tput<br>X = 1 |
|----|-----------------------|---|-------|---------------|
| а  | С                     | b | 1     | 1             |
| b  | d                     | С | 0     | 0             |
| С  | е                     | d | 0     | 1             |
| d  | е                     | f | 1     | 0             |
| е  | а                     | f | 1     | 0             |
| f  | е                     | f | 1     | 0             |

"e" and "f" are said to be equivalent states. So, remove "f" and replace it with "e".

The reduced state table is,

| PS | X = 0  X = 1 |   | X = 0 |   |  |  |  |  |
|----|--------------|---|-------|---|--|--|--|--|
| а  | С            | b | 1     | 1 |  |  |  |  |
| b  | d            | С | 0     | 0 |  |  |  |  |
| С  | е            | d | 0     | 1 |  |  |  |  |
| d  | е            | d | 1     | 0 |  |  |  |  |
| е  | а            | d | 1     | 0 |  |  |  |  |

No further reduction is possible, hence the reduced state diagram is as shown below:



# Example - 5.6

Reduce the following state diagram:





#### **Solution:**

The state table of the state diagram can be given as follows:

| Present | Next State |       | Out |       |     |
|---------|------------|-------|-----|-------|-----|
| State   | X=0        | X = 1 | X=0 | X = 1 |     |
| а       | а          | b     | 0   | 0     | X = |
| [ b     | С          | d     | 0   | 1     |     |
| [ c     | С          | d     | 0   | 1]    |     |
| d       | а          | е     | 1   | 0     |     |
| е       | а          | f     | 1   | 0     |     |
| f       | а          | f     | 1   | 0     |     |

Input

States "b" and "c" have same next state and output for a given value of input. So, these two states are said to be equal and we can replace the state "c" with state "b".

States "e" and "f" have same next state and output for a given value of input. So, these two states are said to be equal and we can replace the state "f" with state "e".

After replacing states "c" and "f" with states "b" and "e" respectively, the resultant state table is as follows:

| Present | Next      | State | Out |       |
|---------|-----------|-------|-----|-------|
| State   | X=0 $X=1$ |       | X=0 | X = 1 |
| а       | а         | b     | 0   | 0     |
| b       | b         | d     | 0   | 1     |
| d       | а         | е     | 1   | 0     |
| е       | а         | е     | 1   | 0     |

States "d" and "e" have same next state and output for a given value of input. So, these two states are said to be equal and we can replace the state "e" with state "d".

After replacing state "e" with state "d", the resultant state table is as follows:

| Present | Next  | State | Out |       |
|---------|-------|-------|-----|-------|
| State   | X = 0 | X=1   | X=0 | X = 1 |
| а       | а     | b     | 0   | 0     |
| b       | b     | d     | 0   | 1     |
| d       | а     | d     | 1   | 0     |

- In the above state table, no two states have same next state and output for a given value of input. Hence there are no equal states and it is not possible to reduce the state table further.
- From the above table, the reduced state diagram of the given state diagram can be drawn as follows:





Example - 5.7

Reduce the following state diagram:



#### **Solution:**

- Let us assume that, the input variable of the circuit as "X" and the output variable of the circuit as "Z".
- The stable table for the given mealy type state diagram is as given below:

| Present | Next  | State | Output (z) |       |
|---------|-------|-------|------------|-------|
| State   | X = 0 | X = 1 | X = 0      | X = 1 |
| а       | а     | b     | 0          | 1     |
| b       | С     | f     | 1          | 0     |
| С       | С     | f     | 0          | 1     |
| d       | а     | b     | 0          | 1     |
| е       | d     | b     | 0          | 1     |
| f       | d     | е     | 1          | 0     |

For states "a" and "d", next state and output are same for an applied input. Hence, states "a" and "d" are said to be equal and the state "d" can be replaced with state "a".

• After replacing state "d" with state "a", the resultant state table is as given below:

| Present | Next  | State | Output (z) |       |  |
|---------|-------|-------|------------|-------|--|
| State   | X = 0 | X = 1 | X = 0      | X = 1 |  |
| а       | а     | b     | 0          | 1     |  |
| b       | С     | f     | 1          | 0     |  |
| С       | С     | f     | 0          | 1     |  |
| е       | а     | b     | 0          | 1     |  |
| f       | а     | е     | 1          | 0     |  |

For states "a" and "e", next state and output are same for an applied input. Hence, states "a" and "e" are said to be equal and the state "e" can be replaced with state "a".

After replacing state "e" with state "a", the resultant state table is as given below:

| Present | Next  | State | Output (z) |       |  |
|---------|-------|-------|------------|-------|--|
| State   | X = 0 | X = 1 | X = 0      | X = 1 |  |
| а       | а     | b     | 0          | 1     |  |
| b       | С     | f     | 1          | 0     |  |
| С       | С     | f     | 0          | 1     |  |
| f       | а     | а     | 1          | 0     |  |

In the above state table, no two states have same next state and output for an applied input. Hence, it is not possible to reduce the state table further.

• So, the corresponding reduced state diagram is as given below:



## **State Assignment**

The process of assigning binary values to the states of the sequential machine is known as "state assignment". The binary values are to be assigned to the states in such a way that it is possible to implement flip-flop input functions using minimum logic gates. The output values of the memory devices are referred to as state variable.

Here in our discussion memory elements are nothing but flip-flops. So, the output of a flip-flop is known as a state variable of the finite state machine. Follow some basic rules while assigning the binary values to the states.

- 1.  $N \le 2^n \Rightarrow N =$  Number of unique states of the system n = Number of state variables (or) number of flip-flops required
- 2. States having the same NEXT STATE for a given input condition should have assignments which can be grouped into logically adjacent cells in a *K*-map.
- 3. 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.
- 4. Resultant binary states must be unique.

# **Transition and Output Table**

- The transition and output table can be obtained from the state table by modifying the entries of the state table to correspond to the states of the machine in accordance with the selected state assignment.
- In this table, the next state and output entries are separated into two sections.
- The next state part of the state table is called the transition table.

## **Excitation Table**

- The excitation table of a sequential machine gives information about the excitations (or) inputs required to be applied to the memory elements (flip-flops) in the sequential circuit to bring the sequential machine from the present state to the next state.
- It also gives information about the outputs of the machine after application of the present inputs.

Example - 5.8 Assign binary values to the states, write transition and output table, excitation table (with *D*-FFs) and obtain the minimal expressions for the state diagram shown below.



| -  | N     | S_           | Out   | <del></del> |
|----|-------|--------------|-------|-------------|
| PS | X = 0 | <i>X</i> = 1 | X = 0 | X = 1       |
| а  | а     | b            | 0     | 0           |
| b  | С     | b            | 0     | 1           |
| С  | С     | а            | 1     | 1           |



#### **Solution:**

## State assignment:

3 unique states  $(a, b, c) \Rightarrow$  So, two states variable (or) two flip-flops are required.

 $a \rightarrow 00$ 

 $b \rightarrow 01$  randomly assigned three unique binary states.

 $c \rightarrow 10$ 

# Transition and output table:

|     |                    | N     | S            | Output (f) |       |  |
|-----|--------------------|-------|--------------|------------|-------|--|
|     | PS                 | X = 0 | <i>X</i> = 1 | X = 0      | X = 1 |  |
| a — | <del>&gt;</del> 00 | 00    | 01           | 0          | 0     |  |
| b — | <del></del> 01     | 10    | 01           | 0          | 1     |  |
| c — | <del>-</del> 10    | 10    | 00           | 1          | 1     |  |

#### **Excitation table:**

|   | PS    |       |   | N              | S     |                       |       | F        |
|---|-------|-------|---|----------------|-------|-----------------------|-------|----------|
|   | $Q_1$ | $Q_0$ | X | Q <sub>1</sub> | $Q_0$ | <i>D</i> <sub>1</sub> | $D_2$ | (output) |
|   | 0     | 0     | 0 | 0              | 0     | 0                     | 0     | 0        |
|   | 0     | 0     | 1 | 0              | 1     | 0                     | 1     | 0        |
|   | 0     | 1     | 0 | 1              | 0     | 1                     | 0     | 0        |
|   | 0     | 1     | 1 | 0              | 1     | 0                     | 1     | 1        |
| ſ | 1     | 0     | 0 | 1              | 0     | 1                     | 0     | 1        |
|   | 1     | 0     | 1 | 0              | 0     | 0                     | 1     | 1        |

 $Q_1$ ,  $Q_0$  are called as state variables which are the outputs of the flip-flops.

#### Minimization:



# 5.2 Design of a Sequential Circuit or Finite State Machine

- Step 1: State the purpose of the machine in simple words.
- Step 2: Draw the state diagram which gives the complete information about the circuit working.
- Step 3: Write the state table for the state diagram obtained in step-2.
- Step 4: Convert the state table into reduced standard form state table by removing the redundant states.
- Step 5: Assign the binary values to the states (state assignment).
- Step 6: Write the transition and output table.
- **Step 7**: Choose the type of flip-flops and form the excitation table.
- **Step 8**: Obtain the minimal expressions flip-flops and the output (based on the contents of the excitation table) using K-maps.
- **Step 9**: Draw the logic diagram using minimal expression obtained in the step 9.

