# INSTITUTE OF AERONAUTICAL ENGINEERING

(Autonomous)



Dundigal, Hyderabad - 500043

# **COURSE CONTENT**

# ANALOG AND DIGITAL ELECTRONICS LABORATORY

| <b>IV Semester: EEE</b>                                       |                                                                               |   |           |      |         |      |        |       |
|---------------------------------------------------------------|-------------------------------------------------------------------------------|---|-----------|------|---------|------|--------|-------|
| Course Code                                                   | Category                                                                      | E | Iours / V | Veek | Credits | Maxi | imum M | larks |
| 4 ECC17                                                       | Core                                                                          | L | Т         | Р    | С       | CIA  | SEE    | Total |
| AECC17                                                        |                                                                               | 0 | 0         | 2    | 1       | 30   | 70     | 100   |
| Contact Classes: Nil                                          | Tutorial Classes: Nil         Practical Classes: 45         Total Classes: 45 |   |           |      |         |      |        |       |
| Prerequisite: Electrical Circuits Linear Algebra and Calculus |                                                                               |   |           |      |         |      |        |       |

## **I. COURSE OVERVIEW:**

This is the main lab where experiments like load test on various machines, speed control tests, open circuit tests, short circuit tests, etc are carried out. And also wide variety of practical experiments are performed here with combination of different rotating machines. The laboratory is also used for research activities in machines and to carry out project works on energy conversion.

## **II. COURSE OBJECTIVES:**

### The students will try to learn:

- I. The characteristics and applications of diodes.
- II. The characteristics of transistor in different configurations.
- III. The function and applications of gates.
- IV. The different combinational circuits.

## **III. COURSE OUTCOMES:**

After successful completion of the course, students should be able to:

- Apply the PN junction characteristics for the diode applications such as half wave and full wave **CO1** rectifier
- Apply the volt-ampere characteristics of PN junction diode, Zener diode for finding cut-in voltage, **CO2** static and dynamic resistance.
- Analyze the input and output characteristics of transistor configurations for determining the input-CO3 output resistances.
- Identify the functionality of Boolean expressions using gates such as and, or, not, nand, nor, xor and **CO4** xnor.
- Build combinational circuits such as adder, subtractor, multiplexers and comparators realization using **CO5** low level elementary blocks.
- CO6 Construct shift registers using the functionality of the flip flops.

# **IV. COURSE CONTENT:**

# **EXERCISES FOR ANALOG AND DIGITAL ELECTRONICS LABORATORY**

**Note:** Students are encouraged to bring their own laptops for laboratory practice session

# Introduction

This laboratory course enables students to get practical experience on analog and digital electronics circuits. Analog components and circuits like p-n junction diode, Zener diode etc. and digital electronics exercises like logic gates, adders and substractors, flip flops, counters etc. Simulation packages preferred are vivado software, Multisim etc. Analog Electronics is one of the fundamental courses found in all Electrical Engineering and most science programs. Analog circuit's process signals with continuous variation of voltage.

- The different Components that are normally used in Analog Electronics are:
- 1. Bi polar Junction Transistors
- 2. MOSFET's
- 3. OP-AMP

# **1. Getting Started Exercises**

The semi-conductor diode is created by simply joining an n-type and a p-type material together nothing more just the joining of one material with a majority carrier of electrons to one with a majority carrier of holes.

# 1.1 Determine the V-I characteristics of forward Bias and Reverse Bias P-N junction diode as shown in fig 1 and 2 and draw the V-I Characteristics.



Fig 1. Forward Bias P-N Junction diode



Fig 2. Reverse Bias P-N Junction diode

1.2 A diode connected to an external resistance and an e.m.f. assuming that the barrier potential developed in diode is 0.5V as shown in the fig1.3. Obtain the value of current in the circuit in milli- ampere as shown in the fig.3.



Fig 3. Barrier potential in diode

1.3 The diode used in the circuit shown in the fig.4 has a constant voltage drop of 0.5 V at all current and a maximum power rating of 100 milliwatts. What should be the value of the resistor R, connected in series with the diode for obtaining maximum current?



**Fig 4 Diode Circuit** 

# Try

- 1. Plot the V-I Characteristics of germanium diode and find the cut in voltage.
- 2. Using ua 741 Opamp, design a 1 kHz Relaxation Oscillator with 50% duty cycle. And simulate the same.

# 2.0 Introduction

A Zener diode when reverse biased can either undergo avalanche break down or zener break down. Avalanche break down: If both p-side and n-side of the diode are lightly doped, depletion region at the junction widens. Application of a very large electric field at the junction may rupture covalent bonding between electrons. Such rupture leads to the generation of a large number of charge carriers resulting in avalanche multiplication.

# 2.1 Examine the forward and reverse biased Characteristics Zener Diode as shown in the fig 5 and 6



Fig 5 Zener diode forward biased



Fig 6 Zener diode reverse biased

2.2 Examine the Characteristics of voltage regulator using hardware shown in fig 7.



Fig 7 Voltage Regulator

# 2.3 Design a zener voltage regulator circuit to drive a load of 6V,100 mW from an unregulated input supply of Vmin = 8V, Vmax =12V using a 6V zener diode.

Try

- 1. Find the maximum zener current for the zener diode, Given,  $V_Z$ =6V,  $R_Z$ =1.5 $\Omega$ , R=400 $\Omega$
- 2. The potential of the battery is varied from 10V to 16V. If by zener diode breakdown voltage is 6V, find maximum current through zener diode.

# 3. Introduction

Half-wave rectifier1is an electronic circuit that converts only one-half of the AC cycle into pulsating DC. It uses only half of the AC cycle for the conversion process. Full-wave rectifier is an electronic circuit that converts the entire cycle of AC into pulsating DC. It has two diodes, and its output uses both halves of the AC signal. During the period that one diode blocks the current flow, the other diode conducts and allows the current. Both

half-wave and full-wave rectifiers have their merits and demerits.

3.1 Verification of Half wave rectifier without filters using hardware shown in fig 8 and draw the waveforms.



Fig 8. Half wave rectifier without filter

3.2 Verification of Half wave rectifier with filters using hardware shown in fig 9 and draw the waveforms.



Fig 9. Half wave rectifier with filter

3.3 Verification of Full wave rectifier without filters using hardware shown in fig 10 and draw the waveforms.



Fig 10 Full wave rectifier without filter

3.4 Verification of Full wave rectifier with filters using hardware shown in fig 11 and draw the waveforms.



Fig 11 Full wave rectifier with filter

- 1. Design and verify bridge rectifier with and without filter
- 2. Design and verify precision rectifier

# 4. Introduction

Bipolar junction transistor (BJT) is a 3 terminal (emitter, base, collector) semiconductor device. There are two types of transistors namely NPN and PNP. It consists of two P-N junctions namely emitter junction and collector junction. In Common Emitter configuration the input is applied between base and emitter and the output is taken from collector and emitter. Here emitter is common to both input and output and hence the name common emitter configuration.

# 4.1 Verification of input and output characteristics of CE Configuration using hardware shown in fig 12 and draw the Waveforms.



Fig 12. CE configuration

# 4.2 Verification of input and output characteristics of CE Configuration using hardware shown in Fig 13 and draw the Waveforms



Fig 13 Circuit Diagram for transistor as common base configuration

# Try

- 1. Determine the Gain and Bandwidth of CE (Common Emitter) amplifier using hardware.
- 2. Obtain Drain characteristics and Transfer characteristics of FET.

# 5.Introduction

AND, OR and NOT gates are basic gates. NAND and NOR are universal gates. Basically logic gates are electronic circuits because they are made up of number of electronic devices and components. Inputs and outputs of logic gates can occur only in two levels. These two levels are term HIGH and LOW, or TRUE and FALSE, or ON AND off, OR SIMPLY 1 AND 0. A table which lists all possible combinations of input variables and the corresponding outputs is called a "truth table". It shows how the logic circuit"s output responds to various combinations of logic levels at the inputs.

# 5.1 Basic Gates

- 1. Install Xilinx vivado on your machine.
- 2. Write a VHDL program using vivado simulator for:
  - Verifying the functionality of design under test (DUT) by writing test bench to pass the stimulus
  - o Synthesize the register transfer logic (RTL) using Xilinx XST synthesis tool
  - Elaborate the design and generate bit file to dump RTL code into the zynq series and Zboard FPGA
  - $\circ$  Verify the functionality of the design under test (DUT) on FPGA board

# 5.2 AND-OR-INVERT AND OR-AND-INVERT LOGIC

Write VHDL code to implement the function expressed by the following logic equation

$$Y = \overline{a_0 b_0 + a_1 b_1 + a_2 b_2}$$

Use only simple signal assignment statements in your VHDL data flow model.

## Hints

Use and, or and compliment operators for implementation of the logic.

```
entity tb_AOI port
end tb_AOI;
architecture arch_AOI of AOI is
   signal a0, a1, a2, a3, b0, b1, b2, b3: std_logic := '0';
   signal y: std_logic;
   component AOI port (
         a0, a1, a2, a3, b0, b1, b2, b3: in std_logic;
         y: out std_logic);
   end component;
begin
   DUT: AOI port map (a0, a1, a2, a3, b0, b1, b2, b3, y);
   a0 = '0'; b0 = '0';
   a1 = '0'; b1 = '0';
   a2 = '0'; b2 = '0';
   a3 = '0'; b3 = '0';
   wait for 10 ns;
   a0 = '0'; b0 = '1';
   a1 = '1'; b1 = '0';
a2 = '0'; b2 = '1';
   a3 = '1'; b3 = '0';
   wait for 10 ns;
  . . .
   . . .
   a0 = '1'; b0 = '1';
   a1 = '1'; b1 = '1';
   a2 = '1'; b2 = '1';
   a3 = '1'; b3 = '1';
   wait for 10 ns;
End architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

1. Develop a model for a general or- and-invert gate, with two std\_logic\_vector input ports a and b and a standard-logic output port y.

### **5.3** Product of Sum Boolean expression

Write a program to perform product of sum which evaluates the given Boolean expressions and write the test-bench to verify the functionality with all possible combinations of the input. **Hints** 

```
/**
* Consider the POS expression for F = \pi(0, 1, 2, 4, 8, 9, 10, 12, 13)
                                                                   */
Input a, b, c, d;
Output F;
Minimize the logic for the given F
                                           // POS logic
Implement the logic using basic gates
/** Declare the port signals */
entity POS port (
         a, b, c, d: in std_logic;
         f: out std_logic);
end POS;
/** architecture body */
architecture arch_POS of POS is
Begin
   Y = F(a, b, c, d);
    . . .
End arch_POS;
//Write the test bench for providing the stumulus
entity tb_POS port
end tb_POS;
architecture arch POS of POS is
   signal a, b, c, d: std_logic := '0';
   signal f: std_logic;
   component POS port (
         a, b, c, d: in std_logic;
         f: out std_logic);
   end component;
begin
   DUT: POS port map (a, b, c, d, f);
   a = '0'; b = '0'; c = '0'; d = '0';
   wait 10 ns;
   a = '0'; b ='0'; c = '0'; d ='1';
  wait 10 ns;
   • • •
   . . .
```

a = '1'; b ='1'; c = '1'; d ='1'; wait 10 ns;

End architecture

Provide the stimulus for all 16 possible combinations starting from 0000 to 1111 Simulate the DUT with the given stimulus Verify the output using waveforms Synthesize the design Elaborate the design and dump the bit file into FPGA

#### Try

1. Modify the POS expression including the don't care cases  $F = \pi(0, 1, 2, 4, 9, 10, 12, 13) + d(3, 7, 11)$ 

### 5.4 Sum of Product Boolean expression

Write a program to perform sum of product which evaluates the given Boolean expressions and write

the test-bench to verify the functionality with all possible combinations of the input.

```
/**
* Consider the POS expression for F = \Sigma(0, 1, 2, 4, 8, 9, 10, 12, 13)
                                                                 */
Input a, b, c, d;
Output F;
Minimize the logic for the given F // POS logic
Implement the logic using basic gates
/** Declare the port signals */
entity SOP port (
         a, b, c, d: in std_logic;
         f: out std_logic);
end SOP;
/**
     architecture body */
architecture arch_SOP of SOP is
Begin
   Y = F(a, b, c, d);
    . . .
End arch SOP;
//Write the test bench for providing the stumulus
entity tb_SOP port
end tb_SOP;
architecture arch_SOP of SOP is
   signal a, b, c, d: std_logic := '0';
   signal f: std_logic;
  component SOP port (
```

```
a, b, c, d: in std_logic;
f: out std_logic);
end component;
begin
DUT: SOP port map (a, b, c, d, f);
a = '0'; b ='0'; c = '0'; d ='0';
wait 10 ns;
a = '0'; b ='0'; c = '0'; d ='1';
wait 10 ns;
...
a = '1'; b ='1'; c = '1'; d ='1';
wait 10 ns;
End architecture
Simulate the DUT with the given stimulus
```

Verify the output using waveforms

Synthesize the design

Elaborate the design and dump the bit file into FPGA

## Try

1. Modify the POS expression including the don't care conditions  $F = \Sigma(0, 1, 2, 4, 9, 10, 12, 13) + d(3, 7, 11)$ 

# **5.5** Code Conversions

To familiarize students with code converters. The student should also become familiar with gray to binary conversion, binary to gray conversion.

Given the sequence of three-bit Gray code as (000, 001, 011, 010, 110, 111, 101, 100)

A given Gray code number can be converted into its binary equivalent by going through the following steps:

- 1. Begin with the most significant bit (MSB). The MSB of the binary number is the same as the MSB of the Gray code number.
- 2. The bit next to the MSB (the second MSB) in the binary number is obtained by adding the MSB in the binary number to the second MSB in the Gray code number and disregarding the carry, if any.
- 3. The third MSB in the binary number is obtained by adding the second MSB in the binary number to the third MSB in the Gray code number. Again, carry, if any, is to be ignored.
- 4. The process continues until we obtain the LSB of the binary number.

```
/** Declare the port signals */
entity gray2binary port (
    gray_code: in std_logic_vector(3 downto 0);
```

```
binary code: out std logic vector(3 downto 0));
end gray2binary;
/** architecturebody
                       */
architecture arch_gray2binary of gray2binary is
Begin
    binary code[3] = gray code[3];
    binary_code[2] = gray_code[3] xor gray_code[2];
    . . .
End arch_gray2binary;
//Write the test bench for providing the stumulus
entity tb_gray2binary port
end tb_gray2binary;
architecture arch_gray2binary of gray2binary is
   signal gray_code: std_logic_vector(3 downto 0) := "0000";
   signal binary_code: std_logic_vector(3 downto 0);
   component gray2binary port (
         gray_code: in std_logic_vector(3 downto 0);
         binary_code: out std_logic_vector(3 downto 0));
   end component;
begin
  DUT: gray2binary port map (gray_code, binary_code);
   Process
   begin
        gray_code = gray_code + 1;
        Wait for 10 ns;
   End process;
End architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

- 1. Design and implement the binary to gray code conversion
- 2. Design and implement the binary to excess 3-code conversion
- 3. Design and implement the excess 3-code to binary conversion

# 6. Introduction

NAND gate is universal gate. It can perform all the basic logic function. NAND means NOT AND that is, AND output is NOTed.so NAND gate is combination of an AND gate and a NOT gate. The output is logic 0 level, only when each of its inputs assumes a logic 1 level. For any other combination of inputs, the output is logic 1 level. NAND gate is equivalent to a bubbled OR gate.

NOR gate is universal gate. It can perform all the basic logic function. NOR means NOT OR that is, OR output is NOTed.so NOR gate is combination of an OR gate and a NOT gate. The output is logic 1 level, only when each of its inputs assumes a logic 0 level. For any other combination of inputs, the output is logic 0 level. NOR gate is equivalent to a bubbled AND gate.

# 6.1 Basic gates realization using NAND gate

Realize the inverter gate logic using NAND gate.

NAND gate is actually a combination of two logic gates i.e. AND gate followed by NOT gate. So its output is complement of the output of an AND gate. This gate can have minimum two inputs. By using only NAND gates, we can realize all logic functions: AND, OR, NOT, Ex-OR, Ex-NOR, NOR. So this gate is also called as universal gate.

## Hint

```
/** Declare the port signals */
entity inv_nand port (
         i: in std logic;
         y: out std_logic);
end inv_nand;
/**
     architecture body */
architecture arch_inv_nand of inv_nand is
component nand_gate port (
         a, b: in std_logic;
         y: out std_logic);
  end component;
begin
  DUT: nand_gate port map (i, i, y);
    . . .
End arch_inv_gate;
//Write the test bench for providing the stumulus
entity tb_inv_nand port
end tb_inv_nand;
architecture arch_inv_nand of inv_nand is
   signal i: std logic := '0';
   signal y: std_logic;
   component inv_nand port (
         i: in std_logic;
         y: out std logic);
   end component;
```

begin

```
DUT: inv_nand port map (i, y);
i ='0' after 10 ns;
i ='1' after 10 ns;
. . .
. . .
end architecture
```

- 1. Realize the AND gate logic using NAND gate
- 2. Realize the OR gate logic using NAND gate

# 6.2 Gate realization using NOR gate

Realize the inverter gate logic using NOR gate.

#### Hint

```
/** Gate level model for */
entity inv_nor port (
         i: in std_logic;
         y: out std_logic);
end inv_nor;
/** architecture body */
architecture arch_inv_nor of inv_nand is
component nor_gate port (
         a, b: in std logic;
         y: out std_logic);
  end component;
begin
  DUT: nor_gate port map (i, i, y);
    . . .
End arch_inv_nor;
//Write the test bench for providing the stumulus
entity tb inv nor port
end tb_inv_nor;
architecture arch_inv_nor of inv_nor is
   signal i: std_logic := '0';
   signal y: std_logic;
   component inv_nor port (
         i: in std_logic;
         y: out std_logic);
   end component;
begin
  DUT: inv_nor port map (i, y);
  i ='0' after 10 ns;
```

```
i ='1' after 10 ns;
    . . .
    . . .
End architecture
```

- 1. Realize the AND gate logic using NOR gate
- 2. Realize the OR gate logic using NOR gate

#### 6.3 XOR gate realization using minimum number of NAND gates

Realize XOR gate using minimum number of NAND gates.

## Hint

```
/** Declare the port signals */
entity xor_nand port (
         a, b: in std_logic;
         y: out std_logic);
end xor_nand;
/**
     architecture body */
architecture arch_xor_nand of xor_nand is
component nand_gate port (
         a, b: in std logic;
         y: out std_logic);
  end component;
begin
  DUT: nand_gate port map (a, b, y);
    . . .
End arch_xor_nand;
//Write the test bench for providing the stumulus
entity tb xor nand port
end tb_xor_nand;
architecture arch_xor_nand of xor_nand is
   signal a, b: std_logic := '0';
  signal y: std_logic;
   component xor_nand port (
         a, b: in std_logic;
         y: out std_logic);
  end component;
begin
  DUT: xor_nand port map (a, b, y);
  a ='0' after 10 ns;
   b ='0' after 10 ns;
```

```
•••
```

```
End architecture
```

1. Realize XNOR gate using minimum number of NAND gates

## 6.4 Three input NAND gate using min no of 2 input NAND Gate

Implement 3 input NAND gate realization using minimum number of NAND gates.

a) A and B to the first NAND gateb) Output of first Nand gate is given to the two inputs of the second NAND gate (this basically realizes the inverter functionality)c) Output of second NAND gate is given to the input of the third NAND gate, whose otherinput is C ((A NAND B) NAND (A NAND B)) NAND C Thus, can be implemented using '3'2-input NAND gates.

#### Hints:

Assume three inputs of the NAND gate are A, B and C and connect these inputs as

```
/** Declare the port signals */
entity nand3 port (
         a, b, c: in std_logic;
         y: out std_logic);
end nand3;
/**
      architecture body */
architecture arch_nand3 of nand3 is
component nand2_gate port (
         a, b: in std logic;
         y: out std_logic);
  end component;
begin
  DUT: nand2_gate port map (a, b, y);
    . . .
End arch_nand3;
//Write the test bench for providing the stumulus
entity tb nand3 port
end tb_nand3;
architecture arch_tb_nand3 of tb_nand3 is
   signal a, b: std_logic := '0';
   signal y: std_logic;
   component nand2 port (
         a, b: in std_logic;
```

```
y: out std_logic);
end component;
begin
DUT: nand2 port map (a, b, y);
a ='0' after 10 ns;
b ='0' after 10 ns;
. . .
a = '1' after 10 ns;
b = '1' after 10 ns;
End architecture
```

## Try:

Implement XNOR gate realization using minimum number of NAND gates

# 6.5 User defined logic gate (Muller-C element cell)

Develop a behavioral model for a two-input Muller-C element cell, with two input ports and one output, all of type bit. The inputs and outputs are initially '0'. When both inputs are '1', the output changes to '1'. It stays '1' until both inputs are '0', at which time it changes back to '0'. Your model should have a propagation delay for rising output transitions of 3.5 ns, and for falling output transitions of 2.5 ns.

## Hints:

Assume three inputs of the NAND gate are A, B and C and connect these inputs as,

```
Take inputs A and B
Extract the truth table and Boolean expression as per the specifications
Implement the gate using VHDL model
Write the logic for selecting the stimulus for verifying the logic
/** Declare the port signals */
entity mc_cell port (
         a, b, c: in std_logic;
         y: out std_logic);
end mc_cell;
/** architecture body */
architecture arch_mc_cell of mc_cell is
component mc_cell port (
         a, b: in std_logic;
         y: out std_logic);
   end component;
begin
```

```
DUT: nand2_gate port map (a, b, y);
    . . .
End arch_mc_cell;
//Write the test bench for providing the stumulus
entity tb mc cell port
end tb_mc_cell;
architecture arch_tb_mc_cell of tb_mc_cell is
   signal a, b: std_logic := '0';
   signal y: std_logic;
   component mc_cell port (
         a, b: in std_logic;
         y: out std_logic);
   end component;
begin
  DUT: mc_cell port map (a, b, y);
  a ='0' after 10 ns;
   b ='0' after 10 ns;
   . . .
   . . .
  a = '1' after 10 ns;
   b = '1' after 10 ns;
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

Develop a behavioral model for a two-input Muller-C element cell, with two input ports and one output, all of type bit. The inputs and outputs are initially '1'. When both inputs are '0', the output changes to '0'. It stays '0' until both inputs are '1', at which time it changes back to '1'.

# 7. Introduction

In digital systems, many times it is necessary to select a single data line from several data-input lines and the data from the selected data input line should be available on the output line. The digital circuit which does this task is a multiplexer.

A multiplexer is a digital circuit that selects one of the n data inputs and forwards it to the output. The selection of one of the n inputs is done by the select inputs. To select one of several inputs, we need m select lines such that  $2^m = n$ .

#### 7.1. Implementation of 2x1, 4x1 multiplexers

Develop a behavioral model for a two-input multiplexer, with ports of type bit and a propagation delay from data or select input to data output of 5 ns. You should declare a constant for the propagation delay, rather than writing it as a literal in signal assignments in the model.

The inputs to the MUX are data inputs I1, I0 and a one control input SEL(s) The single output is Y.

```
Hints
/**
        Implementation of 2x1 multiplexer **/
Declare the inputs IO, I1 and S
Declare the output Y.
//Write the logic for selecting the data depends on the select line and
pass to the output
entity mux_2x1 port (
         i0, i1, s: in std_logic;
         y: out std_logic);
end mux_2x1;
/**
      architecture body */
architecture arch_mux_2x1 of mux_2x1 is
   component nand port (
         a, b: in std_logic;
         y: out std_logic);
   end component;
   component inv port (
         i: in std_logic;
         y: out std_logic);
   end component;
begin
   DUT1: inv port map (s, sb);
   DUT2: nand2_gate port map (i0, sb, s1); . . .
   . . .
  . . .
End arch mux2x1;
//Write the test bench for providing the stumulus
entity tb_mux2x1 port
end tb_mux2x1;
architecture arch_tb_mux2x1 of tb_mc_mux2x1 is
   signal i0, i1, s: std_logic := '0';
   signal y: std_logic;
   component mux2x1 port (
         i0, i1, s: in std_logic;
         y: out std_logic);
   end component;
```

```
begin
  DUT: mux2x1 port map (i0, i1, s, y);
  s ='0' after 10 ns, '1' after 10 ns;
   process
   begin
    i0 = ~i0;
    wait for 10ns;
    i1 = ~i1;
     wait for 15ns;
   end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

Develop a behavioral model for a four-input multiplexer, with ports of type bit and a propagation delay from data or select input to data output of 4.5 ns. You should declare a constant for the propagation delay, rather than writing it as a literal in signal assignments in the model.

## 7.2 Implementation of 2x1, 4x1 demultiplexers

Build a behavioral model for a two-input demultiplexers, with ports of type bit and a propagation delay from data or select input to data output of 5 ns.

```
/** architecture body */
architecture arch_dmux_1x2 of dmux_1x2 is
begin
   process(I,s)
   begin
      case S is
        when '0': y0 = I; y1 = 'z';
        • • •
        . . .
End arch dmux1x2;
//Write the test bench for providing the stumulus
entity tb_dmux1x2 port
end tb_dmux1x2;
architecture arch_tb_dmux1x2 of tb_dmux1x2 is
   signal i, s: std_logic := '0';
   signal y0, y1: std_logic;
   component dmux1x2 port (
         i, s: in std_logic;
         y0, y1: out std_logic);
  end component;
begin
  DUT: dmux1x2 port map (i, s, y0, y1);
  s ='0' after 10 ns, '1' after 10 ns;
  process
  begin
    i = ~i;
    wait for 10ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

- 1 Modify the program to function as 1x4 demultiplexers
- 2 Modify the program to function as 1x8 demultiplexers

#### 7.3 Realization of higher order multiplexers using lower order multiplexers

Realize the higher order multiplexers using lower order multiplexers. Write the VHDL model for the realized circuits. Simulate the test benches for the corresponding and verify the design under test by plotting the waveforms. Figure 1 shows realization of 4x1 mux using 2x1 mux.



Figure 1: Realization of 4x1 mux using 2x1 mux

/\*\*

Realize the lower order multiplexers for design of higher order multiplexers. \*\*/

In work library simulate the lower order multiplexer

For the realized higher order multiplexer, instance the component in the declaration part of the architecture

By using positional or name mapping instance the component with the signals

## Hint

 $//\ensuremath{\mathbb{W}}$  rite the logic for selecting the data depends on the select line and pass to the output

```
DUT2: mux2x1 port map (i2, i3, s(1), s2);
   . . .
   . . .
   . . .
End arch_mux4x1;
//Write the test bench for providing the stumulus
entity tb_mux4x1 port
end tb_mux4x1;
architecture arch_tb_mux4x1 of tb_mux4x1 is
   signal i0, i1, i2, i3: std_logic := '0';
   signal s: std_logic_vector(1 donwto 0) := "00";
   signal y: std_logic;
   component mux4x1 port (
         i0, i1, i2, i3: in std_logic;
         s: in std_logic_vector(1 donwto 0);
         y: out std_logic);
   end component;
begin
  DUT: mux4x1 port map (i0, i1, i2, i3, s, y);
  s ='00' after 10 ns, '01' after 10 ns . . .;
   process
   begin
    i0 = ~i0;
    wait for 10ns;
    i1 = ~i1;
    wait for 12ns;
    i2 = ~i2;
     wait for 14ns;
    i3 = ~i3;
    wait for 16ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

# 7.4 Realization of basic gates using 2x1 multiplexer

Realize all the basic gates like AND and inverter using 2x1 multiplexer.

#### /\*\* Realize the multiplexers for function as basic logic gates \*\*/

In work library simulate the 2x1 multiplexer

For the realized basic gates using 2x1 multiplexer, instance the component in the declaration part of the architecture

```
//\ensuremath{\mathbb{W}} rite the logic for selecting the data depends on the select line and
pass to the output
entity mux_and port (
         a, b: in std_logic;
         y: out std_logic);
end mux_2x1;
/**
    architecture body */
architecture arch_mux_and of mux_and is
   component mux2x1 port (
         i0, i1, s: in std_logic;
         y: out std_logic);
  end component;
  // declare intermediate signals
begin
  DUT1: mux2x1 port map ('0', b, a, y);
   . . .
   . . .
End arch_mux_and;
//Write the test bench for providing the stumulus
entity tb_mux_and port
end tb_mux_and;
architecture arch tb mux and of tb mux and is
   signal a, b: std_logic := '0';
  signal y: std_logic;
   component mux_and port (
         a, b: in std_logic;
         y: out std_logic);
  end component;
begin
  DUT: mux_and port map (a, b, y);
  process
   begin
    a = ~a;
    wait for 10ns;
    b = \sim b;
    wait for 12ns;
   end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

- 1. Realize all the OR gate using 2x1 multiplexer
- 2. Realize all the basic gates like XOR and XNOR using 2x1 multiplexer
- 3. Realize all the inverter using 2x1 multiplexer

# 8. Introduction

A decoder is a multiple input multiple output logic circuit which converts coded input into coded output where input and output codes are different. The input code generally has fewer bits than the output code. Each input code word produces a different output code word i.e there is one to one mapping can be expressed in truth table. In the block diagram of decoder circuit the encoded 2n information is present as n input producing 2 through output  $2^n -1$ .

### 8.1 Implementation of 2 to 4 decoder

Write the VHDL code for the circuit contains an input bundle of two input signals and an output bundle of four decoded signals. The input bundle, i<sub>0</sub>, i<sub>1</sub> represents decoder inputs. The output bus, Y0, Y1, Y2 and Y3, are used to indicate the decoded output for the two inputs. The relationship between the input and output is shown in the table below. Use a selected signal assignment statement in the solution.

```
/**
 Implementation of 2 to 4 decoder.
 **/
Declare the inputs I0, I1.
Declare the output Y0, Y1, Y2 and Y3.
I1
         10
                  Y3
                          Y2
                                    Y1
                                             Y0
0
         0
                  0
                           0
                                    0
                                             1
0
        1
                  0
                           0
                                   1
                                             0
                                             0
1
         0
                  0
                           1
                                    0
                                             0
1
         1
                           0
                  1
                                    0
```

```
//Write VHDL model for 2 to 4 decoder gate level model
entity dec2to4 port (
         i0, i1: in std logic;
         y0, y1, y2, y3: out std_logic);
end dec2to4;
/** architecture body */
architecture arch_dec2to4 of dec2to4 is
   component nand_gate port (
         a, b: in std_logic;
         y: out std_logic);
   end component;
   // component declaration for inverter
  // declare intermediate signals
begin
  DUT1: nand_gate port map (ni1, ni0, y0);
   . . .
```

```
• • •
  . . .
End arch_dec2to4;
//Write the test bench for providing the stumulus
entity tb dec2to4 port
end tb_dec2to4;
architecture arch_tb_dec2to4 of tb_dec2to4 is
   signal i0, i1: std_logic := '0';
   signal y0, y1, y2, y3: std_logic;
   component dec2x4 port (
         i0, i1: in std_logic;
         y0, y1, y2, y3: out std_logic);
   end component;
begin
  DUT: dec2to4 port map (i0,i1, y0, y1, y2, y3);
   process
   begin
     i0 = ~i0;
    wait for 10ns;
    i1 = ~i1;
     wait for 15ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

- 1. Write a program to implement gate level model for 2 to 4 decoder. Plot the waveforms
- 2. Write a program to implement behavioral model for 2 to 4 decoder. Plot the waveforms

#### 8.2 Implementation of 3 to 8 decoder

Build behavioral model to function as 3 to 8 decoder.

```
y0, y1, y2, y4, y5, y6, y7: out std_logic);
end dec3to8;
/** architecture body */
architecture arch_dec3to8 of dec3to8 is
  // declare intermediate signals
begin
   process(i0, i1, i2)
   begin
      { y0, y1, y2, y4, y5, y6, y7} = "00000000";
      case {i2, i1, i0} is
        when "000" => Y0 <= '1';
        when "001" => Y0 <= '1';
        when "010" => Y0 <= '1';
        . . .
        . . .
        . . .
      End case
   End process;
End arch dec3to8;
//Write the test bench for providing the stumulus
entity tb_dec3to8 port
end tb_dec3to8;
architecture arch_tb_dec3to8 of tb_dec3to8 is
   signal i0, i1, i2: std_logic := '0';
  signal y0, y1, y2, y3, y4, y5, y6, y7: std_logic;
   component dec3x8 port (
         i0, i1, i2: in std_logic;
         y0, y1, y2, y3, y4, y5, y6, y7: out std_logic);
  end component;
begin
  DUT: dec3to8 port map (i0, i1, i2, y0, y1, y2, y3, y4, y5, y6, y7);
   process
   begin
    i0 = ~i0;
    wait for 10ns;
     i1 = ~i1;
    wait for 15ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

- Construct a 4-to-16 line decoder with two 3-to-8 line decoders having active LOW ENABLE inputs.
- 2. Implement the three-variable Boolean function  $F = \bar{a}c + a\bar{b}c + a\bar{b}c$  using (i) an 8-to-1 multiplexer and (ii) a 4-to-1 multiplexer.

8.3 Realization of higher order multiplexers using lower order multiplexers

Construct a 4-to-16 line decoder with two 3-to-8 line decoders having active LOW ENABLE inputs.

#### Hints

/\*\*
Realize the lower order multiplexers for design of higher order multiplexers
\*\*/
In work library simulate the lower order multiplexer
For the realized higher order multiplexer, instance the component in the
declaration part of the architecture
By using positional or name mapping instance the component with the signals
Design a test bench
Write the logic for generating stimulus for the input signals
Plot the wave form for all possible select lines
Synthesize the design

Elaborate the design and dump the bit file into FPGA

#### Try

Construct a 3-to-8 line decoder with two 2-to-4 line decoders having active LOW ENABLE inputs.

#### 8.4 Realization of basic gates using 2x1 multiplexer

Realize all the basic gates like AND, OR, XOR, XNOR and inverter using 2x1 multiplexer

/\*\* Realize the multiplexers for function as basic logic gates \*\*/

In work library simulate the 2x1 multiplexer

For the realized basic gates using 2x1 multiplexer, instance the component in the declaration part of the architecture

By using positional or name mapping instance the component with the signals

Design a test bench

Write the logic for generating stimulus for the input signals

Plot the wave form for all possible select lines

```
Synthesize the design
```

Elaborate the design and dump the bit file into FPGA

# Try

Realization of BCD-to-seven-segment decoder for a light emitting diode (LED) display

Develop a functional model of a BCD-to-seven-segment decoder for a light emitting diode (LED) display. The decoder has a 4-bit input that encodes a numeric digit between 0 and 9. There are seven outputs indexed from 'a' to 'g', corresponding to the seven segments of the LED display as shown in the margin. An output bit being '1' causes the corresponding segment to illuminate. For each input digit, the decoder activates the appropriate combination of segment outputs to form the displayed representation of the digit.

# Hint:

For example, for the input "0010", which encodes the digit 2, the output is "1101101". Your model should use a selected signal assignment statement to describe the decoder function in truth-table form.

# 9. Introduction

An encoder is a digital circuit that performs inverse operation of a decoder. An encoder has 2n input lines and n output lines. In encoder the output lines generates the binary code corresponding to the input value. In octal to binary encoder it has eight inputs, one for each octal digit and three output that generate the corresponding binary code. In encoder it is assumed that only one input has a value of one at any given time otherwise the circuit is meaningless. It has an ambiguila that when all inputs are zero the outputs are zero. The zero outputs can also be generated when D0 = 1.

# 9.1 Implementation of 4 to 2 encoder

An encoder is a digital circuit that converts a set of binary inputs into a unique binary code. The binary code represents the position of the input and is used to identify the specific input that is active. Encoders are commonly used in digital systems to convert a parallel set of inputs into a serial code.

The 4 to 2 Encoder consists of four inputs Y3, Y2, Y1 & Y0, and two outputs A1 & A0. At any time, only one of these 4 inputs can be '1' in order to get the respective binary code at the output. The figure below shows the logic symbol of the 4 to 2 encoder.

/\*\* Implementation of 4 to 2 decoder \*\*/ Declare the inputs I0, I1, I2, I3. Declare the output Y0 and Y1 Ι3 12 Y0 I1 10 Y1 0 0 0 1 0 0 0 0 1 0 0 1 0 1 0 0 0 1 0 1 0 0 1 1

Hints

```
//Write VHDL model for 2 to 4 decoder gate level model
entity enc4to2 port (
    i : in STD_LOGIC_VECTOR(3 downto 0);
    y : out STD_LOGIC_VECTOR(1 downto 0) );
end enc4to2;
architecture arch_enc4to2 of enc4to2 is
begin
    process(i)
    begin
        if (i="1000") then y <= "00";
        elsif (i="0100") then y <= "01";
        elsif (i="0010") then y <= "10";
        elsif (i="0001") then y <= "11";
        else y <= "ZZ";</pre>
        end if;
    end process;
End arch_enc4to2;
//Write the test bench for providing the stumulus
entity tb_enc4to2 port
end tb_enc4to2;
architecture arch tb enc4to2 of tb enc4to2 is
   signal i : in STD LOGIC VECTOR(3 downto 0) := "0000";
  signal y : out STD_LOGIC_VECTOR(1 downto 0);
   component enc4to2 port (
         i : in STD_LOGIC_VECTOR(3 downto 0);
         y : out STD_LOGIC_VECTOR(1 downto 0));
   end component;
begin
  DUT: enc4to2 port map (i, y);
  process
   begin
    i = i + '1';
    wait for 10ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

# Try

1. Modify VHDL behavioral model with gate level model for 4 to 2 encoder. Plot the waveforms.

2. Decimal to BCD Encoder.

The decimal-to-binary encoder usually consists of 10 input lines and 4 output lines. Each input line corresponds to each decimal digit and 4 outputs correspond to the BCD code. This encoder accepts the decoded decimal data as an input and encodes it to the BCD output which is available on the output lines.

3. Octal to Binary Encoder (8 to 3 Encoder)

The 8 to 3 Encoder or octal to Binary encoder consists of 8 inputs: Y7 to Y0 and 3 outputs: A2, A1 & A0. Each input line corresponds to each octal digit and three outputs generate corresponding binary code.

## 9.2 Implementation of 8 to 3 priority encoder

A 8 to 3 priority encoder has eight inputs Y7, Y6, Y5, Y4, Y3, Y2, Y1 & Y0 and two outputs A2, A1 and A0. Here, the input, Y7 has the highest priority, whereas the input, Y0 has the lowest priority. In this case, even if more than one input is '1' at the same time, the output will be the binary code corresponding to the input, which is having higher priority.

We considered one more output, V in order to know, whether the code available at outputs is valid or not.

- If at least one input of the encoder is '1', then the code available at outputs is a valid one. In this case, the output, V will be equal to 1.
- If all the inputs of encoder are '0', then the code available at outputs is not a valid one. In this case, the output, V will be equal to 0.

The Truth table of 4 to 2 priority encoder is shown below.

| /**              | Impleme              | entation o             | f 4 to 2          | decoder | **/ |
|------------------|----------------------|------------------------|-------------------|---------|-----|
| Declar<br>Declar | re the i<br>re the c | nputs I0,<br>output Y0 | I1, I2,<br>and Y1 | 13.     |     |
| I3               | 12                   | I1                     | 10                | Y1      | YØ  |
| 0                | 0                    | 0                      | 1                 | 0       | 0   |
| 0                | 0                    | 1                      | 0                 | 0       | 1   |
| 0                | 1                    | 0                      | 0                 | 1       | 0   |
| 1                | 0                    | 0                      | 0                 | 1       | 1   |

```
//Write VHDL model for 2 to 4 decoder gate level model
entity penc8to3 port (
    i : in STD_LOGIC_VECTOR(7 downto 0);
    y : out STD_LOGIC_VECTOR(2 downto 0) );
end enc4to2;
architecture arch_penc8to3 of penc8to3 is
begin
    y <= "111" when i(7)='1' else
       "110" when i(6)='1' else
       "101" when i(5)='1' else
       "100" when i(4)='1' else
       "011" when i(3)='1' else
       "010" when i(2)='1' else
```

```
"001" when i(1)='1' else
        "000";
End arch_penc8to3;
//Write the test bench for providing the stumulus
entity tb penc8to3 port
end tb_penc8to3;
architecture arch_tb_penc8to3 of tb_penc8to3 is
   signal i : in STD_LOGIC_VECTOR(7 downto 0) := "00000000";
   signal y : out STD_LOGIC_VECTOR(2 downto 0);
   component penc8to3 port (
         i : in STD_LOGIC_VECTOR(7 downto 0);
         y : out STD_LOGIC_VECTOR(2 downto 0));
   end component;
begin
  DUT: penc8to3 port map (i, y);
   process
   begin
     i = i + '1';
     wait for 10ns;
   end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

1. Modify VHDL behavioral model with gate level model for 8 to 3 encoder. Plot the waveforms.

2. Realize 8to3 priority encoder using 2x1 mux and implement with VHDL gate level model.

# 10. Introduction

In digital electronics, adders and subtractors both are the combinational logic circuits (a combinational logic circuit is one whose output depends only on the present inputs, but not on the past outputs) that can add or subtract numbers, more specifically binary numbers. Adders and subtractors are the crucial parts of arithmetic logic circuits in processing devices like microprocessors or microcontrollers.

A combinational logic circuit which is designed to add two binary digits is called as a half adder. The half adder provides the output along with a carry value (if any). The half adder circuit is designed by connecting an EX-OR gate and one AND gate. It has two input terminals and two output terminals for sum and carry.

#### **10.1 Implementation of half adder**

Design a gate level circuit for half adder and verify for the following truth table and write a test bench for verifying the functionality of the half adder.

| Consider the inputs are A, | B and outputs | are Sum, Cout |
|----------------------------|---------------|---------------|
|----------------------------|---------------|---------------|

| А | В | Sum | Cout |
|---|---|-----|------|
| 0 | 0 | 0   | 0    |
| 0 | 1 | 1   | 0    |
| 1 | 0 | 1   | 0    |
| 1 | 1 | 0   | 1    |

### Hints

The code pattern for implementing half adder:

```
// Declare the port signals
Input a, b;
Output sum, cout
//Write VHDL model for half adder in behavioral flow model
entity ha_df port (
          a, b: in std_logic;
          sum, cout: out std_logic);
end ha_df;
/** architecture body */
architecture arch_ha_df of ha_df is
begin
   process(a, b)
   begin
      case {a, b} is
         when "00" => sum <= '0'; cout <= '0';
        when "01" => sum <= '1'; cout <= '0';
when "10" => sum <= '1'; cout <= '0';</pre>
         . . .
         . . .
         . . .
      End case
   End process;
End arch_ha_df;
//Write the test bench for providing the stumulus
entity tb_ha_df port
end tb_ha_df;
architecture arch_tb_ha_df of tb_ha_df is
   signal a, b: std_logic := '0';
   signal sum, cout: std_logic;
```

```
component ha df port (
         a, b: in std_logic;
         sum, cout: out std_logic);
  end component;
begin
  DUT: ha_df port map (a, b, sum, cout);
  process
  begin
    a = ~a;
    wait for 10ns;
     b = \sim b;
    wait for 15ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

## **10.2 Implementation of full adder**

Design a gate level circuit for full adder and verify for the following truth table and write a test bench for verifying the functionality of the full adder.

Consider the inputs are A, B, C and outputs are Sum, Cout

| А | В | С | Sum | Cout |
|---|---|---|-----|------|
| 0 | 0 | 0 | 0   | 0    |
| 0 | 0 | 1 | 1   | 0    |
| 0 | 1 | 0 | 1   | 0    |
| 0 | 1 | 1 | 0   | 1    |
| 1 | 0 | 0 | 1   | 0    |
| 1 | 0 | 1 | 0   | 1    |
| 1 | 1 | 0 | 0   | 1    |
| 1 | 1 | 1 | 1   | 1    |

Hints

The pseudo code for printing full adder:

```
end fa_gl;
/** architecture body */
architecture arch_fa_gl of ga_gl is
  component xor_gate port (
         a, b: in std_logic;
         y: out std_logic);
  end component;
    component declaration for or_gate, and_gate
begin
    u0: xor_gate port map(a, b, x1);
    u1: xor_gate port map(x1, cin, sum);
    • • •
    . . .
End arch_fa_gl;
//Write the test bench for providing the stumulus
entity tb_fa_gl port
end tb_fa_gl;
architecture arch_tb_fa_gl of tb_fa_gl is
   signal a, b, cin: std_logic := '0';
  signal sum, cout: std_logic;
   component fa_gl port (
         a, b, cin: in std_logic;
         sum, cout: out std_logic);
  end component;
begin
  DUT: fa gl port map (a, b, cin, sum, cout);
   process
   begin
    a = ~a;
    wait for 5ns;
    b = ~b;
    wait for 10ns;
     cin = ~cin;
     wait for 15ns;
  end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

### 10.3 Realization of full adder using half adders

Design a gate level circuit for full adder using half adder and verify for the functionality and write a test bench for verifying the functionality of the full adder.

#### Hints

The pseudo code for printing full adder:

```
// Declare the port signals
Input a, b, c;
Output sum, cout
Work lib should consists of half adder, or_gate modules
entity fa_ha port (
         a, b, cin: in std_logic;
         sum, cout: out std_logic);
end fa_ha;
/**
     architecture body */
architecture arch_fa_ha of ga_ha is
   component ha_df port (
         a, b: in std_logic;
         y: out std_logic);
   end component;
    component declaration for or_gate, and_gate
begin
    u0: xor_gate port map(a, b, x1);
    u1: xor_gate port map(x1, cin, sum);
    . . .
    . . .
End arch_fa_gl;
//Write the test bench for providing the stumulus
entity tb_fa_gl port
end tb_fa_gl;
architecture arch_tb_fa_gl of tb_fa_gl is
   signal a, b, cin: std_logic := '0';
   signal sum, cout: std_logic;
   component fa_gl port (
         a, b, cin: in std_logic;
         sum, cout: out std_logic);
   end component;
begin
   DUT: fa_gl port map (a, b, cin, sum, cout);
   process
```

```
begin
  a = ~a;
  wait for 5ns;
  b = ~b;
  wait for 10ns;
  cin = ~cin;
  wait for 15ns;
end process
End architecture
Plot the wave form for all possible select lines
Synthesize the design
Elaborate the design and dump the bit file into FPGA
```

#### 10.4 Design and implement 4-bit ripple carry adder

Design a gate level circuit for ripple carry adder using full adder and verify for the functionality and write a test bench for verifying the functionality of the ripple carry adder.

#### Hints

The pseudo code for printing full adder:

```
// Declare the port signals
Input a, b; //vector of 4-bit size
Input cin;
Output sum; //vector of 4-bit size
Output cout;
// Declare xor gate, and gate
Component declaration for full adder
// instance xor gate, and gate
Port map for full adder
```

#### **10.5 Implementation of half subtractor**

Design a gate level circuit for half subtractor and verify for the following truth table and write a test bench for verifying the functionality of the half subtractor.

Consider the inputs are A, B and outputs are Diff, Bout В Diff Bout А 0 0 0 0 0 1 1 1 1 0 1 0 1 1 0 0

## Hints

The code pattern for printing half subtractor:

```
// Declare the port signals
Input a, b;
Output diff, bout
// Declare xor gate, and gate
Component declaration for xor gate, and gate
// instance xor gate, and gate
Port map for xor gate
Port map for and gate
```

## **10.6 Implementation of full subtractor**

Design a gate level circuit for full subtractor and verify for the following truth table and write a test bench for verifying the functionality of the full subtractor.

| Consider | the | inputs ar | еA, B, | Bin and | outputs | are | Diff, | Bout |  |
|----------|-----|-----------|--------|---------|---------|-----|-------|------|--|
| А        | В   | Bin       | Sum    | Bout    |         |     |       |      |  |
| 0        | 0   | 0         | 0      | 0       |         |     |       |      |  |
| 0        | 0   | 1         | 1      | 1       |         |     |       |      |  |
| 0        | 1   | 0         | 1      | 1       |         |     |       |      |  |
| 0        | 1   | 1         | 0      | 1       |         |     |       |      |  |
| 1        | 0   | 0         | 1      | 0       |         |     |       |      |  |
| 1        | 0   | 1         | 0      | 0       |         |     |       |      |  |
| 1        | 1   | 0         | 0      | 0       |         |     |       |      |  |
| 1        | 1   | 1         | 1      | 1       |         |     |       |      |  |

### Hints

The pseudo *code* for printing full subtractor:

```
// Declare the port signals
Input a, b, bin;
Output diff, bout
// Declare xor gate, and gate
Component declaration for xor gate, and gate
// instance xor gate, and gate
Port map for xor gate
Port map for and gate
```

### 10.7 Realization of full subtractor using half subtractor

Design a gate level circuit for full subtractor using half subtractor and verify for the functionality and write a test bench for verifying the functionality of the full subtractor.

### Hints

The pseudo code for printing full subtractor:

// Declare the port signals
Input a, b, bin;
Output diff, bout
// Declare xor gate, and gate
Component declaration for half subtractor, and gate, or gate
// instance xor gate, and gate
Port map for half subtractor
Port map for and gate
Port map for or gate

## Try

Design a gate level circuit for ripple carry adder using full adder and verify for the functionality and write a test bench for verifying the functionality of the half adder.

#### Hints

The pseudo code for printing full adder:

| // Declare the | port signals                      |
|----------------|-----------------------------------|
| Input a, b;    | <pre>//vector of 4-bit size</pre> |
| Input cin;     |                                   |
| Output sum;    | //vector of 4-bit size            |
| Output cout;   |                                   |
|                |                                   |
| // Declare xor | gate, and gate                    |

Component declaration for full adder

// instance xor gate, and gate
Port map for full adder

# 11. Introduction

Shift registers, like counters, are a form of sequential logic. Sequential logic, unlike combinational logic, is not only affected by the present inputs but also by the prior history. In other words, sequential logic remembers past events. Shift registers produce a discrete delay of a digital signal or waveform.

# 11.1 4- bit barrel shifter

A barrel shifter is a digital circuit that can shift a data word by a specified number of bits without use of

any sequential logic, only pure combinational logic. There are 3 type of bitwise shift operation: logical shift, arithmetic shift, and circular shift (rotate). The data can be shifted to the left as well as to the right circular shift.

## Hints

Consider the port specification as

Input datain // 8 bit wide

Input sel // 3 bit wide to support 16 operations

Input dataout // 8 bit wide

The circuit allows rotating the input data word right, where the amount of rotating is selected by the control inputs. The circuit can design by three stages of 2:1 multiplexer.

When all multiplexer select inputs are active (low), the input data passes straight through the cascade of the multiplexers and the output data (q<sub>7</sub>....,q<sub>0</sub>) is equal to the input data (d<sub>7</sub>..... d<sub>0</sub>). When S<sub>2</sub>control signal is selected, the first stage of multiplexers performs a rotate-right by one bit operation, due to their inter-connection to the next lower input.

The second stage of multiplexers performs a rotate-right by two bits when  $S_1$  control signal is selected.

Here the corresponding multiplexer inputs are connected to their second next-lower input.

Finally, the third stage of multiplexers performs a rotate-right by four bits, when  $S_0$  control signal is selected. The design uses a case statement to exhaustively list all combinations of the amt signal and the corresponding rotated results.

## Try:

- 1. Modify the barrel shifter by changing the number of select lines to 4 bit wide to support 16 different functionalities.
- 2. Modify the barrel shifter by changing the number of data lines to 16 bit wide to support 16 different functionalities.

# 11.2. 8- bit ALU

Arithmetic Logic Unit (ALU) is one of the most important digital logic components in CPUs. It normally executes arithmetic operations such as addition, subtraction, multiplication, division, etc. and logic operations such as and, or, xor, xnor, nand, nor, not, buffer, rotate and shift operations.

## Hints

Consider the port specification as

Input A, B // 8 bit wide

Input sel // 4 bit wide to support 16 operations

Input dataout // 8 bit wide

// The logic and arithmetic operations being implemented in the ALU are as follows:

| 1. Arithmetic Addition:      | $ALU_Out = A + B;$                               |
|------------------------------|--------------------------------------------------|
| 2. Arithmetic Subtraction    | ALU_Out = A - B;                                 |
| 3. Arithmetic Multiplication | ALU_Out = A * B;                                 |
| 4. Arithmetic Division       | $ALU_Out = A / B;$                               |
| 5. Logical Shift Left        | ALU_Out = A logical shifted left by 1;           |
| 6. Logical Shift Right       | ALU_Out = A logical shifted right by 1;          |
| 7. Rotate Left               | ALU_Out = A rotated left by 1;                   |
| 8. Rotate Right              | ALU_Out = A rotated right by 1;                  |
| 9. Logical AND               | ALU_Out = A AND B;                               |
| 10. Logical OR               | ALU_Out = A OR B;                                |
| 11. Logical XOR              | ALU_Out = A XOR B;                               |
| 12. Logical NOR              | ALU_Out = A NOR B;                               |
| 13. Logical NAND             | ALU_Out = A NAND B;                              |
| 14. Logical XNOR             | ALU_Out = A XNOR B;                              |
| 15. Greater comparison       | $ALU_Out = 1 \text{ if } A > B \text{ else } 0;$ |

16. Equal comparison

 $ALU_Out = 1 A = B else 0;$ 

The second stage of multiplexers performs a rotate-right by two bits when  $S_1$  control signal is selected.

Here the corresponding multiplexer inputs are connected to their second next-lower input.

Finally, the third stage of multiplexers performs a rotate-right by four bits, when  $S_0$  control signal is selected. The design uses a case statement to exhaustively list all combinations of the amt signal and the corresponding rotated results.

## Try:

- 1. Modify the ALU by changing the number of select lines to 4 bit wide to support 16 different functionalities.
- 2. Modify the ALU by changing the number of data lines to 16 bit wide to support 16 different functionalities.

# 12. Exercises on Latches and Flip-flops

Computers and calculators use Flip-flop for their memory. A combination of number of flip flops will produce some amount of memory. Flip flop is formed using logic gates, which are in turn made of transistors. Flip flop are basic building blocks in the memory of electronic devices. Each flip flop can store one bit of data. Latches and flip – flops are both 1 – bit binary data storage devices. The main difference between a latch and a flip – flop is the triggering mechanism. Latches are transparent when

enabled ,whereas flip – flops are dependent on the transition of the clock signal i.e. either positive edge or negative edge.

### 12.1 SR latch, JK latch, D latch and T latch

Construct an SR latch using NOR gates. Verify its operation and demonstrate the circuit.

Write an entity declaration for a positive level-triggered SR-latch with asynchronous active-low preset and clear inputs, and Q and outputs. Include concurrent assertion statements and passive processes as necessary in the entity declaration to verify that,

- The preset and clear inputs are not activated simultaneously,
- The setup time of 6 ns from the J and K inputs to the rising clock edge is observed,
- The hold time of 2 ns for the J and K inputs after the rising clock edge is observed and
- The minimum pulse width of 5 ns on each of the clock, preset and clear inputs is observed.

Write a gate level architecture body for the SR latch and a test bench that exercises the statements in the entity declaration.

#### Hints

```
// Declare port signal
Input rst_l, clk;
Input s, r;
Output q, qb;
// Component declaration of NAND gates
Component NAND_gate (input a, b; output y);
// component instance in the architecture body of VHDL program
NAND_gate port map(s, qb, q);
NAND_gate port map(r, q, qb);
// Test bench for SR latch
Decise a test baseb to appende the stimulue for the inputs of pro-
Decise a test baseb to appende the stimulue for the inputs of pro-
section.
```

Design a test bench to provide the stimulus for the inputs s, r Generate a clk signal with 5MHz frequency Generate the reset logic to reset the latch at initial

### Try

- 1. Construct SR latch using NAND gates. Verify its operation and demonstrate the circuit
- 2. Construct JK latch using NAND gates. Verify its operation and demonstrate the circuit
- 3. Construct D latch using NAND gates. Verify its operation and demonstrate the circuit
- 4. Construct T latch using NAND gates. Verify its operation and demonstrate the circuit

#### 12.2 JK flip-flop, D flip-flop and T flip-flop

Construct flip-flops using latches and verify its operation and demonstrate the circuit.

Write an entity declaration for a positive edge-triggered JK-flipflop with asynchronous active-low preset and clear inputs, and Q and outputs. Include

concurrent assertion statements and passive processes as necessary in the entity declaration to verify that,

- The preset and clear inputs are not activated simultaneously,
- The setup time of 6 ns from the J and K inputs to the rising clock edge is observed,
- The hold time of 2 ns for the J and K inputs after the rising clock edge is observed
- The minimum pulse width of 5 ns on each of the clock, preset and clear inputs is observed.

Write a structural architecture body for the flipflop and a test bench that exercises the statements in the entity declaration.

Hints
The pseudo code for SR latch
// Declare port signal
Input rst\_l, clk;
Input s, r;
Output q, qb;
// Component declaration of NAND gates
Component NAND\_gate (input a, b; output y);
// component instance in the architecture body of VHDL program
NAND\_gate port map(s, qb, q);
NAND\_gate port map(r, q, qb);
// Test bench for SR latch
Design a test bench to provide the stimulus for the inputs s, r
Generate a clk signal with 5MHz frequency
Generate the reset logic to reset the latch at initial

# Try

# **Design 2-bit register**

Write component instantiation statements to model the structure shown by the schematic diagram in Figure. Assume that the entity ttl\_74x74 and the corresponding architecture basic have been analyzed into the library work. Figure 2 shows the 2-bit register.



Figure 2: 2-bit register.

# 13. Introduction

A special type of sequential circuit used to count the pulse is known as a counter, or a collection of flip flops where the clock signal is applied is known as counters. The counter is one of the widest applications of the flip flop. Based on the clock pulse, the output of the counter contains a predefined state. The number of the pulse can be counted using the output of the counter.

There are two types of counters: Synchronous counter and Asynchronous counter.

## 13.1: 4-bit synchronous counter with synchronous reset

Build an entity for a 4-bit counter with synchronous reset input. Include a process in the entity declaration that measures the duration of each reset pulse and reports the duration at the end of each pulse.

# Hints

```
/**
    Declare the port signals */
entity counter_synrst port (
         clk, rst: in std_logic;
         q: out std_logic_vector(3 downto 0));
end counter synrst;
/** architecturebody */
architecture arch_counter_synrst of counter_synrst is
Begin
    Process (clk, rst)
    Begin
       If clk'event and clk = '1' then
          If rst then
                q = "0000";
          else
                 q = q + 1;
       end if:
    end process
End arch_counter_synrst;
//Write the test bench for providing the stumulus
entity tb_counter_synrst port
end tb_counter_synrst;
architecture arch_tb_counter_synrst of tb_counter_synrst is
   signal clk, rst: std logic := '0';
   signal q: std_logic_vector(3 downto 0);
   component counter synrst port (
         clk, rst: in std logic;
         q: out std_logic_vector(3 downto 0));
   end component;
```

begin

```
DUT: counter_synrst port map (gray_code, binary_code);
   Process
   begin
        clk = ~clk;
        Wait for 10 ns;
  end process;
   Process
   begin
        rst = '0';
        Wait for 10 ns;
        rst = '1';
        wait;
   end process;
end architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
```

- 1 Design 4-bit synchronous counter with asynchronous reset
- 2 Design 4-bit asynchronous counter with synchronous reset
- 3 Design 4-bit asynchronous counter with asynchronous reset

### 13.2 Decade counter with asynchronous reset

Construct an entity for a decade counter with asynchronous reset input. Include a process in the entity declaration that measures the duration of each reset pulse and reports the duration at the end of each pulse.

```
if (q = "1010") then
                 q = "0000";
          else
                 q = q + 1;
          end if;
       end if;
    end process
End arch_dec_counter_asynrst;
//Write the test bench for providing the stumulus
entity tb_dec_counter_asynrst port
end tb_dec_counter_asynrst;
architecture arch_tb_dec_counter_asynrst of tb_dec_counter_asynrst is
   signal clk, rst: std_logic := '0';
   signal q: std_logic_vector(3 downto 0);
  component dec_counter_asynrst port (
         clk, rst: in std_logic;
         q: out std_logic_vector(3 downto 0));
   end component;
begin
  DUT: dec_counter_asynrst port map (clk, rst, q);
   Process
   begin
        clk = ~clk;
        Wait for 10 ns;
   end process;
   Process
  begin
        rst = '0';
        Wait for 10 ns;
        rst = '1';
        wait;
   end process;
end architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
Elaborate the design and create bit file
Dump the bit file in zybo fpga
```

- 1 Design decade synchronous counter with synchronous reset.
- 2 Design counter to count the events from 3 to 12.

## 13.3 4-bit serial in serial out shift register (SISO)

In digital systems it is often necessary to have circuits that can shift the bits of a vector by one or more bit positions to the left or right. Design a circuit that can shift a four-bit vector W = w3w2w1w0 one bit position to the right when a control signal Shift is equal to 1. Let the outputs of the circuit be a four-bit vector Y = y3y2y1y0 and a signal k, such that if Shift = 1 then y3 = 0, y2 = w3, y1 = w2, y0 = w1, and k = w0. If Shift = 0 then Y = W and k = 0.

Build an entity for a shift register to drive the resister serially and output the data serially. Write a test bench architecture to simulate and verify the design.

```
/**
    Declare the port signals */
entity siso port (
        clk, rst: in std_logic;
        sin : in std_logic;
        q: out std_logic_vector(3 downto 0));
end siso;
/**
      architecturebody */
architecture arch_siso of siso is
Begin
    Process (clk, rst)
    Begin
      If rst then
                q = "0000";
       elif clk'event and clk = '1' then
          q[3] = sin;
          q[2] = q[3];
          q[1] = q[2];
          q[0] = q[1];
       end if;
    end process
End arch_siso;
//Write the test bench for providing the stumulus
entity tb siso port
end tb siso;
architecture arch_tb_siso of tb_siso is
   signal clk, rst: std_logic := '0';
   signal sin: std logic := '0';
   signal q: std_logic_vector(3 downto 0);
   component siso port (
         clk, rst: in std_logic;
```

```
sin : in std logic;
         q: out std_logic_vector(3 downto 0));
   end component;
begin
  DUT: siso port map (clk, rst, sin, q);
   Process
  begin
        clk = \sim clk;
        Wait for 10 ns;
   end process;
   Process
  begin
        rst = '0';
        Wait for 10 ns;
        rst = '1';
        wait;
   end process;
  Process
   begin
        sin = ~sin;
        Wait for 25 ns;
   end process;
end architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
Elaborate the design and create bit file
Dump the bit file in zybo FPGA
```

- 1 Design 4-bit serial in parallel out shift register (SIPO).
- 2 Design 4-bit parallel in serial out shift register (PISO).
- 3 Design 4-bit parallel in parallel out shift register (PIPO).

# 14. Introduction

A carry look-ahead adder (CLA) **is an electronic adder used for binary addition.** Due to the quick additions performed, it is also known as a fast adder. The CLA logic uses the concepts of generating and propagating carries. We can say that the CLA adder is the successor of the Ripple Carry Adder

## 14.1 Carry look ahead adder

Build 4- bit carry look ahead adder (CLA) and justify the speed of operation CLA is more than ripple carry adder

Develop a functional model of a 3-bit carry-look-ahead adder. The adder has two 3-bit data inputs, a (2 downto 0) and b(3 downto 0); a 3-bit data output, s(2 downto 0); a carry input, c\_in; a carry output, c\_out; a carry generate output, g; and a carry propagate output, p. The adder is described by the logic equations and associated propagation delays: where the Gi are the intermediate carry generate signals, the Pi are the intermediate carry propagate signals and the Ci are the intermediate carry signals. C–1 is c\_in and C3 is cout. Your model should use the expanded equation to calculate the intermediate carries, which are then used to calculate the sums.

 $s_i = a_i \bigoplus b_i \bigoplus c_{i-1}$  $g_i = a_i \cdot b_i$  $p_i = a_i + b_i$  $c_i = g_i + p_i c_{i-1}$ 

```
/**
     Declare the port signals */
entity cla port (
        a, b: in std_logic-vector(2 downto 0);
        sum: out std_logic_vector(2 downto 0);
        cout: out std logic);
end cla;
/** architecturebody */
architecture arch_cla of cla is
Begin
    g0 = a[0] \& b[0];
    p0 = a[0] | b[0];
    c1 = g0 + p0 \& c0;
     . . . . . . .
     . . . . . . .
     . . . . . . .
End arch cla;
//Write the test bench for providing the stumulus
entity tb_cla port
end tb_cla;
architecture arch_tb_cla of tb_cla is
   signal a, b: std_logic_vector(2 downto 0) := "000";
   signal cin: std_logic := '0';
   signal sum: std_logic_vector(s downto 0);
   component cla port (
         a, b: in std_logic-vector(2 downto 0);
         sum: out std_logic_vector(2 downto 0);
         cout: out std logic);
   end component;
begin
  DUT: cla port map (clk, rst, sin, q);
   Process
   begin
```

```
a = a + "0110"
wait for 10 ns;
b = b + "1010"
end process;
end architecture
// After post simulation
Simulate the design using Xilinx software
Plot the wave forms and verify the functionality of the design
Synthesize the design
Elaborate the design and create bit file
Dump the bit file in zybo FPGA
```

#### Try:

- 1. Design and implement 4-bit carry look ahead adder
- 2. Design and implement 4-bit ripple carry adder

# **14.2 Exercises on VENDING MACHINE CONTROLLER**

Vending-Machine Controller sells candy bars for 25 cents. The inputs are nickel\_in, dime\_in, and quarter\_in, indicating the type of coin that was deposited, plus clock (clk) and reset (rst), to which the circuit responds with the outputs candy\_out, to dispense a candy bar, plus nickel\_out or dime\_out, asserted when change is due. Design this circuit using the FSM approach. Also, estimate the number of flip-flops that will be required. Figure 3. Shows the block level diagram representation of vending machine controller and Figure 15 shows the state diagram of the vending machine.



Figure 15: State diagram of the vending machine controller

```
/**
      VHDL model for gray counter */
entity vend_mach is
        Clk, rst : in std logic;
port(
        Ni_in, Dime_in, Quarter_in : in std_logic;
        Candy_out, Ni_out, Dime_out : out std_logic
    );
end vend_mach;
architecture Behavioral of vend_mach is
--type of state machine and signal declaration.
type state_type is (st0, st5, st10, st15, st20, st25, st30, st35, st40, st45);
signal next_state : state_type;
begin
process(Clk, rst)
begin
    if(rising_edge(Clk)) then
        case next_s is
            when st0 =>
                if(Ni in) then
                     next_state <= st5;</pre>
                elsif(Dime_in) then
                     next_state <= st10;</pre>
                 elsif(Quarter_in) then
                     next_state <= st25;</pre>
                end if;
            when st5 =>
                 . . .
                 . . .
                  . . .
        end case;
    end if;
end process;
end Behavioral;
```

1. Implement the vending machine using Melay finite state machine

# 16. Final Notes

The only way to learn programming is program, program and program on challenging problems. The problems in this tutorial are certainly NOT challenging. There are tens of thousands of challenging problems available – used in training for various programming contests (such as International Collegiate Programming Contest (ICPC), International Olympiad in Informatics (IOI)). Check out these sites:

 Cadence certifications (https://www.cadence.com/en\_US/home/training/become-cadencecertified.html#dds0  National Institute of Electronics and Information Technology (https://reg.nielitchennai.edu.in)

## Student can have any one of the following certifications:

- NPTEL Digital design
- NPTEL HDL programming

# V. TEXT BOOKS

- 1. Douglas Perry, "VHDL", Tata McGraw Hill, 4<sup>th</sup> edition, 2002.
- 2. W.H. Gothmann, "Digital Electronics- An introduction to theory and practice", PHI, 2<sup>nd</sup> edition, 2006.

# **VI. REFERENCE BOOKS**

- 1. Jacob Millman, Herbert Taub, Mothiki S PrakashRao, "Pulse Digital and Switching Waveforms", Tata McGraw-Hill, 3<sup>rd</sup> edition, 2008.
- 2. David A. Bell, "Solid State Pulse Circuits", PHI, 4<sup>th</sup> edition, 2002.
- 3. D Roy Chowdhury, "Linear Integrated Circuits", New Age International (p) Ltd, 2<sup>nd</sup> edition, 2003.
- 3. Ramakanth A. Gayakwad, "Op-Amps linear ICs", PHI, 3<sup>rd</sup> edition, 2003.