A4: P1[F2()] by A2;
set V = the carrier of F1() --> NAT;
reconsider Gen = the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) as GeneratorSet of FreeMSA ( the carrier of F1() --> NAT) by MSAFREE2:6;
A5: F3() .:.: ( the carrier of F1() --> NAT) c= rngs F3() by EQUATION:12;
the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) is_transformable_to the Sorts of F2()
proof
let i be set ; :: according to PZFMISC1:def 3 :: thesis: ( not i in the carrier of F1() or not the Sorts of F2() . i = {} or the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) . i = {} )
assume A6: i in the carrier of F1() ; :: thesis: ( not the Sorts of F2() . i = {} or the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) . i = {} )
assume the Sorts of F2() . i = {} ; :: thesis: the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) . i = {}
hence the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) . i = {} by A6; :: thesis: verum
end;
then doms (F3() -hash) = the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) by MSSUBFAM:17;
then A7: (F3() -hash) .:.: the Sorts of (FreeMSA ( the carrier of F1() --> NAT)) = rngs (F3() -hash) by EQUATION:13;
rngs F3() c= rngs (F3() -hash) by Th1;
then A8: F3() .:.: ( the carrier of F1() --> NAT) c= (F3() -hash) .:.: Gen by A7, A5, PBOOLE:13;
A9: F3() -hash is_homomorphism FreeMSA ( the carrier of F1() --> NAT),F2() by Def1;
A10: for A being non-empty MSAlgebra of F1()
for B being strict non-empty MSSubAlgebra of A st P1[A] holds
P1[B] by A3;
A11: for C being non-empty MSAlgebra of F1()
for G being ManySortedFunction of the carrier of F1() --> NAT, the Sorts of C st P1[C] holds
ex H being ManySortedFunction of F2(),C st
( H is_homomorphism F2(),C & H ** F3() = G & ( for K being ManySortedFunction of F2(),C st K is_homomorphism F2(),C & K ** F3() = G holds
H = K ) ) by A1;
F3() .:.: ( the carrier of F1() --> NAT) is V8() GeneratorSet of F2() from BIRKHOFF:sch 5(A11, A4, A10);
hence F3() -hash is_epimorphism FreeMSA ( the carrier of F1() --> NAT),F2() by A8, A9, EQUATION:23; :: thesis: verum