Combinational Logic Circuits

Similar documents
IT 201 Digital System Design Module II Notes

ELCT201: DIGITAL LOGIC DESIGN

Gate Level Minimization Map Method

2.1 Binary Logic and Gates

ELCT201: DIGITAL LOGIC DESIGN


Combinational Logic & Circuits

Chapter 2. Boolean Expressions:

Gate-Level Minimization

Combinational Logic Circuits Part III -Theoretical Foundations

數位系統 Digital Systems 朝陽科技大學資工系. Speaker: Fuw-Yi Yang 楊伏夷. 伏夷非征番, 道德經察政章 (Chapter 58) 伏者潛藏也道紀章 (Chapter 14) 道無形象, 視之不可見者曰夷

DKT 122/3 DIGITAL SYSTEM 1

Chapter 3. Gate-Level Minimization. Outlines

Gate-Level Minimization

Gate-Level Minimization

CS8803: Advanced Digital Design for Embedded Hardware

Literal Cost F = BD + A B C + A C D F = BD + A B C + A BD + AB C F = (A + B)(A + D)(B + C + D )( B + C + D) L = 10

Experiment 3: Logic Simplification

Chapter 2 Combinational

Gate Level Minimization

Assignment (3-6) Boolean Algebra and Logic Simplification - General Questions

Combinational Logic Circuits

Chapter 2 Combinational Logic Circuits

A B AB CD Objectives:

2.6 BOOLEAN FUNCTIONS

Gate-Level Minimization. BME208 Logic Circuits Yalçın İŞLER

Module -7. Karnaugh Maps

CHAPTER-2 STRUCTURE OF BOOLEAN FUNCTION USING GATES, K-Map and Quine-McCluskey

Boolean Algebra and Logic Gates

Specifying logic functions

Simplification of Boolean Functions

Bawar Abid Abdalla. Assistant Lecturer Software Engineering Department Koya University

CMPE223/CMSE222 Digital Logic

UNIT-4 BOOLEAN LOGIC. NOT Operator Operates on single variable. It gives the complement value of variable.

Unit-IV Boolean Algebra

SWITCHING THEORY AND LOGIC CIRCUITS

LSN 4 Boolean Algebra & Logic Simplification. ECT 224 Digital Computer Fundamentals. Department of Engineering Technology

Contents. Chapter 3 Combinational Circuits Page 1 of 34

X Y Z F=X+Y+Z

BOOLEAN ALGEBRA. Logic circuit: 1. From logic circuit to Boolean expression. Derive the Boolean expression for the following circuits.

Chapter 2 Combinational Logic Circuits

ECE380 Digital Logic

2008 The McGraw-Hill Companies, Inc. All rights reserved.

Digital Logic Design. Outline

Experiment 4 Boolean Functions Implementation

Logic and Computer Design Fundamentals. Chapter 2 Combinational Logic Circuits. Part 3 Additional Gates and Circuits

Chapter 3 Simplification of Boolean functions

R.M.D. ENGINEERING COLLEGE R.S.M. Nagar, Kavaraipettai

CSCI 220: Computer Architecture I Instructor: Pranava K. Jha. Simplification of Boolean Functions using a Karnaugh Map

Gate-Level Minimization. section instructor: Ufuk Çelikcan

Digital Logic Design (CEN-120) (3+1)

Standard Forms of Expression. Minterms and Maxterms

Chapter 2 Boolean algebra and Logic Gates

Lecture (05) Boolean Algebra and Logic Gates

Switching Circuits & Logic Design

Code No: 07A3EC03 Set No. 1

Simplification of Boolean Functions

Boolean algebra. June 17, Howard Huang 1

Combinational Circuits Digital Logic (Materials taken primarily from:

Incompletely Specified Functions with Don t Cares 2-Level Transformation Review Boolean Cube Karnaugh-Map Representation and Methods Examples

Boolean Algebra. BME208 Logic Circuits Yalçın İŞLER

Karnaugh Map (K-Map) Karnaugh Map. Karnaugh Map Examples. Ch. 2.4 Ch. 2.5 Simplification using K-map

Code No: R Set No. 1

Summary. Boolean Addition

UNIT 2 BOOLEAN ALGEBRA

Slide Set 5. for ENEL 353 Fall Steve Norman, PhD, PEng. Electrical & Computer Engineering Schulich School of Engineering University of Calgary

ENGINEERS ACADEMY. 7. Given Boolean theorem. (a) A B A C B C A B A C. (b) AB AC BC AB BC. (c) AB AC BC A B A C B C.

1. Mark the correct statement(s)

Review. EECS Components and Design Techniques for Digital Systems. Lec 05 Boolean Logic 9/4-04. Seq. Circuit Behavior. Outline.

(Refer Slide Time 6:48)

Digital Logic Lecture 7 Gate Level Minimization

QUESTION BANK FOR TEST

Computer Science. Unit-4: Introduction to Boolean Algebra

UNIT II. Circuit minimization

Chapter 6. Logic Design Optimization Chapter 6

CS470: Computer Architecture. AMD Quad Core

Binary logic. Dr.Abu-Arqoub

Points Addressed in this Lecture. Standard form of Boolean Expressions. Lecture 4: Logic Simplication & Karnaugh Map

Chapter 2. Boolean Algebra and Logic Gates

Code No: R Set No. 1

Switching Theory And Logic Design UNIT-II GATE LEVEL MINIMIZATION

4 KARNAUGH MAP MINIMIZATION

Lecture 5. Chapter 2: Sections 4-7


Ch. 5 : Boolean Algebra &

Lecture 4: Implementation AND, OR, NOT Gates and Complement

Code No: R Set No. 1

NODIA AND COMPANY. GATE SOLVED PAPER Computer Science Engineering Digital Logic. Copyright By NODIA & COMPANY

Bawar Abid Abdalla. Assistant Lecturer Software Engineering Department Koya University

Menu. Algebraic Simplification - Boolean Algebra EEL3701 EEL3701. MSOP, MPOS, Simplification

B.Tech II Year I Semester (R13) Regular Examinations December 2014 DIGITAL LOGIC DESIGN

Chapter 3. Boolean Algebra and Digital Logic

Circuit analysis summary

UNIT- V COMBINATIONAL LOGIC DESIGN

Introduction. The Quine-McCluskey Method Handout 5 January 24, CSEE E6861y Prof. Steven Nowick

VALLIAMMAI ENGINEERING COLLEGE. SRM Nagar, Kattankulathur DEPARTMENT OF ELECTRONICS AND COMMUNICATION ENGINEERING EC6302 DIGITAL ELECTRONICS

Chap-2 Boolean Algebra

Chapter 2: Combinational Systems

MODULE 5 - COMBINATIONAL LOGIC

Announcements. Chapter 2 - Part 1 1

Transcription:

Chapter 2 Combinational Logic Circuits J.J. Shann (Slightly trimmed by C.P. Chung)

Chapter Overview 2-1 Binary Logic and Gates 2-2 Boolean Algebra 2-3 Standard Forms 2-4 Two-Level Circuit Optimization 2-5 Map Manipulation 2-6 Multiple-Level Circuit Optimization 2-7 Other Gate Types 2-8 Exclusive-OR Operator and Gates 2-9 High-Impedance Outputs 2-10 Chapter Summary J.J. Shann 2-2

2-1 Binary Logic and Gates Digital circuits: hardware components that manipulate binary information are implemented using transistors and interconnections in integrated circuits. Logic gate: basic ckt that performs a specific logical op J.J. Shann 2-3

A. Binary Logic Binary logic: deals w/ binary variables and the ops of a special form of mathematical logic (called boolean algebra) applied to these variables. binary variable: variable that take on two discrete values resembles binary arithmetic, but should no be confused w/ each other: When we talk about logic, everything is bitwise or true/false; bits do not associate w/ each other to mean magnitude When we talk about arithmetic, some group of bits are now treated as representing a magnitude J.J. Shann 2-4

Basic Logic Operations Basic logical ops: p.31, Table 2-1 AND:, identical to binary multiplication OR:, resemble binary addition In binary logic, 1 1 1 In binary arithmetic: 1 1 10 NOT: complement;, J.J. Shann 2-5

Truth Table Truth table: a table of combinations of the binary variables showing the relationship b/t the values that the variables take on and the values of the result of the op. 2 n rows, n: # variables E.g.: truth table for AND op J.J. Shann 2-6

B. Logic Gates Logic gate: is an electronic ckt that operate on one or more input signals to produce an output signal. The input terminals of logic gates accept binary signals within the allowable range and respond at the output terminals w/ binary signals that fall within a specified range. E.g.: transition region indeterminate region J.J. Shann 2-7

Graphic symbols of 3 basic logic gates: Timing diagram: This diagram has little to do with timing; I prefer to call it I/O voltage relationship diagram J.J. Shann 2-8

Multiple-input logic gates: AND and OR gates may have 2 inputs. E.g.: J.J. Shann 2-9

2-2 Boolean Algebra Boolean algebra: is an algebra dealing w/ binary variables and logic ops binary variables: are designated by letters of the alphabet logic ops: AND, OR, NOT Boolean expression: an algebraic expression formed by using binary variables, the constants 0 and 1, the logic op symbols, and parentheses. e.g.: ( Y Z) Z 1 J.J. Shann 2-10

Boolean Function Boolean function: can be described by a Boolean equation, a truth table, or a logic ckt diagram Single-output Boolean function Multiple-output Boolean function Every output should be treated independently; so this in effect is composed of many single-output boolean functions J.J. Shann 2-11

Boolean Equation Boolean equation: consists of a binary variable identifying the function followed by an equal sign and a Boolean expression. expresses the logical relationship b/t binary variables can be expressed in a variety of ways E.g.: F(, Y, Z) YZ YZ WYZ WY WYZ literals YZ terms J.J. Shann 2-12

Truth Table Truth table for a function: is unique a list of all combinations of 1 s and 0 s that can be assigned to the binary variables and a list that shows the value of the function for each binary combination. E.g.: F (, Y, Z) YZ J.J. Shann 2-13

Logic Circuit Diagram Logic circuit diagram: An algebraic expression for a Boolean function Can be mapped to a ckt diagram composed of logic gates Circuit gates are interconnected by wires that carry logic signals. E.g.: F (, Y, Z) YZ Combinational logic circuits J.J. Shann 2-14

A. Basic Identities of Boolean Algebra Basic identities of Boolean Algebra:, Y, Z: binary variable (Note similarities between formulas on the same row) J.J. Shann 2-15

Duality Principle Dual: The dual of an algebraic expression is obtained by interchanging OR and AND ops and replacing 1 s by 0 s and 0 s by 1 s (OR AND, 0 1) E.g.: dual Duality principle: 0 1 A Boolean equation remains valid if we take the dual of the expressions on both sides of the equals sign. E.g.: 1. 0 2. 1 J.J. Shann 2-16

Verification of Identities Verification of an identity: by truth table or verified identities E.g.: 0 (eq. 1) Case 1: 0, 0 0 0 0 Case 2: 1, 0 1 0 1 E.g.: DeMorgan s theorem 0 0 0 0 0 1 1 0 1 ( Y) Y (eq. 16) J.J. Shann 2-17

General DeMorgan s Theorem DeMorgan s theorem: Y Y Y Y General DeMorgan s theorem: 1... 2... 2 n 1 n... 2... 1 2 n 1 n J.J. Shann 2-18

B. Algebraic Manipulation Simplification of Boolean functions: Boolean algebra is a useful tool for simplifying digital ckts. E.g.: F YZ YZ Z F YZ YZ Z Y ( Z Z ) Z 14 : x( y z) xy xz Y 1 Z 7 : x x 1 Y Z 2 : x 1 x J.J. Shann 2-19

F YZ YZ Y Z Z J.J. Shann 2-20

Implementing Boolean Equations When a Boolean equation is implemented w/ logic gates: each term requires a gate each variable within the term designates an input to the gate literal: a single variable within a term that may or may not be complemented E.g.: F YZ YZ Z 3 terms & 8 literals 2 terms & 4 literals F Y Z * Reduce # of terms, # of literals, or both in a Boolean expression is often possible to obtain a simpler ckt J.J. Shann 2-21

Reducing Expressions by Boolean Algebra Boolean algebra may be applied to reduce an expression for obtaining a simpler ckt: Aside: there are Computer tools for synthesizing logic ckt Manual method: cut-and-try E.g.s: i. ii. iii. iv. v. vi. Y ( ( ( Y Y Y Y ) Y )( (1 Y ) ( Y ) ( Y )( Y ) Y ) Y Y Y ) dual YY Y Y J.J. Shann 2-22

C. Complement of a Function Complement of a function F: interchange of 1 s to 0 s and 0 s to 1 s for the values of F in the truth table, or can be derived algebraically by applying DeMorgan s theorem interchange AND and OR ops and complement each variable and constant, or Y Y Y Y take the dual of the function equation and complement each literal: OR AND, 0 1 (Last two methods exemplified below on following two pages) J.J. Shann 2-23

J.J. Shann 2-24 Examples Complementing functions by applying DeMorgan s theorem: E.g.s: YZ YZ F 1 ) ( ) ( ) ( ) ( ) ( 1 Z Y Z Y YZ YZ YZ YZ F ) ( 2 YZ YZ F ) ( ) ( ) ( ) ( ) ( )) ( ( 2 Z Y Z Y YZ Z Y YZ Z Y YZ Z Y F Y Y Y Y

J.J. Shann 2-25 Complementing functions by using duals: E.g.s: (dual: OR AND, 0 1) 1 1 1 ) ( ) ( each literal complement ) ( ) ( of dual F Z Y Z Y Z Y Z Y F YZ YZ F 2 2 2 ) ( ) ( each literal complement ) ( ) ( of dual ) ( F Z Y Z Y Z Y Z Y F YZ YZ F

2-3 Standard Forms Standard forms of Boolean expressions: Contain sum of product terms & product of sum terms Two types: sum-of-products form (product term) (product term) product-of-sums form (sum term) (sum term) Product term: a logical product (AND) among literals E.g.: Y Z Sum terms a logical sum (OR) among literals E.g.: YZ J.J. Shann 2-26

A. Minterms and Maxterms Minterm: m j a product term in which all the variables appear exactly once, either complemented or uncomplemented represents exactly one combination of the binary variables in a truth table A literal is a complemented variable if the corresponding bit of the related binary combination is 0 and is an uncomplemented variable if it is 1. This combination makes the corresponding minterm true, and all other minterms false There are 2 n distinct minterms for n variables. Symbol: m j, j: denotes the decimal equivalent of the binary combination for which the minterm has the value 1 E.g.: Minterms for 3 variables J.J. Shann 2-27

E.g.: Minterms for 3 variables * A literal is a complemented variable if the corresponding bit of the related binary combination is 0 and is an uncomplemented variable if it is 1. J.J. Shann 2-28

Maxterms Maxterm: M j a sum term that contains all the variables in complemented or uncomplemented form represents exactly one combination of the binary variables in a truth table A literal is a uncomplemented variable if the corresponding bit of the related binary combination is 0 and is an complemented variable if it is 1. has the value 0 for that combination and 1 for all others There are 2 n distinct maxterms for n variables. Symbol: M j, j: denotes the decimal equivalent of the binary combination for which the maxterm has the value 0 E.g.: Maxterms for 3 variables J.J. Shann 2-29

E.g.: Maxterms for 3 variables * A literal is a uncomplemented variable if the corresponding bit of the related binary combination is 0 and is an complemented variable if it is 1. J.J. Shann 2-30

Minterms vs. Maxterms A minterm a function, not equal to 0, having the min # of 1 s in its row in the truth table (see p. 28) A maxterm a function, not equal to 1, having the max # of 1 s in its row in the truth table (see p.30 M j (m j ) E.g.: For 3 variables & j 3 m 3 YZ m YZ Y Z 3 M 3 J.J. Shann 2-31

Representing Boolean Function by m j s or M j s Given the truth table of a function a Boolean function in sum of minterms or in product of maxterms Sum of minterms: a logical sum of all the minterms that produce a 1 in the function. Product of maxterms: a logical product of all the maxterms that produce a 0 in the function. J.J. Shann 2-32

E.g.: Represent F and F in sum-of-minterms form F Y Z Y Z YZ YZ m 0 m 2 m 5 m 7 m(0,2,5,7) F YZ YZ Y Z Y Z m 1 m3 m4 m6 m(1,3,4,6) J.J. Shann 2-33

J.J. Shann 2-34 E.g.: Represent F in product-of-maxterms form ),,, M( Z Y Z Y Z Y Z Y M m M M M M m m m m m m m m F j j 13 4 6 ) )( )( )( ( ) ( 6 4 3 1 6 4 3 1 6 4 3 1 ) (1,3,4,6 ),, ( m Z Y F

Conversion of SoP to Sum-of-minterms Form Conversion: by means of truth table or Boolean algebra E Y Z Method 1: by truth table E.g.:Convert to sum-of-minterms form E Y Z truth table m(0,1,2,4,5 ) J.J. Shann 2-35

E.g.:Convert E Y Z to sum-of-minterms form Method 2: by Boolean algebra E Y Z Y ( )( Z Z ) Z( Y Y ) YZ YZ YZ YZ YZ YZ YZ YZ YZ YZ YZ m(0,1,2,4,5) J.J. Shann 2-36

Summary of the Properties of Minterms There are 2 n minterms for n Boolean variables. These minterms can be regarded as from 0 to 2 n 1. Any Boolean function can be expressed in sum of minterms. The complement of a function contains those minterms not included in the original function. A function that includes all the 2 n minterms is equal to logic 1. E.g.: G(, Y) Σm(0,1,2,3) 1 J.J. Shann 2-37

Summary of the Properties of Maxterms There are 2 n maxterms for n Boolean variables. These maxterms can be regarded as from 0 to 2 n 1. Any Boolean function can be expressed in product of maxterms. The complement of a function contains those maxterms not included in the original function. A function that includes all the 2 n maxterms is equal to logic 0. E.g.: G(, Y) ΠM(0,1,2,3) 0 J.J. Shann 2-38

B. Sum of Products (SoP) Sum-of-products form: a standard form that contains product terms w/ any number of literals. These AND terms are ORing together. E.g.: F (, Y, Z) Y Y Z Y Sum-of-minterms form: is a special case of SoP form is obtained directly from a truth table contains the max # of literals in each term and usually has more product terms than necessary simplify the expression to reduce the # of product terms and the # of literals in the terms a simplified expression is in sum-of-products form J.J. Shann 2-39

Logic Diagram for an SoP form Logic diagram for an SoP form: consists of a group of AND gates followed by a single OR gate. 2-level implementation or 2-level ckt Assumption: The input variables are directly available in their complemented and uncomplemented forms. ( Inverters are not included in the diagram) E.g.: F Y Y Z Y J.J. Shann 2-40

C. Product of Sums (PoS) Product-of-sums form: a logical product of sum terms & each logical sum term may have any # of distinct literals. 2-level gating structure Special case: Product-of-maxterms form E.g.: F ( Y Z) ( Y Z ) J.J. Shann 2-41

D. Nonstandard Form Nonstandard form: E.g.: F AB C(D E) 3-level Nonstandard form Standard form: By using the distributive laws E.g.: F AB C(D E) AB CD DE 2-level Standard form vs Nonstandard form J.J. Shann 2-42

2-4 Two-Level Circuit Optimization Representation of a Boolean function: Truth table: unique Algebraic expression: many different forms digital logic circuit Minimization of Boolean function: Algebraic manipulation: literal minimization ( 2-2) use the rules and laws of Boolean algebra Disadv.: It lacks specific rules to predict each succeeding step in the manipulation process. Map method: gate-level minimization ( 2-4~2-5) a simple straightforward procedure using Karnaugh map (K-map) Disadv.: Maps for more than 4 variables are not simple to use. * The simplest algebraic expression: not unique J.J. Shann 2-43

A. Cost Criteria Two cost criteria: i. Literal cost the # of literal appearances in a Boolean expression ii. Gate input cost ( ) the # of inputs to the gates in the implementation iii. Analyses and comparison to follow J.J. Shann 2-44

Literal Cost Literal cost: the # of literal appearances in a Boolean expression E.g.: F F Adv.: is very simple to evaluate by counting literal appearances Disadv.: does not represent ckt complexity accurately in all cases E.g.: G G ( A AB C( D AB CD ABCD B)( B E) CE ABCD C)( C 5 literals 6 literals 8 literals D)( D A) 8 literals J.J. Shann 2-45

Gate Input Cost Gate input cost: the # of inputs to the gates in the implementation For SoP or PoS eqs, the gate input cost can be found by the sum of all literal appearances the # of terms excluding terms that consist only of a single literal the # of distinct complemented single literals (optional) E.g.: p.2-51 G ABCD ABCD G ( A B)( B C)( C 8 2 ( D)( D 8 4 ( is a good measure for contemporary logic implementation A) is proportional to the # of transistors and wires used in implementing a logic ckt. (especially for ckt 2 levels) 4) gate input counts 4) J.J. Shann 2-46

B. The Map Method Map method: Karnaugh map simplification a simple straightforward procedure K-map: a pictorial form of a truth table a diagram made up of squares Each square represents one minterm of the function. Any adjacent squares in the map differ by only one variable. The simplified expressions produced by the map are always in one of the two standard forms: SOP (sum of products) if you work with 1s, or POS (product of sums) if you work with 0s J.J. Shann 2-47

(a) Two-Variable Map Two-variable map: 4 squares, one for each minterm. A function of 2 variables can be represented in the map by marking the squares that correspond to the minterms of the function. F(,Y) * Any adjacent squares in the map differ by only one variable. J.J. Shann 2-48

Example E.g.: <Ans> F 1 (,Y) F 2 m 1 m 2 m 3 m 3 Y Y Y Y Y ( Y Y ) Y ( )( Y ) Y J.J. Shann 2-49

(b) Three-Variable Map Three-variable map: 8 minterms 8 squares F(,Y,Z) Only one bit changes in value from one adjacent column to the next Any two adjacent squares in the map differ by only one variable, which is primed in one square and unprimed in the other. E.g.: m 5 & m 7 Note: Each square has 3 adjacent squares. The right & left edges touch each other to form adjacent squares. E.g.: m 4 m 0, m 5, m 6 J.J. Shann 2-50

Map Minimization of SOP Expression Basic property of adjacent squares: Any two adjacent squares in the map differ by only one variable: primed in one square and unprimed in the other E.g.: m 5 YZ, m7 YZ Any two minterms in adjacent squares that are ORed together can be simplified to a single product term after removal of the different variable. E.g.: m 5 m7 YZ YZ Z( Y Y ) Z J.J. Shann 2-51

Procedure of map minimization of SOP expression: i. A 1 is marked in each minterm that represents the function. ii. Find possible adjacent 2 k squares: 2 adjacent squares (i.e., minterms) remove 1 literal 4 adjacent squares (i.e., minterms) remove 2 literal 2 k adjacent squares (i.e., minterms) remove k literal The larger the # of squares combined, the less the # of literals in the product (AND) term. * It is possible & encouraged to use the same square more than once. J.J. Shann 2-52

Example 2-3 Simplify the Boolean function F(, Y, Z) Σm(2,3,4,5) <Ans.> F Y Y 0 1 3 2 4 5 7 6 J.J. Shann 2-53

4-minterm Product terms Product terms using 4 minterms: E.g.: F(, Y, Z) Σm(0,2,4,6) m 0 m 2 m 4 m 6 Y Z Y Z Y Z Y Z Z( Y Y ) Z( Y Y ) Z Z Z( ) Z J.J. Shann 2-54

E.g.: F(, Y, Z) Σm(0,1,2,3,6,7) 0 1 3 2 4 5 7 6 J.J. Shann 2-55

Example 2-4 Simplify the Boolean function F F 1 <Ans.> (, Y, Z) 2 (, Y, Z) m(3,4,6,7) m(0,2,4,5,6) 0 1 3 2 0 1 3 2 4 5 7 6 4 5 7 6 J.J. Shann 2-56

Non-unique Optimized Expressions There may be alternative ways of combining squares to product equally optimized expressions: E.g.: F(, Y, Z) m(1,3,4,5,6 ) 0 1 3 2 F(, Y, Z) m(1,3,4,5,6 ) Z Z Y 4 5 7 6 Z Z YZ J.J. Shann 2-57

Simplifying Functions not Expressed as Sumof-minterms Form If a function is not expressed as a sum of minterms: How to apply the map method here? use the map to obtain the minterms of the function & then simplify the function E.g.: Given the Boolean function F Z Y YZ YZ <Ans.> F Z Y YZ YZ 1, 3 2, 3 5 3, 7 0 1 3 2 m(1,2,3,5,7 ) Z Y 4 5 7 6 J.J. Shann 2-58

(c) Four-Variable Map Four-variable map: 16 minterms 16 squares F(W,, Y, Z) Note: Each square has 4 adjacent squares. The map is considered to lie on a surface w/ the top and bottom edges, as well as the right and left edges, touching each other to form adjacent squares. E.g.: m 8 m 0, m 9, m 10, m 12 J.J. Shann 2-59

Example 2-5 Simplify the Boolean function F(W,, Y, Z) Σ(0,1,2,4,5,6,8,9,12,13,14) <Ans.> 0 1 3 2 4 5 7 6 12 13 15 14 1 8 9 11 10 F Y W Z Z J.J. Shann 2-60

Example 2-6 Simplify the Boolean function F ( A, B, C, D) ABC BCD ABC <Ans.> ABCD 0 1 3 2 4 5 7 6 12 13 15 14 1 8 9 11 10 F BD BC ACD J.J. Shann 2-61

Relationship b/t the # of adjacent squares and the # of literals in the term: Any 2 k adjacent squares, for k o, 1,, n, in an n-variable map, will represent an area that gives a term of n k literals. J.J. Shann 2-62

Maps for more than 4 variables are not as simple to use: Employ computer programs specifically written to facilitate the simplification of Boolean functions w/ a large # of variables. J.J. Shann 2-63

2-5 Map Manipulation When choosing adjacent squares in a map: Ensure that all the minterms of the function are covered when combining the squares. Minimize the # of terms in the expression. avoid any redundant terms whose minterms are already covered by other terms J.J. Shann 2-64

A. Essential Prime Implicants Implicant: A product term is an implicant of a function if the function has the value 1 for all minterms of the product term. Prime implicant: PI a product term obtained by combining the max. possible # of adjacent squares in the map Essential prime implicant: EPI, must be included in resultant simplified F function If a minterm in a square is covered by only one PI, that PI is said to be essential. Look at each square marked w/ a 1 and check the # of PIs that cover it. J.J. Shann 2-65

Example: p.2-57 Find the PIs and EPIs of the Boolean function F(, Y, Z) Σm(1,3,4,5,6) <Ans.> 0 1 3 2 F(, Y, Z) m(1,3,4,5,6 ) Z Z Y 4 5 7 6 Z Z YZ 4 PIs : Z, Z, Y, YZ 2 EPIs : Z ( m3), Z ( m6 ) J.J. Shann 2-66

Example Find the PIs and EPIs of the Boolean function F(A,B,C,D) Σ(0,2,3,5,7,8,9,10,11,13,15) <Ans.> 6 PIs: BD, B'D', CD, B'C, AD, AB' 2 EPIs: BD (m5), B'D' (m0) J.J. Shann 2-67

Example (Cont ) Find the PIs and EPIs of the Boolean function F(A,B,C,D) Σ(0,2,3,5,7,8,9,10,11,13,15) <Ans.> Non-essential 6 PIs: BD, B'D', CD, B'C, AD, AB' 2 EPIs: BD (m 5 ), B'D' (m 0 ) J.J. Shann 2-68

B. Finding the Simplified Expression Procedure for finding the simplified expression from the map: (SoP form) i. Determine all PIs. ii. The simplified expression is obtained from the logical sum of all the EPIs plus other PIs that may be needed to cover any remaining minterms not covered by the EPIs. There may be more than one expression that satisfied the simplification criteria. J.J. Shann 2-69

Example 2-7 Simplify the Boolean function F(A,B,C,D) Σ(1,3,4,5,6,7,12,14) <Ans.> PIs: A'D, BD', A'B EPIs: A'D (m 1, m 3 ), BD' (m 12, m 14 ) A D: m 1,m 3,m 5,m 7 ; BD : m 4,m 6,m 12,m 14 sorted: m 1, m 3, m 4, m 5, m 6, m 7, m 12, m 14 F AD BD J.J. Shann 2-70

Example 2-8 Simplify the Boolean function F(A,B,C,D) Σ(0,5,10,11,12,13,15) <Ans.> EPIs : ABCD BCD ABC ABC Combine PIs that contains m 15 ACD F ABCD BCD ABC ABC or ABD J.J. Shann 2-71

Selection Rule of Nonessential PIs Selection rule of Nonessential PIs: Minimize the overlap among PIs as much as possible. Make sure that each PI selected includes at least 1 minterm not included in any other PI selected. It results in a simplified, although not necessarily minimum cost, SoP expression. J.J. Shann 2-72

Example 2-9 Simplify the Boolean function F(A,B,C,D) Σm(0,1,2,4,5,10,11,13,15) <Ans.> EPI : AC F( A, B, C, D) AC ABD ABC ABD J.J. Shann 2-73

Example: p.2-74 Simplify the Boolean function F(A,B,C,D) Σ(0,2,3,5,7,8,9,10,11,13,15) <Ans.> AB CD 6 PIs: BD, B'D', CD, B'C, AD, AB' 2 EPIs: BD, B'D' EPIs: BD, B'D' m 0,m 2, m 5, m 7, m 8, m 10, m 13, m 15 ; missing m 3, m 9, & m 11 Combine PIs that contains m 3,m 9, m 11 (CD, B'C, AD, AB') F BD B'D' CD AD BD B'D' CD AB' BD B'D' B'C AD BD B'D' B'C AB' J.J. Shann 2-74 EPIs nonepis

C. Product-of-Sums (PoS) Optimization Approach 1: First obtain simplified F' in the form of sum of products Then apply DeMorgan's theorem F (F')' > F': sum of products F: product of sums Approach 2: combinations of the maxterms of F E.g.: i. A 0 is marked in each maxterm that represents the function. ii. Find possible adjacent 2 k squares and realize each set as a sum (OR) term, w/ variables being complemented. CD M 0 M 1 (ABCD)(ABCD') (ABC)(DD') ABC AB 00 01 11 10 00 M 0 M 1 M 3 M 2 01 M 4 M 5 M 7 M 6 11 M 12 M 13 M 15 M 14 10 M 8 M 9 M 11 M 10 J.J. Shann 2-75

Example 3-8 Simplify the Boolean function in (a) SoP and (b) PoS: F(A,B,C,D) Σm(0,1,2,5,8,9,10) <Ans.> (a) F B D B C A C D (b) Approach 1: F AB CD BD F ( F ) ( A B)( C D)( B D) Approach 2: Think in terms of maxterms J.J. Shann 2-76

Gate implementation: (a) F B D B C A C D (b) F ( A B)( C D)( B D) The implementation of a function in a standard form is said to be a two-level implementation. Assumption: The input variables are directly available in their complement Inverters are not needed. Determine which form will be best for a function: GIC (gate input count)? J.J. Shann 2-77

D. Don t-care Conditions What is a Don t care condition: the unspecified minterms of a function is represented by an E.g.: A 4-bit decimal code has 6 combinations which are not used. Due to Incompletely specified function: has unspecified outputs for some input combinations Simplification of an incompletely specified function: When choosing adjacent squares to simplify the function in the map, the s may be assumed to be either 0 or 1, whichever gives the simplest expression. An need not be used at all if it does not contribute to covering a larger area. J.J. Shann 2-78

Example 2-11 Simplify the Boolean function F (w,x,y,z) Σm(1,3,7,11,15) which has the don t-care conditions d (w,x,y,z) Σm(0,2,5). <Ans.> (a) SOP: F (w,x,y,z) yz w x Σm(0,1,2,3,7,11,15) F (w,x,y,z) yz w z Σm(1,3,5,7,11,15) (b) POS: F (w,x,y,z) z (w y) Σm(1,3,5,7,11,15) J.J. Shann 2-79

2-6 Multiple-Level Circuit Optimization 2-level ckt optimization: can reduce the cost of combinational logic ckts Multi-level ckts: ckts w/ more than 2 levels There are often additional cost saving available objective of this optimization May accompany longer delay J.J. Shann 2-80

Example E.g.: G ABC ABD E ACF ADF <Ans.> 2-level implementation: gate-input cost 17 Multi-level implementation: distributive law G ABC ABD E ACF ADF AB( C D) E AF( C D) ( AB AF)( C D) E A( B F)( C D) E J.J. Shann 2-81

J.J. Shann 2-82

Multiple-level Optimization Multiple-level ckt optimization (simplification): is based on the use of a set of transformations that are applied in conjunction w/ cost evaluation to find a good, but not necessarily optimum solution. J.J. Shann 2-83

Multilevel Optimization Transformations Transformations: Factoring: is finding a factored form from either a SoP or PoS expression for a function Decomposition: is the expression of a function as a set of new functions Extraction: is the expression of multiple functions as a set of new functions Substitution of a function G into a function F: is expressing F as a function of G and some or all of the original variables of F Elimination: flattening or collapsing is the inverse of substitution function G in an expression for function F is replaced by the expression for G J.J. Shann 2-84

J.J. Shann 2-85 A. Transformation for GIC Reduction E.g. 2-12: Multilevel optimization transformations <Ans.> BCF BCE ABF ABE ABCD H BCDEF ADF ADE ACF ACE G 2 1 2 1 1 2 ) ( ) )( ( )) ( ) ( ( ) ( B A EF B D C A BCDEF F E D C A BCDEF F E D F E C A BCDEF DF DE CF CE A BCDEF ADF ADE ACF ACE G F E CD 2 1

J.J. Shann 2-86 (Cont d) C A F E CD 3 2 1 )) )( ( ) ( ( )) ( ) ( ( ) ( F E C A CD A B F E C F E A ACD B CF CE AF AE ACD B BCF BCE ABF ABE ABCD H ( 2) 3 1 2 1 2 1 A B H B A G extraction of G & H: substitution:

J.J. Shann 2-87 BCF BCE ABF ABE ABCD H BCDEF ADF ADE ACF ACE G ( 2) 3 1 2 1 2 1 A B H B A G C A F E CD 3 2 1

Key to successful transformations: is the determination of the factors to be used in decomposition or extraction and choice of the transformation sequence to apply J.J. Shann 2-88

B. Transformation for Delay Reduction Define: Path delay-- the length of time it takes for a change in a signal to propagate down a path through the gates Define: Critical path-- the longest path(s) through a ckt Situation: In a large proportion of designs, the length of the longest path(s) through the ckt is often constrained. The # of gates in series may need to be reduced. Critical path gate elimination transformation J.J. Shann 2-89

Elimination transform: replaces intermediate variables, i, w/ the expressions on their right hand sides or removes other factoring of some variables Reduces the # of gates in series Determination of factor or combination of factors to be eliminated: while watching for the effect of increasing gate input count the increase in gate input count for the combinations of eliminations that reduce the problem path lengths by at lease one gate are of interest Reducing both path length and gate input count often cannot be achieved simultaneously J.J. Shann 2-90

Example 2-13 E.g.: Transformation for delay reduction Assumption: Ignore the delay of NOT gate. G A 1 2 B 1 2 H B( A 1 3 2) 1 2 3 CD E F A C GIC 25 J.J. Shann 2-91

G A 1 H B( A 1 3 2) 1 CD 2 E F GIC 25 3 A C <Ans.> 3 combinations of eliminations that reduce 1 gate delay: i. removal of the factor B in H GIC increases 0 and H path length reduced ii. removal of the intermediate variables 1, 2, 3 GIC increases 20 (?) and H path length further reduced iii. removal of B, 1, 2, 3 GIC increases 23 (?) and H path length again reduced 2 B 1 2 G A 1 H B A 1 2 B B 3 1 G ACE ACF ADE ADF BCDEF H B( ACD AE AF CE CF) G ACE ACF ADE ADF BCDEF H ABCD ABE ABF BCE BCF 2 2 1 2 3 CD E F A C J.J. Shann 2-92

J.J. Shann 2-93 2 3 1 2 1 2 1 B BA H B A G ( 2) 3 1 2 1 2 1 A B H B A G C A F E CD 3 2 1 Eliminate the factor B

2-7 Other Gate Types Basic logic operations: AND, OR, NOT All possible functions of n binary variables: n binary variables 2 n distinct minterms 2 2n possible functions E.g.: n 2 4 minterms 16 possible functions J.J. Shann 2-94

J.J. Shann 2-95

The 16 functions can be subdivided into 3 categories: 1. 2 functions that produce a constant 0 or 1. 2. 4 functions w/ unary operations complement (NOT) and transfer. 3. 10 functions w/ binary operators that define eight different operations AND, OR, NAND, NOR, exclusive-or, equivalence, inhibition, and implication. J.J. Shann 2-96

Digital Logic Gates Boolean expression: AND, OR and NOT operations It is easier to implement a Boolean function in these types of gates. Consider the construction of other types of logic gates: the feasibility and economy of implementing the gate w/ electronic components the basic properties of the binary operations E.g.: commutativity, associativity, the ability of the gate to implement Boolean functions alone or in conjunction w/ other gates the convenience of representing gate functions that are frequently used J.J. Shann 2-97

AND OR Primitive Digital Logic Gates NOT (inverter) Buffer amplify an electrical signal to permit more gates to be attached to the output or to decrease the time it takes for signals to propagate through the ckt 3-state Buffer ( 2-9) NAND NOR J.J. Shann 2-98

Define: Universal gate-- a gate type that alone can be used to implement all Boolean functions E.g.: NAND gate, NOR gate Proof of a universal gate: Show that the logical ops of AND, OR, and NOT can be obtained w/ the universal gate only. E.g.: Show that the NAND gate is a universal gate J.J. Shann 2-99

E.g.: Show that the NAND gate is a universal gate J.J. Shann 2-100

E.g.: Simplify the Boolean function and implement it by NAND gates <Ans.> F(, Y, Z) m(0,2,4,5,6) Y Z J.J. Shann 2-101

Method 1: Y Z AND OR Y Z Y Z J.J. Shann 2-102

Method 2: Y Z Y Z Y Z J.J. Shann 2-103

Complex Digital Logic Gates Exclusive-OR ( 2-8) NOR ( 2-8) AND-OR-Invert (AOI) the complement of SoP E.g.: 2-1 AOI F Y Z E.g.: 3-2-2 AOI F TUV W YZ OR-AND-Invert (OAI) the dual of AOI the complement of PoS AND-OR (AO) OR-AND (OA) J.J. Shann 2-104

Adv. of using complex gates: reduce the ckt complexity needed for implementing specific Boolean functions in order to reduce integrated ckt (IC) cost reduce the time required for signals to propagate through a ckt J.J. Shann 2-105

2-8 Exclusive-OR Operator and Gates Exclusive-OR: OR, Y Y is equal to 1 if exactly one input variable is equal to 1 Exclusive-NOR: NOR, also called equivalence Y Y Y Y is equal to 1 if both and Y are equal to 1 or if both are equal to 0. OR & NOR are the complement to each other. Y Y Y ( Y )( Y ) Y Y They are particularly useful in arithmetic operations and error-detection and correction ckts. J.J. Shann 2-106

Properties of OR Identities: 0 1 0 1 Y Y Y Y can be verified by using a truth table or by replacing the op by its equivalent Boolean expression Commutativity and associativity: A B B A (A B) C A (B C) A B C OR gates w/ three or more inputs J.J. Shann 2-107

Implementations of OR function OR function is usually constructed w/ other types of gates: J.J. Shann 2-108

Odd Function Multiple-variable OR operation: odd function equal to 1 if the input variables have an odd # of 1 s E.g.: 3-variable OR Y Z ( Y Y ) Z ( Y Y ) Z ( Y Y ) Z Y Z Y Z YZ YZ m(1,2,4,7) is equal to 1 if only one variable is equal to 1 or if all three variables are equal to 1. J.J. Shann 2-109

E.g.: 4-variable OR A B C D (AB A B) (CD C D) (AB A B)(CD C D ) (AB A B )(CD C D) Σ(1, 2, 4, 7, 8, 11, 13, 14) n-variable OR function: the logical sum of the 2 n /2 minterms whose binary numerical values have an odd # of 1 s. J.J. Shann 2-110

Even Function Multiple-variable NOR op: an even function E.g.: 4-variable NOR n-variable NOR function: the logical sum of the 2 n /2 minterms whose binary numerical values have an even # of 1 s. J.J. Shann 2-111

Logic Diagram of Odd & Even Functions Logic diagram of odd & even functions: Multiple-input Odd function: J.J. Shann 2-112

Example Simplify the Boolean function and implement it by OR gates and other gates F(W,, Y, Z) Σ(1, 4, 7, 8, 13) <Ans.> YZ W 1 1 1 1 1 F Y (W Z) WZ ( Y) or Y (W Z) W YZ or Y (W Z) W YZ J.J. Shann 2-113

2-9 High-Impedance Outputs Output values of a gate may be: 0 or 1, as usual; plus Hi-Z: high-impedance state behaves as an open ckt, i.e., looking back into the ckt, the output appears to be disconnected * Where can this be useful? Gates w/ only logic 0 and 1 outputs cannot have their outputs connected together. * Gates w/ Hi-Z output values can have their outputs connected together, provided that no 2 gates drive the line at the same time to opposite 0 and 1 values. Structures that provide Hi-Z: 3-state buffers or others transmission gates J.J. Shann 2-114

Three-State Buffers 3-state buffer: J.J. Shann 2-115

Multiplexer constructed by 3- state buffers: E.g.: 2-to-1 MU Input 0 Input 1 MU Output Selection input J.J. Shann 2-116

Transmission Gates Transmission gate (TG): J.J. Shann 2-117

OR gate constructed from transmission gates: J.J. Shann 2-118

2-10 Chapter Summary Primitive logic ops: AND, OR, NOT Boolean algebra Minterm & maxterm standard forms SoP and PoS standard forms 2-level gate ckts 2 cost measures for ckt optimization: # of input literals to a ckt total # of inputs to the gates in a ckt J.J. Shann 2-119

Circuit optimization: 2-level ckt optimization Boolean algebra manipulation K-map Quine-McCluskey method Multi-level ckt optimization Other logic gates: NAND, NOR OR, NOR Hi-Z outputs: 3-state buffer transmission gates J.J. Shann 2-120