1 / 50

Understanding Representing Integer Data in Computing

Explore the fundamentals of representing integer data in computing, covering signed and unsigned integers, sign-magnitude and two's complement schemes, decimal complement representations, addition, subtraction, overflow, and more.

allena
Download Presentation

Understanding Representing Integer Data in Computing

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. 477 666 Representing Integer Data ( Subject has no point !! ) 1 A99ACF 11011011011011 7652993002 3419 Book : Chapter 4

  2. Basic Definition • An integer is a number which has no fractional part. Examples: -2022 -213 0 1 666 54323434565434

  3. No. of bits Binary BCD ASCII 1 0 – 1 2 0 – 3 3 0 – 7 4 0 – 15 0 – 9 5 0 – 31 6 0 – 63 7 0 – 127 8 0 – 255 0 – 99 0 – 9 9 0 – 511 16 0 - 65,535 0 – 9999 0 – 99 24 0 – 16,777,215 0 – 999999 0 – 999 Etc. Ranges for Data Formats

  4. In General (binary) Remember !!

  5. Signed Integers • Previous examples were for “unsigned integers” (positive values only!) • Must also have a mechanism to represent “signed integers” (positive and negative values!) • E.g., -510 = ?2 • Two common schemes: 1) sign-magnitude 2) two’s complement

  6. +5: 0 0 0 1 0 1 -5: 1 0 0 1 0 1 +ve -ve 5 5 Sign-Magnitude • Extra bit on left to represent sign • 0 = positive value • 1 = negative value • E.g., 6-bit sign-magnitude representation of +5 and –5:

  7. Ranges (revisited)

  8. In General (revisited)

  9. Difficulties with Sign-Magnitude • Two representations of zero • Using 6-bit sign-magnitude… • 0: 000000 • 0: 100000 • Arithmetic is awkward! pp. 95-96

  10. Complementary Representations • 9’s complement • 10’s complement • 1’s complement

  11. Range shifting decimal integers – 9’s complement 501 -498 Figure 4.5 Range shifting decimal integers

  12. 9’s Decimal Complement • Taking the complement: subtracting a value from a standard basis value • Decimal (base 10) system diminished radix complement • Radix minus 1 = 10 – 1 9 as the basis • 3-digit example: base value = 999 • Range of possible values 0 to 999 arbitrarily split at 500 999 – 499

  13. Find the 9’s Complement representation for the 3 digit number -467 999 -467 --------- 532

  14. Find the 9’s Complement representation for the 4 digit number -467 9999 - 467 --------- 9 532

  15. Find the 9’s Complement representation for the 4 digit number -3120 9999 -3120 --------- 6879

  16. Addition as a counting process Figure 4.6 Addition as a counting process

  17. Using 9’s Complement. If we are using 4 bits, the number 5450 represents ? 9999 – 5450 --------- -4549

  18. Addition with wraparound 999 -300 ------ 699 Figure 4.7 Addition with wraparound 200 + (-300) = -100

  19. Addition with End-around Carry • Count to the right crosses the modulus • End-around carry • Add 2 numbers in 9’s complementary arithmetic • If the result has more digits than specified, add carry to the result (1099)

  20. - + One’s complement representation Figure 4.10 One’s complement representation

  21. Finding one’s complement for a negative Number • Invert the bits ! For example one’s complement of -58 using 8 bits 0011 1010 = 58 1100 0101 = -58

  22. Invert to get magnitude Addition • Add 2 positive 8-bit numbers • Add 2 8-bit numbers with different signs • Take the 1’s complement of 58 (i.e., invert)0011 10101100 0101

  23. Addition with Carry • 8-bit number 0000 0010(210)1111 1101 • Add • 9 bits End-around carry

  24. Subtraction • 8-bit number • Invert 0101 1010(9010)1010 0101 • Add • 9 bits End-around carry

  25. Overflow • 8-bit number • 256 different numbers • Positive numbers: 0 to 127 • Add • Test for overflow • 2 positive inputs produced negative result overflow! • Wrong answer! • Programmers beware: some high-level languages, e.g., some versions of BASIC, do not check for overflow adequately Invert to get magnitude

  26. Ten’s complement scale Figure 4.11 Ten’s complement scale

  27. What is the 3-digit 10’s complement of 247? 1000 - 247 ------- 753

  28. Exercises – Complementary Notations • What is the 3-digit 10’s complement of 17? • Answer: • 777 is a 10’s complement representation of what decimal value? • Answer: Skip answer Answer

  29. Exercises – Complementary Notations Answer • What is the 3-digit 10’s complement of 17? • Answer: 983 • 777 is a 10’s complement representation of what decimal value? • Answer: 223 • 1000 • - 777 • 223

  30. Two’s Complement • Most common scheme of representing negative numbers in computers • Affords natural arithmetic (no special rules!) • To represent a negative number in 2’s complement notation… • Decide upon the number of bits (n) • Find the binary representation of the positive value in n-bits • Flip all the bits (change 1’s to 0’s and vice versa) • Add 1 Learn! kc

  31. Two’s complement representation Figure 4.12 Two’s complement representation

  32. 000101 +5 111010 + 1 111011 -5 Two’s Complement Example • Represent –5 in binary using 2’s complement notation • Decide on the number of bits • Find the binary representation of the +ve value in 6 bits • Flip all the bits • Add 1 6 (for example) 111010

  33. +5: 0 0 0 1 0 1 -5: 1 1 1 0 1 1 +ve 5 -ve Sign Bit • In 2’s complement notation, the MSB is the sign bit (as with sign-magnitude notation) • 0 = positive value • 1 = negative value ? (previous slide)

  34. “Complementary” Notation • Conversions between positive and negative numbers are easy • For binary (base 2)… 2’s C +ve -ve 2’s C

  35. +5 0 0 0 1 0 1 2’s C 1 1 1 0 1 0+ 1 -5 1 1 1 0 1 1 2’s C 0 0 0 1 0 0+ 1 +5 0 0 0 1 0 1 Example

  36. Exercise – 2’s C conversions • What is -20 expressed as an 8-bit binary number in 2’s complement notation? • Answer: • 1100011 is a 7-bit binary number in 2’s complement notation. What is the decimal value? • Answer:

  37. Exercise – 2’s C conversions Answer • What is -20 expressed as an 8-bit binary number in 2’s complement notation? • Answer: 11101100 • 1100011 is a 7-bit binary number in 2’s complement notation. What is the decimal value? • Answer: -29

  38. Detail for -20 -> 11101100 -2010: Positive Value = 00010100 “Flip”: 11101011 Add 1: + 1 11101100 (One’s complement) kc

  39. Detail for 1100011 -> - 29 2’s Complement: 1100011 “Flip”: 0011100 Add One: + 1 0011101 Converts to: = - 29 (One’s complement) kc

  40. Negative, sign bit = 1 Zero or positive, sign bit = 0 Range for 2’s Complement • For example, 6-bit 2’s complement notation 100000 100001 111111 000000 000001 011111 -32 -31 ... -1 0 1 ... 31

  41. Ranges (revisited)

  42. In General (revisited) Hint! Learn this table!

  43. 2’s Complement Addition • Easy • No special rules • Just add

  44. Sign-magnitude Twos-complement 1 1 1 1 1 1 1 1 -5: 10000101+5: +00000101 10001010 -5: 11111011+5: +00000101 00000000 What is -5 plus +5? • Zero, of course, but let’s see

  45. 2’s Complement Subtraction • Easy • No special rules • Just subtract, well … actually … just add! A – B = A + (-B) add 2’s complement of B

  46. +3: 000011 1s C: 111100 +1: 1 -3: 111101 001010+111101 000111 What is 10 subtract 3? • 7, of course, but… • Let’s do it (we’ll use 6-bit values) 10 – 3 = 10 + (-3) = 7

  47. (-(-3)) = 3 -3: 111101 1s C: 000010 +1: 1 +3: 000011 001010+000011 001101 What is 10 subtract -3? • 13, of course, but… • Let’s do it (we’ll use 6-bit values) 10 – (-3) = 10 + (-(-3)) = 13

  48. Overflow • the result of the calculation does not fit the available number of bits for the result • Ex: 1 sign bit, 2 bits for the number 010 + 010 ---------------- 100 • Detection: sign of the result is different then the signs of the operands

  49. Overflow • 8-bit number • 256 different numbers • Positive numbers: 0 to 127 • Add • Test for overflow • 2 positive inputs produced negative result overflow! • Wrong answer! • Programmers beware: some high-level languages, e.g., some versions of BASIC, do not check for overflow adequately Invert to get magnitude

  50. Carry • the result of an addition (or subtraction) exceeds the allocated bits, independently of the sign • Ex: 1 sign bit, 2 bits for the number (carry, not overflow) 010 + 110 ----------- 1000

More Related