:: The set of primitive recursive functions
:: by Grzegorz Bancerek and Piotr Rudnicki
:: 
:: Received July 27, 2001
:: Copyright (c) 2001 Association of Mizar Users
theorem :: COMPUT_1:1
canceled; 
theorem :: COMPUT_1:2
canceled; 
theorem Th3: :: COMPUT_1:3
theorem :: COMPUT_1:4
canceled; 
theorem Th5: :: COMPUT_1:5
theorem Th6: :: COMPUT_1:6
theorem Th7: :: COMPUT_1:7
theorem Th8: :: COMPUT_1:8
theorem :: COMPUT_1:9
theorem Th10: :: COMPUT_1:10
theorem Th11: :: COMPUT_1:11
theorem Th12: :: COMPUT_1:12
theorem Th13: :: COMPUT_1:13
:: deftheorem Def1   defines compatible COMPUT_1:def 1 : 
theorem Th14: :: COMPUT_1:14
theorem Th15: :: COMPUT_1:15
theorem Th16: :: COMPUT_1:16
theorem Th17: :: COMPUT_1:17
theorem Th18: :: COMPUT_1:18
:: deftheorem   COMPUT_1:def 2 : 
canceled; 
:: deftheorem Def3   defines len-total COMPUT_1:def 3 : 
theorem Th19: :: COMPUT_1:19
theorem Th20: :: COMPUT_1:20
theorem Th21: :: COMPUT_1:21
theorem Th22: :: COMPUT_1:22
theorem Th23: :: COMPUT_1:23
theorem Th24: :: COMPUT_1:24
Lm1: 
for D being non  empty   set 
 for f being  homogeneous  PartFunc of (D * ),D holds 
 ( ( f is  quasi_total  & not f is  empty  ) iff  dom f = (arity f) -tuples_on D )
 
theorem Th25: :: COMPUT_1:25
theorem Th26: :: COMPUT_1:26
theorem :: COMPUT_1:27
theorem Th28: :: COMPUT_1:28
:: deftheorem   COMPUT_1:def 4 : 
canceled; 
:: deftheorem   COMPUT_1:def 5 : 
canceled; 
:: deftheorem Def6   defines with_the_same_arity COMPUT_1:def 6 : 
:: deftheorem Def7   defines arity COMPUT_1:def 7 : 
theorem :: COMPUT_1:29
:: deftheorem    defines HFuncs COMPUT_1:def 8 : 
theorem Th30: :: COMPUT_1:30
theorem Th31: :: COMPUT_1:31
theorem Th32: :: COMPUT_1:32
theorem Th33: :: COMPUT_1:33
:: deftheorem    defines const COMPUT_1:def 9 : 
theorem Th34: :: COMPUT_1:34
theorem Th35: :: COMPUT_1:35
:: deftheorem Def10   defines succ COMPUT_1:def 10 : 
theorem :: COMPUT_1:36
canceled; 
theorem Th37: :: COMPUT_1:37
theorem Th38: :: COMPUT_1:38
:: deftheorem    defines proj COMPUT_1:def 11 : 
theorem Th39: :: COMPUT_1:39
theorem Th40: :: COMPUT_1:40
theorem Th41: :: COMPUT_1:41
theorem Th42: :: COMPUT_1:42
theorem Th43: :: COMPUT_1:43
theorem :: COMPUT_1:44
theorem Th45: :: COMPUT_1:45
theorem Th46: :: COMPUT_1:46
theorem :: COMPUT_1:47
theorem Th48: :: COMPUT_1:48
theorem Th49: :: COMPUT_1:49
theorem Th50: :: COMPUT_1:50
theorem Th51: :: COMPUT_1:51
theorem Th52: :: COMPUT_1:52
definition
let g, 
f1, 
f2 be  
NAT  *  -defined   to-naturals   homogeneous  Function;
let i be    
Element of  
NAT ;
pred g is_primitive-recursively_expressed_by f1,
f2,
i means :
Def12: 
:: COMPUT_1:def 12
 ex 
n being   
Element of  
NAT  st 
(  
dom g c= n -tuples_on NAT  & 
i >= 1 & 
i <= n & 
(arity f1) + 1 
= n & 
n + 1 
=  arity f2 & ( for 
p being   
FinSequence of  
NAT   st  
len p = n holds 
( ( 
p +* i,
0  in  dom g implies  
Del p,
i in  dom f1 ) & (  
Del p,
i in  dom f1 implies 
p +* i,
0  in  dom g ) & ( 
p +* i,
0  in  dom g implies 
g . (p +* i,0 ) = f1 . (Del p,i) ) & ( for 
n being   
Element of  
NAT  holds 
 ( ( 
p +* i,
(n + 1) in  dom g implies ( 
p +* i,
n in  dom g & 
(p +* i,n) ^ <*(g . (p +* i,n))*> in  dom f2 ) ) & ( 
p +* i,
n in  dom g & 
(p +* i,n) ^ <*(g . (p +* i,n))*> in  dom f2 implies 
p +* i,
(n + 1) in  dom g ) & ( 
p +* i,
(n + 1) in  dom g implies 
g . (p +* i,(n + 1)) = f2 . ((p +* i,n) ^ <*(g . (p +* i,n))*>) ) ) ) ) ) );
 
end;
 
:: deftheorem Def12   defines is_primitive-recursively_expressed_by COMPUT_1:def 12 : 
for 
g, 
f1, 
f2 being 
NAT  *  -defined   to-naturals   homogeneous  Function for 
i being   
Element of  
NAT  holds 
 ( 
g is_primitive-recursively_expressed_by f1,
f2,
i iff  ex 
n being   
Element of  
NAT  st 
(  
dom g c= n -tuples_on NAT  & 
i >= 1 & 
i <= n & 
(arity f1) + 1 
= n & 
n + 1 
=  arity f2 & ( for 
p being   
FinSequence of  
NAT   st  
len p = n holds 
( ( 
p +* i,
0  in  dom g implies  
Del p,
i in  dom f1 ) & (  
Del p,
i in  dom f1 implies 
p +* i,
0  in  dom g ) & ( 
p +* i,
0  in  dom g implies 
g . (p +* i,0 ) = f1 . (Del p,i) ) & ( for 
n being   
Element of  
NAT  holds 
 ( ( 
p +* i,
(n + 1) in  dom g implies ( 
p +* i,
n in  dom g & 
(p +* i,n) ^ <*(g . (p +* i,n))*> in  dom f2 ) ) & ( 
p +* i,
n in  dom g & 
(p +* i,n) ^ <*(g . (p +* i,n))*> in  dom f2 implies 
p +* i,
(n + 1) in  dom g ) & ( 
p +* i,
(n + 1) in  dom g implies 
g . (p +* i,(n + 1)) = f2 . ((p +* i,n) ^ <*(g . (p +* i,n))*>) ) ) ) ) ) ) );
defpred S1[   Element of  NAT ,   Element of  HFuncs NAT ,   Element of  HFuncs NAT ,   FinSequence of  NAT ,   Element of  NAT ,  homogeneous  Function] means ( ( $5 in  dom $4 & $4 +* $5,$1 in  dom $2 & ($4 +* $5,$1) ^ <*($2 . ($4 +* $5,$1))*> in  dom $6 implies $3 = $2 +* (($4 +* $5,($1 + 1)) .--> ($6 . (($4 +* $5,$1) ^ <*($2 . ($4 +* $5,$1))*>))) ) & ( (  not $5 in  dom $4 or  not $4 +* $5,$1 in  dom $2 or  not ($4 +* $5,$1) ^ <*($2 . ($4 +* $5,$1))*> in  dom $6 ) implies $3 = $2 ) );
definition
let f1, 
f2 be  
NAT  *  -defined   to-naturals   homogeneous  Function;
let i be    
Element of  
NAT ;
let p be    
FinSequence of  
NAT ;
func  primrec f1,
f2,
i,
p ->    Element of  
HFuncs NAT  means :
Def13: 
:: COMPUT_1:def 13
 ex 
F being  
Function of 
NAT ,
(HFuncs NAT ) st 
( 
it = F . (p /. i) & ( 
i in  dom p &  
Del p,
i in  dom f1 implies 
F . 0  = (p +* i,0 ) .--> (f1 . (Del p,i)) ) & ( (  not 
i in  dom p or  not  
Del p,
i in  dom f1 ) implies 
F . 0  =  {}  ) & ( for 
m being   
Element of  
NAT  holds 
 ( ( 
i in  dom p & 
p +* i,
m in  dom (F . m) & 
(p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 implies 
F . (m + 1) = (F . m) +* ((p +* i,(m + 1)) .--> (f2 . ((p +* i,m) ^ <*((F . m) . (p +* i,m))*>))) ) & ( (  not 
i in  dom p or  not 
p +* i,
m in  dom (F . m) or  not 
(p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 ) implies 
F . (m + 1) = F . m ) ) ) );
existence 
 ex b1 being   Element of  HFuncs NAT  ex F being  Function of NAT ,(HFuncs NAT ) st 
( b1 = F . (p /. i) & ( i in  dom p &  Del p,i in  dom f1 implies F . 0  = (p +* i,0 ) .--> (f1 . (Del p,i)) ) & ( (  not i in  dom p or  not  Del p,i in  dom f1 ) implies F . 0  =  {}  ) & ( for m being   Element of  NAT  holds 
 ( ( i in  dom p & p +* i,m in  dom (F . m) & (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 implies F . (m + 1) = (F . m) +* ((p +* i,(m + 1)) .--> (f2 . ((p +* i,m) ^ <*((F . m) . (p +* i,m))*>))) ) & ( (  not i in  dom p or  not p +* i,m in  dom (F . m) or  not (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 ) implies F . (m + 1) = F . m ) ) ) )
 
uniqueness 
for b1, b2 being   Element of  HFuncs NAT   st  ex F being  Function of NAT ,(HFuncs NAT ) st 
( b1 = F . (p /. i) & ( i in  dom p &  Del p,i in  dom f1 implies F . 0  = (p +* i,0 ) .--> (f1 . (Del p,i)) ) & ( (  not i in  dom p or  not  Del p,i in  dom f1 ) implies F . 0  =  {}  ) & ( for m being   Element of  NAT  holds 
 ( ( i in  dom p & p +* i,m in  dom (F . m) & (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 implies F . (m + 1) = (F . m) +* ((p +* i,(m + 1)) .--> (f2 . ((p +* i,m) ^ <*((F . m) . (p +* i,m))*>))) ) & ( (  not i in  dom p or  not p +* i,m in  dom (F . m) or  not (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 ) implies F . (m + 1) = F . m ) ) ) ) &  ex F being  Function of NAT ,(HFuncs NAT ) st 
( b2 = F . (p /. i) & ( i in  dom p &  Del p,i in  dom f1 implies F . 0  = (p +* i,0 ) .--> (f1 . (Del p,i)) ) & ( (  not i in  dom p or  not  Del p,i in  dom f1 ) implies F . 0  =  {}  ) & ( for m being   Element of  NAT  holds 
 ( ( i in  dom p & p +* i,m in  dom (F . m) & (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 implies F . (m + 1) = (F . m) +* ((p +* i,(m + 1)) .--> (f2 . ((p +* i,m) ^ <*((F . m) . (p +* i,m))*>))) ) & ( (  not i in  dom p or  not p +* i,m in  dom (F . m) or  not (p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 ) implies F . (m + 1) = F . m ) ) ) ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def13   defines primrec COMPUT_1:def 13 : 
for 
f1, 
f2 being 
NAT  *  -defined   to-naturals   homogeneous  Function for 
i being   
Element of  
NAT  for 
p being   
FinSequence of  
NAT  for 
b5 being   
Element of  
HFuncs NAT  holds 
 ( 
b5 =  primrec f1,
f2,
i,
p iff  ex 
F being  
Function of 
NAT ,
(HFuncs NAT ) st 
( 
b5 = F . (p /. i) & ( 
i in  dom p &  
Del p,
i in  dom f1 implies 
F . 0  = (p +* i,0 ) .--> (f1 . (Del p,i)) ) & ( (  not 
i in  dom p or  not  
Del p,
i in  dom f1 ) implies 
F . 0  =  {}  ) & ( for 
m being   
Element of  
NAT  holds 
 ( ( 
i in  dom p & 
p +* i,
m in  dom (F . m) & 
(p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 implies 
F . (m + 1) = (F . m) +* ((p +* i,(m + 1)) .--> (f2 . ((p +* i,m) ^ <*((F . m) . (p +* i,m))*>))) ) & ( (  not 
i in  dom p or  not 
p +* i,
m in  dom (F . m) or  not 
(p +* i,m) ^ <*((F . m) . (p +* i,m))*> in  dom f2 ) implies 
F . (m + 1) = F . m ) ) ) ) );
theorem Th53: :: COMPUT_1:53
theorem Th54: :: COMPUT_1:54
theorem Th55: :: COMPUT_1:55
theorem Th56: :: COMPUT_1:56
theorem Th57: :: COMPUT_1:57
theorem Th58: :: COMPUT_1:58
definition
let f1, 
f2 be  
NAT  *  -defined   to-naturals   homogeneous  Function;
let i be    
Element of  
NAT ;
func  primrec f1,
f2,
i ->    Element of  
HFuncs NAT  means :
Def14: 
:: COMPUT_1:def 14
 ex 
G being  
Function of 
(((arity f1) + 1) -tuples_on NAT ),
(HFuncs NAT ) st 
( 
it =  Union G & ( for 
p being   
Element of 
((arity f1) + 1) -tuples_on NAT  holds  
G . p =  primrec f1,
f2,
i,
p ) );
existence 
 ex b1 being   Element of  HFuncs NAT  ex G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT ) st 
( b1 =  Union G & ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) )
 
uniqueness 
for b1, b2 being   Element of  HFuncs NAT   st  ex G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT ) st 
( b1 =  Union G & ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) ) &  ex G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT ) st 
( b2 =  Union G & ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def14   defines primrec COMPUT_1:def 14 : 
theorem Th59: :: COMPUT_1:59
theorem Th60: :: COMPUT_1:60
theorem Th61: :: COMPUT_1:61
Lm2: 
now 
let f1, 
f2 be  non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function; 
::  thesis:  for p being   Element of ((arity f1) + 1) -tuples_on NAT 
 for i, m being   Element of  NAT 
 for F1, F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F1 . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F1 . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F1 . M,F1 . (M + 1),p +* i,(m + 1),i,f2] ) & ( i in  dom (p +* i,m) &  Del (p +* i,m),i in  dom f1 implies F . 0  = {((p +* i,m) +* i,0 )} --> (f1 . (Del (p +* i,m),i)) ) & ( (  not i in  dom (p +* i,m) or  not  Del (p +* i,m),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,m,i,f2] ) holds 
F1 = Flet p be    
Element of 
((arity f1) + 1) -tuples_on NAT ; 
::  thesis:  for i, m being   Element of  NAT 
 for F1, F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F1 . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F1 . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F1 . M,F1 . (M + 1),p +* i,(m + 1),i,f2] ) & ( i in  dom (p +* i,m) &  Del (p +* i,m),i in  dom f1 implies F . 0  = {((p +* i,m) +* i,0 )} --> (f1 . (Del (p +* i,m),i)) ) & ( (  not i in  dom (p +* i,m) or  not  Del (p +* i,m),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,m,i,f2] ) holds 
F1 = Flet i, 
m be    
Element of  
NAT ; 
::  thesis:  for F1, F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F1 . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F1 . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F1 . M,F1 . (M + 1),p +* i,(m + 1),i,f2] ) & ( i in  dom (p +* i,m) &  Del (p +* i,m),i in  dom f1 implies F . 0  = {((p +* i,m) +* i,0 )} --> (f1 . (Del (p +* i,m),i)) ) & ( (  not i in  dom (p +* i,m) or  not  Del (p +* i,m),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,m,i,f2] ) holds 
F1 = Fset pm1 = 
p +* i,
(m + 1);
set pm = 
p +* i,
m;
let F1, 
F be   
Function of 
NAT ,
(HFuncs NAT ); 
::  thesis:  ( ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F1 . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F1 . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F1 . M,F1 . (M + 1),p +* i,(m + 1),i,f2] ) & ( i in  dom (p +* i,m) &  Del (p +* i,m),i in  dom f1 implies F . 0  = {((p +* i,m) +* i,0 )} --> (f1 . (Del (p +* i,m),i)) ) & ( (  not i in  dom (p +* i,m) or  not  Del (p +* i,m),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,m,i,f2] ) implies F1 = F )assume that A1: 
( ( 
i in  dom (p +* i,(m + 1)) &  
Del (p +* i,(m + 1)),
i in  dom f1 implies 
F1 . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not 
i in  dom (p +* i,(m + 1)) or  not  
Del (p +* i,(m + 1)),
i in  dom f1 ) implies 
F1 . 0  =  {}  ) )
 
and A2: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F1 . M,
F1 . (M + 1),
p +* i,
(m + 1),
i,
f2]
 
and A3: 
( ( 
i in  dom (p +* i,m) &  
Del (p +* i,m),
i in  dom f1 implies 
F . 0  = {((p +* i,m) +* i,0 )} --> (f1 . (Del (p +* i,m),i)) ) & ( (  not 
i in  dom (p +* i,m) or  not  
Del (p +* i,m),
i in  dom f1 ) implies 
F . 0  =  {}  ) )
 
and A4: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F . M,
F . (M + 1),
p +* i,
m,
i,
f2]
 ; 
::  thesis:  F1 = FA5: 
(  
dom p =  dom (p +* i,m) &  
dom p =  dom (p +* i,(m + 1)) )
 
by FUNCT_7:32;
A6: 
(p +* i,m) +* i,
0  = 
p +* i,
0 
by FUNCT_7:36
.= 
(p +* i,(m + 1)) +* i,
0 
by FUNCT_7:36
;
A7:  
Del (p +* i,m),
i = 
 
Del p,
i
by Th6
.= 
 
Del (p +* i,(m + 1)),
i
by Th6
;
for 
x being   
set   st 
x in  NAT  holds 
F . x = F1 . x
 
proof 
defpred S2[   
Element of  
NAT ] 
means F . $1 
= F1 . $1;
A8: 
S2[ 
0 ]
 
by A1, A3, A5, A6, A7;
A9: 
for 
k being   
Element of  
NAT   st 
S2[
k] holds 
S2[
k + 1]
 
proof 
let k be    
Element of  
NAT ; 
::  thesis:  ( S2[k] implies S2[k + 1] )
assume A10: 
S2[
k]
 ; 
::  thesis:  S2[k + 1]
A11: 
(p +* i,m) +* i,
k = 
p +* i,
k
by FUNCT_7:36
.= 
(p +* i,(m + 1)) +* i,
k
by FUNCT_7:36
;
A12: 
(p +* i,m) +* i,
(k + 1) = 
p +* i,
(k + 1)
by FUNCT_7:36
.= 
(p +* i,(m + 1)) +* i,
(k + 1)
by FUNCT_7:36
;
per cases 
( ( i in  dom (p +* i,m) & (p +* i,m) +* i,k in  dom (F . k) & ((p +* i,m) +* i,k) ^ <*((F . k) . ((p +* i,m) +* i,k))*> in  dom f2 ) or  not i in  dom (p +* i,m) or  not (p +* i,m) +* i,k in  dom (F . k) or  not ((p +* i,m) +* i,k) ^ <*((F . k) . ((p +* i,m) +* i,k))*> in  dom f2 )
 ;
suppose A13: 
( 
i in  dom (p +* i,m) & 
(p +* i,m) +* i,
k in  dom (F . k) & 
((p +* i,m) +* i,k) ^ <*((F . k) . ((p +* i,m) +* i,k))*> in  dom f2 )
 ; 
::  thesis:  S2[k + 1]
hence F . (k + 1) = 
(F . k) +* (((p +* i,m) +* i,(k + 1)) .--> (f2 . (((p +* i,m) +* i,k) ^ <*((F . k) . ((p +* i,m) +* i,k))*>)))
by A4
.= 
F1 . (k + 1)
by A2, A5, A10, A11, A12, A13
; 
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
A15: 
for 
k being   
Element of  
NAT  holds  
S2[
k]
 
from NAT_1:sch 1(A8, A9);
let x be    
set ; 
::  thesis:  ( x in  NAT  implies F . x = F1 . x )
assume 
x in  NAT 
 ; 
::  thesis:  F . x = F1 . x
hence 
F . x = F1 . x
 by A15; 
::  thesis:  verum
 
end;
 
hence 
F1 = F
 by FUNCT_2:18; 
::  thesis:  verum
 
end;
 
Lm3: 
now 
let f1, 
f2 be  non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function; 
::  thesis:  for p being   Element of ((arity f1) + 1) -tuples_on NAT 
 for i, m being   Element of  NAT   st i in  dom p holds 
for F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,(m + 1),i,f2] ) holds 
( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) )let p be    
Element of 
((arity f1) + 1) -tuples_on NAT ; 
::  thesis:  for i, m being   Element of  NAT   st i in  dom p holds 
for F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,(m + 1),i,f2] ) holds 
( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) )let i, 
m be    
Element of  
NAT ; 
::  thesis:  ( i in  dom p implies for F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,(m + 1),i,f2] ) holds 
( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) ) )assume A1: 
i in  dom p
 ; 
::  thesis:  for F being  Function of NAT ,(HFuncs NAT )  st ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,(m + 1),i,f2] ) holds 
( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) )set pm = 
p +* i,
m;
set pm1 = 
p +* i,
(m + 1);
let F be   
Function of 
NAT ,
(HFuncs NAT ); 
::  thesis:  ( ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 implies F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 ) implies F . 0  =  {}  ) & ( for M being   Element of  NAT  holds  S1[M,F . M,F . (M + 1),p +* i,(m + 1),i,f2] ) implies ( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) ) )assume that A2: 
( ( 
i in  dom (p +* i,(m + 1)) &  
Del (p +* i,(m + 1)),
i in  dom f1 implies 
F . 0  = {((p +* i,(m + 1)) +* i,0 )} --> (f1 . (Del (p +* i,(m + 1)),i)) ) & ( (  not 
i in  dom (p +* i,(m + 1)) or  not  
Del (p +* i,(m + 1)),
i in  dom f1 ) implies 
F . 0  =  {}  ) )
 
and A3: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F . M,
F . (M + 1),
p +* i,
(m + 1),
i,
f2]
 ; 
::  thesis:  ( (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m) & not p +* i,(m + 1) in  dom (F . m) )thus 
(F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m)
  ::  thesis:  not p +* i,(m + 1) in  dom (F . m)
proof 
per cases 
( ( i in  dom (p +* i,(m + 1)) & (p +* i,(m + 1)) +* i,m in  dom (F . m) & ((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 ) or  not i in  dom (p +* i,(m + 1)) or  not (p +* i,(m + 1)) +* i,m in  dom (F . m) or  not ((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 )
 ;
suppose 
( 
i in  dom (p +* i,(m + 1)) & 
(p +* i,(m + 1)) +* i,
m in  dom (F . m) & 
((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 )
 ; 
::  thesis:  (F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m)
then A4: 
F . (m + 1) = (F . m) +* (((p +* i,(m + 1)) +* i,(m + 1)) .--> (f2 . (((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*>)))
 by A3;
( 
(p +* i,m) . i = m & 
(p +* i,(m + 1)) . i = m + 1 )
 
by A1, FUNCT_7:33;
then 
( 
p +* i,
m <> p +* i,
(m + 1) & 
p +* i,
(m + 1) = (p +* i,(m + 1)) +* i,
(m + 1) )
 
by FUNCT_7:36;
then 
not 
p +* i,
m in {((p +* i,(m + 1)) +* i,(m + 1))}
 by TARSKI:def 1;
then 
not 
p +* i,
m in  dom ({((p +* i,(m + 1)) +* i,(m + 1))} --> (f2 . (((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*>)))
 ;
hence 
(F . (m + 1)) . (p +* i,m) = (F . m) . (p +* i,m)
 by A4, FUNCT_4:12; 
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
A5: 
for 
m, 
k being   
Element of  
NAT   st 
p +* i,
k in  dom (F . m) holds 
k <= m
 
proof 
defpred S2[   
Element of  
NAT ] 
means for 
k being   
Element of  
NAT   st 
p +* i,
k in  dom (F . $1) holds 
k <= $1;
A6: 
S2[ 
0 ]
 
proof 
let k be    
Element of  
NAT ; 
::  thesis:  ( p +* i,k in  dom (F . 0 ) implies k <=  0  )
assume A7: 
p +* i,
k in  dom (F . 0 )
 ; 
::  thesis:  k <=  0 
per cases 
( ( i in  dom (p +* i,(m + 1)) &  Del (p +* i,(m + 1)),i in  dom f1 ) or  not i in  dom (p +* i,(m + 1)) or  not  Del (p +* i,(m + 1)),i in  dom f1 )
 ;
suppose 
( 
i in  dom (p +* i,(m + 1)) &  
Del (p +* i,(m + 1)),
i in  dom f1 )
 ; 
::  thesis:  k <=  0 
then 
 dom (F . 0 ) = {((p +* i,(m + 1)) +* i,0 )}
 by A2, FUNCOP_1:19;
then A8: 
p +* i,
k = 
(p +* i,(m + 1)) +* i,
0 
by A7, TARSKI:def 1
.= 
p +* i,
0 
by FUNCT_7:36
;
k = 
(p +* i,k) . i
by A1, FUNCT_7:33
.= 
 
0 
by A1, A8, FUNCT_7:33
;
hence 
k <=  0 
 ; 
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
A9: 
for 
m being   
Element of  
NAT   st 
S2[
m] holds 
S2[
m + 1]
 
proof 
let m be    
Element of  
NAT ; 
::  thesis:  ( S2[m] implies S2[m + 1] )
assume A10: 
S2[
m]
 ; 
::  thesis:  S2[m + 1]
let k be    
Element of  
NAT ; 
::  thesis:  ( p +* i,k in  dom (F . (m + 1)) implies k <= m + 1 )
assume A11: 
p +* i,
k in  dom (F . (m + 1))
 ; 
::  thesis:  k <= m + 1
per cases 
( ( i in  dom (p +* i,(m + 1)) & (p +* i,(m + 1)) +* i,m in  dom (F . m) & ((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 ) or  not i in  dom (p +* i,(m + 1)) or  not (p +* i,(m + 1)) +* i,m in  dom (F . m) or  not ((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 )
 ;
suppose 
( 
i in  dom (p +* i,(m + 1)) & 
(p +* i,(m + 1)) +* i,
m in  dom (F . m) & 
((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*> in  dom f2 )
 ; 
::  thesis:  k <= m + 1
then 
F . (m + 1) = (F . m) +* (((p +* i,(m + 1)) +* i,(m + 1)) .--> (f2 . (((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*>)))
 by A3;
then 
 dom (F . (m + 1)) = (dom (F . m)) \/ (dom ({((p +* i,(m + 1)) +* i,(m + 1))} --> (f2 . (((p +* i,(m + 1)) +* i,m) ^ <*((F . m) . ((p +* i,(m + 1)) +* i,m))*>))))
 by FUNCT_4:def 1;
then A12: 
 
dom (F . (m + 1)) = (dom (F . m)) \/ {((p +* i,(m + 1)) +* i,(m + 1))}
 by FUNCOP_1:19;
thus 
k <= m + 1
  
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
thus 
for 
n being   
Element of  
NAT  holds  
S2[
n]
 
from NAT_1:sch 1(A6, A9); ::  thesis:  verum
 
end;
 
thus 
not 
p +* i,
(m + 1) in  dom (F . m)
  ::  thesis:  verum
 
end;
 
Lm4: 
now 
let f1, 
f2 be  non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function; 
::  thesis:  for p being   Element of ((arity f1) + 1) -tuples_on NAT 
 for i, m being   Element of  NAT   st i in  dom p holds 
for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))let p be    
Element of 
((arity f1) + 1) -tuples_on NAT ; 
::  thesis:  for i, m being   Element of  NAT   st i in  dom p holds 
for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))let i, 
m be    
Element of  
NAT ; 
::  thesis:  ( i in  dom p implies for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n))) )assume A1: 
i in  dom p
 ; 
::  thesis:  for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))let G be   
Function of 
(((arity f1) + 1) -tuples_on NAT ),
(HFuncs NAT ); 
::  thesis:  ( ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) implies for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n))) )assume A2: 
for 
p being   
Element of 
((arity f1) + 1) -tuples_on NAT  holds  
G . p =  primrec f1,
f2,
i,
p
 ; 
::  thesis:  for k, n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))thus 
for 
k, 
n being   
Element of  
NAT  holds   
dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))
  ::  thesis:  verum
proof 
let k be    
Element of  
NAT ; 
::  thesis:  for n being   Element of  NAT  holds   dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + n)))
set pk = 
p +* i,
k;
defpred S2[   
Element of  
NAT ] 
means  dom (G . (p +* i,k)) c=  dom (G . (p +* i,(k + $1)));
A3: 
S2[ 
0 ]
 
;
A4: 
now 
let n be    
Element of  
NAT ; 
::  thesis:  ( S2[n] implies S2[b1 + 1] )assume A5: 
S2[
n]
 ; 
::  thesis:  S2[b1 + 1]set pkn = 
p +* i,
(k + n);
set pkn1 = 
p +* i,
((k + n) + 1);
set m = 
k + n;
consider F being   
Function of 
NAT ,
(HFuncs NAT ) such that A6: 
 
primrec f1,
f2,
i,
(p +* i,(k + n)) = F . ((p +* i,(k + n)) /. i)
 and A7: 
( ( 
i in  dom (p +* i,(k + n)) &  
Del (p +* i,(k + n)),
i in  dom f1 implies 
F . 0  = ((p +* i,(k + n)) +* i,0 ) .--> (f1 . (Del (p +* i,(k + n)),i)) ) & ( (  not 
i in  dom (p +* i,(k + n)) or  not  
Del (p +* i,(k + n)),
i in  dom f1 ) implies 
F . 0  =  {}  ) )
 
and A8: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F . M,
F . (M + 1),
p +* i,
(k + n),
i,
f2]
 
by Def13;
consider F1 being   
Function of 
NAT ,
(HFuncs NAT ) such that A9: 
 
primrec f1,
f2,
i,
(p +* i,((k + n) + 1)) = F1 . ((p +* i,((k + n) + 1)) /. i)
 and A10: 
( ( 
i in  dom (p +* i,((k + n) + 1)) &  
Del (p +* i,((k + n) + 1)),
i in  dom f1 implies 
F1 . 0  = ((p +* i,((k + n) + 1)) +* i,0 ) .--> (f1 . (Del (p +* i,((k + n) + 1)),i)) ) & ( (  not 
i in  dom (p +* i,((k + n) + 1)) or  not  
Del (p +* i,((k + n) + 1)),
i in  dom f1 ) implies 
F1 . 0  =  {}  ) )
 
and A11: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F1 . M,
F1 . (M + 1),
p +* i,
((k + n) + 1),
i,
f2]
 
by Def13;
A12: 
F1 = F
 by A7, A8, A10, A11, Lm2;
A13: 
(  
dom p =  dom (p +* i,k) &  
dom p =  dom (p +* i,((k + n) + 1)) &  
dom p =  dom (p +* i,(k + n)) )
 
by FUNCT_7:32;
then A14: 
(p +* i,((k + n) + 1)) /. i = 
(p +* i,((k + n) + 1)) . i
by A1, PARTFUN1:def 8
.= 
(k + n) + 1
by A1, FUNCT_7:33
;
A15: 
(p +* i,(k + n)) /. i = 
(p +* i,(k + n)) . i
by A1, A13, PARTFUN1:def 8
.= 
k + n
by A1, FUNCT_7:33
;
A16: 
G . (p +* i,(k + (n + 1))) = F . ((k + n) + 1)
 by A2, A9, A12, A14;
A17: 
G . (p +* i,(k + n)) = F . (k + n)
 by A2, A6, A15;
per cases 
( ( i in  dom (p +* i,(k + n)) & (p +* i,(k + n)) +* i,(k + n) in  dom (F . (k + n)) & ((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 ) or  not i in  dom (p +* i,(k + n)) or  not (p +* i,(k + n)) +* i,(k + n) in  dom (F . (k + n)) or  not ((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 )
 ;
suppose 
( 
i in  dom (p +* i,(k + n)) & 
(p +* i,(k + n)) +* i,
(k + n) in  dom (F . (k + n)) & 
((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 )
 ; 
::  thesis:  S2[b1 + 1]
then 
F . ((k + n) + 1) = (F . (k + n)) +* (((p +* i,(k + n)) +* i,((k + n) + 1)) .--> (f2 . (((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*>)))
 by A8;
then 
 dom (F . ((k + n) + 1)) = (dom (F . (k + n))) \/ (dom ({((p +* i,(k + n)) +* i,((k + n) + 1))} --> (f2 . (((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*>))))
 by FUNCT_4:def 1;
then 
 dom (F . (k + n)) c=  dom (F . ((k + n) + 1))
 by XBOOLE_1:7;
hence 
S2[
n + 1]
 
by A5, A16, A17, XBOOLE_1:1; 
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
thus 
for 
n being   
Element of  
NAT  holds  
S2[
n]
 
from NAT_1:sch 1(A3, A4); ::  thesis:  verum
 
end;
 
 
end;
 
Lm5: 
now 
let f1, 
f2 be  non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function; 
::  thesis:  for p being   Element of ((arity f1) + 1) -tuples_on NAT 
 for i, m being   Element of  NAT   st i in  dom p holds 
for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n)))let p be    
Element of 
((arity f1) + 1) -tuples_on NAT ; 
::  thesis:  for i, m being   Element of  NAT   st i in  dom p holds 
for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n)))let i, 
m be    
Element of  
NAT ; 
::  thesis:  ( i in  dom p implies for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n))) )assume A1: 
i in  dom p
 ; 
::  thesis:  for G being  Function of (((arity f1) + 1) -tuples_on NAT ),(HFuncs NAT )  st ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) holds 
for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n)))let G be   
Function of 
(((arity f1) + 1) -tuples_on NAT ),
(HFuncs NAT ); 
::  thesis:  ( ( for p being   Element of ((arity f1) + 1) -tuples_on NAT  holds  G . p =  primrec f1,f2,i,p ) implies for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n))) )assume A2: 
for 
p being   
Element of 
((arity f1) + 1) -tuples_on NAT  holds  
G . p =  primrec f1,
f2,
i,
p
 ; 
::  thesis:  for k, n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n)))thus 
for 
k, 
n being   
Element of  
NAT   st not 
p +* i,
k in  dom (G . (p +* i,k)) holds 
 not 
p +* i,
k in  dom (G . (p +* i,(k + n)))
  ::  thesis:  verum
proof 
let k be    
Element of  
NAT ; 
::  thesis:  for n being   Element of  NAT   st not p +* i,k in  dom (G . (p +* i,k)) holds 
 not p +* i,k in  dom (G . (p +* i,(k + n)))
set pk = 
p +* i,
k;
defpred S2[   
Element of  
NAT ] 
means ( not 
p +* i,
k in  dom (G . (p +* i,k)) implies  not 
p +* i,
k in  dom (G . (p +* i,(k + $1))) );
A3: 
S2[ 
0 ]
 
;
A4: 
for 
n being   
Element of  
NAT   st 
S2[
n] holds 
S2[
n + 1]
 
proof 
let n be    
Element of  
NAT ; 
::  thesis:  ( S2[n] implies S2[n + 1] )
assume that A5: 
S2[
n]
 
and A6: 
not 
p +* i,
k in  dom (G . (p +* i,k))
 ; 
::  thesis:  not p +* i,k in  dom (G . (p +* i,(k + (n + 1))))
set pkn = 
p +* i,
(k + n);
set pkn1 = 
p +* i,
((k + n) + 1);
set m = 
k + n;
consider F being   
Function of 
NAT ,
(HFuncs NAT ) such that A7: 
 
primrec f1,
f2,
i,
(p +* i,(k + n)) = F . ((p +* i,(k + n)) /. i)
 and A8: 
( ( 
i in  dom (p +* i,(k + n)) &  
Del (p +* i,(k + n)),
i in  dom f1 implies 
F . 0  = ((p +* i,(k + n)) +* i,0 ) .--> (f1 . (Del (p +* i,(k + n)),i)) ) & ( (  not 
i in  dom (p +* i,(k + n)) or  not  
Del (p +* i,(k + n)),
i in  dom f1 ) implies 
F . 0  =  {}  ) )
 
and A9: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F . M,
F . (M + 1),
p +* i,
(k + n),
i,
f2]
 
by Def13;
consider F1 being   
Function of 
NAT ,
(HFuncs NAT ) such that A10: 
 
primrec f1,
f2,
i,
(p +* i,((k + n) + 1)) = F1 . ((p +* i,((k + n) + 1)) /. i)
 and A11: 
( ( 
i in  dom (p +* i,((k + n) + 1)) &  
Del (p +* i,((k + n) + 1)),
i in  dom f1 implies 
F1 . 0  = ((p +* i,((k + n) + 1)) +* i,0 ) .--> (f1 . (Del (p +* i,((k + n) + 1)),i)) ) & ( (  not 
i in  dom (p +* i,((k + n) + 1)) or  not  
Del (p +* i,((k + n) + 1)),
i in  dom f1 ) implies 
F1 . 0  =  {}  ) )
 
and A12: 
for 
M being   
Element of  
NAT  holds  
S1[
M,
F1 . M,
F1 . (M + 1),
p +* i,
((k + n) + 1),
i,
f2]
 
by Def13;
A13: 
F1 = F
 
by A8, A9, A11, A12, Lm2;
A14: 
(  
dom p =  dom (p +* i,k) &  
dom p =  dom (p +* i,((k + n) + 1)) &  
dom p =  dom (p +* i,(k + n)) )
 
by FUNCT_7:32;
then A15: 
(p +* i,((k + n) + 1)) /. i = 
(p +* i,((k + n) + 1)) . i
by A1, PARTFUN1:def 8
.= 
(k + n) + 1
by A1, FUNCT_7:33
;
(p +* i,(k + n)) /. i = 
(p +* i,(k + n)) . i
by A1, A14, PARTFUN1:def 8
.= 
k + n
by A1, FUNCT_7:33
;
then A16: 
not 
p +* i,
k in  dom (F . (k + n))
 
by A2, A5, A6, A7;
A17: 
G . (p +* i,(k + (n + 1))) = F . ((k + n) + 1)
 
by A2, A10, A13, A15;
per cases 
( ( i in  dom (p +* i,(k + n)) & (p +* i,(k + n)) +* i,(k + n) in  dom (F . (k + n)) & ((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 ) or  not i in  dom (p +* i,(k + n)) or  not (p +* i,(k + n)) +* i,(k + n) in  dom (F . (k + n)) or  not ((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 )
 ;
suppose 
( 
i in  dom (p +* i,(k + n)) & 
(p +* i,(k + n)) +* i,
(k + n) in  dom (F . (k + n)) & 
((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*> in  dom f2 )
 ; 
::  thesis:  not p +* i,k in  dom (G . (p +* i,(k + (n + 1))))
then 
F . ((k + n) + 1) = (F . (k + n)) +* (((p +* i,(k + n)) +* i,((k + n) + 1)) .--> (f2 . (((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*>)))
 by A9;
then 
 dom (F . ((k + n) + 1)) = (dom (F . (k + n))) \/ (dom ({((p +* i,(k + n)) +* i,((k + n) + 1))} --> (f2 . (((p +* i,(k + n)) +* i,(k + n)) ^ <*((F . (k + n)) . ((p +* i,(k + n)) +* i,(k + n)))*>))))
 by FUNCT_4:def 1;
then A18: 
 
dom (F . ((k + n) + 1)) = (dom (F . (k + n))) \/ {((p +* i,(k + n)) +* i,((k + n) + 1))}
 by FUNCOP_1:19;
k <= k + n
 by NAT_1:11;
then A19: 
k <> (k + n) + 1
 
by NAT_1:13;
( 
(p +* i,k) . i = k & 
((p +* i,(k + n)) +* i,((k + n) + 1)) . i = (k + n) + 1 )
 
by A1, A14, FUNCT_7:33;
then 
not 
p +* i,
k in {((p +* i,(k + n)) +* i,((k + n) + 1))}
 by A19, TARSKI:def 1;
hence 
not 
p +* i,
k in  dom (G . (p +* i,(k + (n + 1))))
 by A16, A17, A18, XBOOLE_0:def 3; 
::  thesis:  verum
 
end;
 
 
end;
 
 
end;
 
thus 
for 
n being   
Element of  
NAT  holds  
S2[
n]
 
from NAT_1:sch 1(A3, A4); ::  thesis:  verum
 
end;
 
 
end;
 
Lm6: 
for i, m being   Element of  NAT 
 for f1, f2 being non  empty  NAT  *  -defined   to-naturals   homogeneous  Function
 for p being   Element of ((arity f1) + 1) -tuples_on NAT   st i in  dom p holds 
( ( p +* i,0  in  dom (primrec f1,f2,i) implies  Del p,i in  dom f1 ) & (  Del p,i in  dom f1 implies p +* i,0  in  dom (primrec f1,f2,i) ) & ( p +* i,0  in  dom (primrec f1,f2,i) implies (primrec f1,f2,i) . (p +* i,0 ) = f1 . (Del p,i) ) & ( p +* i,(m + 1) in  dom (primrec f1,f2,i) implies ( p +* i,m in  dom (primrec f1,f2,i) & (p +* i,m) ^ <*((primrec f1,f2,i) . (p +* i,m))*> in  dom f2 ) ) & ( p +* i,m in  dom (primrec f1,f2,i) & (p +* i,m) ^ <*((primrec f1,f2,i) . (p +* i,m))*> in  dom f2 implies p +* i,(m + 1) in  dom (primrec f1,f2,i) ) & ( p +* i,(m + 1) in  dom (primrec f1,f2,i) implies (primrec f1,f2,i) . (p +* i,(m + 1)) = f2 . ((p +* i,m) ^ <*((primrec f1,f2,i) . (p +* i,m))*>) ) )
 
theorem :: COMPUT_1:62
theorem :: COMPUT_1:63
theorem Th64: :: COMPUT_1:64
theorem :: COMPUT_1:65
for 
i, 
m being   
Element of  
NAT  for 
f1, 
f2 being non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function for 
p being   
Element of 
((arity f1) + 1) -tuples_on NAT   st 
i in  dom p holds 
( 
p +* i,
(m + 1) in  dom (primrec f1,f2,i) iff ( 
p +* i,
m in  dom (primrec f1,f2,i) & 
(p +* i,m) ^ <*((primrec f1,f2,i) . (p +* i,m))*> in  dom f2 ) ) 
by Lm6;
theorem :: COMPUT_1:66
for 
i, 
m being   
Element of  
NAT  for 
f1, 
f2 being non  
empty  NAT  *  -defined   to-naturals   homogeneous  Function for 
p being   
Element of 
((arity f1) + 1) -tuples_on NAT   st 
i in  dom p & 
p +* i,
(m + 1) in  dom (primrec f1,f2,i) holds 
(primrec f1,f2,i) . (p +* i,(m + 1)) = f2 . ((p +* i,m) ^ <*((primrec f1,f2,i) . (p +* i,m))*>) by Lm6;
theorem Th67: :: COMPUT_1:67
theorem Th68: :: COMPUT_1:68
theorem :: COMPUT_1:69
:: deftheorem Def15   defines composition_closed COMPUT_1:def 15 : 
:: deftheorem Def16   defines primitive-recursion_closed COMPUT_1:def 16 : 
:: deftheorem Def17   defines primitive-recursively_closed COMPUT_1:def 17 : 
theorem Th70: :: COMPUT_1:70
Lm7: 
for X being non  empty   set 
 for n, i being   Element of  NAT   st 1 <= i & i <= n holds 
for x being   Element of X
 for p being   Element of n -tuples_on X holds  p +* i,x in n -tuples_on X
 
;
theorem Th71: :: COMPUT_1:71
theorem Th72: :: COMPUT_1:72
theorem Th73: :: COMPUT_1:73
theorem Th74: :: COMPUT_1:74
theorem Th75: :: COMPUT_1:75
theorem Th76: :: COMPUT_1:76
theorem Th77: :: COMPUT_1:77
:: deftheorem    defines PrimRec COMPUT_1:def 18 : 
theorem Th78: :: COMPUT_1:78
:: deftheorem Def19   defines primitive-recursive COMPUT_1:def 19 : 
definition
func  initial-funcs  ->   Subset of 
(HFuncs NAT ) equals :: COMPUT_1:def 20
{(0  const 0 ),(1 succ 1)} \/ { (n proj i) where n, i is    Element of  NAT  : ( 1 <= i & i <= n ) } ;
coherence 
{(0  const 0 ),(1 succ 1)} \/ { (n proj i) where n, i is    Element of  NAT  : ( 1 <= i & i <= n ) }  is   Subset of (HFuncs NAT )
 
let Q be   
Subset of 
(HFuncs NAT );
func  PR-closure Q ->   Subset of 
(HFuncs NAT ) equals :: COMPUT_1:def 21
Q \/ { g where g is    Element of  HFuncs NAT  :  ex f1, f2 being   Element of  HFuncs NAT  ex i being   Element of  NAT  st 
( f1 in Q & f2 in Q & g is_primitive-recursively_expressed_by f1,f2,i ) } ;
coherence 
Q \/ { g where g is    Element of  HFuncs NAT  :  ex f1, f2 being   Element of  HFuncs NAT  ex i being   Element of  NAT  st 
( f1 in Q & f2 in Q & g is_primitive-recursively_expressed_by f1,f2,i ) }  is   Subset of (HFuncs NAT )
 
func  composition-closure Q ->   Subset of 
(HFuncs NAT ) equals :: COMPUT_1:def 22
Q \/ { (f * <:F:>) where f is    Element of  HFuncs NAT , F is   with_the_same_arity   Element of (HFuncs NAT ) *  : ( f in Q &  arity f =  len F &  rng F c= Q ) } ;
coherence 
Q \/ { (f * <:F:>) where f is    Element of  HFuncs NAT , F is   with_the_same_arity   Element of (HFuncs NAT ) *  : ( f in Q &  arity f =  len F &  rng F c= Q ) }  is   Subset of (HFuncs NAT )
 
 
end;
 
:: deftheorem    defines initial-funcs COMPUT_1:def 20 : 
:: deftheorem    defines PR-closure COMPUT_1:def 21 : 
:: deftheorem    defines composition-closure COMPUT_1:def 22 : 
:: deftheorem Def23   defines PrimRec-Approximation COMPUT_1:def 23 : 
theorem Th79: :: COMPUT_1:79
theorem Th80: :: COMPUT_1:80
theorem Th81: :: COMPUT_1:81
theorem Th82: :: COMPUT_1:82
:: deftheorem Def24   defines nullary COMPUT_1:def 24 : 
:: deftheorem Def25   defines unary COMPUT_1:def 25 : 
:: deftheorem Def26   defines binary COMPUT_1:def 26 : 
:: deftheorem Def27   defines ternary COMPUT_1:def 27 : 
registration
let f be   
primitive-recursive   unary  Function;
let g be   
primitive-recursive   ternary  Function;
cluster  primrec f,
g,1
 ->  primitive-recursive   binary  ;
coherence 
(  primrec f,g,1 is  primitive-recursive  &  primrec f,g,1 is  binary  )
 
cluster  primrec f,
g,2
 ->  primitive-recursive   binary  ;
coherence 
(  primrec f,g,2 is  primitive-recursive  &  primrec f,g,2 is  binary  )
 
 
end;
 
theorem Th83: :: COMPUT_1:83
theorem Th84: :: COMPUT_1:84
theorem Th85: :: COMPUT_1:85
theorem Th86: :: COMPUT_1:86
Lm8: 
now 
let g be  non  
empty   homogeneous   quasi_total  PartFunc of 
(NAT  * ),
NAT ; 
::  thesis:  (  arity g = 2 implies (  dom <:<*(3 proj 1),(3 proj 3)*>:> = (dom (3 proj 1)) /\ (dom (3 proj 3)) &  dom <:<*(3 proj 1),(3 proj 3)*>:> = 3 -tuples_on NAT  &  dom (g * <:<*(3 proj 1),(3 proj 3)*>:>) = 3 -tuples_on NAT  &  ex G being  homogeneous  PartFunc of (NAT  * ),NAT  st 
( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  ) ) )assume A1: 
 
arity g = 2
 ; 
::  thesis:  (  dom <:<*(3 proj 1),(3 proj 3)*>:> = (dom (3 proj 1)) /\ (dom (3 proj 3)) &  dom <:<*(3 proj 1),(3 proj 3)*>:> = 3 -tuples_on NAT  &  dom (g * <:<*(3 proj 1),(3 proj 3)*>:>) = 3 -tuples_on NAT  &  ex G being  homogeneous  PartFunc of (NAT  * ),NAT  st 
( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  ) )thus A2: 
 
dom <:<*(3 proj 1),(3 proj 3)*>:> = (dom (3 proj 1)) /\ (dom (3 proj 3))
 by FUNCT_6:62; 
::  thesis:  (  dom <:<*(3 proj 1),(3 proj 3)*>:> = 3 -tuples_on NAT  &  dom (g * <:<*(3 proj 1),(3 proj 3)*>:>) = 3 -tuples_on NAT  &  ex G being  homogeneous  PartFunc of (NAT  * ),NAT  st 
( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  ) )hence A3:  
dom <:<*(3 proj 1),(3 proj 3)*>:> = 
(3 -tuples_on NAT ) /\ (dom (3 proj 3))
by Th40
.= 
(3 -tuples_on NAT ) /\ (3 -tuples_on NAT )
by Th40
.= 
3 
-tuples_on NAT 
; 
::  thesis:  (  dom (g * <:<*(3 proj 1),(3 proj 3)*>:>) = 3 -tuples_on NAT  &  ex G being  homogeneous  PartFunc of (NAT  * ),NAT  st 
( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  ) )reconsider z3 = 
<*0 ,0 ,0 *> as    
FinSequence of  
NAT  ;
 len z3 = 3
 
by FINSEQ_1:62;
then A4: 
z3 is    
Element of 3 
-tuples_on NAT 
 by FINSEQ_2:110;
A5: 
 
dom g = 2 
-tuples_on NAT 
 by A1, Th25;
set G = 
g * <:<*(3 proj 1),(3 proj 3)*>:>;
now 
let x be    
set ; 
::  thesis:  ( ( x in  rng <:<*(3 proj 1),(3 proj 3)*>:> implies x in  dom g ) & ( x in  dom g implies x in  rng <:<*(3 proj 1),(3 proj 3)*>:> ) )set f = 
<*(3 proj 1),(3 proj 3)*>;
set F = 
<:<*(3 proj 1),(3 proj 3)*>:>;
A6:  
product (rngs <*(3 proj 1),(3 proj 3)*>) = 
 
product <*(rng (3 proj 1)),(rng (3 proj 3))*>
by FUNCT_6:34
.= 
 
product <*NAT ,(rng (3 proj 3))*>
by Th40
.= 
 
product <*NAT ,NAT *>
by Th40
.= 
2 
-tuples_on NAT 
by FUNCT_6:6
;
assume 
x in  dom g
 ; 
::  thesis:  x in  rng <:<*(3 proj 1),(3 proj 3)*>:>then consider d1, 
d2 being    
Element of  
NAT  such that A8: 
x = <*d1,d2*>
 by A5, FINSEQ_2:120;
reconsider x' = 
<*d1,0 ,d2*> as    
Element of 3 
-tuples_on NAT  by FINSEQ_2:124;
<:<*(3 proj 1),(3 proj 3)*>:> . x' = 
<*((3 proj 1) . x'),((3 proj 3) . x')*>
by A2, A3, FUNCT_6:62
.= 
<*(x' . 1),((3 proj 3) . x')*>
by Th42
.= 
<*(x' . 1),(x' . 3)*>
by Th42
.= 
<*d1,(x' . 3)*>
by FINSEQ_1:62
.= 
x
by A8, FINSEQ_1:62
;
hence 
x in  rng <:<*(3 proj 1),(3 proj 3)*>:>
 by A3, FUNCT_1:def 5; 
::  thesis:  verum
 
end;
 
then A9: 
 
rng <:<*(3 proj 1),(3 proj 3)*>:> =  dom g
 by TARSKI:2;
hence A10: 
 
dom (g * <:<*(3 proj 1),(3 proj 3)*>:>) = 3 
-tuples_on NAT 
 by A3, RELAT_1:46; 
::  thesis:   ex G being  homogeneous  PartFunc of (NAT  * ),NAT  st 
( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  )
 rng g c=  NAT 
 by RELAT_1:def 19;
then 
 rng (g * <:<*(3 proj 1),(3 proj 3)*>:>) c=  NAT 
 by A9, RELAT_1:47;
then reconsider G = 
g * <:<*(3 proj 1),(3 proj 3)*>:> as   
PartFunc of 
(NAT  * ),
NAT  by A10, MSUALG_1:12, RELSET_1:11;
then reconsider G = 
G as   
homogeneous  PartFunc of 
(NAT  * ),
NAT  by UNIALG_1:def 1;
take G = 
G; 
::  thesis:  ( G = g * <:<*(3 proj 1),(3 proj 3)*>:> & G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  )thus 
G = g * <:<*(3 proj 1),(3 proj 3)*>:>
 ; 
::  thesis:  ( G is    Element of  HFuncs NAT  &  arity G = 3 & G is  quasi_total  & not G is  empty  )
G is    
Element of  
PFuncs (NAT  * ),
NAT 
 by PARTFUN1:119;
then 
G in  HFuncs NAT 
 ;
hence 
G is    
Element of  
HFuncs NAT 
 ; 
::  thesis:  (  arity G = 3 & G is  quasi_total  & not G is  empty  )
for 
x being  
FinSequence  st 
x in  dom G holds 
3 
=  len x
 by A10, FINSEQ_1:def 18;
hence 
 arity G = 3
 
by A4, A10, UNIALG_1:def 10; 
::  thesis:  ( G is  quasi_total  & not G is  empty  )hence 
( 
G is  
quasi_total  & not 
G is  
empty  )
 
by A10, Th25; 
::  thesis:  verum
 
end;
 
:: deftheorem    defines (1,2)->(1,?,2) COMPUT_1:def 28 : 
registration
let g be  
NAT  *  -defined   to-naturals   homogeneous   len-total   binary  Function;
cluster  (1,2)->(1,?,2) g -> non  
empty   len-total   ternary  ;
coherence 
( not  (1,2)->(1,?,2) g is  empty  &  (1,2)->(1,?,2) g is  ternary  &  (1,2)->(1,?,2) g is  len-total  )
 
 
end;
 
theorem Th87: :: COMPUT_1:87
theorem Th88: :: COMPUT_1:88
:: deftheorem    defines [+] COMPUT_1:def 29 : 
theorem Th89: :: COMPUT_1:89
definition
func  [*]  ->   primitive-recursive   binary  Function equals :: COMPUT_1:def 30
 primrec (1 const 0 ),
((1,2)->(1,?,2) [+] ),2;
coherence 
 primrec (1 const 0 ),((1,2)->(1,?,2) [+] ),2 is   primitive-recursive   binary  Function
 ;
 
end;
 
:: deftheorem    defines [*] COMPUT_1:def 30 : 
theorem Th90: :: COMPUT_1:90
:: deftheorem    defines [!] COMPUT_1:def 31 : 
theorem :: COMPUT_1:91
definition
func  [^]  ->   primitive-recursive   binary  Function equals :: COMPUT_1:def 32
 primrec (1 const 1),
((1,2)->(1,?,2) [*] ),2;
coherence 
 primrec (1 const 1),((1,2)->(1,?,2) [*] ),2 is   primitive-recursive   binary  Function
 ;
 
end;
 
:: deftheorem    defines [^] COMPUT_1:def 32 : 
theorem :: COMPUT_1:92
:: deftheorem    defines [pred] COMPUT_1:def 33 : 
theorem Th93: :: COMPUT_1:93
definition
func  [-]  ->   primitive-recursive   binary  Function equals :: COMPUT_1:def 34
 primrec (1 proj 1),
((1,2)->(1,?,2) ([pred]  * <:<*(2 proj 2)*>:>)),2;
coherence 
 primrec (1 proj 1),((1,2)->(1,?,2) ([pred]  * <:<*(2 proj 2)*>:>)),2 is   primitive-recursive   binary  Function
 ;
 
end;
 
:: deftheorem    defines [-] COMPUT_1:def 34 : 
theorem :: COMPUT_1:94