2014-11-30 21:16:01 -08:00
|
|
|
prelude constant N : Type.{1}
|
2014-06-15 10:40:18 -07:00
|
|
|
definition B : Type.{1} := Type.{0}
|
2014-10-02 16:20:52 -07:00
|
|
|
constant ite : B → N → N → N
|
|
|
|
constant and : B → B → B
|
|
|
|
constant f : N → N
|
|
|
|
constant p : B
|
|
|
|
constant q : B
|
|
|
|
constant x : N
|
|
|
|
constant y : N
|
|
|
|
constant z : N
|
2014-07-01 16:55:41 -07:00
|
|
|
infixr `∧`:25 := and
|
2014-10-20 18:40:55 -07:00
|
|
|
notation `if` c `then` t:45 `else` e:45 := ite c t e
|
2014-06-15 10:40:18 -07:00
|
|
|
check if p ∧ q then f x else y
|
|
|
|
check if p ∧ q then q else y
|
2014-10-02 16:20:52 -07:00
|
|
|
constant list : Type.{1}
|
|
|
|
constant nil : list
|
|
|
|
constant cons : N → list → list
|
2014-06-15 10:40:18 -07:00
|
|
|
-- Non empty lists
|
|
|
|
notation `[` l:(foldr `,` (h t, cons h t) nil) `]` := l
|
|
|
|
check [x, y, z, x, y, y]
|
|
|
|
check [x]
|
|
|
|
notation `[` `]` := nil
|
|
|
|
check []
|