Presentation is loading. Please wait.

Presentation is loading. Please wait.

PROCESSING Designing and developing a program. Objectives Understand programming as the process of writing computer instructions that achieve a goal Understand.

Similar presentations


Presentation on theme: "PROCESSING Designing and developing a program. Objectives Understand programming as the process of writing computer instructions that achieve a goal Understand."— Presentation transcript:

1 PROCESSING Designing and developing a program

2 Objectives Understand programming as the process of writing computer instructions that achieve a goal Understand computing as the study of algorithms Be able to state: Properties of algorithms 3 basic control structures Be able to: Write a (simple) algorithm Effectively use a variable in an algorithm Appreciate high level languages

3 Computer Science is no more about computers than astronomy is about telescopes. - attributed to E.W. Dijkstra

4 Computing Computing is not: The study of computers The study of how to write programs The study of computer applications Computing is the study of algorithms, where an algorithm is a procedure that solves a problem using an ordered, unambiguous, finite set of operations.

5 Algorithms Algorithms are powerful constructs used in problem solving. To be computed, they must have the following properties: Finite Ordered Unambiguous

6 6 Operations The operations used in algorithms are primitive tasks that can be executed. Primitive operations are the “basic” operations in the application domain, e.g., basic arithmetic, drawing graphical shapes.

7 Example: Card Sorting Write instructions for sorting cards: 1. The cards start face down on the table 2. The instructions must be for only one person. 3. The person moving the cards can only have one card in each hand at any point (i.e. s/he can only look at the values of two cards) 4. The instructions can't require that the person remember the value of a card once they put it down. You can however use the space on the table however you like. 7

8 8 Control Structures Control structures specify the ordering of the operations in the algorithm. There are three basic control structures: Sequence Selection Repetition

9 9 Sequence A sequence of multiple operations is executed in order. operation 1 operation 2 … operation n operation 1 operation 2 operation n …

10 10 Selection Selective operations are executed conditionally. if condition then set of operations 1 else set of operations 2 condition operations1 T F operations2

11 11 Repetition (conditional version) Some repetitive operations are conditional. Pattern: Repeat while condition set of operations Move on condition operations TF

12 12 Repetition (list version) Repetitive operations are executed iteratively. Some repetitive operations process lists of items. Pattern: Repeat for each list element set of operations on current element Go on to next list element

13 Example: Card Sorting Write instructions for sorting cards: 1. The cards start face down on the table 2. The instructions must be for only one person. 3. The person moving the cards can only have one card in each hand at any point (i.e. s/he can only look at the values of two cards) 4. The instructions can't require that the person remember the value of a card once they put it down. You can however use the space on the table however you like. 13

14 14 Euclid of Alexandria (325-265BC) The Elements Euclid’s Algorithm finds the greatest common divisor of two positive natural numbers, a & b (where a ≥ b). Images from www-groups.dcs.st-andrews.ac.uk & wikipedia.org

15 15 Example: Euclid’s Algorithm Test Cases: GCD(36,16) → 4; GCD(1,1) → 1; GCD(1260,198) → 18 Given: Two positive natural numbers a & b Set remainder = some non-zero value Repeat these steps until remainder = 0 Set remainder = the remainder of a divided by b If remainder = 0 Then Print GCD is b Else Set a = b and b = remainder Go on to the next repetition

16 Programming Programming is the process of writing sets of computer instructions, called programs, to create user experiences. Programs must be written in a language, called a programming language, that: The machine will understand; Has adequate expressive power; The programmer can understand and use productively.

17 17 Programming Languages High-level programming languages (HLLs) are not created equal. Choose an appropriate language for each sort of experience: Small business applications; Enterprise applications; System applications; Data-based applications; Graphic design applications.

18 18 Fredrick P. Brooks (1931- ) The Mythical Man-Month What’s the Big Idea Joys of programming We enjoy designing things because we are created in the image of God. The computer is a powerful and rewarding tool to use. Woes of programming The “mindless” details can be excessively tedious. Products become obsolete too quickly. As the child delights in his mud pie, so the adult enjoys building things, especially things of his own design. I think this delight must be an image of God's delight in making things, a delight shown in the distinctness and newness of each leaf and each snowflake. - F. P. Brooks, Jr. The Mythical Man-Month, 1975 images from: http://www.amazon.com/

19 19 Software Engineering The goal of software engineering is to produce systems that have the following characteristics: - The algorithm and data structures solve the problem correctly and efficiently. - The encoded algorithm is understandable. - The resulting system is usable. Achieving this for large problems requires creativity and ingenuity.

20 20 The Development Life-Cycle Realistic problems tend to be large enough to require the disciplined effort of multiple people, coordinated into phases: Analysis; Design; Implementation; Testing; Maintenance.

21 21 Sequential Development The software development life-cycle is traditionally viewed sequentially. Analysis Implementation Testing Maintenance Design

22 22 Iterative/Incremental Development Agile development tends to use a more iterative and incremental model. Design Testing Implementation Analysis

23 Engineering a Program Programs must be written in a language that the computer “understands”. Virtual Machines Computer hardware Machine language Assembly language High-level language 23

24 Machine Language A computer only understands a specially designed machine language. Machine language statements are: Stored in a computer’s memory, which is a sequence of binary digits (bits – 0 or 1): Retrieved from memory and executed one at a time 24

25 25 An Example (hypothetical) 0001000000000000000001000000000000100100000000 0000000100000000010010001100000000000001000000 0010000100010000000000000100000000110001000000 0000110100010000000000001001000000000000000100 0001100100100011000000000000010000000010000100 010000000010000100000000110001110000000000010...

26 26 A Real Example SPARC executable machine code 000001110111010100000101 000001000110000100000110 000000000000010000000010 000000000000010000000000 000000000000000000000000 000000000000000000000010 000000000000000000000000 000000000000000000000001 000000000000000000000001 000000000011010000110000 000000000000000000000000 000000000000000001100100 000000000000000000000000 000000010011000100100100 000000000000000000000000 000000000000000001100100 000000000000000001000000 000000000000000000000101 000000000000000001010000 000000000000000000110011 000000000000000000110001 000000000000000000000000 000000000000000000000110 000000000000000000000000 000000000000000001100100 000000000000000000000001 000000000000000001100100 000000000000000000000000 000000000000000000000000 000000000000001001000000 000000000000000000000000 000000000000000000000101 000000000000000000000000 000000000000000000000000 000000000000000000000011 000000000000000000000000 000000000000001100100100 000000000000000000000000 000000000000000000000000 000000000000000000100001 … this goes on for another 1600 lines... Intel Pentium executable machine code 000000100111000000010001 000001100100010101000110 000001100010010101010100 000000100001000000010001 000001100111000101010001 000001110001000101100100 000000100111000101010111 000000100001000101000011 000000000101000000010101 000001100001010101000111 000000110001000101000011 000001100001010100110111 000001100110010101010111 000001100100010101100000 000001100010010101010100 000000100111000101000100 000000000110010001110010 000001010111010000010010 000001010111010100110111 000001100111000101000111 000001010111010101100101 000001100111010101000011 000001110000000101010101 000001100110000101010001 000001100010000101000101 000001100001010100110111 000000000110010001110010 000000000100010000010010 000001100010000001010110 000001100011000101000101 000001010111010000010001 000001010111010100110111 000001100000010101010101 000001100111000101010001 000000000100010001110011 000001110001010001010110 000001100110000101000011 000000110001000000010001 000000000100010001110011 000001110010000001010110 000001110000000101110001 000000000100010101000101 000000110001000001100011 000000000100010001110011 000001100010010001010110 000001100010000101010110 000001100011000101000101 000000000101000000010101 000001110010000001010110 000001110100000101000101 000000000110010101100100 000000000100010000010010 … this goes on for another 74 lines...

27 Computer History Early Computers required a programmer to write in machine language: It was easy to make mistakes. The mistakes were hard to find. The resulting program was not portable. As a result, programming in machine language was very difficult. 27

28 Assembly Language To make programming easier, you can: Devise a set of abbreviations corresponding to the machine language instructions. Create a program to translate them into machine language. 0010111010101001 0110101010110101 1010011010111100 MOVx,ACC ADD1,ACC STOACC,y Assembler 28

29 29 The Real Example Intel Pentium assembly language: _main: pushl %ebp movl %esp,%ebp subl $24,%esp call ___main movl $1,-4(%ebp) movl -4(%ebp),%eax addl $2,%eax movl %eax,-8(%ebp) xorl %eax,%eax jmp L2.align 4 L2: movl %ebp,%esp popl %ebp ret SPARC assembly language: main: save%sp, -120, %sp mov1, %o0 st%o0, [%fp-20] ld[%fp-20], %o0 add%o0, 2, %o1 st%o1, [%fp-24] mov0, %i0 b.LL2 nop mov0, %i0 b.LL2 nop.LL2: ret restore

30 30 The Real Example Intel Pentium assembly language: _main: pushl %ebp movl %esp,%ebp subl $24,%esp call ___main movl $1,-4(%ebp) movl -4(%ebp),%eax addl $2,%eax movl %eax,-8(%ebp) xorl %eax,%eax jmp L2.align 4 L2: movl %ebp,%esp popl %ebp ret SPARC assembly language: main: save%sp, -120, %sp mov1, %o0 st%o0, [%fp-20] ld[%fp-20], %o0 add%o0, 2, %o1 st%o1, [%fp-24] mov0, %i0 b.LL2 nop mov0, %i0 b.LL2 nop.LL2: ret restore 000001110111010100000101 000001000110000100000110 000000000000010000000010 000000000000010000000000 000000000000000000000000 000000000000000000000010 000000000000000000000000 000000000000000000000001 000000000000000000000001 000000000011010000110000 000000000000000000000000 000000000000000001100100 000000000000000000000000 000000010011000100100100 000000000000000000000000 000000000000000001100100 000000000000000001000000 000000000000000000000101 000000000000000001010000 000000000000000000110011 000000000000000000110001 000000000000000000000000 000000000000000000000110 000000000000000000000000 000000000000000001100100 000000000000000000000001 000000000000000001100100 000000000000000000000000 000000000000000000000000 000000000000001001000000 000000000000000000000000 000000000000000000000101 000000000000000000000000 000000000000000000000000 000000000000000000000011 000000000000000000000000 000000000000001100100100 000000000000000000000000 000000000000000000000000 000000000000000000100001 000000100111000000010001 000001100100010101000110 000001100010010101010100 000000100001000000010001 000001100111000101010001 000001110001000101100100 000000100111000101010111 000000100001000101000011 000000000101000000010101 000001100001010101000111 000000110001000101000011 000001100001010100110111 000001100110010101010111 000001100100010101100000 000001100010010101010100 000000100111000101000100 000000000110010001110010 000001010111010000010010 000001010111010100110111 000001100111000101000111 000001010111010101100101 000001100111010101000011 000001110000000101010101 000001100110000101010001 000001100010000101000101 000001100001010100110111 000000000110010001110010 000000000100010000010010 000001100010000001010110 000001100011000101000101 000001010111010000010001 000001010111010100110111 000001100000010101010101 000001100111000101010001 000000000100010001110011 000001110001010001010110 000001100110000101000011 000000110001000000010001 000000000100010001110011 000001110010000001010110 000001110000000101110001 000000000100010101000101 000000110001000001100011 000000000100010001110011 000001100010010001010110 000001100010000101010110 000001100011000101000101 000000000101000000010101 000001110010000001010110 000001110100000101000101 000000000110010101100100 000000000100010000010010 Intel Assembler Sun Assembler

31 Computer History The EDSAC (1949) was the first computer credited with using an assembler. Assemblers allowed programmers to use mnemonics: + The programs were much easier to read. + It was much easier to find and fix mistakes. - The programs were still not portable. 31

32 High Level Language To improve on assembly language, you can: Devise a set of instructions modeled on well-understood human formalisms, e.g., Create a program to translate them into machine language: Compiler Interpreter x = 1; y = x+2; 32

33 Compilers A compiler translates an entire program into machine language. 1010110011110101 0000000000010000 0010111010110101 0000000000010010 0010111011111101 0000000000010100 x = 1; y = x+2; Compiler 33

34 34 The Real Example int main() { int x, y; x = 1; y = x + 2; return 0; } 000001110111010100000101 000001000110000100000110 000000000000010000000010 000000000000010000000000 000000000000000000000000 000000000000000000000010 000000000000000000000000 000000000000000000000001 000000000000000000000001 000000000011010000110000 000000000000000000000000 000000000000000001100100 000000000000000000000000 000000010011000100100100 000000000000000000000000 000000000000000001100100 000000000000000001000000 000000000000000000000101 000000000000000001010000 000000000000000000110011 000000000000000000110001 000000000000000000000000 000000000000000000000110 000000000000000000000000 000000000000000001100100 000000000000000000000001 000000000000000001100100 000000000000000000000000 000000000000000000000000 000000000000001001000000 000000000000000000000000 000000000000000000000101 000000000000000000000000 000000000000000000000000 000000000000000000000011 000000000000000000000000 000000000000001100100100 000000000000000000000000 000000000000000000000000 000000000000000000100001 000001110111010100000101 000001000110000100000110 000000000000010000000010 000000000000010000000000 000000000000000000000000 000000000000000000000010 000000000000000000000000 000000000000000000000001 000000000000000000000001 000000000011010000110000 000000000000000000000000 000000000000000001100100 000000000000000000000000 000000010011000100100100 000000000000000000000000 000000000000000001100100 000000000000000001000000 000000000000000000000101 000000000000000001010000 000000000000000000110011 000000000000000000110001 000000000000000000000000 000000000000000000000110 000000000000000000000000 000000000000000001100100 000000000000000000000001 000000000000000001100100 000000000000000000000000 000000000000000000000000 000000000000001001000000 000000000000000000000000 000000000000000000000101 000000100111000000010001 000001100100010101000110 000001100010010101010100 000000100001000000010001 000001100111000101010001 000001110001000101100100 000000100111000101010111 000000100001000101000011 000000000101000000010101 000001100001010101000111 000000110001000101000011 000001100001010100110111 000001100110010101010111 000001100100010101100000 000001100010010101010100 000000100111000101000100 000000000110010001110010 000001010111010000010010 000001010111010100110111 000001100111000101000111 000001010111010101100101 000001100111010101000011 000001110000000101010101 000001100110000101010001 000001100010000101000101 000001100001010100110111 000000000110010001110010 000000000100010000010010 000001100010000001010110 000001100011000101000101 000001010111010000010001 000001010111010100110111 000001100000010101010101 000001100111000101010001 000000000100010001110011 000001110001010001010110 000001100110000101000011 000000110001000000010001 000000000100010001110011 000001110010000001010110 000001110000000101110001 000000000100010101000101 000000110001000001100011 000000000100010001110011 000001100010010001010110 000001100010000101010110 000001100011000101000101 000000000101000000010101 000001110010000001010110 000001110100000101000101 000000000110010101100100 000000000100010000010010 Intel C++ compiler Sun C++ compiler

35 Interpreters An interpreter decodes each individual instruction and then executes it: + development is easier - execution is slower Some languages (e.g., Lisp) allow both interpretation and compilation. helloPRINT “hello” Interpreter 35

36 Compilation + Interpretation Languages can combine compilation and interpretation. Compiler class intro { public static void main (String args[]) { int x, y; x = 1; y = x + 2; return; } Interpreter for UNIX Interpreter for Windows Interpreter for MacOS class intro extends java.lang.Object { intro(); public static void main(java.lang.String[]); } Method intro() 0 aload_0 1 invokespecial #1 4 return Method void main(java.lang.String[]) 0 iconst_1 1 istore_1 2 iload_1 3 iconst_2 4 iadd 5 istore_2 6 return 36


Download ppt "PROCESSING Designing and developing a program. Objectives Understand programming as the process of writing computer instructions that achieve a goal Understand."

Similar presentations


Ads by Google