Binary Numbers • Numbering Systems • Counting • Symbolic • Bases • Common Bases (10, 2, 8, 16) • Representing Information • Binary to Decimal Conversions • Bit Groupings • Encoding Information Craig Schock, 2003 Numbering Systems • There are many different ways to represent numbers • Counting Based Systems • The number is represented by the same number of counters • Symbolic • Uses symbols to represent values 7= Craig Schock, 2003 Symbolic Numbering Systems • The symbols within the numbering systems are an “abstraction” of the actual number. • The symbol represents a value • Abstraction: A symbolic representation of a thing or idea. • In order for an abstraction to be useful, people must agree on its meaning. • Symbols are combined to represent larger numbers Craig Schock, 2003 Numbering Bases • Each symbolic numbering system has a “base” • Base: The number of symbols in the system • eg. Decimal has 10 symbols (0-9) 0 1 2 3 4 Craig Schock, 2003 5 6 7 8 9 Common Bases • The most common base used in western society is base 10 (decimal) • It is based on 10 symbols • Humans have 10 “digits” • In the computer world, there are other commonly used bases: • Binary (base 2, 0-1) • Octal (base 8, 0-7) • Hexadecimal (base 16, 0-9, A-F) Craig Schock, 2003 Decimal: Representing Numbers • Because decimal has 10 digits, it can easily represent numbers 0-9. 0 1 2 3 4 5 6 7 8 9 However, representing numbers which are larger than the number of symbols poses a problem. Craig Schock, 2003 Decimal: Positional Notation • Symbolic systems deal with representing large numbers through a positional notation. • The actual value of the symbol is based on its position • Multiplication and addition is employed to increase the value • The factor used in the multiplication is the base Note: base 10 First column starts at “1” x10x10 x10 x1 7 5 6 10 2 10 1 10 = 0 Craig Schock, 2003 7 x 10 x 10 + 5 x 10 + 6x1 Information • Information: What is it? A message received and understood that reduces the recipient’s uncertainty • “Uncertainty” implies that for information to be present, there must be at least 2 possible outcomes. • If there was only 1 outcome, there would be no uncertainty. • If we were to represent information as a numbering system, it would be a system which contained at least 2 symbols. Craig Schock, 2003 Representing Information • We could choose any numbering system to represent information. • Whatever system we choose, it must contain at least 2 symbols. • Electrically, it is easy to represent a system containing 2 symbols using switches. • Off • On • We can also think of philosophical systems based on “truthness” and “falseness” Craig Schock, 2003 Binary – Base 2 • Binary is a numbering system which contains 2 symbols (i.e. base 2) • For easy interoperability with other bases (such as decimal), we choose the digits “0” and “1” to represent the two possible values • A “bit” is a single BInary digiT • A bit is the smallest unit of information • What if the information we need to represent has more than 2 possibilities? Craig Schock, 2003 Binary – Positional Notation • As with decimal, we can represent values which are larger than the number of symbols we have. • This is accomplished through the use of a positional notation. Because the base is 2, the multiplier for each position is x2 Note: base 2 x2x2 x2 x1 1 1 1 2 2 2 1 2 = 0 Craig Schock, 2003 1x2x2+ 1x2+ 1x1 Binary to Decimal Conversions • Because humans work well with decimal, it is useful to know how to convert between binary and decimal: 0000 = 0 0001 = 1 0010 = 2 0011 = 3 0100 = 4 0101 = 5 0110 = 6 0111 = 7 Craig Schock, 2003 1000 = 8 1001 = 9 1010 = 10 1011 = 11 1100 = 12 1101 = 13 1110 = 14 1111 = 15 Binary to Decimal Conversions (contd) 8 4 1 1 2 1 0 1 = 1x8 + 1x4 + 1x1 = 8+4+1= 13 To convert to decimal, represent the column values in decimal 128 64 1 0 32 16 8 4 0 1 1 1 2 1 0 1 1x128 + 1x16 + 1x8 + 1x4 + 1x1 = 128 + 16 + 8 + 4 + 1 = 157 Craig Schock, 2003 = How many bits to use? • In the last few slides, we have seen binary numbers which contain differing numbers of digits – 3 bits, 4 bits, and 8 bits • How many bits should one use? • That depends on what information one wishes to represent. • eg. How many bits are necessary to represent the days of the week? Craig Schock, 2003 How Many bits? • Days of the week. Let’s let each bit combination represent one day: 000 = Sunday 001 = Monday 010 = Tuesday 011 = Wednesday 100 = Thursday 101 = Friday 110 = Saturday • Because there are 7 days of the week, we need enough bits which have at least 7 different combinations. (3 bits) Craig Schock, 2003 Bits and Combinations • How can we tell how many combinations a given number of bits will provide? • The answer is based on a simple formula: n n bits provides 2 combinations 1 bit = 2 combinations 2 bits = 4 combinations 3 bits = 8 combinations 4 bits = 16 combinations 5 bits = 32 combinations 6 bits = 64 combinations 7 bits = 128 combinations 8 bits = 256 combinations 9 bits = 512 combinations 10 bits = 1024 combinations 11 bits = 2048 combinations 12 bits = 4096 combinations 13 bits = 8192 combinations 14 bits = 16384 combinations 15 bits = 32768 combinations 16 bits = 65536 combinations Craig Schock, 2003 More combinations • How many bits are necessary to represent • The days of the month? • Your age • The year of your birth? • The number of cars you have owned? • Your salary? • The salary of a CEO of a multinational corporation? • The Canadian national debt? • The US national debt? • The number of atoms in the universe? Craig Schock, 2003 Bit groupings • Relatively speaking, there are few cases where the information content only requires 1 bit. • Bits are usually grouped into larger units. • Common groupings include: 4 bits = 1 nybble (not commonly used) 8 bits = 1 byte 1024 bytes = 1 kilobyte (or 1K) 1024 * 1024 bits = 1048576 bits = 1 megabits = 131072 bytes 1024 * 1024 bytes = 1048576 bytes = 1 Megabyte 1024 * 1024 * 1024 bytes = 1073741824 bytes = 1 Gigabyte Craig Schock, 2003 What does it mean? • Exercise: What do the following numbers mean? 102, 102, 102, 126, 126, 102, 102, 102 0, 24, 24, 0, 24, 24, 24, 24 24, 24, 24, 24, 24, 0, 24, 24 Craig Schock, 2003 What does it mean? 102 = 01100110 102 = 01100110 102 = 01100110 126 = 01111110 126 = 01111110 102 = 01100110 102 = 01100110 102 = 01100110 0 = 00000000 24 = 00011000 24 = 00011000 0 = 00000000 24 = 00011000 24 = 00011000 24 = 00011000 24 = 00011000 Craig Schock, 2003 24 = 00011000 24 = 00011000 24 = 00011000 24 = 00011000 24 = 00011000 0 = 00000000 24 = 00011000 24 = 00011000 What does it mean? 11 11 11 11 11 11 111111 111111 11 11 11 11 11 11 11 11 11 11 11 11 Craig Schock, 2003 11 11 11 11 11 11 11 Information Encoding • The exercise illustrates and important concept in computer science. • We have learned that binary numbers can be used to represent information. Information, as a series of bits, can be represented as decimal numbers. The example provided a series of decimal numbers. But what do they mean? • What the numbers mean is a matter of definition • Information is encoded using bits • Encoding is an abstraction. Craig Schock, 2003 ASCII Codes • ASCII – American Standard Code for Information Interchange • ASCII is an 7 bit encoding which is used to represent the Roman alphabet, numbers, standard symbols and printer control characters. • Some companies expanded ASCII to 8 bits. They used the extra combinations to encode special characters Craig Schock, 2003 The ASCII Standard Dec Char 0 NUL 1 SOH 2 STX 3 ETX 4 EOT 5 ENQ 6 ACK 7 BEL 8 BS 9 HT 10 LF 11 VT 12 FF 13 CR 14 SO 15 SI 16 DLE 17 DC1 18 DC2 19 DC3 20 DC4 21 NAK 22 SYN Dec Char 23 ETB 24 CAN 25 EM 26 SUB 27 ESC 28 FS 29 GS 30 RS 31 US 32 SPACE 33 ! 34 " 35 # 36 $ 37 % 38 & 39 ' 40 ( 41 ) 42 * 43 + 44 , 45 - Dec Char 46 . 47 / 48 0 49 1 50 2 51 3 52 4 53 5 54 6 55 7 56 8 57 9 58 : 59 ; 60 < 61 = 62 > 63 ? 64 @ 65 A 66 B 67 C 68 D Dec Char 69 E 70 F 71 G 72 H 73 I 74 J 75 K 76 L 77 M 78 N 79 O 80 P 81 Q 82 R 83 S 84 T 85 U 86 V 87 W 88 X 89 Y 90 Z 91 [ Craig Schock, 2003 Dec Char 92 \ 93 ] 94 ^ 95 _ 96 ` 97 a 98 b 99 c 100 d 101 e 102 f 103 g 104 h 105 i 106 j 107 k 108 l 109 m 110 n 111 o 112 p 113 q 114 r Dec Char 115 s 116 t 117 u 118 v 119 w 120 x 121 y 122 z 123 { 124 | 125 } 126 ~ 127 DEL Using ASCII • Using the ASCII standard, we can encode an English sentence as a series of ASCII values I would like to buy some cheese. 73, 32, 119, 111, 117, 108, 100, 32, 108, 105, 107, 101, 32, 116, 111, 32, 98, 117, 121, 32, 115, 111, 109, 101, 32, 99, 104, 101, 101, 115, 101, 46 • How many bytes are needed to encode the above sentence using ASCII? 32 byes Craig Schock, 2003