let f be Relation; for n being Element of NAT
for p1, p2 being Function of NAT,(bool [:(field f),(field f):]) st p1 . 0 = id (field f) & ( for k being Nat holds p1 . (k + 1) = f * (p1 . k) ) & p2 . 0 = id (field f) & ( for k being Nat holds p2 . (k + 1) = f * (p2 . k) ) holds
p1 = p2
let n be Element of NAT ; for p1, p2 being Function of NAT,(bool [:(field f),(field f):]) st p1 . 0 = id (field f) & ( for k being Nat holds p1 . (k + 1) = f * (p1 . k) ) & p2 . 0 = id (field f) & ( for k being Nat holds p2 . (k + 1) = f * (p2 . k) ) holds
p1 = p2
let p1, p2 be Function of NAT,(bool [:(field f),(field f):]); ( p1 . 0 = id (field f) & ( for k being Nat holds p1 . (k + 1) = f * (p1 . k) ) & p2 . 0 = id (field f) & ( for k being Nat holds p2 . (k + 1) = f * (p2 . k) ) implies p1 = p2 )
assume that
A1:
p1 . 0 = id (field f)
and
A2:
for k being Nat holds p1 . (k + 1) = f * (p1 . k)
and
A3:
p2 . 0 = id (field f)
and
A4:
for k being Nat holds p2 . (k + 1) = f * (p2 . k)
; p1 = p2
defpred S1[ Nat, Relation, set ] means $3 = f * $2;
A5:
for k being Nat holds S1[k,p1 . k,p1 . (k + 1)]
by A2;
set FX = bool [:(field f),(field f):];
reconsider ID = id (field f) as Element of bool [:(field f),(field f):] by PARTFUN1:45;
A6:
p2 . 0 = ID
by A3;
A7:
for k being Nat
for x, y1, y2 being Element of bool [:(field f),(field f):] st S1[k,x,y1] & S1[k,x,y2] holds
y1 = y2
;
A8:
for k being Nat holds S1[k,p2 . k,p2 . (k + 1)]
by A4;
A9:
p1 . 0 = ID
by A1;
p1 = p2
from NAT_1:sch 14(A9, A5, A6, A8, A7);
hence
p1 = p2
; verum