Chapter Four Combinational Logic 1. C OMBINATIONAL C IRCUITS It consists of input variables, logic gates and output variables. Output is function of input.

Slides:



Advertisements
Similar presentations
Combinational Circuits
Advertisements

Combinational Circuits
التصميم المنطقي Second Course
CSE-221 Digital Logic Design (DLD)
Combinational Logic Chapter 4. Digital Circuits Introduction Logic circuits for digital systems may be combinational or sequential. A combinational.
Design of Arithmetic Circuits – Adders, Subtractors, BCD adders
Combinational Logic Chapter 4.
Combinational Logic1 DIGITAL LOGIC DESIGN by Dr. Fenghui Yao Tennessee State University Department of Computer Science Nashville, TN.
CS 105 Digital Logic Design
Combinational Circuits
Combinational Circuits
Chapter 3 Decoder and Encoder Digital Logic Design III
Morgan Kaufmann Publishers
Combinational Logic Design
Outline Analysis of Combinational Circuits Signed Number Arithmetic
Combinational Logic Chapter 4. Digital Circuits Combinational Circuits Logic circuits for digital system Combinational circuits the outputs are.
1 COMBINATIONAL LOGIC One or more digital signal inputs One or more digital signal outputs Outputs are only functions of current input values (ideal) plus.
Sahar Mosleh PageCalifornia State University San Marcos 1 Multiplexer, Decoder and Circuit Designing.
Chap 3. Chap 3. Combinational Logic Design. Chap Combinational Circuits l logic circuits for digital systems: combinational vs sequential l Combinational.
Dr. Ahmed El-Bialy, Dr. Sahar Fawzy Combinational Circuits Dr. Ahmed El-Bialy Dr. Sahar Fawzy.
Chapter 3 Combinational Design Digital Logic Design III
Combinational Circuits
CS2100 Computer Organisation MSI Components (AY2015/6 Semester 1)
1 Chapter 4 Combinational Logic Logic circuits for digital systems may be combinational or sequential. A combinational circuit consists of input variables,
Combinational Logic By Taweesak Reungpeerakul
1 Combinational Logic Logic and Digital System Design - CS 303 Erkay Savaş Sabancı University.
Combinational Logic. Digital Circuits Introduction Logic circuits for digital systems may be combinational or sequential. A combinational circuit.
Digital System Ch4-1 Chapter 4 Combinational Logic Ping-Liang Lai ( 賴秉樑 ) Digital System 數位系統.
D IGITAL L OGIC D ESIGN I G ATE -L EVEL M INIMIZATION.
Boolean Algebra and Logic Gates 1 Computer Engineering (Logic Circuits) Lec. # 8 (Combinational Logic Circuit) Dr. Tamer Samy Gaafar Dept. of Computer.
(Combinational Logic Circuit)
CHAPTER 4 Combinational Logic
Logic Gates Logic gates are electronic digital circuit perform logic functions. Commonly expected logic functions are already having the corresponding.
CHAPTER 4 Combinational Logic Design- Arithmetic Operation (Section 4.6&4.9)
Chapter Four Combinational Logic 1. C OMBINATIONAL C IRCUITS It consists of input variables, logic gates and output variables. Output is function of input.
CS 105 DIGITAL LOGIC DESIGN Chapter 4 Combinational Logic 1.
Chap 2. Combinational Logic Circuits
Fuw-Yi Yang1 數位系統 Digital Systems Department of Computer Science and Information Engineering, Chaoyang University of Technology 朝陽科技大學資工系 Speaker: Fuw-Yi.
Chapter Four Combinational Logic 1. Discrete quantities of information are represented in digital systems by binary codes. A binary code of n bits is.
1 Chapter 4 Combinational Logic Logic circuits for digital systems may be combinational or sequential. A combinational circuit consists of input variables,
Logic Design CS221 1 st Term combinational circuits Cairo University Faculty of Computers and Information.
CHAPTER 2 Digital Combinational Logic/Arithmetic Circuits
1 Fundamentals of Computer Science Combinational Circuits.
1 Combinational Logic EE 208 – Logic Design Chapter 4 Sohaib Majzoub.
Combinational Circuit Design. Digital Circuits Combinational CircuitsSequential Circuits Output is determined by current values of inputs only. Output.
Module 11.  In Module 9, we have been introduced to the concept of combinational logic circuits through the examples of binary adders.  Meanwhile, in.
ECE DIGITAL LOGIC LECTURE 15: COMBINATIONAL CIRCUITS Assistant Prof. Fareena Saqib Florida Institute of Technology Fall 2015, 10/20/2015.
Binary Parallel Adders
C OMBINATIONAL L OGIC D ESIGN 1 Eng.Maha AlGubali.
Logic Design (CE1111 ) Lecture 4 (Chapter 4) Combinational Logic Prepared by Dr. Lamiaa Elshenawy 1.
UNIT 8 COMBINATIONAL CIRCUIT DESIGN AND SIMULATION USING GATES
Fuw-Yi Yang1 數位系統 Digital Systems Department of Computer Science and Information Engineering, Chaoyang University of Technology 朝陽科技大學資工系 Speaker: Fuw-Yi.
MSI Circuits.
Chapter 4 Combinational Logic. 4.1 Introduction   Logic circuits for digital systems may be combinational or sequential. A combinational circuit consists.
Combinational Circuits: MSI Components
Gunjeet Kaur Dronacharya Group of Institutions. Binary Adder-Subtractor A combinational circuit that performs the addition of two bits is called a half.
Presented by A. Maleki Fall Semester, 2010
Chap 3. Combinational Logic Design
Combinational Logic Logic circuits for digital systems may be combinational or sequential. A combinational circuit consists of input variables, logic gates,
Computer Architecture CST 250
1 Chapter 4 Combinational Logic Logic circuits for digital systems may be combinational or sequential. A combinational circuit consists of input variables,
FUNCTION OF COMBINATIONAL LOGIC CIRCUIT
Chapter 4 Combinational Logic
FIGURE 4.1 Block diagram of combinational circuit
INTRODUCTION TO LOGIC DESIGN Chapter 4 Combinational Logic
Ch 4. Combinational logic
Digital System Design Combinational Logic
Chapter-4 Combinational Logic
Digital System Design Combinational Logic
Presentation transcript:

Chapter Four Combinational Logic 1

C OMBINATIONAL C IRCUITS It consists of input variables, logic gates and output variables. Output is function of input only i.e. no feedback When input changes, output changes (after a delay) n inputsm outputs Combinational Circuits  2

C OMBINATIONAL C IRCUITS Analysis Given a circuit, find out its function Function may be expressed as: Boolean function Truth table Design Given a desired function, determine its circuit Function may be expressed as: Boolean function Truth table ? ? ? 3

A NALYSIS P ROCEDURE Boolean Expression Approach F 1 =T 2 +T 3= AB'C'+A'BC'+A'B'C+ABC F 2 =AB+AC+BC T 2 =ABC T 1 =A+B+C F 2 =AB+AC+BC F’ 2 =( A’+B’ )( A’+C’ )( B’+C’ ) T 3 =AB'C'+A'BC'+A'B'C 4

A NALYSIS P ROCEDURE We can obtain the truth table directly from the logic diagram Truth Table Approach A B C F1F1 F2F = 0 T2 = 0 T1 = 0 0 F2 = 0 F’2 = 1 T3 =

6 Full Adder Circuit

A NALYSIS P ROCEDURE Truth Table Approach = 0 = 1 = 0 = 1 = 0 = 1 = 0 = A B C F1F1 F2F

A NALYSIS P ROCEDURE Truth Table Approach = 0 = 1 = 0 = 1 = 0 = 1 = 0 = 1 = A B C F1F1 F2F

A NALYSIS P ROCEDURE Truth Table Approach = 0 = 1 = 0 = 1 = 0 = 1 = 0 = A B C F1F1 F2F

A NALYSIS P ROCEDURE Truth Table Approach = A B C F1F1 F2F B 0101 A1010 C B 0010 A0111 C F 1 =AB'C'+A'BC'+A'B'C+ABC F 2 =AB+AC+BC 10

D ESIGN P ROCEDURE Given a problem statement: Determine the number of inputs and outputs Derive the truth table Simplify the Boolean expression for each output Produce the required circuit Example: Design a circuit to convert a “BCD” code to “Excess -3” code  4-bits  0-9 values  4-bits  Value+3 ? 11

D ESIGN P ROCEDURE BCD-to-Excess 3 Converter A B C D w x y z x x C 111 B A xxxx 11 xx D C B A xxxx 1 xx D C B A xxxx 1 xx D C B A xxxx 1 xx D w = A+BC+BDx = B’C+B’D+BC’D’ y = C’D’+CDz = D’ 12

13

D ESIGN P ROCEDURE BCD-to-Excess 3 Converter w = A + B(C+D) x = B’(C+D) + B(C+D)’ y = (C+D)’ + CD z = D’ A B C D w x y z x x 14

S EVEN -S EGMENT D ECODER (digital clock) a b c g e d f ? wxyzwxyz abcdefgabcdefg w x y za b c d e f g x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x 1 1 x x x x x x x y x w xxxx 11 xx z BCD code a = w + y + xz + x’z’b =... c =... d =... 15

B INARY A DDER Half Adder Adds 1-bit plus 1-bit Produces Sum and Carry HA xyxy SCSC x y C S x + y ─── C S xyxy SCSC 16

B INARY A DDER Full Adder Adds 1-bit plus 1-bit plus 1-bit Produces Sum and Carry x y z C S x + y + z ─── C S FA xyzxyz SCSC y 0101 x1010 z y 0010 x0111 z S = xy'z'+x'yz'+x'y'z+xyz = x  y  z C = xy + xz + yz 17

B INARY A DDER Full Adder xyzxyz SCSC xyzxyz SCSC S = xy'z'+x'yz'+x'y'z+xyz = x  y  z C = xy + xz + yz 18 Implementation of full adder in sum of products form

B INARY A DDER Implementation of Full Adder with two half adder and an OR gate. xyzxyz SCSC HA xyzxyz SCSC 19

B INARY A DDER c 3 c 2 c 1. + x 3 x 2 x 1 x 0 + y 3 y 2 y 1 y 0 ──────── Cy S 3 S 2 S 1 S 0 FA x 3 x 2 x 1 x 0 FA y 3 y 2 y 1 y 0 S 3 S 2 S 1 S 0 C 4 C 3 C 2 C 1 0 Binary Adder x 3 x 2 x 1 x 0 y 3 y 2 y 1 y 0 S3S2S1S0S3S2S1S0 C0C0 C4C4 Carry Propagate Addition 20

Subscript i3210 Input carry0110 Ci 1011 xi 0011 yi Sum1110 Si Output carry0011 Ci+1 21

Carry propagation When the correct outputs are available The critical path counts : ( A 0, B 0, C 0 ) → C 1 → C 2 → C 3 → ( C 4, S 3 ) When 4-bits full-adder → 8 gate levels ( n -bits: 2 n gate levels) Figure 4.10 Full Adder with P and G Shown 22

B INARY A DDERS (P ARALLEL ) Reduce the carry propagation delay Employ faster gates Look-ahead carry (more complex mechanism, yet faster) Carry propagate: P i = A i  B i Carry generate: G i = A i B i Sum: S i = P i  C i Carry: C i+1 = G i + P i C i C 0 = Input carry C 1 = G 0 +P 0 C 0 C 2 = G 1 +P 1 C 1 = G 1 +P 1 ( G 0 +P 0 C 0 ) = G 1 +P 1 G 0 +P 1 P 0 C 0 C 3 = G 2 +P 2 C 2 = G 2 +P 2 G 1 +P 2 P 1 G 0 + P 2 P 1 P 0 C 0 23

C ARRY L OOK - AHEAD A DDER (1/2) Logic diagram Fig Logic Diagram of Carry Look-ahead Generator 24

C ARRY L OOK - AHEAD A DDER (2/2) 4-bit carry-look ahead adder Propagation delay of C 3, C 2 and C 1 are equal. Fig Bit Adder with Carry Look-ahead 25

B INARY S UBTRACTOR Use 2’s complement with binary adder x – y = x + (- y ) = x + y’

B INARY A DDER /S UBTRACTOR M : Control Signal (Mode) M = 0  F = x + y M = 1  F = x – y  F = x + y ’ + 1 y  0 = y y  1 = y' 27

O VER F LOW : When two numbers with n digits each are added and the sum is a number occupying n + 1 digits, we say that an overflow occurred. Unsigned Binary Numbers 2’s Complement Numbers FA x 3 x 2 x 1 x 0 FA y 3 y 2 y 1 y 0 S 3 S 2 S 1 S 0 C 4 C 3 C 2 C 1 0 Carry FA x 3 x 2 x 1 x 0 FA y 3 y 2 y 1 y 0 S 3 S 2 S 1 S 0 C 4 C 3 C 2 C 1 0 Overflow

 An overflow cannot occur after an addition if one number is positive and the other is negative. since adding a positive number to a negative number produces a result whose magnitude is smaller than the larger of the two original numbers.  An overflow may occur when the two numbers added are both (+) or both (-). Consider 8 bit register ( ).

30 T HE P ROBLEMS : 4.1, 4.3, 4.4, 4.6( A ), 4.10, 4.11, 4.13, 4.15

31 BCD A DDER 4-bits plus 4-bits Operands : 0 to 9 This is called BCD adder. In order to add two decimal digits with a possible carry-in of 1, then the maximum sum is 19. The following table shows the sum when performed in binary and compared to the sum when performed in BCD. In both cases five outputs are needed. + x 3 x 2 x 1 x 0 + y 3 y 2 y 1 y 0 ──────── Cy S 3 S 2 S 1 S 0

32

From the table, when the sum is greater than 9, a correction is needed. The correction is adding 6 to the binary sum. The BCD adder will then consist of the 4-bit binary adder. A second 4-bit binary adder is needed to add 6 to the sum when it is greater than = The required logic circuit needed to detect if correction is needed can be obtained as follows: C = K + Z 8 Z 4 +Z 8 Z 2 33

34 BCD A DDER

B INARY M ULTIPLIER To multiply two 2-bit binary numbers B1 B0 and A1 A0, we may use half adders & AND gates. 35

36

37 For J multiplier bits and K multiplicand bits, we need ( J x K ) AND gates and ( J – 1) K -bit adders to produce a product of J + K bits. In the previous example, K = 4, J = 3, so we need 12 AND gates and 2 four-bit adders to produce a product of seven bits.

M AGNITUDE C OMPARATOR Compare 4-bit number to 4-bit number 3 Outputs: Expandable to more number of bits 0010, 1000 (Using XNOR Gates for equality) Magnitude Comparator A 3 A 2 A 1 A 0 B 3 B 2 B 1 B 0 A B

M AGNITUDE C OMPARATOR

D ECODERS Extract “ Information ” from the code n -to- m line decoder ( n inputs, m <= 2 n output) Binary Decoder Example: 2-bit Binary Number Binary Decoder x1x0 x1x0 Only one lamp will turn on

D ECODERS 2-to-4 Line Decoder I 1 I 0 Y 0 Y 1 Y 2 Y BinaryDecoder I1I0 I1I0 Y0Y1 Y2Y3 Y0Y1 Y2Y3

D ECODERS 3-to-8 Line Decoder (Binary to Octal conversion) BinaryDecoder I2I1I0 I2I1I0 Y0Y1 Y2Y3Y4Y5 Y6Y7 Y0Y1 Y2Y3Y4Y5 Y6Y7

43

D ECODERS “ Enable ” Control BinaryDecoder I1I0E I1I0E Y0Y1 Y2Y3 Y0Y1 Y2Y3 EI 1 I 0 Y 0 Y 1 Y 2 Y 3 0x

45 4 x16 decoder constructed with two 3 x 8 decoders

D ECODERS Expansion E I 1 I 0 Y 7 Y 6 Y 5 Y 4 Y 3 Y 2 Y 1 Y I 2 I 1 I 0 BinaryDecoder I0I1E I0I1E Y3Y2 Y1Y0 Y3Y2 Y1Y0 Y7Y6 Y5Y4Y3Y2 Y1Y0 Y7Y6 Y5Y4Y3Y2 Y1Y0 I0I1E I0I1E Y3Y2 Y1Y0 Y3Y2 Y1Y0 3 x8 decoder constructed with two 2 x 4 decoders

D ECODERS Active-High / Active-Low I 1 I 0 Y 0 Y 1 Y 2 Y I 1 I 0 Y 0 Y 1 Y 2 Y BinaryDecoder I1I0 I1I0 Y0Y1 Y2Y3 Y0Y1 Y2Y3 I1I0 I1I0 Y0Y1 Y2Y3 Y0Y1 Y2Y3

I MPLEMENTATION U SING D ECODERS Each output is a minterm All minterms are produced Sum the required minterms Example: Full Adder S ( x, y, z ) = ∑(1, 2, 4, 7) C ( x, y, z ) = ∑(3, 5, 6, 7) x y z C S

A function with a long list of minterms requires an OR gate with a large number of inputs. If the number of minterms in the function is greater than 2 n /2, then F’ can be expressed with fewer minterms. So we use a NOR gate to sum the minterms of F’. The output of NOR gate complements this sum and generates the normal output F. 49

I MPLEMENTATION U SING D ECODERS WITH NAND GATES I2I1I0 I2I1I0 Y7Y6 Y5Y4Y3Y2 Y1Y0 Y7Y6 Y5Y4Y3Y2 Y1Y0 Binary Decoder xyz xyz S C

E NCODERS Put “ Information ” into code (it generates the binary code corresponding to the input value). Binary Encoder Example: 4-to-2 Binary Encoder x 0 x 1 x 2 x 3 y 1 y Binary Encoder y1y0 y1y0 x 0 x 1 x 2 x3 Only one switch should be activated at a time

E NCODERS Octal-to-Binary Encoder (8-to-3) I 7 I 6 I 5 I 4 I 3 I 2 I 1 I 0 Y 2 Y 1 Y BinaryEncoder Y2Y1Y0Y2Y1Y0 I7I6 I5I4I3I2 I1I0 I7I6 I5I4I3I2 I1I0

P RIORITY E NCODERS 4-Input Priority Encoder ( V is a valid bit indicator) PriorityEncoder VyxVyx D3D2 D1D0D3D2 D1D0

54 1

55

E NCODER / D ECODER P AIRS Y2Y1Y0Y2Y1Y0 I7I6 I5I4I3I2 I1I0 I7I6 I5I4I3I2 I1I0 I2I1I0 I2I1I0 Y7Y6 Y5Y4Y3Y2 Y1Y0 Y7Y6 Y5Y4Y3Y2 Y1Y0 Binary Encoder Binary Decoder

M ULTIPLEXERS (D ATA S ELECTOR ) I T S ELECTS BINARY INFORMATION FROM ONE OF MANY INPUT LINES AND DIRECTS IT TO A SINGLE OUTPUT LINE. MUX Y I0I1 I2I3I0I1 I2I3 S 1 S 0 Y 0 I0I0 0 1I1I1 1 0I2I2 1 I3I3

58 2-to-1 MUX

M ULTIPLEXERS 2-to-1 MUX or 2 x 1 MUX 4-to-1 MUX MUX Y S Y I0I1 I2I3I0I1 I2I3 S 1 S 0 I0I1I0I1

M ULTIPLEXERS Quad 2-to-1 MUX MUX Y0 I0I1I0I1 S MUX Y1 I0I1I0I1 S MUX Y2 I0I1I0I1 S MUX Y3 I0I1I0I1 S A0A1A2A3 A0A1A2A3 B0B1B2B3 B0B1B2B3 S MUX A0A1 A2A3A0A1 A2A3 S E Y3Y2 Y1Y0Y3Y2 Y1Y0 B0B1 B2B3B0B1 B2B3 (two 4-bits input, one 4-bits output)

I MPLEMENTATION U SING M ULTIPLEXERS MUX Y I0I1 I2I3I0I1 I2I3 S 1 S 0 x y zF Example F ( x, y, z ) = ∑(1, 2, 6, 7) x y F F = z z z F = 0 0 F = 1 1

MUX Y I0I1 I2I3I4I5 I6I7I0I1 I2I3I4I5 I6I7 S 2 S 1 S 0 I MPLEMENTATION U SING M ULTIPLEXERS A B C DF Example F ( A, B, C, D ) = ∑(1, 3, 4, 11, 12, 13, 14, 15) A B C F F = D D D D F = 0 0 F = D F = 1 0 D 1 1

Y I0I1 I2I3I4I5 I6I7I0I1 I2I3I4I5 I6I7 S 2 S 1 S 0 M ULTIPLEXER E XPANSION 8-to-1 MUX using Dual 4-to-1 MUX & one 2x1 Mux MUX Y I0I1 I2I3I0I1 I2I3 S 1 S 0 MUX Y I0I1 I2I3I0I1 I2I3 S 1 S 0 MUX Y I0I1I0I1 S 0 1

65 / 65 D E M ULTIPLEXERS DeMUX I Y3Y2Y1Y0Y3Y2Y1Y0 S 1 S 0 Y 3 Y2Y2 Y1Y1 Y0Y I 0 100I0 1 00I00 1 I000

D E M ULTIPLEXERS / D ECODERS BinaryDecoder I1I0E I1I0E Y0Y1 Y2Y3 Y0Y1 Y2Y3 EI 1 I 0 Y 3 Y 2 Y 1 Y 0 0x DeMUX I Y0Y1Y2Y3Y0Y1Y2Y3 S 1 S 0 Y 3 Y2Y2 Y1Y1 Y0Y I 0 100I0 1 00I00 1 I000

T HREE -S TATE G ATES Tri-State Buffer AY C C AY 0 xHi-Z AY C

T HREE -S TATE G ATES Y=Y= A C B A if C = 1 B if C = 0 2-to-1 line mux

T HREE -S TATE G ATES I0I0 Y E S1S1 I1I1 I2I2 I3I3 BinaryDecoder I1I0E I1I0E Y3Y2 Y1Y0 Y3Y2 Y1Y0 S0S0 4-to-1 line mux

70 T HE P ROBLEMS : 4.18, 4.20 ( A ), 4.21, 4.22, , 4.29, 4.31, , 4.35