:: Algebra of Normal Forms Is a Heyting Algebra
:: by Andrzej Trybulec
:: 
:: Received January 3, 1991
:: Copyright (c) 1991 Association of Mizar Users
theorem Th1: :: HEYTING1:1
:: deftheorem    defines c= HEYTING1:def 1 : 
:: deftheorem Def2   defines [ HEYTING1:def 2 : 
theorem :: HEYTING1:2
canceled; 
theorem :: HEYTING1:3
:: deftheorem    defines @ HEYTING1:def 3 : 
theorem :: HEYTING1:4
canceled; 
theorem :: HEYTING1:5
canceled; 
theorem :: HEYTING1:6
canceled; 
theorem Th7: :: HEYTING1:7
theorem Th8: :: HEYTING1:8
theorem :: HEYTING1:9
canceled; 
theorem Th10: :: HEYTING1:10
:: deftheorem Def4   defines Atom HEYTING1:def 4 : 
theorem Th11: :: HEYTING1:11
theorem Th12: :: HEYTING1:12
theorem :: HEYTING1:13
theorem Th14: :: HEYTING1:14
theorem Th15: :: HEYTING1:15
Lm2: 
for A being   set 
 for u, v being  Element of (NormForm A)  st u [= v holds 
for x being   Element of [:(Fin A),(Fin A):]  st x in u holds 
 ex b being   Element of  DISJOINT_PAIRS A st 
( b in v & b c= x )
 
Lm3: 
for A being   set 
 for u, v being  Element of (NormForm A)  st ( for a being   Element of  DISJOINT_PAIRS A  st a in u holds 
 ex b being   Element of  DISJOINT_PAIRS A st 
( b in v & b c= a ) ) holds 
u [= v
 
definition
let A be    
set ;
func  pair_diff A ->   BinOp of 
[:(Fin A),(Fin A):] means :
Def5: 
:: HEYTING1:def 5
for 
a, 
b being   
Element of 
[:(Fin A),(Fin A):] holds  
it . a,
b = a \ b;
existence 
 ex b1 being  BinOp of [:(Fin A),(Fin A):] st 
for a, b being   Element of [:(Fin A),(Fin A):] holds  b1 . a,b = a \ b
 
correctness 
uniqueness 
for b1, b2 being  BinOp of [:(Fin A),(Fin A):]  st ( for a, b being   Element of [:(Fin A),(Fin A):] holds  b1 . a,b = a \ b ) & ( for a, b being   Element of [:(Fin A),(Fin A):] holds  b2 . a,b = a \ b ) holds 
b1 = b2;
 
end;
 
:: deftheorem Def5   defines pair_diff HEYTING1:def 5 : 
definition
let A be    
set ;
let B be    
Element of  
Fin (DISJOINT_PAIRS A);
func  - B ->    Element of  
Fin (DISJOINT_PAIRS A) equals :: HEYTING1:def 6
(DISJOINT_PAIRS A) /\ { [{ (g . t1) where t1 is    Element of  DISJOINT_PAIRS A : ( g . t1 in t1 `2  & t1 in B ) } ,{ (g . t2) where t2 is    Element of  DISJOINT_PAIRS A : ( g . t2 in t2 `1  & t2 in B ) } ] where g is    Element of  Funcs (DISJOINT_PAIRS A),[A] : for s being   Element of  DISJOINT_PAIRS A  st s in B holds 
g . s in (s `1 ) \/ (s `2 ) } ;
coherence 
(DISJOINT_PAIRS A) /\ { [{ (g . t1) where t1 is    Element of  DISJOINT_PAIRS A : ( g . t1 in t1 `2  & t1 in B ) } ,{ (g . t2) where t2 is    Element of  DISJOINT_PAIRS A : ( g . t2 in t2 `1  & t2 in B ) } ] where g is    Element of  Funcs (DISJOINT_PAIRS A),[A] : for s being   Element of  DISJOINT_PAIRS A  st s in B holds 
g . s in (s `1 ) \/ (s `2 ) }  is    Element of  Fin (DISJOINT_PAIRS A)
 
correctness 
;
let C be    
Element of  
Fin (DISJOINT_PAIRS A);
func B =>> C ->    Element of  
Fin (DISJOINT_PAIRS A) equals :: HEYTING1:def 7
(DISJOINT_PAIRS A) /\ { (FinPairUnion B,((pair_diff A) .: f,(incl (DISJOINT_PAIRS A)))) where f is    Element of  Funcs (DISJOINT_PAIRS A),[:(Fin A),(Fin A):] : f .: B c= C } ;
coherence 
(DISJOINT_PAIRS A) /\ { (FinPairUnion B,((pair_diff A) .: f,(incl (DISJOINT_PAIRS A)))) where f is    Element of  Funcs (DISJOINT_PAIRS A),[:(Fin A),(Fin A):] : f .: B c= C }  is    Element of  Fin (DISJOINT_PAIRS A)
 
correctness 
;
 
end;
 
:: deftheorem    defines - HEYTING1:def 6 : 
:: deftheorem    defines =>> HEYTING1:def 7 : 
theorem Th16: :: HEYTING1:16
theorem Th17: :: HEYTING1:17
theorem Th18: :: HEYTING1:18
theorem Th19: :: HEYTING1:19
theorem Th20: :: HEYTING1:20
theorem Th21: :: HEYTING1:21
Lm4: 
 Fin (DISJOINT_PAIRS {} ) = {{} ,{[{} ,{} ]}}
 
theorem Th22: :: HEYTING1:22
theorem Th23: :: HEYTING1:23
theorem Th24: :: HEYTING1:24
Lm5: 
now 
let A be    
set ; 
::  thesis:  for K being   Element of  Normal_forms_on A
 for b being   Element of  DISJOINT_PAIRS A
 for f being   Element of  Funcs (DISJOINT_PAIRS A),[:(Fin A),(Fin A):] holds  ((pair_diff A) .: f,(incl (DISJOINT_PAIRS A))) . b = (f . b) \ blet K be    
Element of  
Normal_forms_on A; 
::  thesis:  for b being   Element of  DISJOINT_PAIRS A
 for f being   Element of  Funcs (DISJOINT_PAIRS A),[:(Fin A),(Fin A):] holds  ((pair_diff A) .: f,(incl (DISJOINT_PAIRS A))) . b = (f . b) \ blet b be    
Element of  
DISJOINT_PAIRS A; 
::  thesis:  for f being   Element of  Funcs (DISJOINT_PAIRS A),[:(Fin A),(Fin A):] holds  ((pair_diff A) .: f,(incl (DISJOINT_PAIRS A))) . b = (f . b) \ blet f be    
Element of  
Funcs (DISJOINT_PAIRS A),
[:(Fin A),(Fin A):]; 
::  thesis:  ((pair_diff A) .: f,(incl (DISJOINT_PAIRS A))) . b = (f . b) \ bthus ((pair_diff A) .: f,(incl (DISJOINT_PAIRS A))) . b = 
(pair_diff A) . (f . b),
((incl (DISJOINT_PAIRS A)) . b)
by FUNCOP_1:48
.= 
(pair_diff A) . (f . b),
b
by FUNCT_1:35
.= 
(f . b) \ b
by Def5
; 
::  thesis:  verum
 
end;
 
theorem Th25: :: HEYTING1:25
Lm6: 
for A being   set 
 for a being   Element of  DISJOINT_PAIRS A
 for u being  Element of (NormForm A)
 for K being   Element of  Normal_forms_on A  st a in K ^ (K =>> (@ u)) holds 
 ex b being   Element of  DISJOINT_PAIRS A st 
( b in u & b c= a )
 
theorem Th26: :: HEYTING1:26
definition
let A be    
set ;
func  pseudo_compl A ->   UnOp of the 
carrier of 
(NormForm A) means :
Def8: 
:: HEYTING1:def 8
for 
u being  
Element of 
(NormForm A) holds  
it . u =  mi (- (@ u));
existence 
 ex b1 being  UnOp of the carrier of (NormForm A) st 
for u being  Element of (NormForm A) holds  b1 . u =  mi (- (@ u))
 
correctness 
uniqueness 
for b1, b2 being  UnOp of the carrier of (NormForm A)  st ( for u being  Element of (NormForm A) holds  b1 . u =  mi (- (@ u)) ) & ( for u being  Element of (NormForm A) holds  b2 . u =  mi (- (@ u)) ) holds 
b1 = b2;
func  StrongImpl A ->   BinOp of the 
carrier of 
(NormForm A) means :
Def9: 
:: HEYTING1:def 9
for 
u, 
v being  
Element of 
(NormForm A) holds  
it . u,
v =  mi ((@ u) =>> (@ v));
existence 
 ex b1 being  BinOp of the carrier of (NormForm A) st 
for u, v being  Element of (NormForm A) holds  b1 . u,v =  mi ((@ u) =>> (@ v))
 
correctness 
uniqueness 
for b1, b2 being  BinOp of the carrier of (NormForm A)  st ( for u, v being  Element of (NormForm A) holds  b1 . u,v =  mi ((@ u) =>> (@ v)) ) & ( for u, v being  Element of (NormForm A) holds  b2 . u,v =  mi ((@ u) =>> (@ v)) ) holds 
b1 = b2;
let u be   
Element of 
(NormForm A);
func  SUB u ->    Element of  
Fin the 
carrier of 
(NormForm A) equals :: HEYTING1:def 10
 bool u;
coherence 
 bool u is    Element of  Fin the carrier of (NormForm A)
 
correctness 
;
func  diff u ->   UnOp of the 
carrier of 
(NormForm A) means :
Def11: 
:: HEYTING1:def 11
for 
v being  
Element of 
(NormForm A) holds  
it . v = u \ v;
existence 
 ex b1 being  UnOp of the carrier of (NormForm A) st 
for v being  Element of (NormForm A) holds  b1 . v = u \ v
 
correctness 
uniqueness 
for b1, b2 being  UnOp of the carrier of (NormForm A)  st ( for v being  Element of (NormForm A) holds  b1 . v = u \ v ) & ( for v being  Element of (NormForm A) holds  b2 . v = u \ v ) holds 
b1 = b2;
 
end;
 
:: deftheorem Def8   defines pseudo_compl HEYTING1:def 8 : 
:: deftheorem Def9   defines StrongImpl HEYTING1:def 9 : 
:: deftheorem    defines SUB HEYTING1:def 10 : 
:: deftheorem Def11   defines diff HEYTING1:def 11 : 
deffunc H1(   set ) ->    Element of  bool [:[:the carrier of (NormForm $1),the carrier of (NormForm $1):],the carrier of (NormForm $1):] = the L_join of (NormForm $1);
deffunc H2(   set ) ->    Element of  bool [:[:the carrier of (NormForm $1),the carrier of (NormForm $1):],the carrier of (NormForm $1):] = the L_meet of (NormForm $1);
Lm7: 
for A being   set 
 for u, v being  Element of (NormForm A)  st v in  SUB u holds 
v "\/" ((diff u) . v) = u
 
theorem Th27: :: HEYTING1:27
Lm8: 
for A being   set 
 for a being   Element of  DISJOINT_PAIRS A
 for u being  Element of (NormForm A)  ex v being  Element of (NormForm A) st 
( v in  SUB u & (@ v) ^ {a} =  {}  & ( for b being   Element of  DISJOINT_PAIRS A  st b in (diff u) . v holds 
b \/ a in  DISJOINT_PAIRS A ) )
 
theorem Th28: :: HEYTING1:28
theorem Th29: :: HEYTING1:29
theorem Th30: :: HEYTING1:30
theorem Th31: :: HEYTING1:31
Lm9: 
now 
let A be    
set ; 
::  thesis:  for u, v being  Element of (NormForm A) holds 
 ( u "/\" H3(u,v) [= v & ( for w being  Element of (NormForm A)  st u "/\" v [= w holds 
v [= H3(u,w) ) )let u, 
v be   
Element of 
(NormForm A); 
::  thesis:  ( u "/\" H3(u,v) [= v & ( for w being  Element of (NormForm A)  st u "/\" v [= w holds 
v [= H3(u,w) ) )deffunc H3(  
Element of 
(NormForm A),  
Element of 
(NormForm A)) 
->    Element of the 
carrier of 
(NormForm A) =  
FinJoin (SUB $1),
(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff $1),$2));
set Psi = 
H2(
A) 
.: (pseudo_compl A),
((StrongImpl A) [:] (diff u),v);
A1: 
now 
let w be   
Element of 
(NormForm A); 
::  thesis:  ( w in  SUB u implies (H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v))) . w [= v )set u2 = 
(diff u) . w;
set pc = 
(pseudo_compl A) . w;
set si = 
(StrongImpl A) . ((diff u) . w),
v;
assume 
w in  SUB u
 ; 
::  thesis:  (H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v))) . w [= vthen A2: 
w "\/" ((diff u) . w) = u
 by Lm7;
A3: 
w "/\" (((pseudo_compl A) . w) "/\" ((StrongImpl A) . ((diff u) . w),v)) = 
(w "/\" ((pseudo_compl A) . w)) "/\" ((StrongImpl A) . ((diff u) . w),v)
by LATTICES:def 7
.= 
(Bottom (NormForm A)) "/\" ((StrongImpl A) . ((diff u) . w),v)
by Th28
.= 
 
Bottom (NormForm A)
by LATTICES:40
;
A4: 
((diff u) . w) "/\" ((StrongImpl A) . ((diff u) . w),v) [= v
 by Th29;
(H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v))) . w = 
H2(
A) 
. u,
((H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v)) . w)
by FUNCOP_1:66
.= 
u "/\" ((H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v)) . w)
by LATTICES:def 2
.= 
u "/\" (H2(A) . ((pseudo_compl A) . w),(((StrongImpl A) [:] (diff u),v) . w))
by FUNCOP_1:48
.= 
u "/\" (((pseudo_compl A) . w) "/\" (((StrongImpl A) [:] (diff u),v) . w))
by LATTICES:def 2
.= 
u "/\" (((pseudo_compl A) . w) "/\" ((StrongImpl A) . ((diff u) . w),v))
by FUNCOP_1:60
.= 
(w "/\" (((pseudo_compl A) . w) "/\" ((StrongImpl A) . ((diff u) . w),v))) "\/" (((diff u) . w) "/\" (((pseudo_compl A) . w) "/\" ((StrongImpl A) . ((diff u) . w),v)))
by A2, LATTICES:def 11
.= 
((diff u) . w) "/\" (((StrongImpl A) . ((diff u) . w),v) "/\" ((pseudo_compl A) . w))
by A3, LATTICES:39
.= 
(((diff u) . w) "/\" ((StrongImpl A) . ((diff u) . w),v)) "/\" ((pseudo_compl A) . w)
by LATTICES:def 7
;
then 
(H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v))) . w [= ((diff u) . w) "/\" ((StrongImpl A) . ((diff u) . w),v)
 by LATTICES:23;
hence 
(H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v))) . w [= v
 by A4, LATTICES:25; 
::  thesis:  verum
 
end;
 
u "/\" H3(
u,
v) 
=  FinJoin (SUB u),
(H2(A) [;] u,(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),v)))
 by LATTICE2:83;
hence 
u "/\" H3(
u,
v) 
[= v
 by A1, LATTICE2:70; 
::  thesis:  for w being  Element of (NormForm A)  st u "/\" v [= w holds 
v [= H3(u,w)let w be   
Element of 
(NormForm A); 
::  thesis:  ( u "/\" v [= w implies v [= H3(u,w) )A5: 
v =  FinJoin (@ v),
(Atom A)
 by Th15;
then A6: 
u "/\" v =  FinJoin (@ v),
(H2(A) [;] u,(Atom A))
 by LATTICE2:83;
assume A7: 
u "/\" v [= w
 ; 
::  thesis:  v [= H3(u,w)
now 
let a be    
Element of  
DISJOINT_PAIRS A; 
::  thesis:  ( a in  @ v implies (Atom A) . a [= H3(u,w) )assume 
a in  @ v
 ; 
::  thesis:  (Atom A) . a [= H3(u,w)then 
(H2(A) [;] u,(Atom A)) . a [= w
 by A6, A7, LATTICE2:46;
then 
H2(
A) 
. u,
((Atom A) . a) [= w
 by FUNCOP_1:66;
then A8: 
u "/\" ((Atom A) . a) [= w
 by LATTICES:def 2;
consider v being   
Element of 
(NormForm A) such that A9: 
v in  SUB u
 and A10: 
(@ v) ^ {a} =  {} 
 and A11: 
for 
b being   
Element of  
DISJOINT_PAIRS A  st 
b in (diff u) . v holds 
b \/ a in  DISJOINT_PAIRS A
 by Lm8;
((diff u) . v) "/\" ((Atom A) . a) [= u "/\" ((Atom A) . a)
 by Th27, LATTICES:27;
then A12: 
((diff u) . v) "/\" ((Atom A) . a) [= w
 by A8, LATTICES:25;
set pf =  
pseudo_compl A;
set sf = 
(StrongImpl A) [:] (diff u),
w;
A13: 
(Atom A) . a [= (pseudo_compl A) . v
 by A10, Th30;
(Atom A) . a [= (StrongImpl A) . ((diff u) . v),
w
 by A11, A12, Th31;
then A14: 
(Atom A) . a [= ((StrongImpl A) [:] (diff u),w) . v
 by FUNCOP_1:60;
((pseudo_compl A) . v) "/\" (((StrongImpl A) [:] (diff u),w) . v) = 
H2(
A) 
. ((pseudo_compl A) . v),
(((StrongImpl A) [:] (diff u),w) . v)
by LATTICES:def 2
.= 
(H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),w)) . v
by FUNCOP_1:48
;
then 
(Atom A) . a [= (H2(A) .: (pseudo_compl A),((StrongImpl A) [:] (diff u),w)) . v
 by A13, A14, FILTER_0:7;
hence 
(Atom A) . a [= H3(
u,
w)
 
by A9, LATTICE2:44; 
::  thesis:  verum
 
end;
 
hence 
v [= H3(
u,
w)
 
by A5, LATTICE2:70; 
::  thesis:  verum
 
end;
 
Lm10: 
for A being   set  holds   NormForm A is  implicative 
 
theorem :: HEYTING1:32
canceled; 
theorem Th33: :: HEYTING1:33
theorem :: HEYTING1:34