CSL101: Introduction to Computers and Programming: Lecture 1: Introduction Instructors Prof Saroj Kaushik Room No : Phone Number : Email : Web Link : 416, Bharati School building (CSE) 1292 (internal) saroj@ cse.iitd.ernet.in http://www.cse.iitd.ac.in/~saroj Prof K K Biswas Room No Phone Number Email Web Link 313, Bharati School building (CSE) 6010 (internal) kkb@cse.iitd.ac.in http://www.cse.iitd.ac.in/~kkb : : : : 1st semester 2011-2012: Time Table Lecture Time: 2.00-3.20 PM Lect Venue : IV LT3 Practical: 11.00-12.50 PM (CSC): 2 hr/week lab for each group Cycle 1 : G1, 6 - Wednesday Cycle 2 : G2, 7 - Thursday Cycle 3 : G3, 8 - Friday Cycle 4 : G4, 9 - Monday Cycle 5 : G5, 10 -Tuesday Course contents • • • • Introduction to Computers Problem solving using computers Development of algorithms? Introduction to programming in a high level language: Python – Syntax and semantics • • • • Algorithms for various applications Advanced features of Python Number Representations Sorting algorithms Course Grading Structure • These weights are indicative, and may change as semester progresses – Minor 1 & 2, each with 15-20% weightage – Major, 30-35% weightage – Quizzes and home assignments, 5-10% weightage – Programming exercises, 20-25% weightage Submission of lab reports • Labs will be conducted by TAs in CSC. • Lecture slides, Lab exercises will be posted on web or Moodle http://www.cse.iitd.ac.in/~saroj • For each exercise there will be a deadline for submission of report/code. • Be sure that you complete the exercise well before the deadline and submit the report in time. • We will not tolerate excuses (power fail, server down, printer fault, lab closed, etc.). • Heavy penalty for late submission To pass the course • A student has to pass EACH of the course components indicated above, by getting at least 30% in each. • Student should get minimum 35% overall to pass the course. • Attend all classes and should be above 75%. • Classes will begin on time and entry will not be allowed later than 5 minutes. • Cheating in tests or assignments will result in ‘F’ grade in the course. • Attend the “Special Help sessions” if you have difficulty in the course. • Keep meeting your TA ( Teaching Assistant) for any difficulty in the course outside the lab timings as well. Text books • For Algorithm: – R. G. Dromey “How to solve it by computer”, Prentice Hall, Indian edition. • Link to an online material on Python Programming: www.greenteapress.com/thinkpython/thinkpython.pdf Introduction to Computers What is a Computer? • Electronic device • Capable of performing – – – – arithmetic operations on numbers logical operations on bits (binary digit) decision test retrieval, manipulation and storage of large amount of data at a very high speed What Does A Computer Do? • Computers can perform four general operations, which comprise the information processing cycle. – – – – Input Process Output Storage • To do each of these computer has devices. Devices that comprise a computer system Monitor (output) Speaker (output) System unit (processor, memory…) Printer (output) Storage devices (CD-RW, Floppy, Hard disk, zip,…) Scanner (input) Mouse (input) Keyboard (input) 11 Why Is a Computer So Powerful? • The ability to perform the information processing cycle with amazing speed. • Reliability (low failure rate). • Accuracy. • Ability to store huge amounts of data and information. • Ability to communicate with other computers. 12 How Does a Computer Know what to do? • It must be given a detailed list of instructions, called a computer program or software, that tells what exactly it has to do. • Before processing a specific job, the computer program corresponding to that job must be created and stored in memory. • Once the program is stored in memory the computer can start the operation by executing the program instructions one after the other. 13 Computer System • A computer system is made up of both – Hardware electronic components – Software Program consisting of set of instruction • Example: Some of the Anology: – Mobile is hardware and corresponding facilities available is software. – CD is hardware and music on it is software. Hardware Components Of A Computer ? • Input devices. • Output devices. • Central Processing Unit • Memory. • Storage devices. The Keyboard • The most commonly used input device is the keyboard on which data is entered by manually keying in or typing certain keys. • A keyboard typically has 101 or 105 keys. The Mouse • Is a pointing device which is used to control the movement of a mouse pointer on the screen to make selections from the screen. • A mouse has one to five buttons. The bottom of the mouse is flat and contains a mechanism that detects movement of the mouse. Output Devices • Output devices make the information resulting from the processing available for use. • The two output devices more commonly used are the printer and the computer screen. • The printer produces a hard copy of your output, and the computer screen produces a soft copy of your output. The Central processing Unit, CPU • The CPU contains electronic circuits that cause processing to occur. • Does the `work‘ of fetching, storing and manipulating values that are stored in the computers memory. • It is considered the “brain” of the computer. Main Components of CPU • Arithmetic Logic Unit (ALU) – The ALU carries out arithmetic operations (e.g. addition and subtraction) and logical operations (e.g. and, or, not) • Control Unit (CU) – The CU controls the execution of instructions. Memory • Memory consists of electronic components that store data including numbers, characters, graphics and sound. • It has two types of memory. – Random Access Memory (RAM) – Read only Memory (ROM) Random Access Memory – RAM • RAM is where programs and data are kept during execution when the processor is actively using them. • RAM is called Main memory or Primary memory. • RAM – Is Volatile - temporary – Has random access to any memory location – Read & write access – Program + data reside in this memory Main Memory • Main memory is: – very closely connected to the processor. – the contents are quickly and easily changed. – holds the programs and data that the processor is actively working with. – interacts with the processor millions of times per second. Read only Memory - ROM • Read only Memory (ROM) – Non volatile – Only read access – Permanent programs reside Cache Memory • A special and very high speed memory used to increase the speed of processing. • Cache is sometimes called CPU cache • Transfer from cache to CPU is very fast as compared to from main memory to CPU. CPU Main Memory ALU + CU Cache Cache Memory • It lies between CPU and main memory. • The cache is usually filled from main memory when instructions or data are fetched into the CPU. • Often the main memory will supply a wider data word to the cache than the CPU requires, to fill the cache more rapidly. • It is expensive and usually small in size. • Stores only segments of programs currently being executed by CPU. • It is also sometimes called buffer. Storage Devices- Secondary memory • Connected to main memory • The contents are easily changed, but this is very slow compared to main memory. • It is used for long-term storage of programs and data. • The processor only occasionally interacts with secondary memory. • The most common types of secondary storage used are – Hard disks – CD-ROM drives – Flash Drives (USB, pen drives) Hard Disk • The hard disk has enormous storage capacity compared to main memory – 300 times the amount of storage in main memory • The hard disk is usually contained in the systems unit of a computer. Reasons for having two types of storage Primary memory Secondary memory 1. 2. 3. 4. 1. 2. 3. 4. Fast Expensive Low capacity Connects directly to the processor Slow Cheap Large capacity Not connected directly to the processor Data Representation in Memory • Data is stored inside the memory in the form of 1’s and 0s, Bits (Binary Digits) as shown below (ON/OFF positions). – For example 1100 0111 0011 1111 0101 1110 • One byte consists of 8 bits. Contd… • How many distinct values can be stored in one byte? • Answer: 28 • Minimum Value: 0 0000 0000 • Maximum value: 28–1 1111 1111 Organization of Main Memory • Main memory consists of a very long list of bytes. • In most modern computers, each byte has an address that is used to locate it. • The picture shows a small part of main memory: • Each row is called memory location that is a single byte and has an address. • The addresses are the integers to the left of the boxes: 0, 1, 2, 3, 4, ... 255 for location of one byte. • The addresses for most computer memory start at 0 and go up in sequence until each byte has an address. • The bits at a memory location are called the contents of that location. • Each location contains a pattern of eight bits, each bit is either 0 or 1. • When people say that a computer has "128 MB of RAM" they are talking about how big its main memory is. Units of Memory • • • • 1 KB (1 KiloByte) contains 1024 Bytes. 1 MB (1 MegaByte) consists of 1024 KB. 1 GB (1 GigaByte) has 1024 MB. 1 TB (1 Terabyte consists of 1024 GB. Table of units of measurement Name Equivalent Number of Bytes power of 2 byte 8 bits 1 20 Kilobyte (KB) Megabyte (MB) Gigabyte (GB) Terabyte 1024 bytes 1024 210 1024 KB 1,048,576 220 1024 MB 1,073,741,824 230 1024 GB 1,099,511,627,776 240 Software • Computer programmers/users write the codes/ instructions that make-up software applications/programs. • Set of instructions is also referred to as lines of code. • Without software a computer is useless, just as a car without someone to drive it. • To get a computer to perform a specific task, it must be given a sequence of unambiguous instructions called a program written in some programming language. Types of Programs • There are two categories of programs. – Application programs (usually called just "applications") that people use to get their work done. – Systems programs keep all the hardware and software running together smoothly. • The difference between "application program" and "system program" is fuzzy. • Often it is more a matter of marketing than of logic. Application Programs Systems Programs • • • • • • • • • • • • Word processors Game programs Spreadsheets Data base packages Graphics programs Web browsers Operating system. Networking system. Database system. Compilers Web site server. Data backup. Example of Types of Software Application Software Operating system Software Operating Systems (OS) • OS coordinates the operation of all the hardware and software components of the computer system. • The operating system is responsible for starting application programs running and finding the resources that they need. • When an application program is running, the operating system manages the details of the hardware for it. • It is there in the background managing resources, doing input and output for the application, and keeping everything else running. • The operating system is always present when the computer is running. Resources managed by OS • OS is a complex collection of many programs that governs the control of various resources such as: – – – – – Processor Main Memory Secondary storage I/O devices Files • The operating system is software; the same hardware can be used with many different operating systems (although only one at a time.) Various Modules of OS • There are various modules of OS – – – – Processor management Memory management Device management Information management • These modules resolve conflicts, optimize performance and acts as an interface between the user’s program and computer hardware. • Modern operating systems usually come with a user interface that enables users to easily interact with application programs by using windows, buttons, menus, icons, the mouse, and the keyboard. • Examples of operating systems are – DOS, Unix, Windows 98, Windows NT, Linux, Solaris, etc. • There are different OS for different kinds of machines. – – – – – Single user machine Batch processing Multiprogramming Time sharing Real time machines Programming Languages Machine Lang Assembly Lang High level Lang Consists of 0 & 1 Comp System directly executes it Pseudo inst Add 2 5 Assembler translates to M/L English like insts Input A, B Compiler translates to M/L Difficult to write Simple to write Simpler to write Highly error prone Less error prone Lesser error prone Machine dependent Machine dependent Machine independent Machine Language • Consider machine of 16-bits Opcode (4-bits) Address (12-bits) • There are 16 possible opcodes (Hypothetical example) Opcode Action 0000 Load accumulator (ACC)from memory 0001 Store accumulator in memory 0010 Add the contents of Acc with specified location and leave the result in ACC 1111 stop M/L program Instructions Machine language • Load ACC from Loc 10 • Add ACC with contents of Loc 20 • Store ACC contents in Loc 30 • Stop • 0000 0000 0000 1010 • 0010 0000 0001 1010 • 0001 0000 0001 1110 • 1111 0000 0000 0000 Assembly Language High level Language (pascal, C, C++, Java) • • • • • • • • • Load Add Store Print Stop X Y Z Z Input X, Y Z = X+Y Output Z Stop One assembly instruction is equivalent to machine instruction • • One high level inst corresponds to many machine instruction • All CPUs have an instruction set (or language) that they understand. • Eventually all assembly level / high level programs must be translated (or compiled) into instructions from this set. • Roughly speaking, all processors have the same sort of instructions available to them. • An executable program is machine language program that runs on a CPU and is always represented as a series of binary digits. • This is achieved by compiling (translating) a high-level program with a special piece of software called a compiler. • Compilers are incredibly complicated programs that accept other programs as input and generate a binary executable object file as output. Types of Files • As far as the hard disk is concerned, all files are the same and are named collections of bytes. Of course, what the files are used for is different. • The OS can take a – program file, copy it into main memory, and start it running. – data file, and supply its information to a running program when it asks. • Often then last part of a file's name (the extension) shows what the file is expected to be used for. For example, – "mydata.txt" the ".txt" means that the file is expected to be used as a collection of text, that is, characters. – “netscape.exe" the ".exe" means that the file is an "executable," that is, a program that is ready to run. – "program1.java" the ".java" means that the file is a source program in the language java (there will be more about source programs later on in these notes.) – To the hard disk, each of these files is the same sort of thing: a collection of bytes. Example Problem : Consider the problem of converting F (Fahrenheit) to C (Centigrade) which is suitable for solution by computer. Formula: C = 5 * (F – 32) / 9 • Set of possible high level instructions: Input : F (given parameters) Output: C (output parameters) read F C = 5 * (F – 32 ) / 9 print C end Compiler • A source program is set of instructions written in a high level language.. • It is translated into a machine language program by a system software called compiler. • It takes a source file as input and produces an executable program (machine language program) as output. • The source program is stored in a file created using a text editor. • The source file is kept on the hard disk. • When you have to run your program (Source program), first compile by compiler and form an executable file. • The source file remains unchanged; a new executable file is created. • The executable file is also kept on hard disk. • Compilers are specific to high level languages (like "C") and a specific to processor type (like "Pentium"), and only runs under a specific operating system (like "Windows".) • The above is what goes on with most languages: Ada, Pascal, C, C++, FORTRAN and others. • Java adds a few more steps, which will be discussed later. Interpreter • There are some language which are not compiled but interpreted by interpreter (BASIC, SML, Python …). • An interpreter is a program that acts like a processor that can directly execute a high level language. • This is a fairly complicated thought. The figure might help: • Here the source program "program.bas" has been written in BASIC (a programming language) by a programmer with a text editor. • It is being interpreted by the BASIC interpreter, which is running on the processor. • The BASIC interpreter will read each command in the source program and do what it says. • When an interpreter is running a BASIC source program, both the interpreter and the source program are in main memory. • The interpreter consists of machine instructions that the hardware can execute directly. • Translator: takes a complete document in one language and creates a complete document in another language, which can then be used at any time. • Interpreter: acts as an intermediate between source language and machine language and converts instruction wise.