An implementation of spartan type theory
This repository shows how to implement a minimalist type theory of the kind that is called "spartan" by some people. The implementation was presented at the School and Workshop on Univalent Mathematics which took place at the University of Birmingham in December 2017.
The type theory
The dependent type theory spartan
has the following ingridients:
- A universe
Type
withType : Type
. - Dependent products written as
forall (x : T₁), T₂
or∀ (x : T₁), T₂
or∏ (x : T₁), T₂
. - Functions written as
fun (x : T) => e
orλ (x : T) ⇒ e
. The typing annotation may be omitted. - Application written as
e₁ e₂
. - Type ascription written as
e : T
.
Top-level commands:
Definition x := e.
-- define a valueAxiom x : T.
-- assume a constantx
of typeT
Check e.
-- print the type ofe
Eval e.
-- evaluatee
a la call-by-valueLoad "⟨file⟩".
-- load a file
Prerequisites
-
The OPAM packages
dune
,menhir
,mehirLib
andsedlex
:opam install dune menhir menihirLib sedlex
-
It is recommended that you also install the
rlwrap
orledit
command line wrapper.
Compilation
You can type:
dune build
to compile thespartan.exe
executable.dune clean
to clean up.
Usage
Once you compile the program, you can run it in interactive mode as ./spartan.exe
Run ./spartan.exe --help
to see the command-line options and general usage.
Source code
The purpose of the implementation is to keep the source uncomplicated and short. The essential bits of source code can be found in the following files. It should be possible for you to just read the entire source code. You should start with the core:
syntax.ml
-- abstract syntax of the inputcontext.ml
-- contextsequal.ml
-- normalizationtypecheck.ml
-- type checking and conversion from abstract syntax to core type theoryTT.ml
-- the core type theory
and continue with the infrastructure
spartan.ml
-- interactive top levelprint.ml
-- printing and message supportdesugar.ml
-- conversion from parsed syntax to abstract syntaxlexer.ml
andparser.mly
-- parsing into concrete syntax
What experiments should I perform to learn more?
There are many things you can try, for example try adding dependent sums, or basic types
unit
, bool
and nat
.