Technical Aspects of the Haskell Language

 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
equational (or conditional-equational) substitution is vital to formal methods

Control bar


















































 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
bullet Based on lambda calculus and combinators
these theories of pure functions inspire higher-order functions and lazy evaluation

Control bar


















































 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
bullet Based on lambda calculus and combinators
bullet Data structure definitions are (roughly) initial algebras
they also look like context-free grammars, thus encouraging embedded languages

Control bar


















































 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
bullet Based on lambda calculus and combinators
bullet Data structure definitions are (roughly) initial algebras
bullet Strong, static type system provides security and flexibility
Hindley-Milner polymorphism allows convenient inference of types

Control bar


















































 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
bullet Based on lambda calculus and combinators
bullet Data structure definitions are (roughly) initial algebras
bullet Strong, static type system provides security and flexibility
bullet Type classes provide for representation independence and data abstraction
we can capture the abstract essence of a component without requiring a specific implementation

Control bar


















































 

Functional Programming in Haskell
Willamette Mathematics Colloquium • Fall 2002

Technical Aspects of the Haskell Language
bullet Programs are sets of equational definitions
bullet Based on lambda calculus and combinators
bullet Data structure definitions are (roughly) initial algebras
bullet Strong, static type system provides security and flexibility
bullet Type classes provide for representation independence and data abstraction
bullet Types as high-level sketches of structure
Haskell increasingly supports type-level features, encouraging high-level "programming-in-the-large"

Control bar