| | Some definitions of interest. |
|
| hall | Def all == p:'a  .  x:'a. (p(x)) |
| | | Thm* 'a:S. all (('a  hbool)  hbool) |
|
| ball | Def  x:T. P(x) ==  ( x:T. P(x)) |
| | | Thm* T:Type, P:(T  ). ( x:T. P(x))  |
|
| hres_forall | Def res_forall == P:'a  . Q:'a  .  res_all('a;x. (P(x));x. (Q(x))) |
| | | Thm* 'a:S. res_forall (('a  hbool)  ('a  hbool)  hbool) |
|
| assert | Def b == if b True else False fi |
| | | Thm* b: . b Prop |
|
| himplies | Def implies == p: . q: . p  q |
| | | Thm* implies (hbool  hbool  hbool) |
|
| bimplies | Def p  q ==  p  q |
| | | Thm* p,q: . p  q  |
|
| hbool | Def hbool ==  |
| | | Thm* hbool S |
|
| hequal | Def equal == x:'a. y:'a. x = y |
| | | Thm* 'a:S. equal ('a  'a  hbool) |
|
| hfun | Def 'a  'b == 'a 'b |
| | | Thm* 'a,'b:S. ('a  'b) S |
|
| prop_to_bool | Def  P == InjCase(lem(P) ; true ; false ) |
| | | Thm* P:Prop. ( P)  |
|
| res_all | Def res_all('a;x.P(x);x.Q(x)) == x:'a. P(x)  Q(x) |
| | | Thm* 'a:Type, P,Q:('a Prop). res_all('a;x.P(x);x.Q(x)) Prop |
|
| stype | Def S == {T:Type| x:T. True } |
| | | Thm* S Type{2} |
|
| tlambda | Def ( x:T. b(x))(x) == b(x) |