ARUNAI ENGINEERING COLLEGE Tiruvannamalai

2116

# DEPARTMENT OF COMPUTER SCIENCE AND ENGINEERING

LAB MANUAL

# CS8382- DIGITAL SYSTEMS LABORATORY

YEAR/SEM: II/III

Arun

# **LIST OF EXPERIMENTS**

- 1. Verification of Boolean Theorems using basic gates.
- 2. Design and implementation of combinational circuits using basic gates for arbitrary functions, code converters.
- 3. Design and implement Half/Full Adder and Subtractor.
- 4. Design and implement combinational circuits using MSI devices:
  - $\Box$  4 bit binary adder / subtractor
  - $\Box$  Parity generator / checker
  - □ Magnitude Comparator
  - □ Application using multiplexers
- 5. Design and implement shift-registers.
- 6. Design and implement synchronous counters.
- 7. Design and implement asynchronous counters.
- 8. Coding combinational circuits using HDL.
- 9. Coding sequential circuits using HDL.

Aruni

10. Design and implementation of a simple digital system (Mini Project).

# **INDEX**

| Ex.No. | Date | Title                                                            | Marks | Staff<br>Sign. |
|--------|------|------------------------------------------------------------------|-------|----------------|
| 1a     |      | STUDY OF LOGIC GATES                                             |       |                |
| 1b     |      | VERIFICATION OF BOOLEAN<br>THEOREMS USING DIGITAL<br>LOGIC GATES | 10    | 9              |
| 2      |      | CODE CONVERTOR                                                   | 0     |                |
| 3a     |      | ADDER AND SUBTRACTOR                                             |       |                |
| 4a     |      | 4-BIT ADDER AND SUBTRACTOR                                       |       |                |
| 4b     |      | PARITY GENERATOR &<br>CHECKER                                    |       |                |
| 4c     |      | MAGNITUDE COMPARATOR                                             |       |                |
| 4d     |      | MULTIPLEXER AND<br>DEMULTIPLEXER                                 |       |                |
| 5      |      | SHIFT REGISTER                                                   |       |                |
| 6      |      | SYNCHRONOUS AND<br>ASYNCHRONOUS COUNTER                          |       |                |
|        |      | CODING – VERILOG & VHDL                                          |       |                |
| 7      |      | BASIC LOGIC GATES                                                |       |                |
| 8      |      | COMBINATIONAL AND<br>SEQUENTIAL CIRCUITS                         |       |                |

#### AIM:

To study about logic gates and verify their truth tables.

# **APPARATUS REQUIRED:**

| SL.NO. | COMPONENT       | SPECIFICATION | QTY |
|--------|-----------------|---------------|-----|
| 1.     | AND GATE        | IC 7408       | 1   |
| 2.     | OR GATE         | IC 7432       | 1   |
| 3.     | NOT GATE        | IC 7404       | 1   |
| 4.     | NAND GATE 2 I/P | IC 7400       | 1   |
| 5.     | NOR GATE        | IC 7402       | 1   |
| 6.     | X-OR GATE       | IC 7486       | 1   |
| 7.     | NAND GATE 3 I/P | IC 7410       | 1   |
| 8.     | IC TRAINER KIT  | -             | 1   |
| 9.     | PATCH CORD      | <b>•</b>      | 14  |

#### **THEORY:**

Circuit that takes the logical decision and the process are called logic gates. Each gate has one or more input and only one output.

OR, AND and NOT are basic gates. NAND, NOR and X-OR are known as universal gates. Basic gates form these gates.

#### AND GATE:

The AND gate performs a logical multiplication commonly known as AND function. The output is high when both the inputs are high. The output is low level when any one of the inputs is low.

#### **OR GATE:**

The OR gate performs a logical addition commonly known as OR function. The output is high when any one of the inputs is high. The output is low level when both the inputs are low.

#### **NOT GATE:**

The NOT gate is called an inverter. The output is high when the input is low. The output is low when the input is high.

#### **AND GATE:**

The NAND gate is a contraction of AND-NOT. The output is high when both inputs are low and any one of the input is low .The output is low level when both inputs are high.

#### **NOR GATE:**

The NOR gate is a contraction of OR-NOT. The output is high when both inputs are low. The output is low when one or both inputs are high.

### **X-OR GATE:**

The output is high when any one of the inputs is high. The output is low when both the inputs are low and both the inputs are high.

### **PROCEDURE:**

- (i) Connections are given as per circuit diagram.
- (ii) Logical inputs are given as per circuit diagram.
- (iii) Observe the output and verify the truth table.

# AND GATE

#### **SYMBOL**



#### TRUTH TABLE

| А | в | A.B |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 1   |



OR GATE

#### SYMBOL :



#### TRUTH TABLE

| А | В | A+B |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 1   |

#### PIN DIAGRAM:



## NOT GATE

# PIN DIAGRAM



**SYMBOL** 



#### TRUTH TABLE :

| A | Ā |
|---|---|
| 0 | 1 |
| 1 | 0 |



### SYMBOL



#### **TRUTH TABLE :**

| Α | в | AB + AB |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 0       |

#### **PIN DIAGRAM**



# **2-INPUT NAND GATE**

## SYMBOL



### TRUTH TABLE

| A | В | A.B |
|---|---|-----|
| 0 | 0 | 1   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 0   |



**3-INPUT NAND GATE** 

SYMBOL :



# TRUTH TABLE

| A        | В  | С   | AB.C |
|----------|----|-----|------|
| D        | 0  | 0   | 1    |
| 0        | 0  | 1   | 1    |
| 0        | 1  | 0   | 1    |
| 0        | 18 | - 1 | - 10 |
| গ        | 0  | D   | 81   |
| <b>1</b> | 0  | 1   |      |
| 1        | 1  | D   | 1    |
| 1        | 1  | 1   | 0    |

PIN DIAGRAM:



### **PIN DIAGRAM**

# NOR GATE

#### SYMBOL :



TRUTH TABLE

| A | в | A+B |
|---|---|-----|
| 0 | O | 1   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 0   |



### **RESULT:**

The logic gates are studied and its truth tables are verified.

# Ex.No.-1b VERIFICATION OF BOOLEAN THEOREMS USING DIGITAL LOGIC GATES

# AIM:

To verify the Boolean Theorems using logic gates.

### **APPARATUS REQUIRED:**

| SL. NO. | COMPONENT        | SPECIFICATION | QTY.            |
|---------|------------------|---------------|-----------------|
| 1.      | AND GATE         | IC 7408       | 1               |
| 2.      | OR GATE          | IC 7432       | 1               |
| 3.      | NOT GATE         | IC 7404       | 1               |
| 4.      | IC TRAINER KIT   | -             | -1              |
| 5.      | CONNECTING WIRES | -             | As per required |

#### **THEORY:**

### **BASIC BOOLEAN LAWS**

#### 1. Commutative Law

The binary operator OR, AND is said to be commutative if,

1. A+B = B+A 2. A.B=B.A

#### 2. Associative Law

The binary operator OR, AND is said to be associative if,

1. A+(B+C) = (A+B)+C 2. A.(B.C) = (A.B).C

#### 3. Distributive Law

The binary operator OR, AND is said to be distributive if,

1. A+(B.C) = (A+B).(A+C) 2. A.(B+C) = (A.B)+(A.C)

### 4. Absorption Law

1. A+AB = A2. A+AB = A+B

**5. Involution (or) Double complement Law** 1. A = A

6. Idempotent Law

 $\bar{1}$ . A+A = A 2. A.A = A

#### 7. Complementary Law

1. A+A' = 12. A.A' = 0

### 8. De Morgan's Theorem

1. The complement of the sum is equal to the sum of the product of the individual complements.

A+B = A.B

2. The complement of the product is equal to the sum of the individual complements. A.B = A+B

#### Associative Laws of Boolean Algebra



$$A \bullet (B \bullet C) = (A \bullet B) \bullet C$$

Proof of the Associative Property for the OR operation: (A+B)+C = A+(B+C)

| Α | В | C | (A+B) | (B+C) | A+(B+C) | (A+B)+C |
|---|---|---|-------|-------|---------|---------|
| 0 | 0 | 0 | 0     | 0     | 0       | 0       |
| 0 | 0 | 1 | 0     | 1     | 1       | 1       |
| 0 | 1 | 0 | 1     | 1     | 1       | 1       |
| 0 | 1 | 1 | 1     | 1     | 1       | 1       |
| 1 | 0 | 0 | 1     | 0     | 1       | 1       |
| 1 | 0 | 1 | 1     | 1     | 1       | 1       |
| 1 | 1 | 0 | 1     | 1     | 1       | 1       |
| 1 | 1 | 1 | 1     | 1     | 1       | 1       |

Proof of the Associative Property for the AND operation:  $(A \cdot B) \cdot C = A \cdot (B \cdot C)$ 

| Α | B | С | (A·B) | (B·C) | A· (B·C) | (A·B)·C |
|---|---|---|-------|-------|----------|---------|
| 0 | 0 | 0 | 0     | 0     | 0        | 0       |
| 0 | 0 | 1 | 0     | 0     | 0        | 0       |
| 0 | 1 | 0 | 0     | 0     | 0        | 0       |
| 0 | 1 | 1 | 0     | 1     | 0        | 0       |
| 1 | 0 | 0 | 0     | 0     | 0        | 0       |
| 1 | 0 | 1 | 0     | 0     | 0        | 0       |
| 1 | 1 | 0 | 1     | 0     | 0        | 0       |
| 1 | 1 | 1 | 1     | 1     | 1        | 1       |

#### Distributive Laws of Boolean Algebra

 $A \bullet (B + C) = A \bullet B + A \bullet C$ A(B+C) = AB + AC



| Proof of Di   | stributive Ru | x = A(B) | + C) | X   | = AB + AC    |       | 9       |
|---------------|---------------|----------|------|-----|--------------|-------|---------|
| Α             | В             | С        | A-B  | A-C | (A·B)+ (A·C) | (B+C) | A·(B+C) |
| 0             | 0             | 0        | 0    | 0   | 0            | 0     | 0       |
| 0             | 0             | 1        | 0    | 0   | 0            | 1     | 0       |
| 0             | 1             | 0        | 0    | 0   | 0            | 1     | 0       |
| 0             | 1             | 1        | 0    | 0   | 0            | 1     | 0       |
| 1             | 0             | 0        | 0    | 0   | 0            | 0     | 0       |
| 1             | 0             | 1        | 0    | 1   | 1            | 1     | 1       |
| 1             | 1             | 0        | 1    | 0   | 1            | 1     | 1       |
| 1             | 1             | 1        | 1    | 1   | 1            | 1     | 1       |
| Proof of Dist | tributive Rul | e        |      |     |              |       |         |

| Α | B | C | A+B | A+C | (A+B) · (A+C) | (B·C) | A+(B·C) |
|---|---|---|-----|-----|---------------|-------|---------|
| 0 | 0 | 0 | 0   | 0   | 0             | 0     | 0       |
| 0 | 0 | 1 | 0   | 1   | 0             | 0     | 0       |
| 0 | 1 | 0 | 1   | 0   | 0             | 0     | 0       |
| 0 | 1 | 1 | 1   | 1   | 1             | 1     | 1       |
| 1 | 0 | 0 | 1   | 1   | 1             | 0     | 1       |
| 1 | 0 | 1 | 1   | 1   | 1             | 0     | 1       |
| 1 | 1 | 0 | 1   | 0   | 1             | 0     | 1       |
| 1 | 1 | 1 | 1   | 1   | 1             | 1     | 1       |

### **Demorgan's Theorem**

a) Proof of equation (1):

Construct the two circuits corresponding to the functions A'. B'and (A+B)' respectively. Show that for all combinations of A and B, the two circuits give identical results. Connect these circuits and verify their operations.





Proof (via Truth Table) of DeMorgan's Theorem  $\overline{A \cdot B} = \overline{A} + \overline{B}$ 

| А | В | A·B | $\overline{A \bullet B}$ | $\overline{A}$ | $\overline{B}$ | $\overline{A} + \overline{B}$ |
|---|---|-----|--------------------------|----------------|----------------|-------------------------------|
| 0 | 0 | 0   | 1                        | 1              | 1              | 1                             |
| 0 | 1 | 0   | 1                        | 1              | 0              | 1                             |
| 1 | 0 | 0   | 1                        | 0              | Ţ              | 1                             |
| 1 | 1 | 1   | 0                        | 0              | 0              | 0                             |
|   |   |     |                          |                | 0              |                               |

b) Proof of equation (2)

Construct two circuits corresponding to the functions A'+B'and (A.B)' A.B, respectively. Show that, for all combinations of A and B, the two circuits give identical results. Connect these circuits and verify their operations.



Proof (via Truth Table) of DeMorgan's Theorem  $\overline{A+B} = \overline{A} \cdot \overline{B}$ 

| А | В | A+B | $\overline{A+B}$ | Ā | $\overline{B}$ | $\overline{A} \cdot \overline{B}$ |
|---|---|-----|------------------|---|----------------|-----------------------------------|
| 0 | 0 | 0   | 1                | 1 | 1              | 1                                 |
| 0 | 1 | 1   | 0                | 1 | 0              | 0                                 |
| 1 | 0 | 1   | 0                | 0 | 1              | 0                                 |
| 1 | 1 | 1   | 0                | 0 | 0              | 0                                 |

#### Commutative Laws of Boolean Algebra

A + B = B + A



 $A \bullet B = B \bullet A$ 



#### We will also use the following set of postulates:

- P1: Boolean algebra is closed under the AND, OR, and NOT operations.
- **P2:** The identity element with respect to is one and + is zero. There is no identity element with respect to logical NOT.
- **P3:** The and + operators are commutative.
- P4: and + are distributive with respect to one another. That is,
  - $A \bullet (B + C) = (A \bullet B) + (A \bullet C) \text{ and } A + (B \bullet C) = (A + B) \bullet (A + C).$
- **P5:** For every value A there exists a value A' such that  $A \cdot A' = 0$  and A + A' = 1. This value is the logical complement (or NOT) of A.
- **P6:** and + are both associative. That is,  $(A \cdot B) \cdot C = A \cdot (B \cdot C)$  and (A+B)+C = A+(B+C). You can prove all other theorems in boolean algebra using these postulates.

#### **PROCEDURE:**

- 1. Obtain the required IC along with the Digital trainer kit.
- 2. Connect zero volts to GND pin and +5 volts to Vcc .
- 3. Apply the inputs to the respective input pins.
- 4. Verify the output with the truth table.

#### **RESULT:**

Thus the above stated Boolean laws are verified.

### Ex.No.-2

## AIM:

To design and implement 4-bit

- (i) Binary to gray code converter
- Gray to binary code converter (ii)
- (iii) BCD to excess-3 code converter
- (iv) Excess-3 to BCD code converter

### **APPARATUS REQUIRED:**

| (iv)   | Excess-3 to BCD code co | onverter      |      |  |
|--------|-------------------------|---------------|------|--|
| ARATUS | <b>REQUIRED:</b>        |               |      |  |
| SL.NO. | COMPONENT               | SPECIFICATION | QTY. |  |
| 1.     | X-OR GATE               | IC 7486       | 1    |  |
| 2.     | AND GATE                | IC 7408       | 1    |  |
| 3.     | OR GATE                 | IC 7432       | 1    |  |
| 4.     | NOT GATE                | IC 7404       | 1    |  |
| 5.     | IC TRAINER KIT          |               | 1    |  |
| 6.     | PATCH CORDS             | -             | 35   |  |

## **THEORY:**

The availability of large variety of codes for the same discrete elements of information results in the use of different codes by different systems. A conversion circuit must be inserted between the two systems if each uses different codes for same information. Thus, code converter is a circuit that makes the two systems compatible even though each uses different binary code.

The bit combination assigned to binary code to gray code. Since each code uses four bits to represent a decimal digit. There are four inputs and four outputs. Gray code is a non-weighted code.

The input variable are designated as B3, B2, B1, B0 and the output variables are designated as C3, C2, C1, Co. from the truth table, combinational circuit is designed. The Boolean functions are obtained from K-Map for each output variable.

A code converter is a circuit that makes the two systems compatible even though each uses a different binary code. To convert from binary code to Excess-3 code, the input lines must supply the bit combination of elements as specified by code and the output lines generate the corresponding bit combination of code. Each one of the four maps represents one of the four outputs of the circuit as a function of the four input variables.

A two-level logic diagram may be obtained directly from the Boolean expressions derived by the maps. These are various other possibilities for a logic diagram that implements this circuit. Now the OR gate whose output is C+D has been used to implement partially each of three outputs.

## **BINARY TO GRAY CODE CONVERTOR**

### **TRUTH TABLE:**

|           | <b>Binary Input</b> |           |           |    | Fray Code | e Output | Ó  |
|-----------|---------------------|-----------|-----------|----|-----------|----------|----|
| <b>B3</b> | B2                  | <b>B1</b> | <b>B0</b> | G3 | G2        | G1       | GO |
| 0         | 0                   | 0         | 0         | 0  | 0         | 0        | 0  |
| 0         | 0                   | 0         | 1         | 0  | 0         | 0        | 1  |
| 0         | 0                   | 1         | 0         | 0  | 0         | 1        | 1  |
| 0         | 0                   | 1         | 1         | 0  | 0         | 1        | 0  |
| 0         | 1                   | 0         | 0         | 0  | 1         | 1        | 0  |
| 0         | 1                   | 0         | 1         | 0  | 1         | 1        | 1  |
| 0         | 1                   | 1         | 0         | 0  | 1         | 0        | 1  |
| 0         | 1                   | 1         | 1         | 0  | 1         | 0        | 0  |
| 1         | 0                   | 0         | 0         |    | 1         | 0        | 0  |
| 1         | 0                   | 0         | 1         | 1  | 1         | 0        | 1  |
| 1         | 0                   | 1         | 0         | 1  | 1         | 1        | 1  |
| 1         | 0                   | 1         | 1         | 1  | 1         | 1        | 0  |
| 1         | 1                   | 0         | 0         | 1  | 0         | 1        | 0  |
| 1         | 1                   | 0         | 1         | 1  | 0         | 1        | 1  |
| 1         | 1                   | 1         | 0         | 1  | 0         | 0        | 1  |
| 1         | 1                   | 1         | 1         | 1  | 0         | 0        | 0  |

K-Map for G<sub>3</sub>



 $G_3 = B_3$ 

# K-Map for G<sub>2</sub>





# K-Map for G<sub>1</sub>



# K-Map for G<sub>0</sub>



G0 = B1 ⊕ B0

# **LOGIC DIAGRAM:**



# **GRAY CODE TO BINARY CONVERTOR**

# **TRUTH TABLE:**

|           |      |           |           |             | 0  |           |           |
|-----------|------|-----------|-----------|-------------|----|-----------|-----------|
|           | GRAY | CODE      |           | BINARY CODE |    |           |           |
| <b>G3</b> | G2   | <b>G1</b> | <b>G0</b> | <b>B3</b>   | B2 | <b>B1</b> | <b>B0</b> |
| 0         | 0    | 0         | 0         | 0           | 0  | 0         | 0         |
| 0         | 0    | 0         | 1         | 0           | 0  | 0         | 1         |
| 0         | 0    | 1         | 1         | 0           | 0  | 1         | 0         |
| 0         | 0    | 1         | 0         | 0           | 0  | 1         | 1         |
| 0         | 1    | 1         | 0         | 0           | 1  | 0         | 0         |
| 0         | 1    | 1         | 1         | 0           | 1  | 0         | 1         |
| 0         | 1    | 0         | 1         | 0           | 1  | 1         | 0         |
| 0         | 1    | 0         | 0         | 0           | 1  | 1         | 1         |
| 1         | 1    | 0         | 0         | 1           | 0  | 0         | 0         |
| 1         | 1    | 0         | 1         | 1           | 0  | 0         | 1         |
| 1         | 1    | 1         | 1         | 1           | 0  | 1         | 0         |
| 1         | 1    | 1         | 0         | 1           | 0  | 1         | 1         |
| 1         | 0    | 1         | 0         | 1           | 1  | 0         | 0         |
| 1         | 0    | 1         | 1         | 1           | 1  | 0         | 1         |
| 1         | 0    | 0         | 1         | 1           | 1  | 1         | 0         |
| 1         | 0    | 0         | 0         | 1           | 1  | 1         | 1         |

# K-Map for B<sub>3</sub>:

| IG2 | 00 | 01 | 11 | 10 |
|-----|----|----|----|----|
| 00  | 0  | 0  | 0  | 0  |
| 01  | 0  | 0  | o  | 0  |
| 11  | 1  | 1  | 1  | 1  |
| 10  | 1  | 1  | 1  | 1  |

$$\mathbf{B3} = \mathbf{G3}$$

# K-Map for B<sub>2</sub>:



B2 = G3⊕G2



Ari





# K-Map for B0:

| G10  | GO |    |    |    |
|------|----|----|----|----|
| G3G2 | 00 | 01 | 11 | 10 |
| 00   | 0  | 1  | 0  | 1  |
| 01   | 1  | 0  | 1  | o  |
| 11   | 0  | 1  | 0  | 1  |
| 10   | 1  | 0  | •  | 0  |



### LOGIC DIAGRAM:



**TRUTH TABLE:** 

# **BCD TO EXCESS-3 CONVERTOR**

**BCD** input

T

# Excess – 3 output

\_\_\_\_\_

| 1          | L  |    | 1  |    |    |    |    |  |
|------------|----|----|----|----|----|----|----|--|
| <b>B</b> 3 | B2 | B1 | BO | G3 | G2 | G1 | GO |  |
| 0          | 0  | 0  | 0  | 0  | 0  | 1  | 1  |  |
| 0          | 0  | 0  | 1  | 0  | 1  | 0  | 0  |  |
| 0          | 0  | 1  | 0  | 0  | 1  | 0  | 1  |  |
| 0          | 0  | 1  | 1  | 0  | 1  | 1  | 0  |  |
| 0          | 1  | 0  | 0  | 0  | 1  | 1  | 1  |  |
| 0          | 1  | 0  | 1  | 1  | 0  | 0  | 0  |  |
| 0          | 1  | 1  | 0  | 1  | 0  | 0  | 1  |  |
| 0          | 1  | 1  | 1  | 1  | 0  | 1  | 0  |  |
| 1          | 0  | 0  | 0  | 1  | 0  | 1  | 1  |  |
| 1          | 0  | 0  | 1  | 1  | 1  | 0  | 0  |  |
| 1          | 0  | 1  | 0  | Х  | Х  | Х  | Х  |  |
| 1          | 0  | 1  | 1  | Х  | Х  | Х  | Х  |  |
| 1          | 1  | 0  | 0  | Х  | Х  | Х  | Х  |  |
| 1          | 1  | 0  | 1  | Х  | Х  | Х  | х  |  |
| 1          | 1  | 1  | 0  | Х  | Х  | Х  | х  |  |
| 1          | 1  | 1  | 1  | Х  | X  | X  | Х  |  |

<u>K-Map for E<sub>3</sub>:</u>



E3 = B3 + B2 (B0 + B1)

K-Map for E<sub>2</sub>:



K-Map for E<sub>1</sub>:

| В1   | в0 |    |    |    |
|------|----|----|----|----|
| ВЗВ2 | 00 | 01 | 11 | 10 |
| 00   | 1  | 0  | 1  | 0  |
| 01   | 1  | 0  | 1  | 0  |
| 11   | x  | ×  | x  | x  |
| 10   | -  | 0  | ×  | x  |
|      |    |    |    | a  |

E1 = B1⊕ B0

K-Map for E<sub>0</sub>:

Arun



E0 = B0

# EXCESS-3 TO BCD CONVERTOR

## **TRUTH TABLE:**

| B3         B2         B1         B0         G3         G2 | 2 G1 | CO |
|-----------------------------------------------------------|------|----|
|                                                           |      | G0 |
|                                                           |      |    |
| 0 0 1 1 0 0                                               | 0    | -0 |
| 0 1 0 0 0                                                 | 0    | 1  |
| 0 1 0 1 0 0                                               | 1    | 0  |
| 0 1 1 0 0 0                                               | 1    | 1  |
| 0 1 1 1 0 1                                               | 0    | 0  |
| 1 0 0 0 1                                                 | 0    | 1  |
| 1 0 0 1 0 1                                               | 1    | 0  |
| 1 0 1 0 0 1                                               | 1    | 1  |
| 1 0 1 1 0                                                 | 0    | 0  |
| 1 1 0 0 1 0                                               | 0    | 1  |

# LOGIC DIAGRAM:



# EXCESS-3 TO BCD CONVERTOR

# **<u>K-Map for A</u>:**



 $\mathbf{A} = \mathbf{X1} \mathbf{X2} + \mathbf{X3} \mathbf{X4} \mathbf{X1}$ 

### K-Map for B:



 $\mathsf{B} = \mathsf{X2} \oplus (\,\overline{\mathsf{X3}} + \overline{\mathsf{X4}}\,)$ 

K-Map for C:

D.M



C = X3⊕X4

## K-Map for D:



#### **PROCEDURE:**

- (i) Connections were given as per circuit diagram.
- (ii) Logical inputs were given as per truth table
- (iii) Observe the logical output and verify with the truth tables.

 $D = \overline{X4}$ 

# **RESULT:**

Thus the following 4-bit converters are designed and constructed.

colled

- (i) Binary to gray code converter
- (ii) Gray to binary code converter
- (iii) BCD to excess-3 code converter
- (iv) Excess-3 to BCD code converter

### Ex.No.-3

## ADDER AND SUBTRACTOR

### AIM:

To design and construct half adder, full adder, half subtractor and full subtractor circuits and verify the truth table using logic gates.

| SL.NO. | COMPONENT      | SPECIFICATION | QTY. |
|--------|----------------|---------------|------|
| 1.     | AND GATE       | IC 7408       | 1    |
| 2.     | X-OR GATE      | IC 7486       | 1    |
| 3.     | NOT GATE       | IC 7404       | 1    |
| 4.     | OR GATE        | IC 7432       | 1    |
| 5.     | IC TRAINER KIT | - 6           | 1    |
| 6.     | PATCH CORDS    | -             | 23   |

### **APPARATUS REQUIRED:**

#### **THEORY:**

### HALF ADDER:

A half adder has two inputs for the two bits to be added and two outputs one from the sum 'S' and other from the carry 'c' into the higher adder position. Above circuit is called as a carry signal from the addition of the less significant bits sum from the X-OR Gate the carry out from the AND gate.

### **FULL ADDER:**

A full adder is a combinational circuit that forms the arithmetic sum of input; it consists of three inputs and two outputs. A full adder is useful to add three bits at a time but a half adder cannot do so. In full adder sum output will be taken from X-OR Gate, carry output will be taken from OR Gate.

## **HALF SUBTRACTOR:**

The half subtractor is constructed using X-OR and AND Gate. The half subtractor has two input and two outputs. The outputs are difference and borrow. The difference can be applied using X-OR Gate, borrow output can be implemented using an AND Gate and an inverter.

### **FULL SUBTRACTOR:**

The full subtractor is a combination of X-OR, AND, OR, NOT Gates. In a full subtractor the logic circuit should have three inputs and two outputs. The two half subtractor put together gives a full subtractor .The first half subtractor will be C and A B. The output will be difference output of full subtractor. The expression AB assembles the borrow output of the half subtractor and the second term is the inverted difference output of first X-OR.

# HALF ADDER

### **TRUTH TABLE:**

| Α | В | CARRY | SUM |
|---|---|-------|-----|
|   | _ |       | _   |
| 0 | 0 | 0     | 0   |
| 0 | 1 | 0     | 1   |
| 1 | 0 | 0     | 1   |
| 1 | 1 | 1     | 0   |
|   |   |       |     |

# K-Map for SUM:



SUM = A'B + AB'

# K-Map for CARRY:



CARRY = AB

# LOGIC DIAGRAM:



# FULL ADDER

# **TRUTH TABLE:**

| Α | B | C | CARRY | SUM |
|---|---|---|-------|-----|
|   |   |   |       |     |
| 0 | 0 | 0 | 0     | 0   |
| 0 | 0 | 1 | 0     | 1   |
| 0 | 1 | 0 | 0     | 1   |
| 0 | 1 | 1 | 1     | 0   |
| 1 | 0 | 0 | 0     | 1   |
| 1 | 0 | 1 | 1     | 0   |
| 1 | 1 | 0 | 1     | 0   |
| 1 | 1 | 1 | 1     | 1   |
|   |   |   |       |     |

# **K-Map for SUM**



SUM = A'B'C + A'BC' + ABC' + ABC

# K-Map for CARRY



 $\mathbf{CARRY} = \mathbf{AB} + \mathbf{BC} + \mathbf{AC}$ 

# LOGIC DIAGRAM:

# FULL ADDER USING TWO HALF ADDER



# **HALF SUBTRACTOR**

## **TRUTH TABLE:**

| Α                | B                | BORROW           | DIFFERENCE       |
|------------------|------------------|------------------|------------------|
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>1<br>0<br>0 | 0<br>1<br>1<br>0 |
|                  |                  |                  |                  |

# **K-Map for DIFFERENCE**



# **DIFFERENCE** = A'B + AB'

K-Map for BORROW



BORROW = A'B



# **FULL SUBTRACTOR**

# **TRUTH TABLE:**

| Α | B | C | BORROW | DIFFERENCE |
|---|---|---|--------|------------|
|   |   |   |        |            |
| 0 | 0 | 0 | 0      | 0          |
| 0 | 0 | 1 | 1      | 1          |
| 0 | 1 | 0 | 1      | 1          |
| 0 | 1 | 1 | 1      | 0          |
| 1 | 0 | 0 | 0      | 1          |
| 1 | 0 | 1 | 0      | 0          |
| 1 | 1 | 0 | 0      | 0          |
| 1 | 1 | 1 | 1      | 1          |

# K-Map for Difference



**Difference = A'B'C + A'BC' + AB'C' + ABC** 

# K-Map for Borrow







### **PROCEEDURE:**

- (i) Connections are given as per circuit diagram.
- (ii) Logical inputs are given as per circuit diagram.
- (iii) Observe the output and verify the truth table.

# **RESULT:**

Thus, the half adder, full adder, half subtractor and full subtractor circuits are designed, constructed and verified the truth table using logic gates.

Ex.No.-4a

### AIM:

To design and implement 4-bit adder and subtractor using basic gates and MSI device IC 7483.

| SL.NO. | COMPONENT      | SPECIFICATION | QTY. |
|--------|----------------|---------------|------|
| 1.     | IC             | IC 7483       | 1    |
| 2.     | EX-OR GATE     | IC 7486       | 1    |
| 3.     | NOT GATE       | IC 7404       | 1    |
| 3.     | IC TRAINER KIT | - 6           | 1    |
| 4.     | PATCH CORDS    | -             | 40   |

#### **APPARATUS REQUIRED:**

#### **THEORY:**

#### **4 BIT BINARY ADDER:**

A binary adder is a digital circuit that produces the arithmetic sum of two binary numbers. It can be constructed with full adders connected in cascade, with the output carry from each full adder connected to the input carry of next full adder in chain. The augends bits of 'A' and the addend bits of 'B' are designated by subscript numbers from right to left, with subscript 0 denoting the least significant bits. The carries are connected in chain through the full adder. The input carry to the adder is  $C_0$  and it ripples through the full adder to the output carry  $C_4$ .

#### **4 BIT BINARY SUBTRACTOR:**

The circuit for subtracting A-B consists of an adder with inverters, placed between each data input 'B' and the corresponding input of full adder. The input carry  $C_0$  must be equal to 1 when performing subtraction.

### **4 BIT BINARY ADDER/SUBTRACTOR:**

The addition and subtraction operation can be combined into one circuit with one common binary adder. The mode input M controls the operation. When M=0, the circuit is adder circuit. When M=1, it becomes subtractor.

#### **4 BIT BCD ADDER:**

Consider the arithmetic addition of two decimal digits in BCD, together with an input carry from a previous stage. Since each input digit does not exceed 9, the output sum cannot be greater than 19, the 1 in the sum being an input carry. The output of two decimal digits must be represented in BCD and should appear in the form listed in the columns.

ABCD adder that adds 2 BCD digits and produce a sum digit in BCD. The 2 decimal digits, together with the input carry, are first added in the top 4 bit adder to produce the binary sum.

### **PIN DIAGRAM FOR IC 7483:**



C

### **4-BIT BINARY ADDER**

### LOGIC DIAGRAM:



# **4-BIT BINARY SUBTRACTOR**



# **4-BIT BINARY ADDER/SUBTRACTOR**





### **TRUTH TABLE:**

|    | Inpu | t Dat | a A |           | Inpu      | t Dat     | a B       |   | A         | Addit     | tion      |           |   | Sub       | otract | tion |           |
|----|------|-------|-----|-----------|-----------|-----------|-----------|---|-----------|-----------|-----------|-----------|---|-----------|--------|------|-----------|
| A4 | A3   | A2    | A1  | <b>B4</b> | <b>B3</b> | <b>B2</b> | <b>B1</b> | C | <b>S4</b> | <b>S3</b> | <b>S2</b> | <b>S1</b> | В | <b>D4</b> | D3     | D2   | <b>D1</b> |
| 1  | 0    | 0     | 0   | 0         | 0         | 1         | 0         | 0 | 1         | 0         | 1         | 0         | 1 | 0         | 1      | 1    | 0         |
| 1  | 0    | 0     | 0   | 1         | 0         | 0         | 0         | 1 | 0         | 0         | 0         | 0         | 1 | 0         | 0      | 0    | 0         |
| 0  | 0    | 1     | 0   | 1         | 0         | 0         | 0         | 0 | 1         | 0         | 1         | 0         | 0 | 1         | 0      | 1    | 0         |
| 0  | 0    | 0     | 1   | 0         | 1         | 1         | 1         | 0 | 1         | 0         | 0         | 0         | 0 | 1         | 0      | 1    | 0         |
| 1  | 0    | 1     | 0   | 1         | 0         | 1         | 1         | 1 | 0         | 0         | 1         | 0         | 0 | 1         | 1      | 1    | 1         |
| 1  | 1    | 1     | 0   | 1         | 1         | 1         | 1         | 1 | 1         | 0         | 1         | 0         | 0 | 1         | 1      | 1    | 1         |
| 1  | 0    | 1     | 0   | 1         | 1         | 0         | 1         | 1 | 0         | 1         | 1         | 1         | 0 | 1         | 1      | 0    | 1         |

### **PROCEDURE:**

- (i) Connections were given as per circuit diagram.
- (ii) Logical inputs were given as per truth table

(iii) Observe the logical output and verify with the truth tables.

### **RESULT:**

Thus the 4-bit adder and subtractor using basic gates and MSI device IC 7483 is designed and implemented.

### Ex.No.-4b PARITY GENERATOR AND CHECKER

#### AIM:

To design and verify the truth table of a three bit Odd Parity generator and checker.

### **APPARATUS REQUIRED:**

| SL. NO. | NAME OF THE APPARATUS  | RANGE   | QUANTITY    |
|---------|------------------------|---------|-------------|
| 1.      | Digital IC trainer kit |         | 1           |
| 2.      | EX-OR gate             | IC 7486 |             |
| 3.      | NOT gate               | IC 7404 |             |
| 4.      | Connecting wires       |         | As required |

#### **THEORY:**

A parity bit is used for the purpose of detecting errors during transmission of binary information. A parity bit is an extra bit included with a binary message to make the number of 1's either odd or even. The message including the parity bit is transmitted and then checked at the receiving end for errors. An error is detected if the checked parity does not correspond with the one transmitted. The circuit that generates the parity bit in the transmitter is called a parity generator and the circuit that checks the parity in the receiver is called a parity checker.

In even parity the added parity bit will make the total number of 1's an even amount and in odd parity the added parity bit will make the total number of 1's an odd amount.

In a three bit odd parity generator the three bits in the message together with the parity bit are transmitted to their destination, where they are applied to the parity checker circuit. The parity checker circuit checks for possible errors in the transmission.

Since the information was transmitted with odd parity the four bits received must have an odd number of 1's. An error occurs during the transmission if the four bits received have an even number of 1's, indicating that one bit has changed during transmission. The output of the parity checker is denoted by PEC (parity error check) and it will be equal to 1 if an error occurs, i.e., if the four bits received has an even number of 1's.

# **ODD PARITY GENERATOR**

### **TRUTH TABLE:**

|        |       | INPUT    | 1       | OUTPUT            |  |
|--------|-------|----------|---------|-------------------|--|
| SL.NO. | ( Thr | ee bit m | essage) | ( Odd Parity bit) |  |
|        | Α     | В        | С       | Р                 |  |
| 1.     | 0     | 0        | 0       | 1                 |  |
| 2.     | 0     | 0        | 1       | 0                 |  |
| 3.     | 0     | 1        | 0       | 0                 |  |
| 4.     | 0     | 1        | 1       | 1                 |  |
| 5.     | 1     | 0        | 0       | 0                 |  |
| 6.     | 1     | 0        | 1       | 1                 |  |
| 7.     | 1     | 1        | 0       | 1                 |  |
| 8.     | 1     | 1        | 1       | 0                 |  |

From the truth table the expression for the output parity bit is, P(A, B, C) =  $\Sigma$  (0, 3, 5, 6)

Also written as,

 $P = A'B'C' + A'BC + AB'C + ABC' = (A \oplus B \oplus C)'$ 

### **ODD PARITY GENERATOR**

### **CIRCUIT DIAGRAM:**



# **ODD PARITY CHECKER**

**CIRCUIT DIAGRAM:** 



# **ODD PARITY CHECKER**

### **TRUTH TABLE:**

| SL.NO. |          | INP   | UT      |        | OUTPUT               |
|--------|----------|-------|---------|--------|----------------------|
| SL.NU. | (4 - Bit | Messa | ge Reco | eived) | (Parity Error Check) |
|        | Α        | B     | С       | Р      | X                    |
| 1.     | 0        | 0     | 0       | 0      | 1                    |
| 2.     | 0        | 0     | 0       | 1      | 0                    |
| 3.     | 0        | 0     | 1       | 0      | 0                    |
| 4.     | 0        | 0     | 1       | 1      | 1                    |
| 5.     | 0        | 1     | 0       | 0      | 0                    |
| 6.     | 0        | 1     | 0       | 1      | 1                    |
| 7.     | 0        | 1     | 1       | 0      | 1                    |
| 8.     | 0        | 1     | 1       | 1      | 0                    |
| 9.     | 1        | 0     | 0       | 0      | 0                    |
| 10.    | 1        | 0     | 0       | 1      | 1                    |
| 11.    | 1        | 0     | 1       | 0      | 1                    |
| 12.    | 1        | 0     | 1       | 1      | 0                    |
| 13.    | 1        | 1     | 0       | 0      | 1                    |
| 14.    | 1        | 1     | 0       | 1      | 0                    |
| 15.    | 1        | 1     | 1       | 0      | 0                    |
| 16.    | 1        | 1     | 1       | 1      | 1                    |

From the truth table the expression for the output parity checker bit is,

X (A, B, C, P) =  $\Sigma$  (0, 3, 5, 6, 9, 10, 12, 15)

The above expression is reduced as,

 $X = (A \oplus B \oplus C \oplus P)$ 

### **PROCEDURE:**

Connections are given as per the circuit diagrams.
 For all the ICs 7<sup>th</sup> pin is grounded and 14<sup>th</sup> pin is given +5 V supply.
 Apply the inputs and verify the truth table for the Parity generator and checker.

# **PIN DIAGRAM FOR IC 74180:**

|     |     |   | T        |
|-----|-----|---|----------|
| 16  | _ 1 | 1 | 14 — VCC |
| 17  | - 2 | С | 13 — 15  |
| PE  | _ 3 | 7 | 12 — 14  |
| PO  | - 4 | 4 | 11 — I3  |
| E   | - 5 | 1 | 10 — I2  |
| 0   | - 6 | 8 | 9 — I1   |
| GND | - 7 | 0 | 8 — IO   |
|     |     |   |          |

### **FUNCTION TABLE:**

| INPUTS                                  |    |    | OUT               | PUTS |
|-----------------------------------------|----|----|-------------------|------|
| Number of High Data                     | PE | PO | $\sum \mathbf{E}$ | ∑O   |
| <b>Inputs</b> ( <b>I0</b> – <b>I7</b> ) |    |    |                   |      |
| EVEN                                    | 1  | 0  | 1                 | 0    |
| ODD                                     | 1  | 0  | 0                 | 1    |
| EVEN                                    | 0  | 1  | 0                 | 1    |
| ODD                                     | 0  | 1  | 1                 | 0    |
| X                                       | 1  | 1  | 0                 | 0    |
| X                                       | 0  | 0  | 1                 |      |

# **16 BIT ODD/EVEN PARITY GENERATOR**

# LOGIC DIAGRAM:



# **TRUTH TABLE:**

| I | 7 Ie | 6 15 | I4 | I3 | I2 | I1 ] | [0 | I7 I6 | I5 : | [4] | [3 I | 2 I 1 | l <b>I</b> 0 | Active | ∑E | ΣO |
|---|------|------|----|----|----|------|----|-------|------|-----|------|-------|--------------|--------|----|----|
| 1 | 1    | 0    | 0  | 0  | 0  | 0    | 0  | 11    | 0    | 0   | 0    | 0     | 00           | 1      | 1  | 0  |
| 1 | 1    | 0    | 0  | 0  | 0  | 0    | 0  | 11    | 0    | 0   | 0    | 0     | 00           | 0      | 0  | 1  |
| 1 | 1    | 0    | 0  | 0  | 0  | 0    | 0  | 01    | 0    | 0   | 0    | 0     | 00           | 0      | 1  | 0  |

### **<u>16 BIT ODD/EVEN PARITY CHECKER</u>**

### LOGIC DIAGRAM



### **TRUTH TABLE:**

| I7 | 7 I( | 6 I: | 5 14 | 13 | I2 | I1 | <b>I0</b> | I7' | 16'15 | °I4' | 13' | 12, | '11' | 10' | Active | ∑E | ∑O |
|----|------|------|------|----|----|----|-----------|-----|-------|------|-----|-----|------|-----|--------|----|----|
| 0  | 0    | 0    | 0    | 0  | 0  | 0  | 1         |     | 00    | 0    | 0   | 0   | 0    | 00  | 1      | 1  | 0  |
| 0  | 0    | 0    | 0    | 0  | 1  | 1  | 0         |     | 00    | 0    | 0   | 0   | 1    | 10  | 0      | 1  | 0  |
| 0  | 0    | 0    | 0    | 0  | 1  | 1  | 0         |     | 00    | 0    | 0   | 0   | 1    | 10  | 1      | 0  | 1  |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |
|    |      |      |      |    |    |    |           |     |       |      |     |     |      |     |        |    |    |

### **RESULT:**

Thus the three bit and 16 bit odd Parity generator and checker circuits were designed, implemented and their truth tables were verified.

### MAGNITUDE COMPARATOR

### AIM:

To design and implement the magnitude comparator using MSI device.

### **APPARATUS REQUIRED:**

| SL.NO. | COMPONENT                  | SPECIFICATION | QTY. |
|--------|----------------------------|---------------|------|
| 1.     | AND GATE                   | IC 7408       | 2    |
| 2.     | X-OR GATE                  | IC 7486       | 1    |
| 3.     | OR GATE                    | IC 7432       | 1    |
| 4.     | NOT GATE                   | IC 7404       | 1    |
| 5.     | 4-BIT MAGNITUDE COMPARATOR | IC 7485       | 2    |
| 6.     | IC TRAINER KIT             | -             | 1    |
| 7.     | PATCH CORDS                | -             | 30   |
|        |                            |               |      |

#### **THEORY:**

The comparison of two numbers is an operator that determine one number is greater than, less than (or) equal to the other number. A magnitude comparator is a combinational circuit that compares two numbers A and B and determine their relative magnitude. The outcome of the comparator is specified by three binary variables that indicate whether A>B, A=B (or) A<B.

 $A = A_3 A_2 A_1 A_0$  $B = B_3 B_2 B_1 B_0$ 

The equality of the two numbers and B is displayed in a combinational circuit designated by the symbol (A=B).

This indicates A greater than B, then inspect the relative magnitude of pairs of significant digits starting from most significant position. A is 0 and that of B is 0.

We have A<B, the sequential comparison can be expanded as

$$A > B = A3B_3^{1} + X_3A_2B_2^{1} + X_3X_2A_1B_1^{1} + X_3X_2X_1A_0B_0^{1}$$
$$A < B = A_3^{1}B_3 + X_3A_2^{1}B_2 + X_3X2A_1^{1}B_1 + X_3X_2X_1A_0^{1}B_0$$

The same circuit can be used to compare the relative magnitude of two BCD digits. Where, A = B is expanded as,

**X**1

**X**0

olleos

$$A = B = (A_3 + B_3) (A_2 + B_2) (A_1 + B_1) (A_0 + B_0)$$

$$\Psi \quad \Psi \quad \Psi \quad \Psi \quad \Psi$$

**X**2

PIN DIAGRAM FOR IC 7485:

**X**3

|                                                                     | 1   |   | 1    |     |
|---------------------------------------------------------------------|-----|---|------|-----|
| В3                                                                  | - 1 |   | 16 — | vcc |
| 1(A <b)< td=""><td>- 2</td><td>1</td><td>15 —</td><td>A3</td></b)<> | - 2 | 1 | 15 — | A3  |
| 1(A=B)                                                              | _ 3 | С | 14 — | B2  |
| 1(A>B)                                                              | - 4 | 7 | 13 — | A2  |
| A>B                                                                 | _ 5 | 4 | 12 — | A1  |
| A=B                                                                 | - 6 | 8 | 11 — | B1  |
| A <b< td=""><td>- 7</td><td>5</td><td>10 —</td><td>AO</td></b<>     | - 7 | 5 | 10 — | AO  |
| GND                                                                 | - 8 |   | 9 —  | В0  |
|                                                                     |     |   |      |     |

### **8-BIT MAGNITUDE COMPARATOR**

### LOGIC DIAGRAM:



# **TRUTH TABLE:**

| A    | <b>N</b> | B    | 6    | A>B | A=B | A <b< th=""></b<> |
|------|----------|------|------|-----|-----|-------------------|
| 0000 | 0000     | 0000 | 0000 | 0   | 1   | 0                 |
| 0001 | 0001     | 0000 | 0000 | 1   | 0   | 0                 |
| 0000 | 0000     | 0001 | 0001 | 0   | 0   | 1                 |

### **PROCEDURE:**

- (i) Connections are given as per circuit diagram.
- (ii) Logical inputs are given as per circuit diagram.
- (iii) Observe the output and verify the truth table.

#### **RESULT:**

Thus the magnitude comparator using MSI device is designed and implemented.

i tradine contra

# Ex.No.-4d MULTIPLEXER AND DEMULTIPLEXER

### AIM:

To design and implement the multiplexer and demultiplexer using logic gates and study of IC 74150 and IC 74154.

| SL.NO. | COMPONENT      | SPECIFICATION | QTY. |
|--------|----------------|---------------|------|
| 1.     | 3 I/P AND GATE | IC 7411       | 2    |
| 2.     | OR GATE        | IC 7432       | 1    |
| 3.     | NOT GATE       | IC 7404       | 1    |
| 2.     | IC TRAINER KIT | - 6           | 1    |
| 3.     | PATCH CORDS    | -             | 32   |

### **APPARATUS REQUIRED:**

#### **THEORY:**

#### **MULTIPLEXER:**

Multiplexer means transmitting a large number of information units over a smaller number of channels or lines. A digital multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line. The selection of a particular input line is controlled by a set of selection lines. Normally there are  $2^n$  input line and n selection lines whose bit combination determine which input is selected.

### **DEMULTIPLEXER:**

The function of Demultiplexer is in contrast to multiplexer function. It takes information from one line and distributes it to a given number of output lines. For this reason, the demultiplexer is also known as a data distributor. Decoder can also be used as demultiplexer.

In the 1: 4 demultiplexer circuit, the data input line goes to all of the AND gates. The data select lines enable only one gate at a time and the data on the data input line will pass through the selected gate to the associated data output line.

# **<u>4:1 MULTIPLEXER</u>**

### **BLOCK DIAGRAM FOR 4:1 MULTIPLEXER:**



### **FUNCTION TABLE:**

| <b>S1</b> | <b>S0</b> | INPUTS Y                    |
|-----------|-----------|-----------------------------|
| 0         | 0         | $D0 \rightarrow D0 S1' S0'$ |
| 0         | 1         | $D1 \rightarrow D1 S1' S0$  |
| 1         | 0         | $D2 \rightarrow D2 S1 S0'$  |
| 1         | 1         | $D3 \rightarrow D3 S1 S0$   |

### Y = D0 S1' S0' + D1 S1' S0 + D2 S1 S0' + D3 S1 S0

**TRUTH TABLE:** 

| <b>S1</b> | <b>S0</b> | Y = OUTPUT |
|-----------|-----------|------------|
| 0         | 0         | D0         |
| 0         | 1         | D1         |
| 1         | 0         | D2         |
| 1         | 1         | D3         |

# CIRCUIT DIAGRAM FOR MULTIPLEXER:



### 1:4 DEMULTIPLEXER

### **BLOCK DIAGRAM FOR 1:4 DEMULTIPLEXER:**



# **FUNCTION TABLE:**

| <b>S1</b> | <b>S0</b> | INPUT                          |
|-----------|-----------|--------------------------------|
| 0         | 0         | $X \rightarrow D0 = X S1' S0'$ |
| 0         | 1         | $X \rightarrow D1 = X S1' S0$  |
| 1         | 0         | $X \rightarrow D2 = X S1 S0'$  |
| 1         | 1         | $X \rightarrow D3 = X S1 S0$   |

Y = X S1' S0' + X S1' S0 + X S1 S0' + X S1 S0

# **TRUTH TABLE:**

|           | INPUT     |     |    | OUTPUT |    |    |  |
|-----------|-----------|-----|----|--------|----|----|--|
| <b>S1</b> | <b>S0</b> | I/P | D0 | D1     | D2 | D3 |  |
| 0         | 0         | 0   | 0  | 0      | 0  | 0  |  |
| 0         | 0         | 1   | 1  | 0      | 0  | 0  |  |
| 0         | 1         | 0   | 0  | 0      | 0  | 0  |  |
| 0         | 1         | 1   | 0  | 1      | 0  | 0  |  |
| 1         | 0         | 0   | 0  | 0      | 0  | 0  |  |
| 1         | 0         | 1   | 0  | 0      | 1  | 0  |  |
| 1         | 1         | 0   | 0  | 0      | 0  | 0  |  |
| 1         | 1         | 1   | 0  | 0      | 0  | 1  |  |

# LOGIC DIAGRAM FOR DEMULTIPLEXER:



### **PIN DIAGRAM FOR IC 74150:**

|         | ř     | ~ |      | 1   |
|---------|-------|---|------|-----|
| E7      | - 1   |   | 24 - | VCC |
| E6      | - 2   | 1 | 23 - | E8  |
| E5      | _ 3   | с | 22 — | E9  |
| E4      | _ 4   | 0 | 21 _ | E10 |
| EЗ      | _ 5   | 7 | 20 _ | E11 |
| E2      | _ 6   | ~ | 19 — | E12 |
| E1      | - 7   | 4 | 18 — | E13 |
| EO      | - 8   | 1 | 17 — | E14 |
| ѕт      | _ 9   |   | 16 — | E15 |
| Q       | - 10  | 5 | 15 _ | A   |
| D       | -11   | 0 | 14 — | в   |
| GND     | - 12  |   | 13 - | с   |
| R IC 74 | 1154: |   |      | G   |
|         |       |   | 100  |     |

#### **PIN DIAGRAM FOR IC 74154:**

|     | (2). | ,  |      |     |
|-----|------|----|------|-----|
| QO  | - 1  |    | 24   | vcc |
| Q1  | - 2  | J. | 23 — | А   |
| Q2  | _ з  | с  | 22 – | в   |
| Q3  | _ 4  |    | 21   | с   |
| Q4  | _ 5  | 7  | 20 _ | D   |
| Q5  | _ 6  |    | 19 — | FE2 |
| Q6  | - 7  | 4  | 18 _ | FE1 |
| Q7  | - 8  | 1  | 17 _ | Q15 |
| Q8  | - 9  |    | 16 - | Q14 |
| Q9  | - 10 | 5  | 15 _ | Q13 |
| Q10 | -11  | 4  | 14   | Q12 |
| GND | - 12 |    | 13 - | Q11 |
|     |      |    |      |     |

### **PROCEDURE:**

- (i) Connections are given as per circuit diagram.
- (ii) Logical inputs are given as per circuit diagram.
- (iii) Observe the output and verify the truth table.

#### **RESULT:**

Thus the multiplexer and demultiplexer using logic gates are designed and implemented.

Ex.No.-5

### SHIFT REGISTER

### AIM:

To design and implement the following shift registers

- (i) Serial in serial out
- (ii) Serial in parallel out
- (iii) Parallel in serial out
- Parallel in parallel out (iv)

### **APPARATUS REQUIRED:**

| ARATUS | REQUIRED:      |               |      |
|--------|----------------|---------------|------|
| SL.NO. | COMPONENT      | SPECIFICATION | QTY. |
| 1.     | D FLIP FLOP    | IC 7474       | 2    |
| 2.     | OR GATE        | IC 7432       | 1    |
| 3.     | IC TRAINER KIT |               | 1    |
| 4.     | PATCH CORDS    | -             | 35   |

#### **THEORY:**

A register is capable of shifting its binary information in one or both directions is known as shift register. The logical configuration of shift register consist of a D-Flip flop cascaded with output of one flip flop connected to input of next flip flop. All flip flops receive common clock pulses which causes the shift in the output of the flip flop. The simplest possible shift register is one that uses only flip flop. The output of a given flip flop is connected to the input of next flip flop of the register. Each clock pulse shifts the content of register one bit position to right.

### **PIN DIAGRAM OF IC 7474:**

|                | 2   |   | 1         |
|----------------|-----|---|-----------|
| CLR0           | - 1 | E | 14 — VCC  |
| D0             | - 2 | С | 13 — CLR1 |
| CLK0           | - 3 | 7 | 12 — D1   |
| PRE0           | - 4 | 4 | 11 — CLK1 |
| S0             | - 5 | 7 | 10 - PRE1 |
| <del>s</del> o | - 6 | 4 | 9 — Q1    |
| GND            | - 7 |   | 8 — Q1    |
|                |     |   |           |

### SERIAL IN SERIAL OUT

# **LOGIC DIAGRAM:**



### **TRUTH TABLE:**

| CLK | Serial In | Serial Out |
|-----|-----------|------------|
| 1   | 1         | 0          |
| 2   | 0         | 0          |
| 3   | 0         | 0          |
| 4   | 1         | 1          |
| 5   | X         | 0          |
| 6   | X         | 0          |
| 7   | X         | 1          |

### SERIAL IN PARALLEL OUT

### **LOGIC DIAGRAM:**



### **TRUTH TABLE:**

|            |          | OUTPUT |       |    |    |  |
|------------|----------|--------|-------|----|----|--|
| CLK        | DATA     | Qa     | QB    | Qc | QD |  |
| 1          | 1        | 1      | 0     | 0  | 0  |  |
| 2          | 0        | 0      | 1     | 0  | 0  |  |
| 3          | 0        | 0      | 0     | 1  | 1  |  |
| 4          | 1        | 1      | 0     | 0  | 1  |  |
| PARA       | ALLEL IN | SERIA  | L OUT |    |    |  |
| <b>M</b> : |          |        |       |    |    |  |

# PARALLEL IN SERIAL OUT

# LOGIC DIAGRAM:



# **TRUTH TABLE:**

|  | CLK | Q3 | Q2 | Q1 | Q0 | O/P |
|--|-----|----|----|----|----|-----|
|  | 0   | 1  | 0  | 0  | 1  | 1   |
|  | 1   | 0  | 0  | 0  | 0  | 0   |
|  | 2   | 0  | 0  | 0  | 0  | 0   |
|  | 3   | 0  | 0  | 0  | 0  | 1   |

# PARALLEL IN PARALLEL OUT

### LOGIC DIAGRAM:



# **TRUTH TABLE:**

|     |                | DATA INPUT |                |                |    | OUTPUT |    |    |
|-----|----------------|------------|----------------|----------------|----|--------|----|----|
| CLK | D <sub>A</sub> | DB         | D <sub>C</sub> | D <sub>D</sub> | QA | QB     | QC | QD |
| 1   | 1              | 0          | 0              | 1              | 1  | 0      | 0  | 1  |
| 2   | 1              | 0          | 1              | 0              | 1  | 0      | 1  | 0  |

### **PROCEDURE:**

- (i) Connections are given as per circuit diagram.
- (ii) Logical inputs are given as per circuit diagram.
- (iii) Observe the output and verify the truth table.

### **RESULT:**

Arun

The Serial in serial out, Serial in parallel out, Parallel in serial out and Parallel in parallel out shift registers are designed and implemented.

# Ex.No.-6 SYNCHRONOUS AND ASYNCHRONOUS COUNTER

### AIM:

To design and implement synchronous and asynchronous counter.

| S.NO. | NAME OF THE APPARATUS  | RANGE   | QUANTITY    |
|-------|------------------------|---------|-------------|
| 1.    | Digital IC trainer kit |         | 1           |
| 2.    | JK Flip Flop           | IC 7473 | 2           |
| 3.    | D Flip Flop            | IC 7473 | 1           |
| 4.    | NAND gate              | IC 7400 | 1           |
| 5.    | Connecting wires       | 6       | As required |

### **APPARATUS REQUIRED:**

#### **THEORY:**

Asynchronous decade counter is also called as ripple counter. In a ripple counter the flip flop output transition serves as a source for triggering other flip flops. In other words the clock pulse inputs of all the flip flops are triggered not by the incoming pulses but rather by the transition that occurs in other flip flops. The term asynchronous refers to the events that do not occur at the same time. With respect to the counter operation, asynchronous means that the flip flop within the counter are not made to change states at exactly the same time, they do not because the clock pulses are not connected directly to the clock input of each flip flop in the counter.

A counter is a register capable of counting number of clock pulse arriving at its clock input. Counter represents the number of clock pulses arrived. A specified sequence of states appears as counter output. This is the main difference between a register and a counter. There are two types of counter, synchronous and asynchronous. In synchronous common clock is given to all flip flop and in asynchronous first flip flop is clocked by external pulse and then each successive flip flop is clocked by Q or Q output of previous stage. A soon the clock of second stage is triggered by output of first stage. Because of inherent propagation delay time all flip flops are not activated at same time which results in asynchronous operation.

### **PIN DIAGRAM FOR IC 7476:**

|      |     | $\neg$ |          |
|------|-----|--------|----------|
| CLK1 | - 1 |        | 16 — K1  |
| PRE1 | - 2 | 1      | 15 — Q1  |
| CLR1 | _ 3 | С      | 14 — Q1  |
| J1   | - 4 | 7      | 13 — GND |
| vcc  | _ 5 | 4      | 12 — K2  |
| CLK2 | - 6 | 7      | 11 — Q2  |
| PRE2 | - 7 | 6      | 10 — Q2  |
| CLR2 | - 8 |        | 9 — J2   |
|      |     |        |          |

# **CIRCUIT DIAGRAM:**



# **TRUTH TABLE:**

Antha

i.

| CLK | QA | QB | QC | QD |
|-----|----|----|----|----|
| 0   | 0  | 0  | 0  | 0  |
| 1   | 1  | 0  | 0  | 0  |
| 2   | 0  | 1  | 0  | 0  |
| 3   | 1  | 1  | 0  | 0  |
| 4   | 0  | 0  | 1  | 0  |
| 5   | 1  | 0  | 1  | 0  |
| 6   | 0  | 1  | 1  | 0  |
| 7   | 1  | 1  | 1  | 0  |
| 8   | 0  | 0  | 0  | 1  |
| 9   | 1  | 0  | 0  | 1  |
| 10  | 0  | 1  | 0  | 1  |
| 11  | 1  | 1  | 0  | 1  |
| 12  | 0  | 0  | 1  | 1  |
| 13  | 1  | 0  | 1  | 1  |
| 14  | 0  | 1  | 1  | 1  |
| 15  | 1  | 1  | 1  | 1  |

# LOGIC DIAGRAM FOR MOD - 10 RIPPLE COUNTER:



# **TRUTH TABLE:**

| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | CLK | QA | QB | QC | QD |
|-------------------------------------------------------------------------------------|-----|----|----|----|----|
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 0   | 0  | 0  | 0  | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 1   | 1  | 0  | 0  | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 2   | 0  | 1  | 0  | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 3   | 1  | 1  | 0  | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 4   | 0  | 0  | 1  | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                               | 5   | 1  | 0  | 1  | 0  |
| 8         0         0         1           9         1         0         0         1 | 6   | 0  | 1  | 1  | 0  |
| 9 1 0 0 1                                                                           | 7   | 1  | 1  | 1  | 0  |
|                                                                                     | 8   | 0  | 0  | 0  | 1  |
| 10 0 0 0 0                                                                          | 9   | 1  | 0  | 0  | 1  |
|                                                                                     | 10  | 0  | 0  | 0  | 0  |

### **PIN DIAGRAM:**

|                | 2)<br> | $\sim$ | 8         |
|----------------|--------|--------|-----------|
| CLR0           | - 1    | Ĩ      | 14 — VCC  |
| D0             | - 2    | С      | 13 — CLR1 |
| CLK0           | _ 3    | 7      | 12 — D1   |
| PRE0           | - 4    | 4      | 11 — CLK1 |
| S0             | - 5    | 7      | 10 - PRE1 |
| <del>s</del> o | - 6    | 4      | 9 — Q1    |
| GND            | - 7    |        | 8 — Q1    |
|                |        |        |           |

# **SYNCHRONOUS COUNTER**

### LOGIC DIAGRAM:



# **TRUTH TABLE:**

|     | OUTPUT |    |    |                |    |
|-----|--------|----|----|----------------|----|
| CLK | DATA   | QA | QB | Q <sub>C</sub> | QD |
| 1   | 1      | 1  | 0  | 0              | 0  |
| 2   | 0      | 0  | 1  | 0              | 0  |
| 3   | 0      | 0  | 0  | 1              | 1  |
| 4   | 1      | 1  | 0  | 0              | 1  |

college

### **PROCEDURE:**

- Connections are given as per circuit diagram. (i)
- Logical inputs are given as per circuit diagram. (ii)
- Observe the output and verify the truth table. (iii)

### **RESULT:**

Thus the synchronous and asynchronous counter are designed and implemented.

# Ex.No.-7 IMPLEMENTATION OF BASIC LOGIC GATES

# AIM:

To implement all the basic logic gates using Verilog and VHDL simulator.

# LOGIC GATE SYMBOLS

# TRUTH TABLES















| 2 Input AND gate |   |     |  |
|------------------|---|-----|--|
| A                | В | A.B |  |
| 0                | 0 | O   |  |
| 0                | 1 | 0   |  |
| 1                | 0 | 0   |  |
| 1                | 1 |     |  |

eg

| 2 Input OR gate |   |     |
|-----------------|---|-----|
| A               | В | A+B |
| 0               | 0 | 0   |
| 0               |   | 1   |
|                 | 0 | 1   |
| 1               | 1 | 1   |

| NOT gate |   |
|----------|---|
| Α        | Ā |
| 0        | 1 |
| 1        | 0 |

20

| 2 Input NAND gate |   |     |
|-------------------|---|-----|
| A                 | В | A.B |
| 0                 | 0 | 1   |
| 0                 | 1 | 1   |
| 1                 | 0 | 1   |
| 1                 | 1 | 0   |

| 2 Input NOR gate |   |     |  |
|------------------|---|-----|--|
| A                | В | A+B |  |
| 0                | 0 | 1   |  |
| 0                | 1 | 0   |  |
| 1                | 0 | 0   |  |
| 1                | 1 | n   |  |

| 2 Input EXOR gate |   |     |
|-------------------|---|-----|
| Α                 | В | A⊕B |
| 0                 | 0 | 0   |
| 0                 | 1 | 1   |
| 1                 | 0 | 1   |
| 1                 | 1 | 0   |

| 2 Inpu | 2 Input EXNOR gate |     |  |  |
|--------|--------------------|-----|--|--|
| A      | В                  | A⊕B |  |  |
| 0      | 0                  | 1   |  |  |
| 0      | 1                  | 0   |  |  |
| · 1.   | 0                  | 0   |  |  |
| 1      | 1                  | 1   |  |  |

# **VERILOG CODE**

| AND GATE                                            | OR GATE                       |
|-----------------------------------------------------|-------------------------------|
| AND GATE                                            | ORGAIL                        |
| module and12(a,b,c);                                | module or12(a,b,d);           |
| input a;                                            | input a;                      |
| input b;                                            | input b;                      |
| output c;                                           | output d;                     |
| assign $c = a \& b$ ;                               | assign $d = a / b$ ;          |
| endmodule                                           | endmodule                     |
|                                                     |                               |
| NAND GATE                                           | XOR GATE                      |
| $\overline{module \ nand12}(a,b,e);$                | module xor12(a,b,h);          |
| input a;                                            | input a;                      |
| input b;                                            | input b;                      |
| output e;                                           | output h;                     |
| assign $e = \sim (a \& b);$                         | assign $h = a \wedge b$ ;     |
| endmodule                                           | endmodule                     |
|                                                     |                               |
| XNOR GATE                                           | NOR GATE                      |
| $module \ xnor12(a,b,i);$                           | module nor12(a,b,f);          |
| input a;                                            | input a;                      |
| input b;                                            | input b;                      |
| output i;                                           | output f;                     |
| $assign i = \sim (a \wedge b);$                     | $assign f = \sim (a \mid b);$ |
| endmodule                                           | endmodule                     |
| NOT CATE                                            |                               |
| $\frac{\text{NOT GATE}}{\text{module not12}(a,g)};$ |                               |
| input a;                                            |                               |
| output g;                                           |                               |
| $assign g = \sim a;$                                |                               |
| endmodule                                           |                               |
|                                                     |                               |

# AND GATE

# **VERILOG CODE:**

module and12(a,b,c);
input a;
input b;
output c;
assign c = a & b;
endmodule

### **OUTPUT WAVEFORM:**

| Name<br>1 a<br>1 b<br>1 c                                                           | Value<br>1<br>1<br>0 |                   | 2,109,450,000 ps   | 2,109,450,100 ps 2 | 109,450,200 ps 2, | 109,450,300 ps 2, | 109,450,400 ps 2, | 109,450,500 ps : |
|-------------------------------------------------------------------------------------|----------------------|-------------------|--------------------|--------------------|-------------------|-------------------|-------------------|------------------|
| ERILOG COI                                                                          |                      |                   | <u>OR (</u>        | <u>GATE</u>        |                   |                   |                   | 99               |
| odule or12(a,b)<br>input a;<br>input b;<br>output d;<br>assign d = a / l<br>dmodule |                      |                   |                    |                    | no                |                   |                   |                  |
| UTPUT WAV                                                                           | EFORM:               | 11,999,600 ps 11. | .999,650 ps (1.999 | ,700 ps  1,999,750 | ps (1,999,800 ps  | : 11,999,850 ps   | 11.999,900 ps     | 11,999,950 ps    |

# OR GATE

### **VERILOG CODE:**

module or12(a,b,d); input a; input b; output d; assign d = a / b; endmodule

### **OUTPUT WAVEFORM:**

| Name                | Value | 1,999,600 ps | 1,99 | 19,65 | 0 ps | 1 | ,999,70 | 0 ps | 1 | ,999,75 | 0 ps | 1,999, | BOO ps | 1,999, | 850 ps | 1,999 | ,900 p | 5 | 1,999 | ,950 ps |   |
|---------------------|-------|--------------|------|-------|------|---|---------|------|---|---------|------|--------|--------|--------|--------|-------|--------|---|-------|---------|---|
| l <mark>la</mark> a | 1     |              |      | _     |      |   |         |      |   |         |      |        |        |        |        | 2     |        |   |       |         |   |
| Ъ                   | 0     |              |      |       |      |   |         |      |   |         |      |        |        |        |        |       |        |   |       |         | 1 |
| l <mark>la</mark> d | 1     |              |      |       |      |   |         |      |   |         |      |        |        | _      |        |       |        |   |       |         |   |

### **NOT GATE**

### **VERILOG CODE:**

module not12(a,g); input a; output g; assign g = a;endmodule

### **OUTPUT WAVEFORM:**

| Name         | Value | 1,999,200 | ps | 1,999,300 | ) ps | 1,999,400 | ps | 1,999,500 | ps | 1,999,600 | ps | 1,999,700 | ) ps | 1,999,800 | ps | 1,999,900 | ) ps |
|--------------|-------|-----------|----|-----------|------|-----------|----|-----------|----|-----------|----|-----------|------|-----------|----|-----------|------|
| 1 <b>6</b> a | 1     |           |    |           |      |           |    |           |    |           |    |           |      |           |    |           |      |
| կ ց          | 0     |           |    |           |      |           |    |           |    |           |    |           |      |           |    |           |      |
|              |       |           |    |           |      |           |    |           |    |           |    |           |      |           |    |           |      |

### EX-OR GATE

### **VERILOG CODE:**

module xor12(a,b,h);
 input a;
 input b;
 output h;
 assign h = a^ b;
endmodule

### **VHDL CODE:**

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL;

end xor\_gate; architecture Behavioral of xor\_gate is begin c <= a xor b; end Behavioral;

### **OUTPUT WAVEFORM:**



inc

### **RESULT:**

Thus all the basic logic gates are implemented and verified using Verilog and VHDL simulator.

colleg

# Ex.No.-8 COMBINATIONAL AND SEQUENTIAL CIRCUITS

### AIM:

To simulate the sequential and combinational circuits using HDL simulator (Verilog and VHDL).

### **<u>1. HALF ADDER</u>**

# **Truth Table**

| Inp | out |        | Output   |
|-----|-----|--------|----------|
| Α   | В   | S(Sum) | C(Carry) |
| 0   | 0   | 0      | 0        |
| 0   | 1   | 1      | 0        |
| 1   | 0   | 1      | 0        |
| 1   | 1   | 1      | 1        |

### <u>Circuit Diagram</u>



# **Graphical Notation**

colled



# **Equations**

S (Sum) =A^B C (Carry) =AB

# Verilog Code:

module hadd(a,b,s,c); input a; input b; output s; output c; assign s = a ^ b; assign c = a & b; endmodule

# **Output:**

| ame                     | Value | 492,916,750 ps | 492,916,800 ps | 492,916,850 ps | 492,916,900 ps | 492,916,950 ps | 492,917,000 ps | 492,917,050 ps |
|-------------------------|-------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| l <mark>o</mark> a      | 1     | - 10 12 10 12  |                | 20 12 20 12    |                | 20 22 22 22    |                | N 12 10 12     |
| VHDL C                  | de    |                |                |                |                |                |                |                |
| <b>1</b> s              | 0     |                |                |                |                |                |                |                |
| <sup>1</sup> ibrary IEE | 1     |                |                |                |                |                |                |                |

use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity halfadder is port( a : in std\_logic; b : in std\_logic; sum : out std\_logic; carry : out std\_logic ); end halfadder; architecture Behavioral of halfadder is begin sum <= (a xor b); carry <= (a and b); end Behavioral;

### **Input:**

# **Output:**

| <u>Input:</u><br>a : 1 ;  |             |      |          |              |              |              |              |              |
|---------------------------|-------------|------|----------|--------------|--------------|--------------|--------------|--------------|
| a : 1 ;<br>b :1;          |             |      |          |              |              |              |              |              |
| Sum : 0                   |             |      |          |              |              |              |              |              |
| Carry :                   |             |      |          |              |              |              |              |              |
| <u>Output:</u>            |             |      |          |              |              |              |              |              |
| outputt                   |             | _    |          |              |              |              |              |              |
| ame                       | Value       | 2,67 | 6,931 ps | 2,676,932 ps | 2,676,933 ps | 2,676,934 ps | 2,676,935 ps | 2,676,936 ps |
|                           |             |      |          | +            |              |              |              |              |
| l <mark>n</mark> a        | 1           |      |          |              |              |              |              |              |
| Ц <mark>а</mark> а<br>Цав | 1           |      |          |              |              |              |              |              |
|                           | 1<br>1<br>0 |      |          |              |              |              |              |              |

# 2. FULL ADDER

### Truth Table

|   | Input |   | O   | utput |
|---|-------|---|-----|-------|
| Α | В     | С | 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     |



### **VHDL Code:**

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity fulladder is port( a : in std\_logic; b : in std\_logic; cin : in std\_logic; sum : out std\_logic; carry : out std\_logic ); end fulladder: architecture Behavioral of fulladder is begin sum <= (a xor b xor cin); carry <= (a and b) or (b and cin) or (a and cin); end Behavioral;

# **Output:**

Ind

### **<u>3. HALF SUBTRACTOR</u>**

### Verilog Code:

module hsub(a,b,d,bor); Input a; Input b; output d; output bor; assign d=)a^b); assign bor = (~a&~b); end module

### VHDL Code:

library IEEE;

colled

use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity halfsubtractor is port( a : in std\_logic; b : in std\_logic; dif : out std\_logic; bor : out std\_logic ); end halfsubtractor; architecture Behavioral of halfsubtractor is begin dif <= a xor b; bor  $\leq ((not a) and b);$ end Behavioral;

# **Output:**

| end halfsubt       |          |               |              |              |              |              |              |      |
|--------------------|----------|---------------|--------------|--------------|--------------|--------------|--------------|------|
|                    | Behavior | al of halfsub | tractor is   |              |              |              |              |      |
| begin              |          |               |              |              |              |              |              |      |
| dif <= a xor       | b;       |               |              |              |              |              |              |      |
| bor <= ((not       | a) and b | o);           |              |              |              |              |              |      |
| end Behavio        |          |               |              |              |              |              |              |      |
|                    |          |               |              |              |              |              |              |      |
| Output:            |          |               |              |              |              |              |              |      |
|                    |          |               |              |              |              |              |              |      |
|                    |          |               |              |              |              |              | 1            | 1    |
| Name               | Value    | 1,979,480 ps  | 1,979,481 ps | 1,979,482 ps | 1,979,483 ps | 1,979,484 ps | 1,979,485 ps | 1,97 |
| l <mark>a</mark> a | 1        |               |              |              |              |              |              |      |
| Ць                 | 0        |               |              |              |              |              |              |      |
| 🗓 dif              | 1        |               |              |              |              |              |              |      |
| u bor              | 0        |               |              |              |              |              |              |      |
|                    |          |               |              |              |              |              |              |      |

# 4. FULL SUBTRACTOR

Verilog Code: module sub(a,b,c,d,b out); input a; input b; input c; output d; output bout; assign  $d = (a \wedge b) \wedge c;$ assign bout = (~a & b)|(b & c)|(c & ~a);endmodule

### **Output:**

| Name               | Value | <br>272,181,300 ps | 272,181,350 ps | 272,181,400 ps | 272, 181, 450 ps | 272,181,500 ps | 272, 181, 550 ps |
|--------------------|-------|--------------------|----------------|----------------|------------------|----------------|------------------|
| l <mark>a</mark> a | 1     |                    |                |                |                  |                |                  |
| Ц                  | 0     |                    |                |                |                  |                |                  |
| l <mark>o</mark> c | 1     |                    |                |                |                  |                |                  |
| log d<br>log bout  | 0     |                    |                |                |                  |                |                  |
| 1 bout             | 0     |                    | _              | -              |                  |                | _                |

### VHDL Code:

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD LOGIC ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity fullsubtractor is port( a : in std\_logic; b : in std\_logic; cin : in std\_logic; dif : out std\_logic; bor : out std\_logic ); end fullsubtractor: architecture Behavioral of fullsubtractor is begin dif <= a xor b xor cin; bor  $\leq$  (((not a) and b) or (( not a) and cin) or (b and cin)); end Behavioral;

### **INPUT:**

### **Output:**

| end Denaviora                | u1,   |     |           |                             |              |              |                                 |
|------------------------------|-------|-----|-----------|-----------------------------|--------------|--------------|---------------------------------|
| <b>INPUT:</b> a : 0 ;        |       |     |           |                             |              |              |                                 |
| b :0;                        |       |     |           |                             |              |              |                                 |
| Cin : 1                      |       |     |           |                             |              |              |                                 |
| Difference : 1<br>Borrow : 1 |       |     |           |                             |              |              |                                 |
| <u>Output:</u>               |       |     |           | C                           |              |              |                                 |
|                              |       | _   |           |                             |              |              |                                 |
| Name                         | ¥alue | 1,9 | 99,995 ps | 1,999,996 ps                | 1,999,997 ps | 1,999,998 ps | 1,999,999 ps 2                  |
| l <mark>la</mark> a          | 0     |     |           | ) (19)20-0.0) (0)/20-0.0) ( |              |              | 01234.0) (01224.0) (01224.0) (2 |
| 1 в                          | 0     |     |           |                             |              |              |                                 |
| l <mark>a</mark> cin         | 1     |     |           |                             |              |              |                                 |
| 1 dif                        | 1     |     |           |                             |              |              |                                 |
| 1 bor                        | 1     |     |           |                             |              |              |                                 |
|                              |       |     |           |                             |              |              |                                 |

### **5. MULTIPLEXER**

# Verilog Code:

module mux4to1(Y, I0,I1,I2,I3, sel); output Y; input I0,I1,I2,I3; input [1:0] sel; reg Y; always @ (sel or I0 or I1 or I2 or I3) case (sel)

collegs

```
2'b00:Y=I0;
2'b01:Y=I1;
2'b10: Y=I2;
2'b11: Y=I3;
endcase
endmodule
```

# Output:

| Value   | C. L. C. L | 1,500 ns |    | 2,000 ns | 2,500 ns | 3,000 ns | 3,500 ns | 4,000 ns | 4,500 ns |
|---------|------------|----------|----|----------|----------|----------|----------|----------|----------|
| 13 - C. |            |          |    |          |          |          |          |          |          |
|         |            |          |    |          | 2        |          |          |          |          |
| e.      |            |          |    |          |          |          |          |          |          |
|         |            |          |    |          | 8        |          |          |          |          |
| 0       | 00         | )        |    |          | 01       | x        | 10       |          | 11       |
|         |            |          |    |          |          |          |          |          |          |
| 0       |            | 00       | 00 |          |          |          |          |          |          |

# VHDL Code:

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity mux is port( inp : in std\_logic\_vector(3 downto 0); sel : in std\_logic\_vector(1 downto 0); muxout : out std\_logic --mux output line ); end mux; architecture Behavioral of mux is begin process(inp,sel) begin case sel is when "00" => muxout <= inp(0); -- mux O/P=1 I/P-- when "01" => muxout <= inp(1); -- mux O/P=2 I/P-- when "10" => muxout <= inp(2); -- mux O/P=3 I/P-- when "11" => muxout <= inp(3); -- mux O/P=4 I/P-- when others => end case; end process; end Behavioral;

# Truth Table:

|       | INPUTS |      |      |      |      |        |  |  |  |  |
|-------|--------|------|------|------|------|--------|--|--|--|--|
| sel 1 | sel0   | inp0 | inpl | inp2 | inp3 | muxout |  |  |  |  |
| 0     | 0      | Ι    | 0    | 0    | 0    | 1      |  |  |  |  |
| 0     | 1      | 0    | I    | 0    | 0    | I      |  |  |  |  |
| 1     | 0      | 0    | 0    | I    | 0    | Ι      |  |  |  |  |
| 1     | 1      | 0    | 0    | 0    | Ι    | I      |  |  |  |  |

### **6. DEMULTIPLEXER**

### Verilog Code:

module demux(S,D,Y); Input [1:0] S; Input D; Output [3:0] Y; reg Y; always @(S OR ) case({D,S}) 3'b100: Y=4'b0001; 3'b101: Y=4'b0000; 3'b111: Y=4'b1000; default:Y=4'b0000; endcase endmodule

### VHDL Code:

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity demux is
port(
dmuxin : in std_logic;
sel : in std_logic_vector(1 downto 0);
oup : out std_logic_vector(3 downto 0)
):
end demux;
architecture Behavioral of demux is
begin
process(dmuxin,sel)
begin
case sel is
when "00" =>
oup(0) \le dmuxin; --1 dmux o/p = dmux i/p--
oup(1) <= '0';
oup(2) <= '0';
oup(3) \le 0';
when "01" =>
oup(0) \le 0';
oup(1) \le dmuxin; -2 dmux o/p = dmux i/p--
oup(2) \le 0';
oup(3) \le '0';
when "10" =>
```

ind

oup(0) <= '0'; oup(1) <= '0'; oup(2) <= dmuxin; --3 dmux o/p = dmux i/p-oup(3) <= '0'; when "11" => oup(0) <= '0'; oup(1) <= '0'; oup(2) <= '0';  $oup(3) \le dmuxin; --4 dmux o/p = dmux i/p-$ when others =>end case; end process; end Behavioral;

### **Truth Table:**

| end case;<br>end proces<br>end Behav | ss;<br>ioral; |               |                |                  |        | 200  |  |  |  |  |
|--------------------------------------|---------------|---------------|----------------|------------------|--------|------|--|--|--|--|
|                                      | INPUTS        |               | OUTPUTS        |                  |        |      |  |  |  |  |
| sel1                                 | sel0          | dmuxin        | oup0           | oup1             | oup2   | oup3 |  |  |  |  |
| 0                                    | 0             | Ι             | Ι              | 0                | 0      | 0    |  |  |  |  |
| 0                                    | 1             | I             | 0              | I                | 0      | 0    |  |  |  |  |
| 1                                    | 0             | I             | 0              | 0                | Ι      | 0    |  |  |  |  |
| 1                                    | 1             | I             | 0              | 0                | 0      | Ι    |  |  |  |  |
|                                      | NOT           | E : I means b | inary input wł | nich is either ( | ) or 1 |      |  |  |  |  |

# **Output:**

| Nam | e                        | Value 🚽 | 0 us | lius<br>Lius IIIIII | 2us  | 3us  | 14 us | 5us (f |
|-----|--------------------------|---------|------|---------------------|------|------|-------|--------|
| l   | 🔓 dmuxin                 | υ       |      |                     |      |      |       |        |
|     | f sel[1:0]               | W       | UU ) | 00                  | 01   | 10   | 1     | 1)     |
|     | f sel[1:0]<br>d oup[3:0] | υυυυ    | UUUU | 0001                | 0010 | 0100 | 1000  | 0000   |
|     |                          |         |      |                     |      |      |       |        |

# **VHDL Code:**

### 7. D FLIPFLOP

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; entity dff is

port( clk : in std\_logic; --clock input rst : in std\_logic; --active low,synchronous reset d : in std\_logic; --d input q,qbar : out std\_logic --flip flop outputs ie,Qn+1 and its complement ); end dff; architecture Behavioral of dff is begin process(clk,rst) begin if rising\_edge(clk) then if (rst = '0') then --active low, synchronous reset q <= '0'; qbar <= '1'; else  $q \ll d;$  $qbar \leq not(d);$ end if; end if; end process; end Behavioral;

# **Output:**

| Name                 | ¥alue | 781,972,900 ps 781,972,950 ps 781,973,000 | ps 781,973,050 ps 781,973,100 ps 781,973,150 ps |
|----------------------|-------|-------------------------------------------|-------------------------------------------------|
| l <mark>a</mark> dk  | 1     |                                           |                                                 |
| l <mark>a</mark> rst | 1     |                                           |                                                 |
| l <mark>e</mark> d   | 1     |                                           |                                                 |
| կ <mark>ա</mark> գ   | 1     |                                           |                                                 |
| 埍 qbar               | 0     |                                           |                                                 |
|                      |       |                                           |                                                 |

### 8. T FLIPFLOP

# Verilog Code :

module tffeq(t,rst, clk,qp, qbar); input t,rst, clk;

output qp, qbar; wire q;

reg qp;

always @ (posedge clk) if (rst)

qp=0; else

 $qp = q^{t}; assign qbar = \sim qp;$ 

endmodule

### 9. JK FLIPFLOP

### Verilog Code:

module jkff(jk,pst,clr,clk,qp,qbar); input [1:0] jk; input pst,clr,clk; output qp,qbar; reg qp; wire q; always @ (posedge clk) if (pst) qp=1;else begin if (clr) qp = 0;else begin case (jk) 2'b00: qp=q; 2'b01 : qp = 1'b0; 2'b10 : qp =1'b1; 2'b11 : qp = ~q;default qp = 0; endcase end end assign qbar =  $\sim q$ ; assign q = qp;

### **Output:**

| output qp,qbar      |                                      |          |              |              |              |              |              |              |              |       |
|---------------------|--------------------------------------|----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-------|
| reg qp;             |                                      |          |              |              |              |              |              |              |              |       |
| wire q;             |                                      |          |              |              |              |              |              |              |              |       |
| always @ (p         |                                      | if (pst) |              |              |              |              |              |              |              |       |
| qp= 1               | ;                                    |          |              |              |              |              |              |              |              |       |
| else                |                                      |          |              |              |              |              |              |              |              |       |
| begin               |                                      |          |              |              |              |              |              |              |              |       |
| if (clr             | )                                    |          |              |              |              |              |              |              |              |       |
| qp = 0              |                                      |          |              |              |              |              |              |              |              |       |
| else                |                                      |          |              |              |              |              |              |              |              |       |
| begin               |                                      |          |              |              |              |              |              |              |              |       |
| case (              |                                      |          |              |              |              |              |              |              |              |       |
|                     | 2'b00: qp=q                          | [;<br>   |              |              |              |              |              |              |              |       |
|                     | 2'b01 : qp =                         | = 1°DU;  |              |              |              |              |              |              |              |       |
|                     | 2'b10 : qp =                         | =1 01;   |              |              |              |              |              |              |              |       |
|                     | 2'b11 : qp =<br>default qp =         |          |              |              |              |              |              |              |              |       |
|                     |                                      | -0,      |              |              |              |              |              |              |              |       |
| endcase<br>end      |                                      |          |              |              |              |              |              |              |              |       |
|                     |                                      |          |              |              |              |              |              |              |              |       |
| end                 | han ar                               |          |              |              |              |              |              |              |              |       |
|                     | $qbar = \sim q;$                     |          |              |              |              |              |              |              |              |       |
| assign of endmodule | $\mathbf{q} = \mathbf{q}\mathbf{p};$ |          |              |              |              |              |              |              |              |       |
| endmodule           |                                      |          |              |              |              |              |              |              |              |       |
| 0 4 4               |                                      |          |              |              |              |              |              |              |              |       |
| <u>Output:</u>      |                                      |          |              |              |              |              |              |              |              |       |
|                     |                                      |          |              |              |              |              |              |              |              |       |
| Name                | Value                                | تسلس     | 2,879,800 ps | 2,880,000 ps | 2,880,200 ps | 2,880,400 ps | 2,880,600 ps | 2,880,800 ps | 2,881,000 ps | 2,881 |
| ik[1:0] 1 pst       | 11                                   |          |              |              |              |              | 11           |              |              |       |
|                     | 1                                    |          |              |              |              |              |              |              |              |       |
|                     | 0                                    |          |              |              |              |              |              |              |              |       |
| 1 gbar              | 0                                    |          |              |              |              |              |              |              |              |       |
| Ug q                | 1                                    |          |              |              |              |              |              |              |              |       |
| Ling op             | 1                                    |          |              |              |              |              |              |              |              |       |
|                     |                                      |          |              |              |              |              |              |              |              |       |

### **10. RIPPLE COUNTER**

# Verilog Code:

module ripple(clkr,st,,t,A,B,C,D); input clk,rst,t; output A,B,C,D; Tff T0(D,clk,rst,t); Tff T1(C,clk,rst,t); Tff T2(B,clk,rst,t);

```
Tff T3(A,clk,rst,t);
endmodule
module Tff(q,clk,rst,t);
input clk,rst,t;
output q;
reg q;
always @(posedge clk)
begin
if(rst)
q \le 1'b0; else
if(t)
q \le -q;
end
endmodule
```

### VHDL Code:

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; ---- Uncomment the following library declaration if instantiating ---- any Xilinx primitives in this code. --library UNISIM; --use UNISIM.VComponents.all; entity counter is Port (rst : in STD\_LOGIC; clk : in STD\_LOGIC; led : out std\_logic\_vector(3 downto 0) ); end counter; architecture Behavioral of counter is signal reg :std\_logic\_vector(3 downto 0); begin process(rst,clk) begin if rst = '1' then reg <= "0000"; elsif rising\_edge(clk) then  $\operatorname{reg} \ll \operatorname{reg} + 1;$ end if; end process;  $led(3 downto 0) \le reg(3 downto 0);$ end Behavioral;

colled

# **Output:**

| Name    | Yalue | 177,764,44 | 0 ps   177 | 764,460 ps | 177,764,480 ps | 177,764,500 ps | 177,764,520 ps | 177,764,540 ps | 177,764,560 ps |
|---------|-------|------------|------------|------------|----------------|----------------|----------------|----------------|----------------|
| 埍 rst   | 0     |            |            |            |                |                |                |                |                |
| 🏪 dk    | 1     |            |            |            |                |                |                |                |                |
| 🕨 📑 led | 0000  | 1110       | 1111 0     | 00 0001    | 0010 0011      | 0100 0101      | 0110 0111      | 1000 1001      | 1010 (1011     |
| 🕨 🍢 reg | 0000  | 1110       | 1111 0     | 00 0001    | 0010 0011      | 0100 0101      | 0110 0111      | 1000 1001      | 1010 (1011     |
|         |       |            |            |            |                |                |                |                |                |

### **11. UPDOWN COUNTER**

olle

6

# Verilog Code:

module updowncount (R, Clock, clr, E, up\_down, Q); parameter n = 4; erind input [n-1:0] R; input Clock, clr, E, up\_down; output [n-1:0] Q; reg [n-1:0] Q; integer direction; always @(posedge Clock) begin if (up\_down) direction = 1; else direction = -1; if (clr)  $Q \ll R$ ; else if (E)  $Q \le Q +$ direction; end endmodule

### **<u>UP Counter:</u>**

| Name                | Value                                   |   | 944,520,800 ps | 944,521,000 ps | 944,521,200 ps | 944,521,400 ps | 944,521,600 ps                          | 944,521,800 ps | 944,522,000 ps | 944,522,200 ps | 944,522,400 ps | 944,522,6 |
|---------------------|-----------------------------------------|---|----------------|----------------|----------------|----------------|-----------------------------------------|----------------|----------------|----------------|----------------|-----------|
| 🕨 帽 R[3:0]          | 1111                                    |   |                |                |                |                | 1111                                    |                |                |                |                |           |
| La Clock            | 0                                       | 1 |                |                |                |                |                                         |                |                |                |                |           |
| 埍 cir               | 0                                       | _ |                |                |                |                |                                         | _              |                |                |                | -         |
| L <mark>e</mark> E  | 1                                       |   |                |                |                |                |                                         |                |                |                |                |           |
| 1 up_down           | 1                                       |   |                |                |                |                |                                         |                |                |                | 1              |           |
| 🕨 🎀 Q[3:0]          | 1111                                    | 1 | 0000 0001      | 0010 0011      | 0100 0101      | 0110 0111      | 1000 1001                               | 1010 1011      | 1100 1101      | 1110 1111      | 0000 0001      | 0010      |
| 🕨 🌃 direction[31:0] | 000000000000000000000000000000000000000 |   |                |                |                | 00000          | 000000000000000000000000000000000000000 | 0000000001     |                |                |                |           |
| 🕨 😻 n[31:0]         | 000000000000000000000000000000000000000 | _ |                |                |                | 00000          | 000000000000000000000000000000000000000 | 0000000100     |                |                |                |           |

#### **DOWN Counter:**

| Name                 | Value                                   | 1,619,453,000 ps | 1,619,453,200 ps | 1,619,453,400 ps | 1,619,453,600 ps | 1,619,453,800 ps                        | 1,619,454,000 ps | ,619,454,200 ps | 1,619,454,400 ps | 1,619,454,600 ps | 1,619,454,8 |
|----------------------|-----------------------------------------|------------------|------------------|------------------|------------------|-----------------------------------------|------------------|-----------------|------------------|------------------|-------------|
| 🕨 🎽 R[3:0]           | 1111                                    |                  |                  |                  |                  | 1111                                    |                  |                 |                  |                  |             |
| La Clock             | 1                                       |                  |                  |                  |                  |                                         |                  |                 |                  |                  |             |
| l <mark>a</mark> cir | 0                                       |                  |                  |                  |                  |                                         |                  |                 |                  |                  |             |
| l <mark>la</mark> €  | 1                                       |                  |                  |                  |                  |                                         |                  |                 |                  |                  | 1           |
| L up_down            | 0                                       |                  |                  |                  |                  |                                         |                  |                 |                  |                  |             |
| 🕨 🎽 Q[3:0]           | 0100                                    | 0000 1111        | 1110 1101        | 1100 1011        | 1010 1001        | 1000 0111                               | 0110 0101        | 0100 0011       | 0010 0001        | 0000 1111        | 1110        |
| direction[31:0]      | 111111111111111111111111111111111111111 |                  |                  | 1                | 11111            | 111111111111111111                      | 1111111111       |                 |                  |                  |             |
| 🕨 😻 n[31:0]          | 000000000000000000000000000000000000000 |                  |                  |                  | 00000            | 000000000000000000000000000000000000000 | 0000000100       |                 |                  |                  |             |

### **12. SHIFT REGISTER**

### a. Serial In Serial Out

olle

6

### **VHDL Code:**

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; --library UNISIM; --use UNISIM.VComponents.all; entity hj is port( clk : in std\_logic; rst : in std\_logic; si: in std\_logic; so: out std\_logic ); end hj; architecture Behavioral of hj is signal temp : std\_logic\_vector(3 downto 0); begin process(clk,rst) begin if rising\_edge(clk) then if rst = '1' then temp <= (others=>'0'); else temp  $\leq$  temp(2 downto 0) & si; end if: end if; end process; so  $\leq temp(3)$ ; end Behavioral;

### Output:

| Name                 | ¥alue | 3    | 35,655,720 ps | 35,655,740 ps | 35,655,760 ps | 35,655,780 ps | 35,655,800 ps |     | 35,655,820 ps |
|----------------------|-------|------|---------------|---------------|---------------|---------------|---------------|-----|---------------|
| l <mark>n</mark> dk  | 1     |      |               |               |               |               |               |     |               |
| l <mark>a</mark> rst | 0     |      |               |               |               |               |               |     |               |
| 埍 si                 | 0     |      |               |               |               |               |               |     |               |
| l <mark>o</mark> so  | 1     |      |               |               |               |               |               |     |               |
| 🕨 👹 temp[3:0]        | 1100  | 1100 | 1000 00       | 0001          | 0011 0111     |               | 1110 1        | .00 | 1000 0        |

# **b. Parallel In Parallel Out**

### **VHDL Code:**

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD\_LOGIC\_ARITH.ALL; use IEEE.STD\_LOGIC\_UNSIGNED.ALL; --library UNISIM; --use UNISIM.VComponents.all; entity hj is port( clk : in std\_logic; rst : in std\_logic; po: out std\_logic\_vector(3 downto 0); pi: in std\_logic\_vector(3 downto 0) ); end hj; architecture Behavioral of hj is signal temp : std\_logic\_vector(3 downto 0); begin process(clk,rst) begin if rising\_edge(clk) then if rst = '1' then temp  $\leq (others = >'0');$ else temp <= pi(3 downto 0);</pre> end if; end if; end process; po <= temp(3 downto 0);</pre> end Behavioral;

#### Output:

76

olle

| Name ¥alue                | 274,846,060 ps | - ·<br> 274,846,080 ps | 274,846,100 ps | 274,846,120 ps | 274,846,140 ps | 27 | 1,846,160 ps | 274,  |
|---------------------------|----------------|------------------------|----------------|----------------|----------------|----|--------------|-------|
| l <mark>a</mark> dk 🛛 1   |                |                        |                |                |                |    |              |       |
| li <mark>n</mark> rst 🛛 0 |                |                        |                |                |                |    |              |       |
| ▶ 驨 po[3:0] 0011          |                |                        |                | C011           |                |    |              | $\pm$ |
| 🕨 📲 pi[3:0] 🛛 🛛 0011      |                |                        |                | C011           |                |    |              | $\pm$ |
| 🕨 🎆 temp[3:0] 🛛 0011      |                |                        |                | Q011           |                |    |              |       |

T: sther lar Thus the sequential and combinational circuits are designed and implemented using HDL simulator (Verilog and VHDL).