Lab1 Lab 1: CSG 711: Programming to Structure Karl Lieberherr.

Slides:



Advertisements
Similar presentations
CSC 270 Nov. 22, 2005 Last Day of Scheme Dr. Stephen Bloch
Advertisements

Higher-Order Functions and Loops c. Kathi Fisler,
Containers CMPS Reusable containers Simple data structures in almost all nontrivial programs Examples: vectors, linked lists, stacks, queues, binary.
CSE341: Programming Languages Lecture 2 Functions, Pairs, Lists Dan Grossman Winter 2013.
MATH 224 – Discrete Mathematics
Adapted from Scott, Chapter 6:: Control Flow Programming Language Pragmatics Michael L. Scott.
Programming Paradigms Introduction. 6/15/2005 Copyright 2005, by the authors of these slides, and Ateneo de Manila University. All rights reserved. L1:
Control Structures Any mechanism that departs from straight-line execution: –Selection: if-statements –Multiway-selection: case statements –Unbounded iteration:
Recursion Ellen Walker CPSC 201 Data Structures Hiram College.
© Janice Regan, CMPT 102, Sept CMPT 102 Introduction to Scientific Computer Programming The software development method algorithms.
Chapter 2: Algorithm Discovery and Design
© 2006 Pearson Addison-Wesley. All rights reserved4-1 Chapter 4 Data Abstraction: The Walls.
CS 201 Functions Debzani Deb.
Main task -write me a program
Chapter 2: Algorithm Discovery and Design
Chapter 2: Algorithm Discovery and Design
Facts about Square Roots. Facts about square roots.
Objects What are Objects Observations
Lab1 Lab 1: CSG 711: Programming to Structure Karl Lieberherr.
Introduction to Programming Lecture Number:. What is Programming Programming is to instruct the computer on what it has to do in a language that the computer.
A Review of Recursion Dr. Jicheng Fu Department of Computer Science University of Central Oklahoma.
Created by, Author Name, School Name—State FLUENCY WITH INFORMATION TECNOLOGY Skills, Concepts, and Capabilities.
Stacks & Recursion. Stack pushpop LIFO list - only top element is visible top.
6 Dec 2001Kestrel1 Teaching with Patterns Matthias Felleisen Daniel Jackson.
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science, C++ Version, Third Edition.
Invitation to Computer Science, Java Version, Second Edition.
Programming Paradigms Procedural Functional Logic Object-Oriented.
DEPARTMENT OF COMPUTER SCIENCE & TECHNOLOGY FACULTY OF SCIENCE & TECHNOLOGY UNIVERSITY OF UWA WELLASSA 1 CST 221 OBJECT ORIENTED PROGRAMMING(OOP) ( 2 CREDITS.
The Design Recipe using Classes CS 5010 Program Design Paradigms "Bootcamp" Lesson 10.5 © Mitchell Wand, This work is licensed under a Creative.
Overloading Binary Operators Two ways to overload –As a member function of a class –As a friend function As member functions –General syntax Data Structures.
TeachScheme, ReachJava Adelphi University Wednesday morning June 24, 2008.
Programming Languages by Ravi Sethi Chapter 6: Groupings of Data and Operations.
Design Patterns Gang Qian Department of Computer Science University of Central Oklahoma.
C++ Programming Basic Learning Prepared By The Smartpath Information systems
Telecooperation/RBG Technische Universität Darmstadt Copyrighted material; for TUD student use only Introduction to Computer Science I Topic 8: Accumulating.
C. Varela; Adapted w. permission from S. Haridi and P. Van Roy1 Functional Programming: Lists, Pattern Matching, Recursive Programming (CTM Sections ,
ICOM 4035 – Data Structures Dr. Manuel Rodríguez Martínez Electrical and Computer Engineering Department.
Curry A Tasty dish? Haskell Curry!. Curried Functions Currying is a functional programming technique that takes a function of N arguments and produces.
Cs1321 December 6, 2001 Review. What is computer science? What's an algorithm? Processes and programs Overview of some programming language concepts Functional.
Principles of programming languages 10: Object oriented languages Isao Sasano Department of Information Science and Engineering.
Types and Programming Languages Lecture 11 Simon Gay Department of Computing Science University of Glasgow 2006/07.
Error Example - 65/4; ! Toplevel input: ! 65/4; ! ^^ ! Type clash: expression of type ! int ! cannot have type ! real.
Lab 11 Lab 1: CSG 711: Programming to Structure Karl Lieberherr.
Object-Oriented Design Concepts University of Sunderland.
CMPSC 16 Problem Solving with Computers I Spring 2014 Instructor: Tevfik Bultan Lecture 4: Introduction to C: Control Flow.
A Recipe for Algorithm Design Or, What to do when the data type doesn't match the function…yet.
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science.
Operational Semantics Mooly Sagiv Reference: Semantics with Applications Chapter 2 H. Nielson and F. Nielson
Java and C# - Some Commonalities Compile into machine-independent, language- independent code which runs in a managed execution environment Garbage Collection.
Principles of programming languages 10: Object oriented languages
Programming what is C++
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Dan Grossman Spring 2017.
Functional Programming
Class 11: Two-argument recursion
Object-Oriented Software Engineering Using UML, Patterns, and Java,
Interface Java 7 COMP T1.
Programming Languages Dan Grossman 2013
CS 326 Programming Languages, Concepts and Implementation
CS 5010 Program Design Paradigms “Bootcamp” Lesson 5.3
Expanded Recursive Diagrams OCAML rapid tour, day 2
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Dan Grossman Autumn 2018.
Functional Programming
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Zach Tatlock Winter 2018.
Programming We have seen various examples of programming languages
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Dan Grossman Spring 2016.
Let's Play "What's the Question"
Announcements Quiz 5 HW6 due October 23
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Dan Grossman Autumn 2017.
CSE341: Programming Languages Lecture 17 Implementing Languages Including Closures Dan Grossman Spring 2019.
Presentation transcript:

Lab1 Lab 1: CSG 711: Programming to Structure Karl Lieberherr

Lab2 Using Dr. Scheme context-sensitive help use F1 as your mouse is on an identifier. HelpDesk is language sensitive. Be patient. try the stepper develop programs incrementally definition and use: Check Syntax use 299 / intermediate with lambda

Lab3 General Recipe Write down the requirements for a function in a suitable mathematical notation. Structural design recipe: page 368/369 HtDP

Lab4 Designing Algorithms Data analysis and design Contract, purpose header Function examples Template Definition –what is a trivially solvable problem? –what is a corresponding solution? –how do we generate new problems –need to combine solutions of subproblems Test

Lab5 Template (define (generative-rec-fun problem) (cond [(trivially-solvable? problem) (determine-solution problem)] [else (combine-solutions … problem … (generative-rec-fun (gen-pr-1 problem)) … (generative-rec-fun (gen-pr-n problem)))]))

Lab6 Template for list-processing (define (generative-rec-fun problem) (cond [(empty? problem) (determine-solution problem)] [else (combine-solutions problem (generative-rec-fun (rest problem)))]))

Lab7 History (Programming to Structure) Frege: Begriffsschrift 1879: “The meaning of a phrase is a function of the meanings of its immediate constituents.” Example: AppleList : Mycons | Myempty. Mycons = Apple AppleList. Apple = int. Myempty =.

Lab8 Meaning of a list of apples? Total weight (tWeight al) –[(Myempty? al) 0] –[(Mycons? al) (Apple-weight(Mycons-first al)) // meaning of first constituent + (tWeight(Mycons-rest al))] // meaning of rest constituent AppleList : Mycons | Myempty. Mycons = Apple AppleList. Apple = int. Myempty =. PL independent AppleList Mycons Myempty Apple int rest first weight

Lab9 In Scheme: Structure (define-struct Mycons (first rest)) (define-struct Apple (weight)) (define-struct Myempty ())

Lab10 Design Information AppleList : Mycons | Myempty. Mycons = Apple AppleList. Apple = int. Myempty =. AppleList Mycons Myempty Apple int rest first weight Scheme solution Mycons Myempty Apple int rest first weight (define-struct Mycons (first rest)) (define-struct Apple (weight)) (define-struct Myempty ())

Lab11 In Scheme: Behavior (define (tWeight al) (cond [(Myempty? al) 0] [(Mycons? al) (+ (Apple-weight (Mycons-first al)) (tWeight (Mycons-rest al)))]))

Lab12 In Scheme: Testing (define list1 (make-Mycons (make-Apple 111) (make-Myempty))) (tWeight list1) 111 (define list2 (make-Mycons (make-Apple 50) list1)) (tWeight list1) 161 Note: A test should return a Boolean value. See tutorial by Alex Friedman on testing in Dr. Scheme.

Lab13 Reflection on Scheme solution Program follows structure Design translated somewhat elegantly into program. Dynamic programming language style. But the solution has problems!

Lab14 Behavior While the purpose of this lab is programming to structure, the Scheme solution uses too much structure! (define (tWeight al) (cond [(Myempty? al) 0] [(Mycons? al) (+ (Apple-weight (Mycons-first al)) (tWeight (Mycons-rest al)))])) duplicates all of it!

Lab15 How can we reduce the duplication of structure? First small step: Express all of structure in programming language once. Eliminate conditional! Implementation of tWeight() has a method for Mycons and Myempty. Extensible by addition not modification. Big win of OO.

Lab16 Solution in Java AppleList: abstract int tWeight(); Mycons: int tWeight() { return (first.tWeight() + rest.tWeight()); } Myempty: int tWeight() {return 0;} AppleList : Mycons | Myempty. Mycons = Apple AppleList. Apple = int. Myempty =. + translated to Java

Lab17 What is better? structure-shyness has improved. No longer enumerate alternatives in functions. Better follow principle of single point of control (of structure).

Lab18 Problem to think about (while you do hw 1) Consider the following two Shape definitions. –in the first, a combination consists of exactly two shapes. –in the other, a combination consists of zero or more shapes. Is it possible to write a program that works correctly for both shape definitions?

Lab19 First Shape Shape : Rectangle | Circle | Combination. Rectangle = "rectangle" int int int int. Circle = "circle" int int int. Combination = "(" Shape Shape ")".

Lab20 Second Shape Shape : Rectangle | Circle | Combination. Rectangle = "rectangle" int int int int. Circle = "circle" int int int. Combination = "(" List(Shape) ")". List(S) ~ {S}.

Lab21 Input (for both Shapes) ( rectangle ( circle rectangle )

Lab22 Think of a shape as a list! A shape is a list of rectangles and circles. Visit the elements of the list to solve the area, inside and bounding box problems.

Lab23 Help with the at function Design the function at. It consumes a set S and a relation R. Its purpose is to collect all the seconds from all tuples in R whose first is a member of S.

Lab24 Deriving Scheme solution (1) at: s: Set r: Relation Set s0 = {}; from r:Relation to p:Pair: if (p.first in s) s0.add(p.second); return s0; at: s: Set r: Relation if empty(r) return empty set else { Set s0 = {}; p1 := r.first(); if (p1.first in s) s0.add(p1.second); return union(s0, at(s, rest(r))} definition decompose based on structure of a relation: either it is empty or has a first element

Lab25 Deriving Scheme solution (2) at: s: Set r: Relation Set s0 = {}; from r:Relation to p:Pair: if (p.first in s) s0.add(p.second); return s0; at: s: Set r: Relation if empty(r) return empty set else { p1 := r.first(); rst = at(s, rest(r)); if (p1.first in s) return rst.add(p1.second) else rst} definition decompose based on structure of a relation: either it is empty or has a first element Why not implement this definition directly using iteration ???

Lab26 Close to final solution ;; at : Symbol Relation -> Set (define (at s R) (cond [(empty? R) empty-set] [else (local ((define p1 (first R)) (define rst (at s (rest R)))) (if (element-of (first p1) s) (add-element (second p1) rst) rst))])) at: s: Set r: Relation if empty(r) return empty set else { p1 := r.first(); rst = at(s, rest(r)); if (p1.first in s) return rst.add(p.second) else rst}

Lab27 dot example Compute the composition of two relations. r and s are relations. r.s (dot r s) is the relation t such that x t z holds iff there exists a y so that x r y and y s z.

Lab28 Why not implement iterative solution? dot Relation r1, r2 Relation r0 = {}; from r1: Relation to p1: Pair from r2: Relation to p2: Pair if (= p1.second p2.first) r0.add( new Pair(p1.first,p2.second)); return r0; if empty(r1) return empty-set else ;; there must be a first element p11 in r1 Relation r0 = empty-set; from r2: Relation to p2: Pair if (= p11.second p2.first) r0.add(new Pair(p11.first,p2.second)); return union (r0, dot((rest r1),r2));

Lab29 Save for later

Lab30 Abstractions abstraction through parameterization: – planned modification points aspect-oriented abstractions: –unplanned extension points

Lab31 Structure The Scheme program has lost information that was available at design time. –The first line is missing in structure definition. –Scheme allows us to put anything into the fields. AppleList : Mycons | Myempty. Mycons = Apple AppleList. Apple = int. Myempty =.

Lab32 Information can be expressed in Scheme Dynamic tests Using object system