12 - A simple equational calculator
Published online by Cambridge University Press: 05 November 2014
Summary
This final chapter is devoted to a single programming project, the design and implementation of a simple calculator for carrying out point-free equational proofs. Although the calculator provides only a small subset of the facilities one might want in an automatic proof assistant, and is highly restrictive in a number of other ways, it will nevertheless be powerful enough to prove many of the point-free laws described in previous chapters – well, provided we are prepared to give it a nudge in the right direction if necessary. The project is also a case study in the use of modules. Each component of the calculator, its associated types and functions, is defined in an appropriate module and linked to other modules through explicit import and export lists.
Basic considerations
The basic idea is to construct a single function calculate with type
calculate :: [Law] → Expr → Calculation
The first argument of calculate is a list of laws that may be applied. Each law consists of a descriptive name and an equation. The second argument is an expression and the result is a calculation. A calculation consists of a starting expression and a sequence of steps. Each step consists of the name of a law and the expression that results by applying the left-hand side of the law to the current expression.
- Type
- Chapter
- Information
- Thinking Functionally with Haskell , pp. 298 - 337Publisher: Cambridge University PressPrint publication year: 2014