490 likes | 526 Views
Number Representation and ALU Operations. Outline. Numbers and number representations Addition and subtraction Logical operations ALU Multiplication Division Floating point numbers & arithmetic. Numbers & Representation. Radix based systems.
E N D
Number Representation and ALU Operations
Outline • Numbers and number representations • Addition and subtraction • Logical operations • ALU • Multiplication • Division • Floating point numbers & arithmetic
Numbers & Representation • Radix based systems • b: base or radix(usually b = 2k in digital systems ) • ai: digits (bits when b = 2) and 0 ai b-1 • How is the representation called when b= 2, 8, and 16? • more natural to computers • Example: 3749 = (1110 1010 0101)2 = (?)8 = (?)16
MSD LSB LSD MSB Representing Numbers • ASCII – text characters • Easy to read and write information • 2 x 3 • 2 (0011 0010)2 and 3 (0011 0011)2 • Complex arithmetic & more storage • Binary numbers • Natural form for computers (easy arithmetic) • Requires formatting routines for I/O • (1110 1010 0101)2 ( 7 2 4 5 )8
Number Types • Unsigned integers • In arithmetic operations which require only positive operands • In address calculations • Signed numbers (positive and negative) • Different representation methods • Floating numbers • Used to represent the real numbers in computers • Scientific and media processing applications requires floating point operations • Different precisions specified by IEEE 754 (single, double precision)
Signed Number Representation What is 11100?
Numbers in MIPS • 32 bit signed numbers: 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0001 0000 0000 0000 0000 0000 0000 0000 0010 ...0111 1111 1111 1111 1111 1111 1111 1110 0111 1111 1111 1111 1111 1111 1111 1111 1000 0000 0000 0000 0000 0000 0000 0000 1000 0000 0000 0000 0000 0000 0000 0001 1000 0000 0000 0000 0000 0000 0000 0010 ...1111 1111 1111 1111 1111 1111 1111 1101 1111 1111 1111 1111 1111 1111 1111 1110 1111 1111 1111 1111 1111 1111 1111 1111
Two's Complement Operations • Negating a two's complement number • Signed Extension: • MIPS 16 bit immediate is converted to 32 bits for arithmetic • copy the MSB into the extended bits • 0010 -> ? • 1010 -> ? • lbu vs. lb • To load ASCII characters from the memory, use lbu • lh – load half • lhu – load half
Signed vs. Unsigned Comparison • Different compare operations required for signed and unsigned types • Signed integer: slt set on less than • Unsigned integer: sltu set on less than unsigned • Example: • $s0 has 1111 1111 1111 1111 1111 1111 1111 1111 • $s1 has 0000 0000 0000 0000 0000 0000 0000 0001 • slt $t0, $s0, $s1 # signed comparison • sltu $t1, $s0, $s1 # unsigned comparison • $t0 = ? $t1 = ? • set-on-less-than instructions:slt, slti, sltu, sltui
Overflow • => no overflow They are different overflow
Operation Operand A Operand B Result indicating overflow A+B 0 0 A+B < 0 < 0 A-B 0 < 0 A-B < 0 0 Overflow Conditions < 0 0 < 0 0
Effects of Overflow • High level languages (such as C/C++) ignores overflows. • MIPS detects overflow • An exception (interrupt – unscheduled procedure call) occurs • Control jumps to a predefined address to invoke the appropriate routine for the exception • Interrupted address is saved for possible resumption • Don't always want to detect overflow • New MIPS instructions: addu, addiu, subu • they do not cause exceptions on overflow
Exception in MIPS • There are three scenarios in exception handling: • Correct & return to program • Return to program with an error code • Abort the program • The address of the instruction that has caused the exception is stored in exception program counter(EPC). • Using move from system control(mfc0) instruction, • mfc0 $s1, $epc #$s1 = $epc • A jump register instruction is used to return to the offending instruction. • jr $s1
We can Trap Overflow addu $t0, $t1, $t2 # $t0 = sum, but no exception xor $t3, $t1, $t2 # Check if their signs differ slt $t3, $t3, $zero # $t3 = 1 if signs differ bne $t3, $zero, No_overflow # their signs differ xor $t3, $t0, $t1 # Check the sign of the result slt $t3, $t3, $zero # $t3 = 1 if the result and one # of the operands’ signs differ bne $t3, $zero, Overflow # signs differ # so there is an overflow ...Overflow:...No_overflow:
0 0 16 10 3 0 op rs rt rd shamt funct unused Logical Operations • Logical shift operations • Right shift (srl) • Left shift (sll) • Logical shift operations filled the emptied bits with 0s. • Example: sll $t2, $s0, 3 • $s0 = 0000 0000 0000 0000 1100 1000 0000 1111 • $t2 = 0000 0000 0000 0110 0100 0000 0111 1000 • Instruction format
ALU Operation 4 a Zero 32 ALU Result 32 Overflow b 32 CarryOut Arithmetic Logic Unit - ALU
ALU Control • We use ALU • to implement arithmetic/logic operations • to calculate addresses • to check branch conditions
Other Operations • Shift operation is done outside of the ALU using a circuit called barrel shifter. • A barrel shifter can shift an integer by the amount from 1 to 31 bits in both directions • it takes one clock cycle to shift independent of the shift amount • Other operations we do outside of ALU: • Multiplication • Division
Datapath of MIPS rs rt Data Memory (Cache) Load Register File Barrel Shifter ALU MDU Store HI LO rd mult, multu
Signed Multiplication • Basic approach is • Store the signs of the operands • Leave out the signs of the operand in the subsequent operations • Do the multiplication • Figure out the sign of the result • Is there a better approach? • Booth’s algorithm
Multiplication in MIPS • MIPS provides a separate pair of 32-bit registers to contain the 64-bit product • called HI and LO • Two instructions to get the product • mflo: move from LO • mfhi: move from HI • Example: • mult $s2, $s3 # (HI, LO) = $s2 $s3mfhi $t1 # $t1 = HImflo $t0 # $t0 = LO • Two multiply instructions: mult and multu • Multiply instructions ignore overflow
0 rs rt 0 0 0x18 mult rs, rt 6 5 5 5 5 6 multu rs, rt 0 rs rt 0 0 0x19 6 5 5 5 5 6 Multiplication in MIPS • Pseudo instructions: • mul rd, rs, rt # without overflow • mulo rd, rs, rt # with overflow • mulou rd, rs, rt # with overflow
Division • More difficult than multiplication • Critical point: divide by 0. • Dividend = Quotient Divisor + Remainder
0 0 rs rs rt rt 0 0 0 0 0x1B 0x1A divu rs, rt div rs, rt 6 5 5 5 5 6 6 5 5 5 5 6 LO := Quotient(rs/rt) HI := Remainder(rs/rt) LO := Quotient(rs/rt) HI := Remainder(rs/rt) Division in MIPS 1/2
Division in MIPS 2/2 div rd, rs, rt pseudo-instruction rd := Quotient(rs/rt) divu rd, rs, rt pseudo-instruction rd := Quotient(rs/rt)
Division by Signed Numbers • Ignore the signs first when dividing • Simplest solution is to keep the signs of divisor and dividend • when their signs disagree negate the result • Difficulty: the sign of the remainder • 7 2 => Q = 3 and R = 1 • (-7) 2 => Q = -3 and R = -1 • (-7) 2 => Q = -4 and R = +1 (anomalous) • Rule: remainder and dividend must have the same sign. • 7 (-2) => Q = -3 and R = +1 • (-7) (-2) => Q = 3 and R = -1
Floating-Point Numbers • We need to represent: • Real numbers e.g. 3.14159265… • Large numbers that cannot be represented with 32-bit integers, e.g. 1080 (number of atoms in the universe) • Very small numbers, e.g. 1.010-9(1 nanosecond) • Floating point representation consists of • sign(S), exponent(E), and significand (f) • (-1)S 0.f 2E • more bits in significand gives more accuracy • more bits in exponent increases range • tradeoff between accuracy and range for fixed-length words
IEEE 754 Floating-Point Standard • single precision: 8 bit exponent, 23 bit significand • double precision: 11 bit exponent, 52 bit significand • In IEEE 754, the leading “1” is implicit. (-1)S 1.f 2E-bias • Form: • Arbitrary: 10001.1010 2E,0.001010 2E • Normalized: 1.1010 2E • Exponent is biased • All 0s is the smallest exponent, all 1s is the largest • bias = 127 for single precision • bias = 1023 for double precision
Largest & Smallest in IEEE 754 • Single precision • Largest: 1.111…11 2254-127 = (2-2-23) 2127 2128 3.4 1038 • Smallest: 1.00…0 21-127 = 2-126 1.18 10-38 • Double precision • Largest: 1.111…11 22046-1023 = (2-2-52) 21023 21023 • Smallest: 1.00…0 21-1023 = 2-1022 • There is a limitation to the numbers we can represent • Overflow: 269 270 = 2139 • Underflow: 2-57 2-88 = 2-145
Why Biased Exponent? • Signed exponents • signed magnitude: additional hardware to compare • two’s complement: with 1 in MSB a negative number look like larger than any positive number. • Biased notation: • (11…11) and (00…00) are reserved • (11…10) is the largest exponent • (00…01) is the smallest exponent • (11…10)-bias (largest positive exponent) • (00…01)-bias (smallest negative exponent)
1 01111110 10000000000000000000000 significand sign exponent IEEE 754 Floating-Point Standard • (–1)S (1+0.f) 2E – bias • Example: • decimal: -0.75 = -3/4 = -3/22 • binary: -0.11 = -1.1 2-1 • floating point: exponent = 126 = 01111110 • IEEE single precision:
Special Numbers • Special numbers NaN, +, - • Divide by zero might give + instead of throwing an exception. • 0/0 is a NaN. • Some numbers are reserved for representing special numbers
Denormalized Numbers • Some very small numbers are allowed to be represented in denormalized form using denormalized numbers (denorms or subnormals). • their exponent is 0 (the same as 0) • (-1)S0.f2-126(no hidden bit) • Smallest normalized number is 1.0000 0000 0000 0000 0000 000 ´ 2-126 . • But the smallest denormalized number is 0.0000 0000 0000 0000 0000 001 ´ 2-126 = 2-149 • Programming is difficult with denormalized numbers. • Some computers even cause an exception.
Floating-Point Addition • Problem: two floating-point numbers with unequal exponents. • Solution: Significand of the number having the smaller exponent are right-shifted to equate their exponent • Significands are added. • Normalize the sum, if it is denormalized (i.e. having leading zeroes, etc.) by • Shifting right and incrementing the exponent • Shifting left and decrementing the exponent • Overflow or underflow? • Round the significand
Examples • Simplified IEEE 754: • 8-bit significand • 4-bit exponent and bias = 7 • max exp = 14-7 = 7 • min exp = 1-7 = -6 • Overflow: • a = 1.10000000 ´ 27 • c = 2´a = 11.00000000´27 = 1.10000000´28 • Underflow: • a = 1.00000000´2-5and b = 1.11111111´2-6 • c = a-b = (1.000000000-0.111111111)´ 2-5=0.000000001´2-5 = 1.00000000´2-14
Floating-Point Addition Compare the exponents;Shift the significand with smaller exponent to the rightuntil exp_a= exp_b start Add significands Normalize the sum:shift right and increment the exponentshift left and decrement the exponent overflow orunderflow exception Test Round the significand to the appropriate number of bits denormalized still normalized done Test
Rounding Modes • Four rounding modes supported by IEEE 754: • Truncate • Round toward + (round up) • Round toward - (round down) • Round to nearest (even number)(default, useful in determining what to do when the number is exactly halfway between).
Example: Floating-Point Addition • A =1.00000101100 2EA • B =1.10000000111 2EB and EA = EB EC = EA + 1
How Many Extra Bits? 1/3 • A =1.00000101100 2EA • B =1.10000111110 2EB and EA - EB = 6
How Many Extra Bits? 2/3 • Guard bit (G) for accuratepostnormalization • Sticky bit (S) for borrow in subtraction
How Many Extra Bits? 3/3 • A =1.000001011002EA • B =1.100000101102EB and EA - EB = 6
Round Bit • We need three extra bits for accurate arithmetic. • Guard (G), Round (R), Sticky(S)
Yet Another Example • A = 1.000000101002EA • B = 1.100001000012EB and EA - EB= 6
One More Example • A = 1.000000101002EA • B = 1.100001100002EB and EA - EB= 6
Floating Point Multiplication • Add the exponents • If the exponents are biased, subtract the bias from the result • Multiply the significands • Normalize the product if necessary • Shifting it right or left • Check overflow or underflow
EC = 5 Floating Point Multiplication • Simplified IEEE 754: • 3-bit significand, 3-bit exponent and bias = 3 • max exp = 6-3 = 3, min exp = 1-3 = -2 • Example: A = 1.0102-1 and B = 1.10122C = A B = ? EC = 2+5-3 = 4
MIPS Floating-Point • 32 fp registers $f0, $f1, …, $f31 • They are used in pairs for double precision • Only even-numbered registers can hold the floating-point numbers. • Single precision • add.s $f2, $f4, $f6 # $f2 = $f4 + $f6 • sub.s $f2, $f4, $f6 # $f2 = $f4 - $f6 • mul.s $f2, $f4, $f6 # $f2 = $f4 $f6 • div.s $f2, $f4, $f6 # $f2 = $f4 / $f6 • Double precision • add.d $f2, $f4, $f6 # $f2 = $f4 + $f6 • sub.d $f2, $f4, $f6 # $f2 = $f4 - $f6 • mul.d $f2, $f4, $f6 # $f2 = $f4 $f6 • div.d $f2, $f4, $f6 # $f2 = $f4 / $f6