# COE 202: Digital Logic Design Fall 2021 – Term 211

# COMPUTER ENGINEERING DEPARTMENT

## **KING FAHD UNIVERSITY OF PETROLEUM & MINERALS**

Instructor:Dr. Muhamed MudawarOffice: 22/410-2Phone: 4642Office Hours:UTR 9:30 to 10:30 AM or by appointmentCourse URL:https://faculty.kfupm.edu.sa/coe/mudawar/coe202/Email:mudawar@kfupm.edu.sa

## **Catalog Description**

Introduction to information representation and number systems. Boolean algebra and switching theory. Canonical forms: minterms and maxterms. Manipulation and minimization of completely and incompletely specified Boolean functions. Propagation delay, timing diagrams. Primitive and complex gates. Combinational circuits design. Multiplexers, decoders, encoders, comparators, adders. Sequential circuit analysis and design, basic flip-flops, clocking and timing diagrams. Registers, counters. Introduction to Verilog.

### Prerequisite: PHYS 102

### **Course Learning Outcomes**

After completing the course, you should be able to:

- 1. Represent numbers and perform arithmetic operations in various number systems.
- 2. List basic identities of Boolean algebra and perform algebraic manipulations of Boolean expressions.
- 3. Simplify functions using the K-map method including the use of don't care conditions.
- 4. Design efficient combinational circuits utilizing basic functional blocks such as adders, comparators, multiplexors, encoders, and decoders.
- 5. Analyze and design efficient sequential circuits using Mealy and Moore models.
- 6. Design registers and counters and understand their applications.
- 7. Model simple combinational and sequential circuits using Verilog HDL and use tools to simulate and verify correctness of design.

#### Textbook

Alan B. Marcovitz, Introduction to Logic Design, Third Edition, McGraw-Hill, 2010.

#### Grading

| Verilog Assignments | 15% |                                      |
|---------------------|-----|--------------------------------------|
| Quizzes             | 15% |                                      |
| Midterm Exam        | 30% | Saturday, October 23, 2021, at 10 AM |
| Final Exam          | 40% | To be announced                      |

- Attendance will be taken regularly. The tenth unexcused absence results in a DN grade.
- No makeup will be made for a missing Quiz or Exam.

| Week | Topics                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | <ul> <li>Introduction, Analog versus Digital.</li> <li>Weighted number systems: decimal, binary, octal, and hexadecimal.</li> <li>Number base conversion.</li> <li>Representing fractions.</li> </ul>                                                                                                                                                                                                                                                                              |
| 2    | <ul> <li>Binary codes, BCD codes, character storage, ASCII Code.</li> <li>Error detection, Parity bit.</li> <li>Binary arithmetic: addition, subtraction &amp; multiplication.</li> <li>Hexadecimal addition and subtraction. Bit shifting.</li> <li>Boolean algebra, truth tables, basic identities, duality principle.</li> </ul>                                                                                                                                                |
| 3    | <ul> <li>DeMorgan's theorem.</li> <li>Algebraic manipulation and expression simplification.</li> <li>Logic gates and logic diagrams.</li> <li>Minterms, Maxterms, Sum-of-Minterms, Product-of-Maxterms.</li> <li>Sum of Products, Products of Sums, 2-Level gate implementation.</li> </ul>                                                                                                                                                                                        |
| 4    | <ul> <li>Additional gates: NAND, NOR, XOR, and XNOR. Universality of NAND and NOR. NAND-NAND and NOR-NOR implementations. Properties of XOR and XNOR. Odd and Even Functions, Parity generation and checking.</li> <li>Introduction to Verilog: Verilog module, gate level modeling and gate delays, module instantiation, continuous assignment and propagation delay, writing a simple test bench.</li> </ul>                                                                    |
| 5-6  | <ul> <li>The Karnaugh map, two, three, and four-variable K-map</li> <li>Prime Implicants and Essential Prime Implicants, Minimal SOP and POS.</li> <li>Don't care conditions and simplification, multiple outputs.</li> <li>Characteristics of logic gates, timing diagrams, gate and propagation delay.</li> <li>Combinational circuit design procedure.</li> <li>Designing a BCD to 7-Segment decoder.</li> </ul>                                                                |
| 7-8  | <ul> <li>Iterative and hierarchical combinational circuit design.</li> <li>Arithmetic circuits: Ripple carry adder design, carry propagation and delay analysis.</li> <li>Magnitude comparator.</li> <li>Signed Integers: sign-magnitude, 1's complement, and 2's complement.</li> <li>Addition and Subtraction of signed 2's complement.</li> <li>Design by contraction: designing an incrementer and decrementer</li> <li>Unsigned versus signed arithmetic circuits.</li> </ul> |
| 9-10 | <ul> <li>Functional Blocks: Decoders, Encoders, and Multiplexers</li> <li>Implementing large decoders hierarchically from smaller decoders.</li> <li>Function implementation using decoders.</li> <li>Encoders and Priority Encoders.</li> <li>Multiplexers, implementing multiplexers using 3-state gates.</li> <li>Implementing large multiplexers hierarchically from smaller ones.</li> <li>Function implementation using multiplexers.</li> <li>Design Examples.</li> </ul>   |

| 11-13 | <ul> <li>Bit vector in Verilog, Verilog operators, module parameters, modeling adders, comparators, and multiplexers.</li> <li>Behavioral description in Verilog, always block and sensitivity list, procedural assignment, if and case statements, modeling a decoder, priority encoder, and ALU.</li> <li>Introduction to sequential circuits, synchronous versus asynchronous, clock cycle and frequency, latches, clocked latches, flip-flops, characteristic tables and equations.</li> <li>Analysis of sequential circuits. state table, state diagram, Mealy vs. Moore, timing diagrams.</li> <li>Sequential circuit design. Design procedure, state diagrams and state tables, Mealy and Moore sequence detectors, tracing state diagrams. Sequential comparator. Designing a counter with a state diagram.</li> <li>Asynchronous/Direct Clear and Set Inputs. Setup, Hold, FF propagation delay. Calculating maximum clock frequency.</li> </ul> |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-15 | <ul> <li>Verilog modeling of D-Latch, D Flip Flop, Synchronous Set/Reset, Asynchronous Set/Reset. Verilog Structural modeling of sequential circuits, FSM modeling.</li> <li>Registers, Registers with parallel load.</li> <li>Shift Registers. Bi-directional shift register. Applications of shift registers.</li> <li>Ripple up/down counters.</li> <li>Synchronous binary counters.</li> <li>Counters with Parallel load, enable, synchronous clear and asynchronous clear.</li> <li>Building counters of different count.</li> <li>Verilog modeling of: Parallel Load Register, Shift Register, Up-Down Counter.</li> </ul>                                                                                                                                                                                                                                                                                                                          |