CISC101 Reminders Labs start this week. Meet your TA! Get help with:

Slides:



Advertisements
Similar presentations
CPU Review and Programming Models CT101 – Computing Systems.
Advertisements

Dr. Ken Hoganson, © August 2014 Programming in R COURSE NOTES 2 Hoganson Language Translation.
Week 3. Assembly Language Programming  Difficult when starting assembly programming  Have to work at low level  Use processor instructions >Requires.
 Suppose for a moment that you were asked to perform a task and were given the following list of instructions to perform:
CSCE 121, Sec 200, 507, 508 Fall 2010 Prof. Jennifer L. Welch.
Assembly Language and Computer Architecture Using C++ and Java
Binary Arithmetic Math For Computers.
Lecture 18 Last Lecture Today’s Topic Instruction formats
Simple Data Type Representation and conversion of numbers
How Computers Work Dr. John P. Abraham Professor UTPA.
IT253: Computer Organization
Chapter 1: Basic Concepts
Computer Systems Organization CS 1428 Foundations of Computer Science.
Microcode Source: Digital Computer Electronics (Malvino and Brown)
CSC 3210 Computer Organization and Programming Chapter 1 THE COMPUTER D.M. Rasanjalee Himali.
4-1 Chapter 4 - The Instruction Set Architecture Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring Principles.
CS 111 – Sept. 15 Chapter 2 – Manipulating data by performing instructions “What is going on in the CPU?” Commitment: –Please read through section 2.3.
PHY 201 (Blum)1 Microcode Source: Digital Computer Electronics (Malvino and Brown)
 Lecture 2 Processor Organization  Control needs to have the  Ability to fetch instructions from memory  Logic and means to control instruction sequencing.
Monday, January 14 Homework #1 is posted on the website Homework #1 is posted on the website Due before class, Jan. 16 Due before class, Jan. 16.
ECE DIGITAL LOGIC LECTURE 2: DIGITAL COMPUTER AND NUMBER SYSTEMS Assistant Prof. Fareena Saqib Florida Institute of Technology Fall 2016, 01/14/2016.
Representation of Data - Instructions Start of the lesson: Open this PowerPoint from the A451 page – Representation of Data/ Instructions How confident.
Winter 2016CISC101 - Prof. McLeod1 Today Go over the Python disassembly “experiment” again. Code interpretation vs. code compilation. History and features.
Winter 2016CISC101 - Prof. McLeod1 Today Numeric representation (or “How does binary and hexadecimal work?”). How can a CPU understand instructions written.
Quiz 1 A sample quiz 1 is linked to the grading page on the course web site. Everything up to and including this Friday’s lecture except that conditionals.
1 Chapter 1: Introduction Appendix A: Binary and Hexadecimal Tutorial Assembly Language for Intel-Based Computers, 3rd edition Kip R. Irvine.
Unit 1 Introduction Number Systems and Conversion.
Assembly language.
Assembly Language (CSW 353)
Topics Introduction Hardware and Software How Computers Store Data
CMSC201 Computer Science I for Majors Lecture 22 – Binary (and More)
Data Representation Binary Numbers Binary Addition
A Closer Look at Instruction Set Architectures
Assignment and Arithmetic expressions
A Closer Look at Instruction Set Architectures
Computer Architecture and Organization Miles Murdocca and Vincent Heuring Chapter 4 – The Instruction Set Architecture.
Chapter 6 Floating Point
CISC101 Reminders Quiz 1 grading underway Next Quiz, next week.
Lecture 4: MIPS Instruction Set
Software comes from heaven when you have good hardware. Ken Olsen
Winter 2018 CISC101 11/22/2018 CISC101 Reminders
CSCI206 - Computer Organization & Programming
CISC101 Reminders Your group name in onQ is your grader’s name.
CSCE Fall 2013 Prof. Jennifer L. Welch.
Winter 2018 CISC101 11/29/2018 CISC101 Reminders
Numbering System TODAY AND TOMORROW 11th Edition
CSCE 121: Simple Computer Model Spring 2015
Overview of Computer Architecture and Organization
CISC101 Reminders Assn 3 due tomorrow, 7pm.
Topics Introduction Hardware and Software How Computers Store Data
Instruction encoding We’ve already seen some important aspects of processor design. A datapath contains an ALU, registers and memory. Programmers and compilers.
CISC101 Reminders Quiz 1 grading underway Next Quiz, next week.
Fall 2018 CISC124 2/15/2019 CISC124 TA names and s will be added to the course web site by the end of the week. Labs start next week in JEFF 155:
Lecture 06 Programming language.
MARIE: An Introduction to a Simple Computer
CISC124 Assignment 1 due this Friday, 7pm.
CSCE Fall 2012 Prof. Jennifer L. Welch.
Instructions in Machine Language
CISC101 Reminders All assignments are now posted.
Winter 2019 CISC101 4/8/2019 CISC101 Reminders
Winter 2019 CISC101 4/16/2019 CISC101 Reminders
CISC101 Reminders Assignment 3 due next Friday. Winter 2019
8051 ASSEMBLY LANGUAGE PROGRAMMING
Winter 2019 CISC101 4/28/2019 CISC101 Reminders
Beyond Base 10: Non-decimal Based Number Systems
CISC101 Reminders Assignment 3 due today.
1.3.7 High- and low-level languages and their translators
Computer Organization and Assembly Language
CS 111 – Sept. 16 Machine language examples Instruction execution
Presentation transcript:

CISC101 Reminders Labs start this week. Meet your TA! Get help with: Winter 2019 CISC101 4/12/2019 CISC101 Reminders Labs start this week. Meet your TA! Get help with: Exercise 1. Python installation issues. Lecture material. Assignment expectations…. Winter 2019 CISC101 - Prof. McLeod Prof. Alan McLeod

Today Numeric Representation. Commanding the CPU. Winter 2019 CISC101 - Prof. McLeod

Numeric Representation Binary numbers or “base 2” is a natural representation of numbers to a computer. As a transition, hexadecimal (or “hex”, base 16) numbers are also used. Octal (base 8) numbers are hardly ever used anymore – so I won’t talk about this base. Decimal (base 10) numbers are not naturally represented in computers. Winter 2019 CISC101 - Prof. McLeod

Reminder – Python Integer Literals From Exercise 1: Binary literals – prefix the number with 0b Octal literals – prefix the number with 0o Hex literals – prefix the number with 0x Decimal literals – don’t prefix the number with anything! Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. In base 2 (digits either 0 or 1): r=2, a binary number: (110101.11)2= 1×25+1×24+0×23+1×22+0×21+1×20 +1×2-1 +1×2-2 =53.75 (in base 10) “r” is the “radix” or the base of the number Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. Hexadecimal Numbers: a base-16 system with 16 digits: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, and F: For example: 16, a hex number: (B65F)16 = 11×163+6×162+5×161+15×160 = 4668710 Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. The algorithms show in the previous two slides show how you can convert from binary or hex to decimal. How to convert from decimal to one of the other bases? Here is another algorithm that you can use: integral part: divide by r and keep the remainder. decimal part: multiply by r and keep the carry “r” is the base - either 2 or 16 Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. For example, convert 625.1510 to binary: So, 62510 is 10011100012 Divisor(r) Dividend Remainder 2 625 2 312 (quotient) 1 2 156 0 2 78 0 2 39 0 2 19 1 2 9 1 2 4 1 2 2 0 2 1 0 0 1 least significant digit most significant digit Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. For the “0.1510” part: So, 0.1510 is 0.0010012 625.15 is: (1001110001.001001)2 Multiplier(r) Multiplicand Carry 2 0 .15 2 0 .30 (product) 0 2 0 .60 0 2 1 .20 1 2 0 .40 0 2 0 .80 0 2 1 .60 1 2 0 .80 0 ... Winter 2019 CISC101 - Prof. McLeod

Aside - Roundoff Error Consider 0.1, for example: (0.1)10 = (0.0 0011 0011 0011 0011 0011…)2 What happens to the part of a real number that cannot be stored? It is lost - the number is either truncated or rounded. The “lost part” is called the Roundoff Error. Winter 2019 CISC101 - Prof. McLeod

An Experiment Without worrying about the syntax details for now, enter the following lines at the Python prompt: >>> sum = 0 >>> for i in range(1000) : sum = sum + 0.1 >>> sum Why is the value in sum not what it should be? Winter 2019 CISC101 - Prof. McLeod

An Experiment, Cont. How many other fractional, real numbers will result in roundoff error when they are stored in a computer? Which ones won’t result in roundoff error? (Hint try adding 0.125 instead of 0.1…) Winter 2019 CISC101 - Prof. McLeod

Not All Numbers! A computer only has a finite amount of memory to store a number: Only a portion of most real numbers can be stored. The majority of real numbers cannot be stored exactly on a computer! Only numbers that are a sum of powers of 2 can be stored exactly. Most calculations made with real numbers on a computer can only yield approximate results! Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. Converting between binary and hex is much easier - done by “grouping” the digits. Each hex digit results in 4 binary digits. Work away from the decimal place. For example: (2C6B.F06)16 = (?)2 ( 2 C 6 B . F 0 6 )16 ( 0010 1100 0110 1011 . 1111 0000 0110)2 Winter 2019 CISC101 - Prof. McLeod

Numeric Representation - Cont. And going from binary to hex: (10110011101.11011)2 = (?)16 ( 0101 1001 1101 . 1101 1000 )2 ( 5 9 D . D 8 )16 Winter 2019 CISC101 - Prof. McLeod

Commanding the Processor CISC101 Commanding the Processor Suppose we want the processor to carry out the operation: X = A * B + C Assume we have used some other operations to put numbers in three memory locations at locations 1024, 1025 and 1026 in RAM, corresponding to A, B and C. We want the result to go into memory location 1027, corresponding to X. Winter 2019 CISC101 - Prof. McLeod Prof. Alan McLeod

X = A * B + C Remember the “von Neumann Cycle”? The operations in the ALU (or “Arithmetic Logic Unit”) part of the CPU would be: Fetch the contents of location 1024 and put it into a register. Fetch the contents of location 1025 and multiply it with the number in the register, storing the result in the register. Fetch the contents of location 1026 and add this value to the contents of the register. Move the contents of the register to memory location 1027. Winter 2019 CISC101 - Prof. McLeod

X = A * B + C, Cont. Naturally, these instructions have to be communicated to the CPU in binary: 1. 00010000000000000000010000000000 2. 00100100000000000000010000000001 3. 00100011000000000000010000000010 4. 00010001000000000000010000000011 byte 1 bytes 2, 3 and 4 opcode operand Winter 2019 CISC101 - Prof. McLeod

Aside – Bytes and Bits A byte is 8 bits. A bit is either 0 or 1. So a byte can range from: 00000000, to 11111111 In base 10 this is 0 to 255 In hex this is 0 to FF So one byte can be represented by two hex digits. Winter 2019 CISC101 - Prof. McLeod

Aside - CPU Pins How many pins on the CPU would be required to input these instructions? Winter 2019 CISC101 - Prof. McLeod

X = A * B + C, Cont What are these instructions in base 10? 16 1024 36 1025 35 1026 17 1027 The operands are the memory locations The opcodes are 16 for “load”, 36 for “multiply”, 35 for “add” and 17 for “store”. The default register is used, so it does not need to be specified. Winter 2019 CISC101 - Prof. McLeod

Machine Language These 4 byte binary commands are examples of machine language. Normally these commands would be viewed in base 16, or hex: 0x10000400 0x24000401 0x23000402 0x11000403 Winter 2019 CISC101 - Prof. McLeod

X = A * B + C, Cont Since “normal” people have problems remembering binary codes and even hexadecimal codes for operations, a “shorthand” language called Assembly Language was introduced at a level above “machine language”: Winter 2019 CISC101 - Prof. McLeod

X = A * B + C, Cont (Pseudo) Assembly language instructions: LOAD A, ACC MULT B, ACC ADD C, ACC STOR ACC, X Each assembly language keyword is immediately translated into the corresponding machine language code by an “interpreter” program called an “Assembler”. Winter 2019 CISC101 - Prof. McLeod

X = A * B + C, Cont A higher level language goes one step above assembly language. For example, in C, C++, C# or Java, you would write: X = A * B + C; (Python is the same, except no semi-colon.) Each high-level line of code gets translated into many lines of assembly code and each line of assembly code must be translated into binary machine language. Much easier to write high level code, right? Winter 2019 CISC101 - Prof. McLeod

Disassembly Experiment Python has a module called “dis” that can show you the assembly language version of a Python line of code, function, object or an entire module. At the >>> prompt type: >>> import dis >>> a = 10 >>> b = 30 >>> c = 2 >>> dis.dis("x = a * b + c") Winter 2019 CISC101 - Prof. McLeod

Disassembly Experiment, Cont. You will see: 1 0 LOAD_NAME 0 (a) 2 LOAD_NAME 1 (b) 4 BINARY_MULTIPLY 6 LOAD_NAME 2 (c) 8 BINARY_ADD 10 STORE_NAME 3 (x) 12 LOAD_CONST 0 (None) 14 RETURN_VALUE Winter 2019 CISC101 - Prof. McLeod

Disassembly Experiment, Cont. One line of Python code required eight lines of assembly! In case you are curious, see section 31.12.1 in the Python help docs (“Standard Library”) for the meaning of assembly instructions. These are explained on the next slide: Winter 2019 CISC101 - Prof. McLeod

Disassembly Experiment, Cont. LOAD_NAME pushes a value onto the stack from a variable name. BINARY_MULTIPLY multiplies the two numbers on top of the stack and puts the result on top of the stack. BINARY_ADD adds the two numbers on top of the stack and puts the result back on the stack. STORE_NAME takes the value on the top of the stack and stores it into a variable name. LOAD_CONST puts a zero on top of the stack, to clear it. RETURN_VALUE returns the value on top of the stack (zero in this case) as a result of the evaluation of the expression. Winter 2019 CISC101 - Prof. McLeod

Disassembly Experiment, Cont. The “stack” register is used to temporarily hold values and the results of calculations. How the stack changes after each instruction: top: 10 a 30 10 b 300 2 300 c 302 a * b + c 302 a * b x a * b a Winter 2019 CISC101 - Prof. McLeod

Aside – What’s a Stack? A “LIFO” – “Last In, First Out” type of data structure. (Like a plate dispenser in a cafeteria!) You “push” values on to the top of the stack and “pop” them off. What is a “stack overflow”? Often results from infinite recursion, for example. Winter 2019 CISC101 - Prof. McLeod

Machine Code Once code is disassembled, the interpreter needs to generate machine code. It uses the opcodes, opargs and operands from each line of assembly. We can view (and sometimes write) machine code in hexadecimal. But, the interpreter will not bother with this stage – it translates from assembly to binary. Now, the code is impossible for most humans to read! Winter 2019 CISC101 - Prof. McLeod

Compiled vs Interpreted Binary commands can be compiled and then written to an *.exe or “executable” file. When you run a file like this the code is sent directly to the CPU, which is very fast! Python does not make these files, but generates binary machine language on the “fly” – sending it directly to the CPU, line by line. Python “interprets” source code, generates machine language and executes it immediately. Winter 2019 CISC101 - Prof. McLeod