# Department of Computer Science Faculty of Computing UNIVERSITI TEKNOLOGI MALAYSIA

| SUBJECT     | : SCSR1013 DIGITAL LOGIC                        |
|-------------|-------------------------------------------------|
| SESSION/SEM | :2020/2021/1                                    |
| LAB 2       | : COMBINATIONAL LOGIC CIRCUIT DESIGN SIMULATION |
|             |                                                 |
| NAME 1      | :YONG ZHI YAN                                   |
| NAME 2      | :                                               |
|             |                                                 |
| DATE        | :10/01/2021                                     |

REMARKS :

MARKS:

### Combinational Digital Circuit Design Simulation Using Deeds Simulator

## A. Objective

- To expose student with producing digital logic circuit, generating truth table and Timing Diagram with Deeds Simulator.
- ii) To expose student with a complete cycle process of a combinatorial circuit design and simulate with Deeds Simulator.

### B. Material

Install Deeds Software for Windows.

### C. Introduction

#### **Deeds Simulator**

The Digital Circuit Simulator *d-DcS* appears to the user as a graphical schematic editor, with a library of simplified logic components, specialized toward pedagogical needs and not describing specific commercial products. As described before, the schematic editor allows building a simple digital networks composed of gates, flip-flops, pre-defined combinational and sequential circuits and custom-defined components (defined as Finite state machine).



Figure 1 Circuit Editor of Digital Circuit Simulator (d-DcS)

Simulation can be interactive or in timing-mode. In **interactive mode**, the student can "animate" the digital system in the editor, controlling its inputs and observing the results. This is the simplest mode to examine a digital network, and this way of operation can be useful for the beginners. In **timing mode**, the behavior of the circuit can be analyzed by a timing diagram window, in which the user can define graphically an input signal sequence and observe the simulation results.

#### Digital Circuit Simulator (d-DcS): A Simple Example

In the following screen shots (Figure 2a, 2b, and 2c), student can see the circuit during the drawing and then simulate it by animation with following simple steps:

- a) student picks-up components from the Component Tool Bar.
- b) connects them using Wires.
- c) student activates the animation.



Figure 2a Drawing Phase of the Digital Circuit Editor: Insertion of Components



Figure 2b Next Phase of the Work: Connection of Components using Wires



Figure 2c Animation: User Switches Inputs and the Circuit Shows Changes on Outputs

To exit the animation, it is necessary to click on the square *Stop* button. Instead, if the timing simulation is to be performed, student should click on the *Timing Simulation* button. This will show the Timing Diagram simulation window (Figure 3).



Figure 3 Timing Diagram Simulation Window

In this window, first student should define the timing of the input signals, drawing them on the diagram with the mouse. A vertical line cursor permits to define the 'end time' of the simulation. When student clicks on the triangular *play* button on the toolbar, the simulation is executed, and its results are displayed in the same window (Figure 4).



Figure 4 Timing Simulation Results, Displayed in Timing Diagram Window

Student can verify the correct behavior of the digital circuit, comparing simulation results with reasoning and theory concepts.

# D. Lab Activities

# Part 1

Simulating logic circuit, construct truth table and timing diagram with Deeds.

Given Boolean expression as follow:

$$Y = AB + BC + AC$$

1. Convert the non-standard Boolean expression into standard form.

2. Based on standard form expression, complete the following truth table.

|   | INPUT |   |   |  |  |
|---|-------|---|---|--|--|
| A | В     | С | Y |  |  |
| 0 | 0     | 0 | 0 |  |  |
| 0 | 0     | 1 | 0 |  |  |
| 0 | 1     | 0 | 0 |  |  |
| 0 | 1     | 1 | 1 |  |  |
| 1 | 0     | 0 | 0 |  |  |
| 1 | 0     | 1 | 1 |  |  |
| 1 | 1     | 0 | 1 |  |  |
| 1 | 1     | 1 | 1 |  |  |

- 3. Using Deeds Simulator, draw the following circuits:
  - a) Circuit (i) for non-standard form (based on the given expression).



Circuit (i)

b) Circuit (ii) for standard form (from your answer in question (1)).



Circuit (ii)

4. Simulate these two circuits in step (3) and complete their truth table.

Compare the simulation result for these two truth tables. What is your conclusion?

Circuit (i)

Circuit (ii)

|   | INPUT |   |   |  |  |
|---|-------|---|---|--|--|
| A | В     | С | Y |  |  |
| 0 | 0     | 0 | 0 |  |  |
| 0 | 0     | 1 | 0 |  |  |
| 0 | 1     | 0 | 0 |  |  |
| 0 | 1     | 1 | 1 |  |  |
| 1 | 0     | 0 | 0 |  |  |
| 1 | 0     | 1 | 1 |  |  |
| 1 | 1     | 0 | 1 |  |  |
| 1 | 1     | 1 | 1 |  |  |

|   | INPUT |   |   |  |  |
|---|-------|---|---|--|--|
| A | В     | С | Y |  |  |
| 0 | 0     | 0 | 0 |  |  |
| 0 | 0     | 1 | 0 |  |  |
| 0 | 1     | 0 | 0 |  |  |
| 0 | 1     | 1 | 1 |  |  |
| 1 | 0     | 0 | 0 |  |  |
| 1 | 0     | 1 | 1 |  |  |
| 1 | 1     | 0 | 1 |  |  |
| 1 | 1     | 1 | 1 |  |  |

## Conclusion:

The outputs for both circuit (i) and circuit (ii) are the same. This indicates that

the standard and non-standard Boolean expression are the same and will give exactly

\_\_\_\_\_

the same output.

5. Simulate output of circuit (ii) with Timing Diagram. Illustrate some examples of different inputs and output.



Y = 1 when A = 0, B = 1, C = 1

Y = 1 when A = 1, B = 0, C = 1

Y = 1 when A = 1, B = 1, C = 0

Y = 1 when A = 1, B = 1, C = 1

#### Part 2

Combinational circuit design process and simulate with Deeds Simulator.

# **Design Process**

- i) Determine Parameter Input / Output and their relations.
- ii) Construct Truth Table.
- iii) Using K-Map, get the SOP optimized form of all Boolean equation outputs.
- iv) Draw the circuit and use duality symbol; convert AND-OR circuit to NAND gates ONLY.
- v) Simulate the design using Deeds Simulator. Check the results according to Truth Table and Timing Diagram Operation.

#### **Problem Situation**

A new digital fault diagnoses circuit is requested to be designed for analyzing four bit 2's complement input binary number from sensors A, B, C, and D. Sensor A represents input MSB and sensor D represents input LSB. As shown in the following Figure 5, bit pattern analysis from input sensors A, B, C, and D will trigger four different output errors (active HIGH) of type E1, E2, E3, and E4.



Figure 5

The following rules are used to activate the error's signal type:

| RULE 1: | E1 is activated if the input number is positive ODD and the |
|---------|-------------------------------------------------------------|
|         | majority of the bits is '0'.                                |

**RULE 2**: E2 is activated if the input number is positive EVEN and the majority of the bits is '0'.

**RULE 3**: E3 is activated if the input number is negative ODD and the majority of the bits is '1'.

**RULE 4**: E4 is activated if the input number is negative EVEN and the majority of the bits is '1'.

**RULE 5**: The output of error signal is invalid if the input has equal bit '0' and bit '1'.

(NOTE: Positive ODD is positive numbers that are odd and negative EVEN is negative numbers that are even).

# **Experimental Steps**

1. Complete Truth Table 1 for Digital Fault Diagnose Circuit. Use variables A, B, C and D as inputs; E1, E2, E3 and E4 as outputs.

**Truth Table 1** 

|   | IN | PUT |   |            | OU | TPUT |           |
|---|----|-----|---|------------|----|------|-----------|
| A | В  | С   | D | <b>E</b> 1 | E2 | Е3   | <b>E4</b> |
| 0 | 0  | 0   | 0 | 0          | 1  | 0    | 0         |
| 0 | 0  | 0   | 1 | 1          | 0  | 0    | 0         |
| 0 | 0  | 1   | 0 | 0          | 1  | 0    | 0         |
| 0 | 0  | 1   | 1 | X          | X  | X    | X         |
| 0 | 1  | 0   | 0 | 0          | 1  | 0    | 0         |
| 0 | 1  | 0   | 1 | X          | X  | X    | X         |
| 0 | 1  | 1   | 0 | X          | X  | X    | X         |
| 0 | 1  | 1   | 1 | 0          | 0  | 0    | 0         |
| 1 | 0  | 0   | 0 | 0          | 0  | 0    | 0         |
| 1 | 0  | 0   | 1 | X          | X  | X    | X         |
| 1 | 0  | 1   | 0 | X          | X  | X    | X         |
| 1 | 0  | 1   | 1 | 0          | 0  | 1    | 0         |
| 1 | 1  | 0   | 0 | X          | X  | X    | X         |
| 1 | 1  | 0   | 1 | 0          | 0  | 1    | 0         |
| 1 | 1  | 1   | 0 | 0          | 0  | 0    | 1         |
| 1 | 1  | 1   | 1 | 0          | 0  | 1    | 0         |

2. Using K-MAP, get minimized SOP Boolean expressions for E1, E2, E3 and E4 circuits.

| CD   |    |           |    |    |
|------|----|-----------|----|----|
| AB \ | 00 | 01        | 11 | 10 |
| 00   |    | $\forall$ | X  |    |
| 01   |    | X         |    | X  |
| 11   | X  |           |    |    |
| 10   |    | X         |    | X  |

| E1 | = | A' | B' | C |
|----|---|----|----|---|
| E1 | = | A' | B' |   |

| CD   |    |    |    |    |
|------|----|----|----|----|
| AB 🔪 | 00 | 01 | 11 | 10 |
| 00   |    |    | X  |    |
| 01   |    | X  |    | X  |
| 11   | X  | 1  | 1  |    |
| 10   |    | X  | J  | X  |

E3 = AD



E2 = A'D'

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

E4 = ACD'

3. From the Boolean expression in the step (2), draw your final E1, E2, E3 and E4 circuits using 2 input basic gates (AND, OR, NOT). Use Deeds Simulator.



- 4. Simulate the Deeds circuit in step (3):
- a) Update Truth Table 2 based on the simulation result.

**Truth Table 2** 

|   | I | NPUT |   |            | OU        | TPUT |    |
|---|---|------|---|------------|-----------|------|----|
| A | В | C    | D | <b>E</b> 1 | <b>E2</b> | E3   | E4 |
| 0 | 0 | 0    | 0 | 0          | 1         | 0    | 0  |
| 0 | 0 | 0    | 1 | 1          | 0         | 0    | 0  |
| 0 | 0 | 1    | 0 | 0          | 1         | 0    | 0  |
| 0 | 0 | 1    | 1 | 1          | 0         | 0    | 0  |
| 0 | 1 | 0    | 0 | 0          | 1         | 0    | 0  |
| 0 | 1 | 0    | 1 | 0          | 0         | 0    | 0  |
| 0 | 1 | 1    | 0 | 0          | 1         | 0    | 0  |
| 0 | 1 | 1    | 1 | 0          | 0         | 0    | 0  |
| 1 | 0 | 0    | 0 | 0          | 0         | 0    | 0  |
| 1 | 0 | 0    | 1 | 0          | 0         | 1    | 0  |
| 1 | 0 | 1    | 0 | 0          | 0         | 0    | 1  |
| 1 | 0 | 1    | 1 | 0          | 0         | 1    | 0  |
| 1 | 1 | 0    | 0 | 0          | 0         | 0    | 0  |
| 1 | 1 | 0    | 1 | 0          | 0         | 1    | 0  |
| 1 | 1 | 1    | 0 | 0          | 0         | 0    | 1  |
| 1 | 1 | 1    | 1 | 0          | 0         | 1    | 0  |

Compare the output results in Truth Table 2 with Truth Table 1. What is your conclusion?

There is no don't care situations for Truth Table 2. This results in the output of Truth Table 2 is not same as Truth Table 1 as all the don't care conditions in Truth Table 1 is either result in all zeros in the outputs or ones in the outputs at Truth Table 2. Hence, we can conclude that the simplest circuit consists of fewest number of logic gates and variables.

b) Timing Diagram



Explain some analysis values based on your timing diagram:

The input of the circuit is active high, it shows output E1 = 1 when A = 0, B = 0, D = 1, output E2 = 1 when A = 0, D = 0, output E3 = 1 when A = 1, D = 1 and output E4 = 1 when A = 1, C = 1, D = 0.

5. Using dual symbol concept, convert your circuit in step (3) to NAND gates only. Use Deeds Simulator.



- 6. Simulate the Deeds circuit in step (5):
- a) Update Truth Table 3 based on the simulation result.

**Truth Table 3** 

| INPUT |   |   |   | OUTPUT     |           |    |    |
|-------|---|---|---|------------|-----------|----|----|
| A     | В | C | D | <b>E</b> 1 | <b>E2</b> | E3 | E4 |
| 0     | 0 | 0 | 0 | 0          | 1         | 0  | 0  |
| 0     | 0 | 0 | 1 | 1          | 0         | 0  | 0  |
| 0     | 0 | 1 | 0 | 0          | 1         | 0  | 0  |
| 0     | 0 | 1 | 1 | 1          | 0         | 0  | 0  |
| 0     | 1 | 0 | 0 | 0          | 1         | 0  | 0  |
| 0     | 1 | 0 | 1 | 0          | 0         | 0  | 0  |
| 0     | 1 | 1 | 0 | 0          | 1         | 0  | 0  |
| 0     | 1 | 1 | 1 | 0          | 0         | 0  | 0  |
| 1     | 0 | 0 | 0 | 0          | 0         | 0  | 0  |
| 1     | 0 | 0 | 1 | 0          | 0         | 1  | 0  |
| 1     | 0 | 1 | 0 | 0          | 0         | 0  | 1  |
| 1     | 0 | 1 | 1 | 0          | 0         | 1  | 0  |
| 1     | 1 | 0 | 0 | 0          | 0         | 0  | 0  |
| 1     | 1 | 0 | 1 | 0          | 0         | 1  | 0  |
| 1     | 1 | 1 | 0 | 0          | 0         | 0  | 1  |
| 1     | 1 | 1 | 1 | 0          | 0         | 1  | 0  |

Compare the output results in Truth Table 3 with Truth Table 2. What is your conclusion?

The Truth Table 3 is same with Truth Table 2. The SOP expression of circuit for Truth table 2 is converted to NAND gates circuit, this shows that NAND gates have the property of acting as NOT gates and AND gates.

# b) Timing Diagram



Explain some analysis values based on your timing diagram:

| The input of the circuit is active high, it shows output $E1 = 1$ when $A = 0$ , $B = 0$ , $D = 1$ , output $E2 = 1$ |
|----------------------------------------------------------------------------------------------------------------------|
| when $A = 0$ , $D = 0$ , output $E3 = 1$ when $A=1$ , $D=1$ and output $E4 = 1$ when $A=1$ , $C=1$ , $D=0$ .         |
|                                                                                                                      |
|                                                                                                                      |
|                                                                                                                      |
|                                                                                                                      |
|                                                                                                                      |



Fully Completed Partially Completed

Checked by: \_\_\_\_\_