:: Curried and Uncurried Functions
:: by Grzegorz Bancerek
:: 
:: Received March 6, 1990
:: Copyright (c) 1990 Association of Mizar Users
theorem Th1: :: FUNCT_5:1
theorem :: FUNCT_5:2
canceled; 
theorem :: FUNCT_5:3
canceled; 
theorem :: FUNCT_5:4
theorem Th5: :: FUNCT_5:5
theorem Th6: :: FUNCT_5:6
theorem :: FUNCT_5:7
theorem Th8: :: FUNCT_5:8
theorem :: FUNCT_5:9
theorem Th10: :: FUNCT_5:10
theorem Th11: :: FUNCT_5:11
theorem Th12: :: FUNCT_5:12
theorem Th13: :: FUNCT_5:13
theorem :: FUNCT_5:14
canceled; 
theorem Th15: :: FUNCT_5:15
theorem :: FUNCT_5:16
for 
x, 
y, 
z, 
t being   
set  holds 
 (  
proj1 {[x,y],[z,t]} = {x,z} &  
proj2 {[x,y],[z,t]} = {y,t} )
theorem Th17: :: FUNCT_5:17
theorem :: FUNCT_5:18
theorem :: FUNCT_5:19
theorem Th20: :: FUNCT_5:20
theorem :: FUNCT_5:21
definition
canceled;canceled;let f be   
Function;
func  curry f ->   Function means :
Def3: 
:: FUNCT_5:def 3
(  
dom it =  proj1 (dom f) & ( for 
x being   
set   st 
x in  proj1 (dom f) holds 
 ex 
g being  
Function st 
( 
it . x = g &  
dom g =  proj2 ((dom f) /\ [:{x},(proj2 (dom f)):]) & ( for 
y being   
set   st 
y in  dom g holds 
g . y = f . x,
y ) ) ) );
existence 
 ex b1 being  Function st 
(  dom b1 =  proj1 (dom f) & ( for x being   set   st x in  proj1 (dom f) holds 
 ex g being  Function st 
( b1 . x = g &  dom g =  proj2 ((dom f) /\ [:{x},(proj2 (dom f)):]) & ( for y being   set   st y in  dom g holds 
g . y = f . x,y ) ) ) )
 
uniqueness 
for b1, b2 being  Function  st  dom b1 =  proj1 (dom f) & ( for x being   set   st x in  proj1 (dom f) holds 
 ex g being  Function st 
( b1 . x = g &  dom g =  proj2 ((dom f) /\ [:{x},(proj2 (dom f)):]) & ( for y being   set   st y in  dom g holds 
g . y = f . x,y ) ) ) &  dom b2 =  proj1 (dom f) & ( for x being   set   st x in  proj1 (dom f) holds 
 ex g being  Function st 
( b2 . x = g &  dom g =  proj2 ((dom f) /\ [:{x},(proj2 (dom f)):]) & ( for y being   set   st y in  dom g holds 
g . y = f . x,y ) ) ) holds 
b1 = b2
 
func  uncurry f ->   Function means :
Def4: 
:: FUNCT_5:def 4
( ( for 
t being   
set  holds 
 ( 
t in  dom it iff  ex 
x being   
set  ex 
g being  
Function ex 
y being   
set  st 
( 
t = [x,y] & 
x in  dom f & 
g = f . x & 
y in  dom g ) ) ) & ( for 
x being   
set  for 
g being  
Function  st 
x in  dom it & 
g = f . (x `1 ) holds 
it . x = g . (x `2 ) ) );
existence 
 ex b1 being  Function st 
( ( for t being   set  holds 
 ( t in  dom b1 iff  ex x being   set  ex g being  Function ex y being   set  st 
( t = [x,y] & x in  dom f & g = f . x & y in  dom g ) ) ) & ( for x being   set 
 for g being  Function  st x in  dom b1 & g = f . (x `1 ) holds 
b1 . x = g . (x `2 ) ) )
 
uniqueness 
for b1, b2 being  Function  st ( for t being   set  holds 
 ( t in  dom b1 iff  ex x being   set  ex g being  Function ex y being   set  st 
( t = [x,y] & x in  dom f & g = f . x & y in  dom g ) ) ) & ( for x being   set 
 for g being  Function  st x in  dom b1 & g = f . (x `1 ) holds 
b1 . x = g . (x `2 ) ) & ( for t being   set  holds 
 ( t in  dom b2 iff  ex x being   set  ex g being  Function ex y being   set  st 
( t = [x,y] & x in  dom f & g = f . x & y in  dom g ) ) ) & ( for x being   set 
 for g being  Function  st x in  dom b2 & g = f . (x `1 ) holds 
b2 . x = g . (x `2 ) ) holds 
b1 = b2
 
 
end;
 
:: deftheorem   FUNCT_5:def 1 : 
canceled; 
:: deftheorem   FUNCT_5:def 2 : 
canceled; 
:: deftheorem Def3   defines curry FUNCT_5:def 3 : 
:: deftheorem Def4   defines uncurry FUNCT_5:def 4 : 
:: deftheorem    defines curry' FUNCT_5:def 5 : 
:: deftheorem    defines uncurry' FUNCT_5:def 6 : 
theorem :: FUNCT_5:22
canceled; 
theorem :: FUNCT_5:23
canceled; 
theorem :: FUNCT_5:24
canceled; 
theorem :: FUNCT_5:25
canceled; 
theorem Th26: :: FUNCT_5:26
theorem Th27: :: FUNCT_5:27
theorem :: FUNCT_5:28
theorem :: FUNCT_5:29
theorem :: FUNCT_5:30
theorem Th31: :: FUNCT_5:31
theorem Th32: :: FUNCT_5:32
theorem Th33: :: FUNCT_5:33
theorem :: FUNCT_5:34
theorem :: FUNCT_5:35
theorem Th36: :: FUNCT_5:36
theorem Th37: :: FUNCT_5:37
theorem Th38: :: FUNCT_5:38
theorem Th39: :: FUNCT_5:39
theorem :: FUNCT_5:40
theorem :: FUNCT_5:41
theorem Th42: :: FUNCT_5:42
theorem :: FUNCT_5:43
theorem Th44: :: FUNCT_5:44
theorem Th45: :: FUNCT_5:45
theorem :: FUNCT_5:46
theorem Th47: :: FUNCT_5:47
theorem Th48: :: FUNCT_5:48
theorem Th49: :: FUNCT_5:49
theorem Th50: :: FUNCT_5:50
theorem Th51: :: FUNCT_5:51
theorem Th52: :: FUNCT_5:52
theorem Th53: :: FUNCT_5:53
theorem :: FUNCT_5:54
theorem Th55: :: FUNCT_5:55
theorem :: FUNCT_5:56
theorem Th57: :: FUNCT_5:57
theorem Th58: :: FUNCT_5:58
theorem :: FUNCT_5:59
theorem :: FUNCT_5:60
theorem :: FUNCT_5:61
theorem :: FUNCT_5:62
theorem Th63: :: FUNCT_5:63
theorem Th64: :: FUNCT_5:64
theorem :: FUNCT_5:65
theorem Th66: :: FUNCT_5:66
theorem Th67: :: FUNCT_5:67
for 
X1, 
Y1, 
X2, 
Y2 being   
set   st 
X1,
Y1 are_equipotent  & 
X2,
Y2 are_equipotent  holds 
(  
Funcs X1,
X2, 
Funcs Y1,
Y2 are_equipotent  &  
card (Funcs X1,X2) =  card (Funcs Y1,Y2) )
theorem :: FUNCT_5:68
theorem :: FUNCT_5:69
for 
X1, 
X2, 
X being   
set   st 
X1 misses X2 holds 
(  
Funcs (X1 \/ X2),
X,
[:(Funcs X1,X),(Funcs X2,X):] are_equipotent  &  
card (Funcs (X1 \/ X2),X) =  card [:(Funcs X1,X),(Funcs X2,X):] )
theorem :: FUNCT_5:70
for 
X, 
Y, 
Z being   
set  holds 
 (  
Funcs [:X,Y:],
Z, 
Funcs X,
(Funcs Y,Z) are_equipotent  &  
card (Funcs [:X,Y:],Z) =  card (Funcs X,(Funcs Y,Z)) )
theorem :: FUNCT_5:71
for 
Z, 
X, 
Y being   
set  holds 
 (  
Funcs Z,
[:X,Y:],
[:(Funcs Z,X),(Funcs Z,Y):] are_equipotent  &  
card (Funcs Z,[:X,Y:]) =  card [:(Funcs Z,X),(Funcs Z,Y):] )
theorem :: FUNCT_5:72
theorem :: FUNCT_5:73
:: deftheorem    defines op1 FUNCT_5:def 7 : 
:: deftheorem    defines op2 FUNCT_5:def 8 :