Two’s Complement The language of machines, part II
Start with a game: e/binary_game_page.htm e/binary_game_page.htm 5 minutes, highest score wins!
Starting with the least significant bit (left to right), add bitwise and remember to carry if needed. Double check in denary if needed. Addition (reminder) 111Carry
Problem We know how to express the naturals using binary, but what about the integers? (Integers are all the positive and negative whole numbers and zero) We don’t use a minus sign – why?
One’s Complement We decide on the number of bits to represent our number, we will typically use a byte. The most significant bit becomes the sign bit. There is a big issue with one’s complement… sign bit
Two’s Complement Two’s Complement allows us to express every number between -2^(n-1) and 2^(n- 1)-1, where n is the bit length. Zero is always just 00000… is always what?
The Method Decide on a word length Start with your absolute value in binary Next, reverse all of the bits Finally, add 1. Express these in base-2 using one byte:
Subtraction Easiest way to subtract two numbers is to convert it to an addition, how can we do this? Addition is easier for most machines than subtraction, why would this be the case?
From binary to hexadecimal For human programming, binary is cumbersome and error prone. We almost always deal in bytes, and so can use the property that 8 bits = 1 byte = 2 hexadecimal digits Hexadecimal (or just hex) is the base-16 number system.
Hex It requires 16 digits starting from zero: 00 11 …… 88 99 A10 B11 C12 D13 E14 F15
Converting to hex from binary Start with the least significant bit and, for every 4 bits, replace with the hex digit, e.g start with binary ‘split’ into 4-bits convert to denary 4.9C-- convert to hex 5.9C-- put together
Denary – Binary - Hexadecimal 1.Say someone’s name then a denary number between 0 and 15 2.That person says the 4-bit binary equivalent and then someone else’s name 3.That person says the hexadecimal digit and starts again from step 1. (what’s wrong with this algorithm?)
Recap Binary addition One’s Complement Two’s Complement Subtraction Hexadecimal