CPL - Chalmers Publication Library
| Utbildning | Forskning | Styrkeområden | Om Chalmers | In English In English Ej inloggad.

Functional Polytypic Programming

Patrik Jansson (Institutionen för datavetenskap)
Göteborg : Chalmers University of Technology, 2000. ISBN: 91-7197-895-X.- 190 s.
[Doktorsavhandling]

Many algorithms have to be implemented over and over again for different datatypes, either because datatypes change during the development of programs, or because the same algorithm is used for several datatypes. Examples of such algorithms are equality tests, pretty printers, and pattern matchers, and polytypic programming is a paradigm for expressing such algorithms. This dissertation introduces polytypic programming for functional programming languages, shows how to construct and prove properties of polytypic algorithms, presents the language extension PolyP for implementing polytypic algorithms in a type safe way, and presents a number of applications of polytypic programming. The applications include a library of basic polytypic building blocks, PolyLib, and two larger applications of polytypic programming: rewriting and data conversion.

PolyP extends a functional language (a subset of Haskell) with a construct for defining polytypic functions by induction on the structure of user-defined datatypes. Programs in the extended language are translated to Haskell.

PolyLib contains powerful structured recursion operators like catamorphisms, maps and traversals, as well as polytypic versions of a number of standard functions from functional programming: sum, length, zip, (==), (<=), etc. Both the specification of the library and a PolyP implementation are presented.

The first larger application is a framework for polytypic programming on terms. We show that an interface of four functions is sufficient to express polytypic functions for pattern matching, unification and term rewriting. Using this framework, a term rewriting function is specified and transformed into an efficient and correct implementation.

In the second application, a number of functions for polytypic data conversion are implemented and proved correct. The conversions considered include pretty printing, parsing, packing and unpacking of structured data. The conversion functions are expressed in an embedded domain specific language for data conversion (a hierarchy of Haskell's constructor classes).

Nyckelord: programming languages, functional programming, algebraic datatypes, polytypic programming, generic programming



Denna post skapades 2006-08-25. Senast ändrad 2014-09-02.
CPL Pubid: 804

 

Läs direkt!

Lokal fulltext (fritt tillgänglig)

Länk till annan sajt (kan kräva inloggning)


Institutioner (Chalmers)

Institutionen för datavetenskap (1993-2001)

Ämnesområden

Information Technology

Chalmers infrastruktur

Examination

Datum: 2000-06-09
Tid: 10:15
Lokal: Hörsalen, Matematiskt Centrum, Eklandagatan 86, Göteborg
Opponent: Professor Mark P Jones

Ingår i serie

Doktorsavhandlingar vid Chalmers tekniska högskola. Ny serie 1584