Polymorphic Type Checking and Monadic Evaluation

Requires a Wolfram Notebook System

Interact on desktop, mobile and cloud with the free Wolfram CDF Player or other Wolfram Language products.

Requires a Wolfram Notebook System

Edit on desktop, mobile and cloud with any Wolfram Language product.

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.



Feedback (field required)
Email (field required) Name
Occupation Organization
Note: Your message & contact information may be shared with the author of any specific Demonstration for which you give feedback.
Send