Affiliation:
1. Chalmers University of Technology, Sweden
2. Harvard University, USA
Abstract
We present a small extension to Haskell called the Key monad. With the Key monad, unique keys of different types can be created and can be tested for equality. When two keys are equal, we also obtain a concrete proof that their types are equal. This gives us a form of dynamic typing, without the need for Typeable constraints. We show that our extension allows us to safely do things we could not otherwise do: it allows us to implement the ST monad (inefficiently), to implement an embedded form of arrow notation, and to translate parametric HOAS to typed de Bruijn indices, among others. Although strongly related to the ST monad, the Key monad is simpler and might be easier to prove safe. We do not provide such a proof of the safety of the Key monad, but we note that, surprisingly, a full proof of the safety of the ST monad also remains elusive to this day. Hence, another reason for studying the Key monad is that a safety proof for it might be a stepping stone towards a safety proof of the ST monad.
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Reference16 articles.
1. Correctness of monadic state
2. Atkey R. (2009). Atkey R. (2009).
3. Unembedding domain-specific languages
4. Parametric higher-order abstract syntax for mechanized semantics
5. Claessen K. (2001). A monad for type casting. Message to the Haskell mailing list https://mail.haskell.org/pipermail/haskell/. Elliott C. (2013). Claessen K. (2001). A monad for type casting. Message to the Haskell mailing list https://mail.haskell.org/pipermail/haskell/. Elliott C. (2013).