sequent_valid |
Def |= S == a:Full(S). a |= S
Thm* S:Sequent. |= S Type
|
full_sequent_assignment |
Def Full(S) == {a:Assignment| a |= S a | S }
Thm* S:Sequent. Full(S) Type
|
Assignment |
Def Assignment == Var  
Thm* Assignment Type
|
sequent_falsifiable |
Def a | S == F S.H.a |= F & F S.C.a | F
Thm* a:Assignment, S:Sequent. a | S Type
|
sequent_rank |
Def (S) == (S.H)+ (S.C)
Thm* Sequent  
|
sequent_satisfiable |
Def a |= S == F S.H.a | F F S.C.a |= F
Thm* a:Assignment, S:Sequent. a |= S Type
|
C |
Def s.C == s.2
Thm* s:Sequent. s.C Formula List
|
Sequent |
Def Sequent == (Formula List) (Formula List)
Thm* Sequent Type
|
Formula |
Def Formula
== rec(formula.Var+formula+(formula formula)+(formula formula)+(formula formula))
Thm* Formula Type
|
H |
Def s.H == s.1
Thm* s:Sequent. s.H Formula List
|
discrete_equality |
Def {T= } == {eq:(T T  )| x,y:T. (eq(x,y))  x = y }
Thm* T:Type. {T= } Type
|
disjoint |
Def disjoint(eq;L1;L2) == x L1.  x( eq) L2
Thm* T:Type, eq:(T T  ), L1,L2:T List. disjoint(eq;L1;L2) Type
|
list_all |
Def x L.P(x)
== (letrec list_all L = (Case of L; nil True ; h.t P(h) & list_all(t)) ) (L)
Thm* T:Type, P:(T Prop), L:T List. x L.P(x) Type
Thm* T:Type, P:(T Type). x nil.P(x) Type
|
list_exists |
Def x L.P(x)
== (letrec list_exists L = (Case of L; nil False ; h.t P(h) list_exists(t)) ) (L)
Thm* T:Type, P:(T Prop), L:T List. x L.P(x) Type
|
formula_falsifiable |
Def a | F == (F under a) = 3
Thm* a:Assignment, F:Formula. a | F Type
|
formula_sat |
Def a |= F == (F under a) = 3
Thm* a:Assignment, F:Formula. a |= F Type
|
Three |
Def  == Unit+Unit+Unit
Thm*  Type
|
Var |
Def Var == Atom
Thm* Var Type
|
assert |
Def b == if b True else False fi
Thm* b: . b Prop
|
iff |
Def P  Q == (P  Q) & (P  Q)
Thm* A,B:Prop. (A  B) Prop
|
is_member |
Def x( eq) L
== (letrec is_member x eq L = (Case of L
nil false
h.t if eq(x,h) true else is_member(x,eq,t) fi) )
(x
,eq
,L)
Thm* T:Type, eq:(T T  ), u:T. u( eq) nil
Thm* T:Type, eq:(T T  ), x:T, L:T List. x( eq) L 
|
bnot |
Def  b == if b false else true fi
Thm* b: .  b 
|
list_rank |
Def (L) == reduce( x,y. (x)+y;0;L)
Thm* (Formula List)  
|
valuation |
Def (F under a)
== (letrec val f = case f:
x (a(x));
  p  val(p);
p  q val(p)  val(q);
p  q val(p)  val(q);
p   q val(p)   val(q); )
(F)
Thm* a:Assignment, F:Formula. (F under a)  
|
formula_rank |
Def
== (letrec formula_rank f = case f:
x 0;
  p (formula_rank(p)+1);
p  q (formula_rank(p)+formula_rank(q)+1);
p  q (formula_rank(p)+formula_rank(q)+1);
p   q (formula_rank(p)+formula_rank(q)+1); )
Thm* Formula  
|
letrec_body |
Def = b == b
|
letrec_arg |
Def x b(x) (x) == b(x)
|
letrec |
Def (letrec f b(f)) == b((letrec f b(f)) ) (recursive)
|
rev_implies |
Def P  Q == Q  P
Thm* A,B:Prop. (A  B) Prop
|
K_and |
Def p  q == case p: 3 3 ; 3 case q: 3 3 ; 3 3 ; 3 3 ;; 3 q;
Thm* p,q: . p  q  
|
K_not |
Def  p == case p: 3 3 ; 3 3 ; 3 3 ;
Thm* p: .  p  
|
Three_0 |
Def 3 == inl( )
Thm* 3  
|
K_imp |
Def p   q == case p: 3 3 ; 3 case q: 3 3 ; 3 3 ; 3 3 ;; 3 q;
Thm* p,q: . p   q  
|
K_or |
Def p  q == case p: 3 q; 3 case q: 3 3 ; 3 3 ; 3 3 ;; 3 3 ;
Thm* p,q: . p  q  
|
Three_2 |
Def 3 == inr(inr( ))
Thm* 3  
|
reduce |
Def reduce(f;k;as) == Case of as; nil k ; a.as' f(a,reduce(f;k;as')) (recursive)
Thm* A,B:Type, f:(A B B), k:B, as:A List. reduce(f;k;as) B
|
formula_case |
Def case F:
x varC(x);
  p1 notC(p1);
p2  p3 andC(p2;p3);
p4  p5 orC(p4;p5);
p6   p7 impC(p6;p7);
== InjCase(F; x. varC(x); F.
InjCase(F; p1. notC(p1); F.
InjCase(F; x. x/p2,p3.andC(p2;p3); F. InjCase(F; x. x/p4,p5.orC(p4;p5), x/p6,p7.impC(p6;p7)))))
|
Three_1 |
Def 3 == inr(inl( ))
Thm* 3  
|
Three_case |
Def case x: 3 case0; 3 case1; 3 case2;
== InjCase(x; zero. case0; one_or_two. InjCase(one_or_two; one. case1; two. case2))
Thm* t:Type{i}, t':Type{j}, t'':Type{k}, c:t, c':t', c'':t''.
case 3 : 3 c; 3 c'; 3 c''; t
Thm* t:Type{i}, t':Type{j}, t'':Type{k}, c:t, c':t', c'':t''.
case 3 : 3 c'; 3 c''; 3 c; t''
Thm* t:Type{i}, t':Type{j}, t'':Type{k}, c:t, c':t', c'':t''.
case 3 : 3 c; 3 c'; 3 c''; t''
|