– 1 – cs 105 computer systems introduction topics: class intro data representation cs 105...

31
– 1 – CS 105 Computer Systems Introduction Topics: Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning Spring 2013

Upload: garey-gaines

Post on 13-Dec-2015

217 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 1 – CS 105

Computer SystemsIntroduction

Computer SystemsIntroduction

Topics:Topics: Class Intro Data Representation

CS 105“Tour of the Black Holes of Computing!”

Rett Bull, Geoff KuenningSpring 2013

Page 2: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 2 – CS 105

Course ThemeCourse Theme

Abstraction is good, but don’t forget reality!

Many CS Courses emphasize abstractionMany CS Courses emphasize abstraction Abstract data types Asymptotic analysis

These abstractions have limitsThese abstractions have limits Especially in the presence of bugs Need to understand underlying implementations

Useful outcomesUseful outcomes Become more effective programmers

Able to find and eliminate bugs efficientlyAble to tune program performance

Prepare for later “systems” classes in CSCompilers, Operating Systems, File Systems, Computer

Architecture, Robotics, etc.

Page 3: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 3 – CS 105

TextbooksTextbooks

Randal E. Bryant and David R. O’Hallaron, Randal E. Bryant and David R. O’Hallaron, “Computer Systems: A Programmer’s Perspective”, 2nd

Edition, Prentice Hall, 2011.

Brian Kernighan and Dennis Ritchie, Brian Kernighan and Dennis Ritchie, “The C Programming Language, Second Edition”, Prentice

Hall, 1988

Larry Miller and Alex QuiliciLarry Miller and Alex Quilici The Joy of C, Wiley, 1997

Page 4: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 4 – CS 105

SyllabusSyllabus

Syllabus on Web: http://www.cs.hmc.edu/~geoff/cs105 Calendar defines due dates Labs: cs105submit for some, others have specific directions

Page 5: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 5 – CS 105

Notes:Notes:

Work groupsWork groups You must work in pairs on all labs Honor-code violation to work without your partner! Corollary: showing up late doesn’t harm only you

HandinsHandins Check calendar for due dates Electronic submissions only

Grading CharacteristicsGrading Characteristics Lab scores tend to be high

Serious handicap if you don’t hand a lab in Tests & quizzes typically have a wider range of scores

I.e., they’re primary determinant of your grade» …but not the ONLY one

Do your share of lab work and reading, or bomb tests Do practice problems in book

Page 6: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 6 – CS 105

FacilitiesFacilities

Assignments will use Intel computer systemsAssignments will use Intel computer systems Not all machines are created alike

Even Intel Macs aren’t necessarily compatibleMost modern machines (including Knuth) are 64-bit

Wilkes: x86/Linux specifically set up for this class Log in on a Mac, then ssh to Wilkes

If you want fancy programs, start X11 firstDirectories are cross-mounted, so you can edit on Knuth

or your Mac, and Wilkes will see your files

…or ssh into Wilkes from your dorm All programs must run on Wilkes: that’s where we

grade

Page 7: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

CS 105 “Tour of the Black Holes of Computing”

TopicsTopics Numeric Encodings

Unsigned & two’s complement

Programming ImplicationsC promotion rules

Basic operationsAddition, negation, multiplication

Programming ImplicationsConsequences of overflowUsing shifts to perform power-of-2 multiply/divide

CS 105

IntegersIntegers

Page 8: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 8 – CS 105

C PuzzlesC Puzzles Taken from old exams Assume machine with 32-bit word size, two’s complement

integers For each of the following C expressions, either:

Argue that it is true for all argument values, orGive example where it is not true

• x < 0 ((x*2) < 0)

• ux >= 0

• x & 7 == 7 (x<<30) < 0

• ux > -1

• x > y -x < -y

• x * x >= 0

• x > 0 && y > 0 x + y > 0

• x >= 0 -x <= 0

• x <= 0 -x >= 0

int x = foo();

int y = bar();

unsigned ux = x;

unsigned uy = y;

Initialization

Page 9: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 9 – CS 105

Encoding IntegersEncoding Integers

short int x = 15213; short int y = -15213;

C short 2 bytes long

Sign BitSign Bit For 2’s complement, most-significant bit indicates sign

0 for nonnegative1 for negative

B2T (X ) xw 1 2w 1 xi 2i

i0

w 2

B2U(X ) xi 2i

i0

w 1

Unsigned Two’s Complement

SignBit

Decimal Hex Binary x 15213 3B 6D 00111011 01101101 y -15213 C4 93 11000100 10010011

Page 10: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 10 – CS 105

Encoding Integers (Cont.)Encoding Integers (Cont.) x = 15213: 00111011 01101101 y = -15213: 11000100 10010011

Weight 15213 -152131 1 1 1 12 0 0 1 24 1 4 0 08 1 8 0 0

16 0 0 1 1632 1 32 0 064 1 64 0 0

128 0 0 1 128256 1 256 0 0512 1 512 0 0

1024 0 0 1 10242048 1 2048 0 04096 1 4096 0 08192 1 8192 0 0

16384 0 0 1 16384-32768 0 0 1 -32768

Sum 15213 -15213

Page 11: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 11 – CS 105

Numeric RangesNumeric Ranges

Unsigned ValuesUnsigned Values UMin = 0

000…0

UMax = 2w – 1111…1

Two’s-Complement ValuesTwo’s-Complement Values TMin = –2w–1

100…0

TMax = 2w–1 – 1

011…1

Other ValuesOther Values Minus 1

111…1Decimal Hex Binary

UMax 65535 FF FF 11111111 11111111TMax 32767 7F FF 01111111 11111111TMin -32768 80 00 10000000 00000000-1 -1 FF FF 11111111 111111110 0 00 00 00000000 00000000

Values for W = 16

Page 12: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 12 – CS 105

Values for Different Word SizesValues for Different Word Sizes

W 8 16 32 64

UMax 255 65,535 4,294,967,295 18,446,744,073,709,551,615 TMax 127 32,767 2,147,483,647 9,223,372,036,854,775,807 TMin -128 -32,768 -2,147,483,648 -9,223,372,036,854,775,808

ObservationsObservations |TMin | = TMax +

1Asymmetric range

UMax = 2 * TMax + 1

C ProgrammingC Programming  #include <limits.h>

K&R Appendix B11

Declares constants, e.g.,  ULONG_MAX  LONG_MAX  LONG_MIN

Values platform-specific

Page 13: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 13 – CS 105

An Important DetailAn Important Detail

No Self-Identifying DataNo Self-Identifying Data Looking at a bunch of bits doesn’t tell you what they mean Could be signed, unsigned integer Could be floating-point number Could be part of a string

Only the Program (Instructions) Knows for Sure!Only the Program (Instructions) Knows for Sure!

Page 14: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 14 – CS 105

Unsigned & SignedNumeric ValuesUnsigned & SignedNumeric Values

X B2T(X)B2U(X)0000 00001 10010 20011 30100 40101 50110 60111 7

–88–79–610–511–412–313–214–115

10001001101010111100110111101111

01234567

EquivalenceEquivalence Same encodings for

nonnegative values

UniquenessUniqueness Every bit pattern represents

unique integer value Each representable integer

has unique bit encoding

Page 15: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 15 – CS 105

short int x = 15213; unsigned short int ux = (unsigned short) x; short int y = -15213; unsigned short int uy = (unsigned short) y;

Casting Signed to UnsignedCasting Signed to Unsigned

C Allows Conversions from Signed to UnsignedC Allows Conversions from Signed to Unsigned

Resulting ValueResulting Value No change in bit representation Nonnegative values unchanged

ux = 15213

Negative values change into (large) positive valuesuy = 50323

Page 16: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 16 – CS 105

Relation BetweenSigned & UnsignedRelation BetweenSigned & Unsigned

uy = y + 2 * 32768 = y + 65536

Weight -15213 503231 1 1 1 12 1 2 1 24 0 0 0 08 0 0 0 0

16 1 16 1 1632 0 0 0 064 0 0 0 0

128 1 128 1 128256 0 0 0 0512 0 0 0 0

1024 1 1024 1 10242048 0 0 0 04096 0 0 0 08192 0 0 0 0

16384 1 16384 1 1638432768 1 -32768 1 32768

Sum -15213 50323

Page 17: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 17 – CS 105

Signed vs. Unsigned in CSigned vs. Unsigned in C

ConstantsConstants By default are considered to be signed integers Unsigned if have “U” as suffix

0U, 4294967259u

CastingCasting Explicit casting between signed & unsigned same as U2T and

T2Uint tx, ty;unsigned ux, uy;tx = (int) ux;uy = (unsigned) ty;

Implicit casting also occurs via assignments and procedure callstx = ux;uy = ty;

Page 18: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 18 – CS 105

Casting SurprisesCasting SurprisesExpression EvaluationExpression Evaluation

If you mix unsigned and signed in single expression, signed values are implicitly cast to unsigned

Including comparison operations <, >, ==, <=, >= Examples for W = 32

ConstantConstant11 ConstantConstant22 RelationRelation EvaluationEvaluation0 0u

-1 0

-1 0u

2147483647 -2147483648

2147483647u -2147483648

-1 -2

(unsigned) -1 -2

2147483647 2147483648u

2147483647 (int) 2147483648u

Page 19: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 19 – CS 105

0 0U == unsigned

-1 0 < signed

-1 0U > unsigned

2147483647 -2147483648 > signed

2147483647U -2147483648 <unsigned

-1 -2 > signed

(unsigned) -1 -2 >unsigned

2147483647 2147483648U <unsigned

2147483647 (int) 2147483648U > signed

Casting SurprisesCasting SurprisesExpression EvaluationExpression Evaluation

If you mix unsigned and signed in single expression, signed values are implicitly cast to unsigned

Including comparison operations <, >, ==, <=, >= Examples for W = 32

ConstantConstant11 ConstantConstant22 RelationRelation EvaluationEvaluation0 0u

-1 0

-1 0u

2147483647 -2147483648

2147483647u -2147483648

-1 -2

(unsigned) -1 -2

2147483647 2147483648u

2147483647 (int) 2147483648u

Page 20: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 20 – CS 105

0

TMax

TMin

–1–2

0

UMaxUMax – 1

TMaxTMax + 1

2’s Comp.Range

UnsignedRange

Explanation of Casting SurprisesExplanation of Casting Surprises

2’s Comp. 2’s Comp. Unsigned Unsigned Ordering Inversion Negative Big Positive

Page 21: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 21 – CS 105

Sign ExtensionSign Extension

Task:Task: Given w-bit signed integer x Convert it to w+k-bit integer with same value

Rule:Rule: Make k copies of sign bit: X = xw–1 ,…, xw–1 , xw–1 , xw–2 ,…, x0

k copies of MSB

• • •X

X • • • • • •

• • •

w

wk

Page 22: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 22 – CS 105

Sign Extension ExampleSign Extension Example

Converting from smaller to larger integer data type C automatically performs sign extension

short int x = 15213; int ix = (int) x; short int y = -15213; int iy = (int) y;

Decimal Hex Binaryx 15213 3B 6D 00111011 01101101ix 15213 00 00 3B 6D 00000000 00000000 00111011 01101101y -15213 C4 93 11000100 10010011iy -15213 FF FF C4 93 11111111 11111111 11000100 10010011

Page 23: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 23 – CS 105

Why Should I Use Unsigned?Why Should I Use Unsigned?

Be careful usingBe careful using C compilers on some machines generate less efficient code

unsigned i;for (i = 1; i < cnt; i++) a[i] += a[i-1];

Easy to make mistakesfor (i = cnt-2; i >= 0; i--) a[i] += a[i+1];

DoDo use when performing modular arithmetic use when performing modular arithmetic Multiprecision arithmetic Other esoteric stuff

DoDo use when need extra bit’s worth of range use when need extra bit’s worth of range Working right up to limit of word size E.g., array sizes

Page 24: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 24 – CS 105

Negating with Complement & IncrementNegating with Complement & IncrementClaim: Following holds for 2’s complementClaim: Following holds for 2’s complement

~x + 1 == -x

ComplementComplement Observation: ~x + x == 1111…112 == -1

IncrementIncrement ~x + x + (-x + 1) == -1 + (-x + 1) ~x + 1 == -x

Warning: Be cautious treating Warning: Be cautious treating intint’s as integers’s as integers OK here (associativity holds)

1 0 0 1 0 11 1 x

0 1 1 0 1 00 0~x+

1 1 1 1 1 11 1-1

Page 25: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 25 – CS 105

Comp. & Incr. ExamplesComp. & Incr. Examples

Decimal Hex Binaryx 15213 3B 6D 00111011 01101101~x -15214 C4 92 11000100 10010010~x+1 -15213 C4 93 11000100 10010011y -15213 C4 93 11000100 10010011

x = 15213

Decimal Hex Binary0 0 00 00 00000000 00000000~0 -1 FF FF 11111111 11111111~0+1 0 00 00 00000000 00000000

0

Page 26: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 26 – CS 105

Unsigned AdditionUnsigned Addition

Standard Addition FunctionStandard Addition Function Ignores carry output

Implements Modular ArithmeticImplements Modular Arithmetics = UAddw(u , v) = u + v mod 2w

• • •

• • •

u

v+

• • •u + v

• • •

True Sum: w+1 bits

Operands: w bits

Discard Carry: w bits UAddw(u , v)

Page 27: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 27 – CS 105

Two’s-Complement AdditionTwo’s-Complement Addition

TAdd and UAdd have identical bit-level behaviorTAdd and UAdd have identical bit-level behavior Signed vs. unsigned addition in C:

int s, t, u, v;

s = (int) ((unsigned) u + (unsigned) v);

t = u + v Will give s == t

• • •

• • •

u

v+

• • •u + v

• • •

True Sum: w+1 bits

Operands: w bits

Discard Carry: w bits TAddw(u , v)

Page 28: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 28 – CS 105

Detecting 2’s-Comp. OverflowDetecting 2’s-Comp. Overflow

TaskTask Given s = TAddw(u , v)

Determine if s = Addw(u , v)

Example

int s, u, v;

s = u + v;

ClaimClaim Overflow iff either:

u, v < 0, s 0 (NegOver)

u, v 0, s < 0 (PosOver)

0

2w –1

2w–1PosOver

NegOver

Page 29: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 29 – CS 105

MultiplicationMultiplicationComputing exact product of Computing exact product of ww-bit numbers -bit numbers xx, , yy

Either signed or unsigned

RangesRanges Unsigned: 0 ≤ x * y ≤ (2w – 1) 2 = 22w – 2w+1 + 1

Up to 2w bits

Two’s complement min: x * y ≥ (–2w–1)*(2w–1–1) = –22w–2 + 2w–1

Up to 2w–1 bits (including 1 for sign)

Two’s complement max: x * y ≤ (–2w–1) 2 = 22w–2

Up to 2w bits, but only for (TMinw)2

Maintaining exact resultsMaintaining exact results Would need to keep expanding word size with each product

computed Done in software by “arbitrary-precision” arithmetic

packages

Page 30: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 30 – CS 105

Power-of-2 Multiply by ShiftingPower-of-2 Multiply by Shifting

OperationOperation u << k gives u * 2k

Both signed and unsigned

ExamplesExamples u << 3 == u * 8 u << 5 - u << 3 == u * 24 Most machines shift and add much faster than multiply

Compiler generates this code automatically

• • •

0 0 1 0 0 0•••

u

2k*

u · 2kTrue Product: w+k bits

Operands: w bits

Discard k bits: w bits UMultw(u , 2k)

•••

k

• • • 0 0 0•••

TMultw(u , 2k)

0 0 0••••••

Page 31: – 1 – CS 105 Computer Systems Introduction Topics: Class Intro Data Representation CS 105 “Tour of the Black Holes of Computing!” Rett Bull, Geoff Kuenning

– 31 – CS 105

Unsigned Power-of-2 Divideby ShiftingUnsigned Power-of-2 Divideby ShiftingQuotient of unsigned by power of 2Quotient of unsigned by power of 2

u >> k gives u / 2k Uses logical shift

Division Computed Hex Binaryx 15213 15213 3B 6D 00111011 01101101x >> 1 7606.5 7606 1D B6 00011101 10110110x >> 4 950.8125 950 03 B6 00000011 10110110x >> 8 59.4257813 59 00 3B 00000000 00111011

0 0 1 0 0 0•••

u

2k/

u / 2kDivision:

Operands:•••

k••• •••

•••0 ••• •••

u / 2k •••Result:

.

Binary Point

0 •••