1 / 23

Arithmetic & Logic Unit

Arithmetic & Logic Unit. Does the calculations Everything else in the computer is there to service this unit Handles integers May handle floating point (real) numbers May be separate FPU (maths co-processor) May be on chip separate FPU (486DX +). ALU Inputs and Outputs. Binary Numerals.

ailis
Download Presentation

Arithmetic & Logic Unit

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. Arithmetic & Logic Unit • Does the calculations • Everything else in the computer is there to service this unit • Handles integers • May handle floating point (real) numbers • May be separate FPU (maths co-processor) • May be on chip separate FPU (486DX +)

  2. ALU Inputs and Outputs

  3. Binary Numerals • 01101101b • Bits are numbered from the right b7 b6b5b4b3b2b1b0 • Subscripts represent the place value • bi has place value 2i • Convert to decimal • b7 * 27+b6*26 + b5*25 +b4*24 +b3*23 +b2*22 +b1*21 + b0*20

  4. Decimal number is converted to binary by repeated divisions by 2 record the remainders Stop when you reach 0 Concatenate the remainders The order: first remainder is least significant bit 55d = 110111b Decimal to Binary

  5. Binary • 3 bits • 000 ;0 • 001 ;1 • 010 ;2 • 011 ;3 • 100 ;4 • 101 ;5 • 110 ;6 • 111 ;7 • 1 bit • 0 ; 0 • 1 ; 1 • 2 bits • 00 ; 0 • 01 ; 1 • 10 ; 2 • 11 ;3

  6. 0000 ;0 0001 ;1 0010 ;2 0011 ;3 0100 ;4 0101 ;5 0110 ;6 0111 ;7 1000 ;8 1001 ;9 1010 ;10 (Ah) 1011 ;11 (Bh) 1100 ;12 (Ch) 1101 ;13 (Dh) 1110 ;14 (Eh) 1111 ;15 (Fh) 4 bits and Hex

  7. Group bits by fours (from right to left, starting with least significant bits) Add zeros as necessary to complete the last group Convert each group to the equivalent hex digit (look up the previous table) Ex: 0101 1110b = 5Eh Binary to Hex

  8. Hex to Binary • Expand each hex digit to the equivalent 4-bit binary form • The leading zeros of leftmost digit can be omitted • 36h = 0011 0110b • (or 110110b)

  9. Binary Storage • A pre-arranged storage size is used • typically byte, word, doubleword, or quadword • at least 8 bits will be required • encode the bits Ex: 65d is 0100 0001b

  10. all 8 bits used to represent the magnitude of the number Minimum 0 (zero) is coded as 00000000b Maximum 255 is coded as 11111111b Unsigned Byte

  11. Singed Byte • two’s complement code is most common • only 7 bits are used for the magnitude • Minimum -128 is coded as 10000000b • Maximum +127 is coded as 01111111b • Zero is 00000000b • Note that we can not read 10000001 as -1.

  12. Remember -x’s 2 complement code is the same as 2n-x. Change Sign Rule Flip all the bits Add 1 Negative Numbers

  13. Geometric Depiction of Twos Complement Integers

  14. The 2’s Complement codes for x and -x add to a power of 2 8-bit code: c+(-c)=28 16-bit code: c+(-c)=216 (-c)=2n-c=[(2n-1)-c]+1 =[(2n-1) + (-c)]+1 Note that (2n-1) is 1111..1b Flip and Plus 1 How Does Change Sign Rule Come From

  15. Benefits • One representation of zero • Arithmetic works easily (see later) • Negating is fairly easy • 3 = 00000011 • Boolean complement gives 11111100 • Add 1 to LSB 11111101

  16. Two’s Compliment • +3 = 00000011 • +2 = 00000010 • +1 = 00000001 • +0 = 00000000 • -1 = 11111111 • -2 = 11111110 • -3 = 11111101

  17. Can We Read 2’s Complement Code Easily? • Positive ones: yes 00110111b(37h) --->55d • Negative ones: No! 11001001b (C9h) ---> not -49h • by Change Signed rule -55d • double check, the code should be the same as 201d ‘s code 201d = 11001001b since -55+ 256 = 201

  18. Conversion Between Lengths • Positive number pack with leading zeros • +18 = 00010010 • +18 = 00000000 00010010 • Negative numbers pack with leading ones • -18 = 11101110 • -18 = 11111111 11101110 • i.e. pack with MSB (sign bit)

  19. Numbers can be added in any number base Use the same algorithm you practiced in second grade! Binary Example: c c c 10101 + 0111 11100 Unsigned Addition

  20. Hex Addition • Hex Example: c c 2CF03 +435C8 704CB • A carry occurs when the sum is sixteen or greater

  21. Unsigned Subtraction • Borrows are worth two • sometimes you need to borrow from afar! b b b b 11000011 - 1101001 01011010

  22. A borrow is worth of 16 Example: b b FCF03 -435C9 B993A Hex Subtraction

More Related