600 likes | 777 Views
Introduction to Programming in Haskell. Chalmers & GU Emil Axelsson and John Hughes (with thanks to Koen Lindström Claessen ). Programming. Exciting subject at the heart of computing Never programmed? Learn to make the computer obey you! Programmed before?
E N D
Introduction to Programming in Haskell Chalmers & GU Emil Axelsson and John Hughes (with thanks to KoenLindströmClaessen)
Programming Exciting subject at the heart of computing Never programmed? Learn to make the computer obey you! Programmed before? Lucky you! Your knowledge will help a lot... ...as you learn a completely new way to program Everyone will learn a great deal from this course!
Goal of the Course Start from the basics, after Datorintroduktion Learn to write small-to-medium sized programs in Haskell Introduce basic concepts of computer science
The Flow Do not break the flow! You prepare in advance I explain in lecture Tuesdays,Fridays You learn with exercises You put to practice with lab assignments Mondays Submit end of each week
Exercise Sessions Mondays Group rooms Come prepared Work on exercises together Discuss and get help from tutor Personal help Make sure you understand this week’s things before you leave
Lab Assignments Work in pairs (Almost) no exceptions! Lab supervision Book a time in advance One time at a time! Start working on lab when you have understood the matter Submit end of each week Feedback Return: The tutor has something to tell you; fix and submit again OK: You are done bring pen and paper even this week!
Getting Help Weekly group sessions personal help to understand material Lab supervision specific questions about programming assignment at hand Discussion forum general questions, worries, discussions
Assessment Written exam (4.5 credits) Consists of small programming problems to solve on paper You need Haskell ”in your fingers” Course work (3 credits) Complete all labs successfully
A Risk 7 weeks is a short time to learn programming So the course is fast paced Each week we learn a lot Catching up again is hard So do keep up! Read the lecture notes each week Make sure you can solve the problems Go to the weekly exercise sessions From the beginning
Course Homepage The course homepage will have ALL up-to-date information relevant for the course Schedule Lab assignments Exercises Last-minute changes (etc.) Or go via the student portal http://www.cse.chalmers.se/edu/course/TDA555/
Software Software = Programs + Data
Data Data is any kind of storable information. Examples: • Numbers • Letters • Email messages • Songs on a CD • Maps • Video clips • Mouse clicks • Programs
Programs Programs compute new data from old data. Example: Starcraft IIcomputes a sequenceofscreen images and sounds from a sequenceofmouseclicks.
Building Software Systems A large system may contain many millions of lines of code. Software systems are among the most complex artefacts ever made. Systems are built by combining existing components as far as possible. Facebook buys video player from Adobe Volvo buys engines from Mitsubishi.
Programming Languages Programs are written in programming languages. There are hundreds of different programming languages, each with their strengths and weaknesses. A large system will often contain components in many different languages.
Programming Languages which language should we teach? Scheme C Lisp BASIC C++ Haskell Java C# ML Python JavaScript csh Curry Perl O’CaML bash Erlang Ruby Prolog Lustre Mercury PostScript VHDL Esterel PDF SQL Verilog
Programming Language Features dynamically typed pure functions higher-order functions statically typed type inference real-time immutable datastructures polymorphism overloading concurrency high performance distribution parameterized types lazy virtual machine Java reflection type classes object oriented compiler interpreter meta-programming Haskell unification C backtracking
Teaching Programming Give you a broad basis Easy to learn more programming languages Easy to adapt to new programming languages Haskell is defining state-of-the-art in programming language development Appreciate differences between languages Become a better programmer!
”Functional Programming” Functions are the basic building blocks of programs Functions are used to compose these building blocks into larger programs A (pure) function computes results from arguments – consistently the same
Industrial Uses of Functional Languages Intel (microprocessor verification) Hewlett Packard (telecom event correlation) Ericsson (telecommunications) Jeppesen (air-crew scheduling) Facebook (chat engine) Credit Suisse (finance) Barclays Capital (finance) Hafnium (automatic transformation tools) Shop.com (e-commerce) Motorola (test generation) Thompson (radar tracking) Microsoft (F#) Jasper (hardware verification) And many more!
Keynotes at Developer Conferences • Eclipse Summit Europé 2009 • Taking Functional Programming into the Mainstream • YOW! 2011, Australia • Escape From the Ivory Tower: The Haskell Journey • Qcon 2012, San Francisco • Testing the Hard Stuff and Staying Sane Don Syme Simon Peyton Jones John Hughes
Why Haskell? • Haskell is a veryhigh-levellanguage (manydetails taken careofautomatically). • Haskell is expressive and concise (canachieve a lotwith a littleeffort). • Haskell is good at handling complex data and combiningcomponents. • Haskell is not a particularlyhigh-performancelanguage (prioritiseprogrammer-time over computer-time).
Example: The squaring function Example: a function to compute -- sq x returns the square of x sq :: Integer -> Integer sq x = x * x
Evaluating Functions To evaluate sq 5: Use the definition—substitute 5 for x throughout sq 5 = 5 * 5 Continue evaluating expressions sq 5 = 25 Just like working out mathematics on paper sq x = x * x
Example: Absolute Value Find the absolute value of a number -- absolute x returns the absolute value of x absolute :: Integer -> Integer absolute x = undefined
Example: Absolute Value Find the absolute value of a number Two cases! If x is positive, result is x If x is negative, result is -x Programs must often choose between alternatives -- absolute x returns the absolute value of x absolute :: Integer -> Integer absolute x | x > 0 = undefined absolute x | x < 0 = undefined Think of the cases! These are guards
Example: Absolute Value Find the absolute value of a number Two cases! If x is positive, result is x If x is negative, result is -x -- absolute x returns the absolute value of x absolute :: Integer -> Integer absolute x | x > 0 = x absolute x | x < 0 = -x Fill in the result in each case
Example: Absolute Value Find the absolute value of a number Correct the code -- absolute x returns the absolute value of x absolute :: Integer -> Integer absolute x | x >= 0 = x absolute x | x < 0 = -x >= is greater than or equal, ¸
Evaluating Guards Evaluate absolute (-5) We have two equations to use! Substitute absolute (-5) | -5 >= 0 = -5 absolute (-5) | -5 < 0 = -(-5) absolute x | x >= 0 = x absolute x | x < 0 = -x
Evaluating Guards Evaluate absolute (-5) We have two equations to use! Evaluate the guards absolute (-5) | False = -5 absolute (-5) | True = -(-5) Discard this equation Keep this one absolute x | x >= 0 = x absolute x | x < 0 = -x
Evaluating Guards Evaluate absolute (-5) We have two equations to use! Erase the True guard absolute (-5) = -(-5) absolute x | x >= 0 = x absolute x | x < 0 = -x
Evaluating Guards Evaluate absolute (-5) We have two equations to use! Compute the result absolute (-5) = 5 absolute x | x >= 0 = x absolute x | x < 0 = -x
Notation We can abbreviate repeated left hand sides Haskell also has if then else absolute x | x >= 0 = x absolute x | x < 0 = -x absolute x | x >= 0 = x | x < 0 = -x absolute x = if x >= 0 then x else -x
Example: Computing Powers Compute(withoutusingbuilt-in x^n)
Example: Computing Powers Compute(withoutusingbuilt-in x^n) Name the function power
Example: Computing Powers Compute(withoutusingbuilt-in x^n) Name the inputs power x n = undefined
Example: Computing Powers Compute(withoutusingbuilt-in x^n) Write a comment -- power x n returns x to the power n power x n = undefined
Example: Computing Powers Compute(withoutusingbuilt-in x^n) Write a typesignature -- power x n returns x to the power n power :: Integer -> Integer -> Integer power x n = undefined
How to Compute power? We cannot write power x n = x * … * x n times
A Table of Powers Each row is x* the previous one Define power x n to compute the nth row n power x n 0 1 1 x 2 x*x 3 x*x*x
A Definition? Testing: Main> power 2 2 ERROR - stack overflow power x n = x * power x (n-1) Why?
A Definition? Testing: Main> power 2 2 Program error: pattern match failure: power 2 0 power x n | n > 0 = x * power x (n-1)
A Definition? Testing: Main> power 2 2 4 First row of the table power x 0 = 1 power x n | n > 0 = x * power x (n-1) The BASE CASE
Recursion First example of a recursive function Defined in terms of itself! Why does it work? Calculate: power 2 2 = 2 * power 2 1 power 2 1 = 2 * power 2 0 power 2 0 = 1 power x 0 = 1 power x n | n > 0 = x * power x (n-1)
Recursion First example of a recursive function Defined in terms of itself! Why does it work? Calculate: power 2 2 = 2 * power 2 1 power 2 1 = 2 * 1 power 2 0 = 1 power x 0 = 1 power x n | n > 0 = x * power x (n-1)
Recursion First example of a recursive function Defined in terms of itself! Why does it work? Calculate: power 2 2 = 2 * 2 power 2 1 = 2 * 1 power 2 0 = 1 power x 0 = 1 power x n | n > 0 = x * power x (n-1) No circularity!
Recursion First example of a recursive function Defined in terms of itself! Why does it work? Calculate: power 2 2 = 2 * power 2 1 power 2 1 = 2 * power 2 0 power 2 0 = 1 power x 0 = 1 power x n | n > 0 = x * power x (n-1) The STACK
Recursion Reduce a problem (e.g. power x n) to a smaller problem of the same kind So that we eventually reach a ”smallest” base case Solve base case separately Build up solutions from smaller solutions Powerful problem solving strategy in any programming language!