SUBJECT : SECR1013 DIGITAL LOGIC SESSION/SEM : 2020/2021 - 1 LAB 2 : COMBINATIONAL LOGIC CIRCUIT DESIGN **SIMULATION** NAME: Nur Syakirah Mohd Shukri DATE: 21/12/2020 ## **Lab #2** # Combinational Digital Circuit Design Simulation Using Deeds Simulator ### A. Objective i) 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 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 (submitted in pdf file) 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. $$Y = AB(C + \overline{C}) + BC(A + \overline{A}) + AC(B + \overline{B})$$ $$Y = ABC + AB\overline{C} + ABC + \overline{A}BC + ABC + A\overline{B}C$$ $$Y = ABC + AB\overline{C} + \overline{A}BC + A\overline{B}C$$ 2. Based on standard form expression, complete the following truth table. | | INPUT | | | | | |---|-------|---|---|--|--| | A | В | C | 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 and cut & paste your circuit below: - a) Circuit (i) for non-standard form (based on the given expression). b) Circuit (ii) for standard form (from your answer in question (1)). - 4. Simulate these two circuits in step (3) and complete their truth table. - (a) Compare the simulation result for these two truth tables. What is your conclusion? Circuit (i) Circuit (ii) | | INPUT | | OUTPUT | |---|-------|---|--------| | 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 | | OUTPUT | |---|-------|---|--------| | 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 | (b) What conclusion can you make? Tips: Write down your observation first. What did you see? Then, you make your conclusion. What can you deduce based on the observation? Based on the experiment, I found that both circuit either nonstandard or standard form, both give the same output. But, circuit(ii) use more gate than circuit(i). Circuit(i) much better and more suitable to use for any project because we can reduce our money and much easier to handle. 5. Simulate output of circuit (ii) with Timing Diagram. Illustrate some examples of different inputs and output. Cut & Paste the timing diagram here. ### Part 2 (video file less than 50MB) 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 analysing 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** | | INPUTS | | | | | OUT | PUTS | | |----|--------|---|---|---|------------|-----|------|----| | | A | В | C | D | <b>E</b> 1 | E2 | E3 | E4 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | 2 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | 3 | 0 | 0 | 1 | 1 | X | X | X | X | | 4 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | | 5 | 0 | 1 | 0 | 1 | X | X | X | X | | 6 | 0 | 1 | 1 | 0 | X | X | X | X | | 7 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | -8 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | -7 | 1 | 0 | 0 | 1 | X | X | X | X | | -6 | 1 | 0 | 1 | 0 | X | X | X | X | | -5 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | | -4 | 1 | 1 | 0 | 0 | X | X | X | X | | -3 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | | -2 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | -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 | 00 | 01 | 11 | 10 | |--------|-----|----|----|----| | AB | | | | | | 00 | | 1 | X | | | 01 | | X | | X | | 11 | X | | | | | 10 | | X | | X | | E1=A'I | B'D | | | | | CD | 00 | 01 | 11 | 10 | | AB | | | | | | 00 | 1 | | X | 1 | X X X X | E2=A | 'n | |------|----------------------------| | | $\boldsymbol{\mathcal{L}}$ | 01 11 10 1 X | V | CD | 00 | 01 | 11 | 10 | |----|----|----|----|----|----| | A] | B\ | | | | | | 00 | ) | | | X | | | | | | | | | | 01 | | | X | | X | | | | | | | | | 11 | | X | 1 | 1 | | | | | | | | | | 10 | ) | | X | 1 | X | | | | | | | | | | | | | | | # E3=AD | CD | 00 | 01 | 11 | 10 | |-----|----|----|----|----| | AB | | | | | | 00 | | | X | | | 0.1 | | 37 | | 37 | | 01 | | X | | X | | 11 | X | | | 1 | | 11 | 71 | | | 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. | | INPUTS | | | | OUTPUTS | | | | |----|--------|---|---|---|------------|----|----|-----------| | | A | В | С | D | <b>E</b> 1 | E2 | E3 | <b>E4</b> | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | 2 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | 3 | 0 | 0 | 1 | 1 | X | X | X | X | | 4 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | | 5 | 0 | 1 | 0 | 1 | X | X | X | X | | 6 | 0 | 1 | 1 | 0 | X | X | X | X | | 7 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | -8 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | -7 | 1 | 0 | 0 | 1 | X | X | X | X | | -6 | 1 | 0 | 1 | 0 | X | X | X | X | | -5 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | -4 | 1 | 1 | 0 | 0 | X | X | X | X | | -3 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | | -2 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | -1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | b) Compare the output results in Truth Table 2 with Truth Table 1. What is your conclusion? =Output truth table 2 and 1 are same. By using Kmap, we can get the Boolean expression to draw the circuit and simulate it. c) Produce the Timing Diagram (you can create your own signals) 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. | | | INPUTS | | | | OUTPUTS | | | | |----|---|--------|---|---|------------|-----------|----|-----------|--| | | A | В | C | D | <b>E</b> 1 | <b>E2</b> | E3 | <b>E4</b> | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | 2 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | | | 3 | 0 | 0 | 1 | 1 | X | X | X | X | | | 4 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | 5 | 0 | 1 | 0 | 1 | X | X | X | X | | | 6 | 0 | 1 | 1 | 0 | X | X | X | X | | | 7 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | -8 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | -7 | 1 | 0 | 0 | 1 | X | X | X | X | | | -6 | 1 | 0 | 1 | 0 | X | X | X | X | | | -5 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | | | -4 | 1 | 1 | 0 | 0 | X | X | X | X | | | -3 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | | | -2 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | -1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | - b) Compare the output results in Truth Table 3 with Truth Table 2. What is your conclusion? - = I get different between truth table 3 and truth table 2. It should be get the same output. Mybe my NAND circuit is wrong c) Produce the Timing Diagram (you can create your own signals)