Polymorphic Type Checking and Monadic Evaluation

Requires a Wolfram Notebook System
Interact on desktop, mobile and cloud with the free Wolfram Player or other Wolfram Language products.
This Demonstration implements an extremely primitive type system in Mathematica. All functions applications are type checked at every stage of evaluation, guaranteeing that any type variables are replaced with new concrete referents and that no evaluation takes place if the types do not match up. Any type of kind * can be supported, as can a select few types of kind * -> * (lists specifically, though that is not shown here). Types are stored in the heads of data, and in order to avoid boilerplate, functions are written monadically. There are also facilities for translating terms (written in the ugly style of the input lines) into strings (the output lines), alongside their type signatures.
Contributed by: Jack Gallagher (July 2015)
(Mathematica Summer Camp 2014)
Open content licensed under CC BY-NC-SA
Snapshots
Details
Reference
[1] D. MacQueen. "Types and Type Checking". (Apr 4, 2000) www.smlnj.org/doc/Conversion/types.html.
Permanent Citation