Digital logic COMP214 Lecture 2 Dr. Sarah M.Eljack Chapter 1 1
Chapter 1 2 Useful for Base Conversion ExponentValue ExponentValue , , , , , , , , , ,048, ,097, Positive Powers of 2
Chapter 1 3 To convert to decimal, use decimal arithmetic to form (digit × respective power of 2). Example:Convert to N 10 : Converting Binary to Decimal
Chapter 1 4 Method 1 Subtract the largest power of 2 (see slide 14) that gives a positive remainder and record the power. Repeat, subtracting from the prior remainder and recording the power, until the remainder is zero. Place 1’s in the positions in the binary result corresponding to the powers recorded; in all other positions place 0’s. Example: Convert to N 2 Converting Decimal to Binary
Chapter 1 5 Commonly Occurring Bases Name Radix Digits Binary 2 0,1 Octal 8 0,1,2,3,4,5,6,7 Decimal 10 0,1,2,3,4,5,6,7,8,9 Hexadecimal 16 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F The six letters (in addition to the 10 integers) in hexadecimal represent:
Converting Binary to Decimal Weighted positional notation shows how to calculate the decimal value of each binary bit: Decimal = (d n-1 2 n-1 ) (d n-2 2 n-2 ) ... (d 1 2 1 ) (d 0 2 0 ) d = binary digit binary = decimal 169: (1 2 7 ) + (1 2 5 ) + (1 2 3 ) + (1 2 0 ) = =169
Convert Unsigned Decimal to Binary Repeatedly divide the decimal integer by 2. Each remainder is a binary digit in the translated value: 37 = stop when quotient is zero least significant bit most significant bit
Another Procedure for Converting from Decimal to Binary Start with a binary representation of all 0’s Determine the highest possible power of two that is less or equal to the number. Put a 1 in the bit position corresponding to the highest power of two found above. Subtract the highest power of two found above from the number. Repeat the process for the remaining number
Another Procedure for Converting from Decimal to Binary Example: Converting 76d to Binary The highest power of 2 less or equal to 76 is 64, hence the seventh (MSB) bit is 1 Subtracting 64 from 76 we get 12. The highest power of 2 less or equal to 12 is 8, hence the fourth bit position is 1 We subtract 8 from 12 and get 4. The highest power of 2 less or equal to 4 is 4, hence the third bit position is 1 Subtracting 4 from 4 yield a zero, hence all the left bits are set to 0 to yield the final answer
Hexadecimal Integers Binary values are represented in hexadecimal.
Converting Binary to Hexadecimal Each hexadecimal digit corresponds to 4 binary bits. Example: Translate the binary integer to hexadecimal
Converting Hexadecimal to Binary Each Hexadecimal digit can be replaced by its 4-bit binary number to form the binary equivalent.
Converting Hexadecimal to Decimal Multiply each digit by its corresponding power of 16: Decimal = (d3 16 3 ) + (d2 16 2 ) + (d1 16 1 ) + (d0 16 0 ) d = hexadecimal digit Examples: Hex 1234 = (1 16 3 ) + (2 16 2 ) + (3 16 1 ) + (4 16 0 ) = Decimal 4,660 Hex 3BA4 = (3 16 3 ) + (11 * 16 2 ) + (10 16 1 ) + (4 16 0 ) = Decimal 15,268
Integer Storage Sizes What is the largest unsigned integer that may be stored in 20 bits? Standard sizes:
Chapter 1 15 Decimal (Base 10) Binary (Base 2) Octal (Base 8) Hexadecimal (Base 16) A B C D E F Good idea to memorize! Numbers in Different Bases
Chapter 1 16 Conversion Between Bases Method 2 To convert from one base to another: 1) Convert the Integer Part 2) Convert the Fraction Part 3) Join the two results with a radix point
Chapter 1 17 Conversion Details To Convert the Integral Part: Repeatedly divide the number by the new radix and save the remainders. The digits for the new radix are the remainders in reverse order of their computation. If the new radix is > 10, then convert all remainders > 10 to digits A, B, … To Convert the Fractional Part: Repeatedly multiply the fraction by the new radix and save the integer digits that result. The digits for the new radix are the integer digits in order of their computation. If the new radix is > 10, then convert all integers > 10 to digits A, B, …
Chapter 1 18 Example: Convert To Base 2 Convert 46 to Base 2 Convert to Base 2: Join the results together with the radix point:
Chapter 1 19 Additional Issue - Fractional Part Note that in this conversion, the fractional part became 0 as a result of the repeated multiplications. In general, it may take many bits to get this to happen or it may never happen. Example: Convert to N = … The fractional part begins repeating every 4 steps yielding repeating 1001 forever! Solution: Specify number of bits to right of radix point and round or truncate to this number.
Chapter 1 20 Checking the Conversion To convert back, sum the digits times their respective powers of r. From the prior conversion of = 1·32 + 0·16 +1·8 +1·4 + 1·2 +0·1 = = = 1/2 + 1/8 + 1/16 = =
Chapter 1 21 Why Do Repeated Division and Multiplication Work? Divide the integer portion of the power series on slide 11 by radix r. The remainder of this division is A 0, represented by the term A 0 /r. Discard the remainder and repeat, obtaining remainders A 1, … Multiply the fractional portion of the power series on slide 11 by radix r. The integer part of the product is A -1. Discard the integer part and repeat, obtaining integer parts A -2, … This demonstrates the algorithm for any radix r >1.
Chapter 1 22 Octal (Hexadecimal) to Binary and Back Octal (Hexadecimal) to Binary: Restate the octal (hexadecimal) as three (four) binary digits starting at the radix point and going both ways. Binary to Octal (Hexadecimal): Group the binary digits into three (four) bit groups starting at the radix point and going both ways, padding with zeros as needed in the fractional part. Convert each group of three bits to an octal (hexadecimal) digit.
Chapter 1 23 Octal to Hexadecimal via Binary Convert octal to binary. Use groups of four bits and convert as above to hexadecimal digits. Example: Octal to Binary to Hexadecimal Why do these conversions work?
Chapter 1 24 A Final Conversion Note You can use arithmetic in other bases if you are careful: Example: Convert to Base 10 using binary arithmetic: Step / 1010 = 100 r 0110 Step / 1010 = 0 r 0100 Converted Digits are | or
Chapter 1 25 Binary Numbers and Binary Coding Flexibility of representation Within constraints below, can assign any binary combination (called a code word) to any data as long as data is uniquely encoded. Information Types Numeric Must represent range of data needed Very desirable to represent data such that simple, straightforward computation for common arithmetic operations permitted Tight relation to binary numbers Non-numeric Greater flexibility since arithmetic operations not applied. Not tied to binary numbers
Chapter 1 26 Given n binary digits (called bits), a binary code is a mapping from a set of represented elements to a subset of the 2 n binary numbers. Example: A binary code for the seven colors of the rainbow Code 100 is not used Non-numeric Binary Codes Binary Number Color Red Orange Yellow Green Blue Indigo Violet
Chapter 1 27 Given M elements to be represented by a binary code, the minimum number of bits, n, needed, satisfies the following relationships: 2 n > M > 2 (n – 1) n = log 2 M where x, called the ceiling function, is the integer greater than or equal to x. Example: How many bits are required to represent decimal digits with a binary code? Number of Bits Required
Chapter 1 28 Number of Elements Represented Given n digits in radix r, there are r n distinct elements that can be represented. But, you can represent m elements, m < r n Examples: You can represent 4 elements in radix r = 2 with n = 2 digits: (00, 01, 10, 11). You can represent 4 elements in radix r = 2 with n = 4 digits: (0001, 0010, 0100, 1000). This second code is called a "one hot" code.
Chapter 1 29 Binary Codes for Decimal Digits Decimal8,4,2,1 Excess3 8,4,-2,-1 Gray There are over 8,000 ways that you can chose 10 elements from the 16 binary numbers of 4 bits. A few are useful:
Chapter 1 30 Binary Coded Decimal (BCD) The BCD code is the 8,4,2,1 code. This code is the simplest, most intuitive binary code for decimal digits and uses the same powers of 2 as a binary number, but only encodes the first ten values from 0 to 9. Example: 1001 (9) = 1000 (8) (1) How many “invalid” code words are there? What are the “invalid” code words?
Chapter 1 31 What interesting property is common to these two codes? Excess 3 Code and 8, 4, –2, –1 Code DecimalExcess 38, 4, –2, –
Chapter 1 32 Warning: Conversion or Coding? Do NOT mix up conversion of a decimal number to a binary number with coding a decimal number with a BINARY CODE. = (This is conversion) 13 0001|0011 (This is coding)