Slide 1

Slide 1 text

Haskell Chris Bentivenga http://sse.se.rit.edu/go/haskell_talk Thursday, December 20, 12

Slide 2

Slide 2 text

Go To: http://sse.se.rit.edu/go/haskell_talk Thursday, December 20, 12

Slide 3

Slide 3 text

What is Haskell? Thursday, December 20, 12

Slide 4

Slide 4 text

Haskell is a computer programming language. In particular, it is a polymorphically statically typed, lazy, purely functional language, quite different from most other programming languages. http://www.haskell.org/haskellwiki/Introduction Thursday, December 20, 12

Slide 5

Slide 5 text

Polymorphically Statically Typed •id :: a -> a •Char -> Char • Int -> Int • Bool -> Bool Thursday, December 20, 12

Slide 6

Slide 6 text

Lazy • Not evaluated when bound • Evaluated when executed • take 5 [1..] • [1,2,3,4,5] Thursday, December 20, 12

Slide 7

Slide 7 text

Purely Functional • Imperative (OO, Procedural): • Execute statements • Change state • Functional: • Evaluate expressions • No state Thursday, December 20, 12

Slide 8

Slide 8 text

Features of Functional Languages • High Order Functions • Purity • Lazy Execution • Recursion Thursday, December 20, 12

Slide 9

Slide 9 text

High Order Functions •filter odd [1,2,3,4,5,6,7] •[1,3,5,7] •filter sq [1,2,3,4,5,6,7] •[2,4] Thursday, December 20, 12

Slide 10

Slide 10 text

Purity • No side effects • Is no state • A function, given the same input will always return the same output • Haskell does have monads • Used to simulate side effects Thursday, December 20, 12

Slide 11

Slide 11 text

Lazy • Not evaluated when bound • Evaluated when executed • take 5 [1..] • [1,2,3,4,5] Already Saw This! Thursday, December 20, 12

Slide 12

Slide 12 text

Recursion • Same as recursion in any other paradigim • One of the few ways to iterate • Is no for loop Thursday, December 20, 12

Slide 13

Slide 13 text

Getting Started in Haskell Thursday, December 20, 12

Slide 14

Slide 14 text

3 Haskell Commands • ghc • Compiler (gcc, g++) • ghci • Interactive (python , irb) • REPL • runghc • Run as interpreted (python <file>, ruby) Thursday, December 20, 12

Slide 15

Slide 15 text

Haskell Basics • Entry point: main function (like C, C++) • Basic output function: print Thursday, December 20, 12

Slide 16

Slide 16 text

Thursday, December 20, 12

Slide 17

Slide 17 text

Thursday, December 20, 12

Slide 18

Slide 18 text

Haskell Functions Thursday, December 20, 12

Slide 19

Slide 19 text

Silly Silly Haskell Notation • $ -- Function Applicator • . -- Function Composition Thursday, December 20, 12

Slide 20

Slide 20 text

Thursday, December 20, 12

Slide 21

Slide 21 text

Currying • Partially fill out the parameters on a function • Creates a new function that expects fewer paramaters Thursday, December 20, 12

Slide 22

Slide 22 text

Thursday, December 20, 12

Slide 23

Slide 23 text

Parameters • Functions technically can’t have more then one parameter • A function with two parameters is technically a function that returns a function that accepts a parameter... Thursday, December 20, 12

Slide 24

Slide 24 text

Thursday, December 20, 12

Slide 25

Slide 25 text

Thursday, December 20, 12

Slide 26

Slide 26 text

Typing System • Strictly typed under the hood • Don’t have to see those types • Can explicitly write out types on a function Thursday, December 20, 12

Slide 27

Slide 27 text

Thursday, December 20, 12

Slide 28

Slide 28 text

/Users/chris/projects/haskell_talk/Types/types.hs:4:10: Couldn't match expected type `Int' with actual type `[Char]' In the first argument of `f', namely `"123"' In the expression: f "123" In an equation for `main': main = f "123" Thursday, December 20, 12

Slide 29

Slide 29 text

Lists • Standard functional data structure • List operations: map, filter, reduce, etc... Thursday, December 20, 12

Slide 30

Slide 30 text

Thursday, December 20, 12

Slide 31

Slide 31 text

Pattern Matching • Function headers have portions already declared • Maps to the most fitting portion Thursday, December 20, 12

Slide 32

Slide 32 text

Thursday, December 20, 12

Slide 33

Slide 33 text

Questions? Thursday, December 20, 12

Slide 34

Slide 34 text

Sources • http://www.haskell.org/haskellwiki/Haskell • http://learnyouahaskell.com Thursday, December 20, 12