Hi! I’m Michael Arntzenius, or “rntz” online. I study, design, and implement programming languages. My PhD dissertation was Datafun, a functional query language. After my PhD I worked at RelationalAI on incremental view maintenance. I’m now a postdoc at UC Berkeley working with Max Willsey.
You can email me (qnrxunery@tznvy.pbz, encoded rot13) or find me on Twitter, Mastodon, or bsky. I’m rntz on GitHub, Goodreads, and Keybase. I have a Twitch but never use it.
| Aug 2024 | Cafés of Cambridge My favorite places to work. | 
| Jan 2019 syntax types | Simple, generic, type-safe substitution in Agda How to avoid needing a new case for every typing rule. | 
| Jan 2019 syntax types | Representing binding in Agda using functions as contexts A simple technique for implementing type-safe substitution. | 
| Jul 2018 | Could an archaeologist grok an iPhone? | 
| Jul 2018 syntax | Parsing list comprehensions is hard ... because it’s hard to tell patterns & expressions apart. | 
| May 2018 haskell | Why I am not a fan of Cabal or Stack Their UI sucks, their docs suck, and they can’t uninstall. | 
| Mar 2018 | Against software development A techno-pessimist “manifesto”, god help me. | 
| Jan 2018 books | Ursula Le Guin is dead She’s survived by many great women writers; here are a few. | 
| Oct 2017 math | Semilattices and their tensor products On distributed computing, databases and dictionaries. | 
| Jan 2017 pl | Aphorisms on programming language design Every decision that matters is a tradeoff. | 
| Jun 2016 lisp pl syntax | Not everything is an expression Lisp macros add new expression forms. What about patterns? | 
| Jul 2014 pl types | Option and null in dynamic languages To use  | 
| Jun 2014 pl syntax | Monoids, scope, and extensibility Can monoids be a basis for scoped syntactic extensibility? | 
| Jun 2014 pl types | On dynamic and static types Type theory is useful even in dynamic languages. | 
| Nov 2011 logic | Belief is indexed by proof system “Belief” in intuitionistic or classical logic need not be exclusive. | 
| Mar 2009 arc pl syntax | Intuitive hygienic macros Hygiene is lexical scoping for macros; to implement it, I use syntactic closures. | 
| Feb 2009 pl types | An odd type inference problem Recursion + polymorphism + type inference = complicated. | 
| Jan 2009 haskell pl | Languages as models of computation ... and monads as tool for model-changing. | 
| Aug 2008 objects pl types | OO and pattern-matching Classes are types are predicates are patterns. Dynamic dispatch is pattern-matching, ordered by specificity. |