#### PUE 3141: ADVANCED DIGITAL SYSTEMS DESIGN #### **LECTURE 1A** #### BY DR. MUTUGI KIRUKI # **Topics:** - i) Overview of digital logic design methodology - ii) Review of combinational logic designs - iii) Review of sequential logic designs with flip flops (FF) #### **References:** - i) Elijah, M. (2009) Foundations of Digital Electronics. University of Nairobi Press - ii) Rafiquzzaman, M. (2005) Fundamentals of Digital Logic & Microcomputer Design (5<sup>th</sup> Edition). Wiley. ## 1. Overview of Digital Logic Design Methodology ## **Design Levels for Digital Systems** - i) Device Level: Utilizes transistors to design logic gates - ii) Logic Level: Design technique in which chips containing logic gates such as AND, OR, and NOT are used to design a digital components such as the ALU. - iii) Systems Level: Type of design in which CPU, memory, and I/O chips are interfaced to build a computer ## General digital logic design methodology Traditionally, there are 3 approaches: - i) Top-down design methodology - Start with larger block of design & then work downwards to sub-block levels. - ii) Bottom-up design methodology - Start with the sub-blocks and use them as the building blocks for the larger system blocks - iii) Hybrid - A combination of bottom-up and top-down is used. # Digital Design Methodology (FPGAs, ASICs ...) - Design & Functional Specification - ✓ State diagrams - ✓ Timing diagrams - ✓ Hardware Description Languages - Design Partition & Entry - ✓ System design partitioned into functional units & individual components - ✓ Behavioral descriptions / modelling - o Simulation & Functional Verification - ✓ Test bench development - ✓ Model verification - Design Integration and Verification - ✓ Individual components verified independently & integrated - Synthesis & post-synthesis - ✓ Synthesize the design from the behavior description - ✓ Synthesis produces netlist to configure target FPGA - ✓ Post-synthesis: design validation & timing verification - o Placement & Routing - ✓ For FPGAs, this involves placing functions into particular Configurable Logic Blocks (CLBs) and slices that are interconnected via switch matrix ## 2. Review of Combinational Logic Designs Digital logic circuits can be broadly classified into 2 types: - i) Combinational Logic - ii) Sequential Logic ### **Combinational Circuit** - Consists of logic gates whose outputs at any time are determined by logic operations on the input values i.e. outputs depend on the current input values. - o Perform an operation that can be specified logically by a set of Boolean equations Combinational Pm outputs o Are memoryless N'inputs o Consist of input variables, output variables, logic gates, and interconnections # **Sequential Circuit** - Can be regarded as combinational circuits that incorporate memory i.e. employ elements that store bit values - Their outputs are functions of the inputs and the bit values in the storage elements. Hence, outputs of sequential circuit depend not only on the current input values, but also on past inputs. - The behavior of the circuit must be specified by a sequence in time of inputs and internal stored bit values # **Combinational Logic Design** - o Typical combinational logic modules include: binary adders, subtractors, comparators, decoders, encoders, multiplexers, and demultiplexers. - Analysis and design of logic circuits is based on Boolean algebra. # Boolean algebra - o Enables logic statements to be represented as mathematical functions. - o An integral part of digital electronic circuit design - o 3 basic logic operations: **OR** (+); **AND** (•); **NOT** $(\bar{A})$ / A' - o 8 basic theorems of Boolean logic: i) $$1 + A = 1$$ v) $$0.A = 0$$ ii) $$0 + A = A$$ $$vi)$$ 1.A = A iii) $$A + A = A$$ $$vii)$$ $A.A = A$ iv) $$A + \overline{A} = 1$$ viii) $$A.\overline{A} = 0$$ - o 3 Boolean algebra laws: - i) Commutative Laws: - iii) Associative Laws: - ii) Distributive Law: - a) A + B = B + A - a) A + (B+C) = (A+B) + C - a) A(B+C) = AB + AC - b) AB = BA - b) A(BC) = (AB)C - o Simplification of logic functions / Boolean expressions - ii) DeMorgan's Theorem - i) Karnaugh Maps **DeMorgan's Theorem \***: If A, B and C are logic variables: i) $$\overline{A+B+C} = \overline{A} \cdot \overline{B} \cdot \overline{C}$$ ii) $$\overline{ABC} = \overline{A} + \overline{B} + \overline{C}$$ Karnaugh Maps (K-map) \* - Well suited for the simplification of logic expressions with up to 4 logic variables - o Consider a 3-variable (ABC) K-map: \*Examples and assignments to be given in physical class