Combinational Logic Design - PowerPoint PPT Presentation

1 / 42
About This Presentation
Title:

Combinational Logic Design

Description:

Combinational Logic Design Overview Binary Subtraction 2 s complement Extension to r s complement Subtraction with complements Binary Adders/Subtractors Signed ... – PowerPoint PPT presentation

Number of Views:136
Avg rating:3.0/5.0
Slides: 43
Provided by: maria394
Category:

less

Transcript and Presenter's Notes

Title: Combinational Logic Design


1
  • Combinational Logic Design

2
Overview
  • Binary Subtraction
  • 2s complement
  • Extension to rs complement
  • Subtraction with complements
  • Binary Adders/Subtractors
  • Signed numbers
  • Signed Addition/Subtraction
  • Overflow problem
  • Binary Multipliers

3
Binary Subtraction
  • Unsigned numbers minus sign is not explicitly
    represented.
  • Given 2 binary numbers M and N, find M-N
  • Case I M N, thus, MSB of Borrow is 0 B
    0 0 0 1 1 0 M 1 1 1 1 0 30 N
    -1 0 0 1 1 -19 Result
    is Correct Dif 0 1 0 1 1
    11
  • Case II N gt M, thus MSB of Borrow is 1 B
    1 1 1 0 0 0 M 1 0 0 1 1 19
    N -1 1 1 1 0 -30
    Result requires correction! Dif 1 0 1 0
    1 21

4
Binary Subtraction (cont.)
  • In general, if N gt M, Dif M-N2n, where n
    bits.
  • In Case II of the previous example, Dif 19-3025
    21.
  • To correct the magnitude of Dif, which should be
    N-M, calculate 2n-(M-N2n).
  • This is known as the 2s complement of Dif.

5
General Procedure
  • To subtract two n-bit numbers, M-N, in base 2
  • Find M-N.
  • If MSB of Borrow is 0, then M N. Result is
    positive and correct.
  • If MSB of Borrow is 1, then N gt M. Result is
    negative and its magnitude must be corrected by
    subtracting it from 2n (find its 2s complement).

6
Another Subtraction Example
  • Given M 01100100 and N 10010110, find M-N.
    B 1 0 0 1 1 1 1 0 0 M 0 1 1 0 0
    1 0 0 100 N -1 0 0 1 0 1 1 0
    -50 Dif 1 1 0 0 1 1 1 0 206 2n
    1 0 0 0 0 0 0 0 0 256 Dif - 1
    1 0 0 1 1 1 0 -206 0 0 0 1 1
    0 0 1 0 50

7
Block Diagram for Subtractor
M0M1M2M3
N0N1N2N3
B
4-bit Subtractor
Enabled when B1 otherwise, just pass
theresult from the subtractor
Selective 2s Complementer
Not the best way to implement a subtractor
circuit!
8
Block Diagram for Binary Adder-Subtractor
Sub/Add1 ? ResultM-N Sub/Add0 ? ResultMN
9
Complements
  • There are 2 types of complements for each base-r
    system
  • Radix (rs) complement, ex. 2s complement and
    10s complement.
  • Diminished radix (r-1s) complement, ex. 1s
    complement and 9s complement.
  • We examine only 2s and 1s complements for base
    2. Same concepts hole for other bases (ex.
    decimal).

10
2s Complement
  • For a positive n digit number N2 in binary, the
    2's complement, 2C(N2), is given by
  • 2C(N2) 2n-N2 , if n gt 0 0 , if n 0
  • Example N2 1010
  • 2C(N2) 24-N2 100002 10102 01102
  • Example N2 11111
  • 2C(N2) 25-N2 1000002 111112 00001 2


11
2s Complement (cont.)
  • Heres an easier way to compute the 2s
    complement
  • Leave all least significant 0s and first 1
    unchanged.
  • Replace 0 with 1 and 1 with 0 in all remaining
    higher significant bits.
  • Examples
  • N 1010 N 01011000 01 10
    10101000
  • 2s complement 2s complement

unchanged
complement
unchanged
complement
12
1s Complement
  • For a positive n digit number N2 in binary, the
    1's complement, 1C(N2), is given by
  • 1C(N2) (2n-1) - N2
  • Example N2 011
  • 1C(N2) (23-1)-N2 1112 0112 1002
  • Example N2 1010
  • 1C(N2) (24-1) - N2 11112 10102 0101 2
  • Observation 1s complement can be derived by
    just complementing all the bits in the number.

13
Observation
  • Compare 1s complement with 2s complement
  • 2n-N (2n-1) - N 1
  • Thus, the 2s complement can be obtained by
    deriving the 1s complement and adding 1 to it.
  • Example
  • N 1001
  • 2C(N) 24 N 10000 1001 0111
  • 1C(N) 24 1 - N 1111 1001 0110
  • ? 2C(N) 1C(N) 1 0110 0001 0111

14
Subtraction with Complements
  • To perform M-N M(-N), we may use a complement
    form to represent the negative number -N, and
    perform a plain old addition.
  • Need to be able to convert the result.

15
Subtraction with 2s complement
  • If we use 2's complements to represent negative
    numbers
  • Form RI M 2C(N2) M (2n-N) M N 2n.
  • If there is a nonzero carry out of the addition,
    M N, so discard that carry and the remaining
    digits are the result R M-N.
  • Otherwise, M lt N, so take the 2s complement of
    RI (2n- RI 2n- (M N 2n) N M), and
    attach a minus sign in front, i.e., the result R
    is-2C(RI2) -(N-M).

16
Example
  • A 1010100 (8410), B 1000011 (6710)
  • Find R A-B
  • 2C(B) 0111101 (6110)
  • AB 10101000111101 10010001
  • Discard carry, R 0010001 (1710) ?
  • Find R B-A
  • 2C(A) 0101100 (4410)
  • BA 10000110101100 1101111
  • R -2C(BA) -0010001 (-17) ?

17
Subtraction with 1s complement
  • If we use 1's complements to represent negative
    numbers
  • Form RI M 1C(N2) M (2n-1-N) M N
    2n-1.
  • If there is a nonzero carry out of the addition,
    M N, so discard that carry and add 1 to the
    remaining digits. The result R M-N.
  • Otherwise, M lt N, so take the 1s complement of
    RI (2n- 1 - RI 2 n- 1 - (M N 2n-1) N M
    ), and attach a minus sign in front, i.e., the
    result R is -1C(RI2) -(N-M).

18
Example
  • A 1010100 (8410), B 1000011 (6710)
  • Find R A-B
  • 1C(B) 0111100 (6010)
  • AB 10101000111100 10010000
  • Discard carry and add 1,R 0010000 1
    0010001 (1710) ?
  • Find R B-A
  • 1C(A) 0101011
  • BA 10000110101011 1101110
  • R -1C(BA) -0010001 (-17) ?

19
Binary Adder/Subtractors
  • If we perform subtraction using complements, we
    eliminate the subtraction operation, and thus,
    can use an adder with appropriate complementer
    for subtraction.
  • Actually, we can use an adder for both addition
    and subtraction
  • Complement subtrahend for subtraction
  • Do not complement subtrahend for addition
  • Thus, to form an adder-subtractor circuit, we
    only need a selective complementer and an adder.

20
Binary Adder/Subtractors (cont.)
  • The subtraction A-B can be performed by taking
    the 2's complement of B and adding to A.
  • The 2's complement of B can be obtained by
    complementing B and adding one to the
    result. A-B A 2C(B) A 1C(B)
    1 A B 1

21
4-bit Binary Adder/Subtractor
  • XOR gates act as programmable inverters

22
4-bit Binary Adder/Subtractor (cont.)
  • When S0, the circuit performs A B. The carry
    in is 0, and the XOR gates simply pass B
    untouched.
  • When S1, the carry into the least significant
    bit (LSB) is 1, and B is complemented (1s
    complement) prior to the addition hence, the
    circuit adds to A the 1s complement of B plus 1
    (from the carry into the LSB).

23
4-bit Binary Adder/Subtractor (cont.)
S0
B1
B2
B3
B0
0
S0 selects addition
24
4-bit Binary Adder/Subtractor (cont.)
S1
B1
B2
B3
B0
1
S1 selects subtraction
25
4-bit Binary Adder/Subtractor (cont.)
When C4 0 and S1 it means that A lt B and we
must correct the result R3R0 (see slide
15). Thus, we must compute 2s complement of
R3R0 Use a specialized 2s complement circuit
or Use the 4-bit Adder/Subtractor again, with
A3A00000, B3B0R3R0, and S1.
26
Signed Binary Numbers
  • Signed-magnitude system Singed numbers are
    represented using the MSB of the binary number to
    indicate the numbers sign
  • If MSB is 0 ? number is positive
  • If MSB is 1 ? number is negative
  • Do not confuse with unsigned numbers!

27
Signed Binary Numbers (cont.)
  • For example
  • -1010 is
  • -10102 in unsigned (- sign is implicit)
  • 110102 in singed (- sing is indicated in MSB1)
  • Another example
  • 10112 is
  • 1110 in unsigned
  • -310 in signed

28
Signed Binary Numbers (cont.)
  • To implement signed-magnitude addition and
    subtraction we need to separate the sing bit from
    the magnitude bits, and treat the magnitude bits
    as an unsigned number (do correction whenever
    necessary).
  • To avoid correction, use the singed-complement
    system.

29
Signed-Complement System
  • The magnitude of the negative number is
    represented in a complement form (2s or 1s
    complement).
  • Ex. Use 8-bits to represent -910 and 910
  • -910 is
  • 10010012 in singed-magnitude
  • 111101102 in singed-1s complement
  • 111101112 in singed-2s complement
  • 910 is 000010012 in any of the above systems

30
Signed-Magnitude Addition-Subtraction
  • To perform addition or subtraction of two numbers
    M and N in signed-magnitude, follow ordinary
    arithmetic rules
  • Same signs Add and keep same sign.
  • Different signs Subtract N from M if end Borrow
    is 1, correct result by taking its 2s
    complement. Sign is negative.
  • Example M00011001, N10100101N is negative, so
    find M-N0011001-0100101 1110100, with end
    borrow 1. This implies that M-N is a negative
    number, so to correct find its 2s complement
    0001100. Result is 10001100.

31
Signed-Complement Addition
  • Addition of two signed numbers, with negative
    ones represented in signed-2s complement, is
    obtained by adding the two numbers (including the
    sing bits). Carry out is discarded.
  • Examples (Assume 5-bit representations) 01010
    (10) 01010 (10) 10110 (-10) 10110
    (-10) 00101 (5) 11011 (-5) 00101
    (5) 11011 (-5) 01111 (15) 00101
    (5) 11011 (-5) 10001 (-15)

32
Signed-Complement Addition (cont.)
  • Do not get confused reading negative numbers in
    signed-2s complement! Remember, if MSB is 1 the
    number is negative and you need to find the 2s
    complement of the magnitude.
  • Example Whats the decimal equivalent of
    10010012?
  • Negative number, since MSB1
  • Magnitude 0010012s complement of magnitude
    110111
  • The number is -5510

33
Signed-Complement Subtraction
  • Subtraction of two signed numbers, with negative
    ones represented in signed-2s complement, is
    obtained by taking the 2s complement of the
    subtrahend (including sing bit) and add it to the
    minuend. Discard carry out.
  • Examples (Assume 5-bit representations) 01010
    (10) 01010 (10) 10110 (-10)
    10110 (-10) -00101 -(5) -11011
    -(-5) -00101 -(5) -11011 -(-5)
    01010 (10) 01010 (10) 10110 (-10)
    10110 (-10) 11011 (-5) 00101
    (5) 11011 (-5) 00101 (5) 00101
    (5) 01111 (15) 10001 (-15)
    11011 (-5)

34
The Overflow problem
  • If the sum of two n-bit numbers results in an n1
    number, then an overflow conditions is said to
    occur.
  • Detection of overflow can be implemented using
    either hardware or software.
  • Detection depends on number system used signed
    or unsigned.

35
The Overflow problem in Unsigned System
  • Addition
  • When Carry out is 1.
  • Subtraction
  • Can never occur. Magnitude of the result is
    always equal or smaller than the larger of the
    two numbers.
  • ? Not REALLY a problem!

36
The Overflow problem in Signed-2s Complement
  • Remember that the MSB is the sign. But, the sign
    is also added! Thus, a carry out equal to 1 does
    not necessarily indicate overflow.
  • Overflow can occur ONLY when both numbers have
    the same sign. This condition can be detected
    when the carry out (Cn) is different than the
    carry at the previous position (Cn-1).

37
The Overflow problem in Signed-2s Complement
(cont.)
  • Example 1 Let M6510 and N6510 in an 8-bit
    signed-2s complement system.
  • M N 010000012
  • MN 10000010 with Cn0. This is clearly wrong!
    Bring Cn as the MSB to get 0100000102 (13010)
    which is correct, but requires 9-bits ? overflow
    occurs.
  • Example 2 Let M-6510 and N-6510 in an 8-bit
    signed-2s complement system.
  • M N 101111112
  • MN 01111110 with Cn1. This is wrong again!
    Bring Cn as the MSB to get 1011111102 (-13010)
    which is correct, but also requires 9-bits ?
    overflow occurs.

38
Overflow Detection in Signed-2s Complement
  • Overflow conditions is detected by comparing the
    carry values into and out of the sign bit (Cn and
    Cn-1).

n-bit Adder/Subtractor with Overflow Detection
Logic
V
Cn1
Cn
C
n-bit Adder/Subtractor
  • C 1 indicates overflow condition when
    adding/subtr. unsigned numbers.
  • V1 indicates overflow condition when
    adding/subtr. signed-2s complement numbers

39
Binary Multiplier
  • Binary multiplication resembles decimal
    multiplication
  • n-bit multiplicand is multiplied by each bit of
    the m-bit multiplier, starting from LSB, to form
    n partial products.
  • Each successive set of partial products is
    shifted 1 bit to the left.
  • Derive result by addition the m rows of partial
    products.

40
Binary Multiplier (cont.)
  • Example
  • Multiplier AA1A0 and multiplicand BB1B0
  • Find C AxB B1 B0
    x A1 A0
    A0B1 A0B0 A1B1 A1B0
    C3 C2 C2
    C0

-----------------
-------------------------------
41
Binary Multiplier Circuit2-bit by 2-bit
multiplier
Half Adders are Sufficient since there is no
Carry-in in addition to the two inputs to sum
42
Binary Multiplier Circuit4-bit by 3-bit
multiplier
4 bit by 3 bit yields a 7 bit result
Write a Comment
User Comments (0)
About PowerShow.com