let A, B be non empty AltGraph ; for F being BimapStr of A,B st F is Contravariant & F is one-to-one holds
for a, b being object of A st F . a = F . b holds
a = b
let F be BimapStr of A,B; ( F is Contravariant & F is one-to-one implies for a, b being object of A st F . a = F . b holds
a = b )
given f being Function of the carrier of A,the carrier of B such that A1:
the ObjectMap of F = ~ [:f,f:]
; FUNCTOR0:def 3,FUNCTOR0:def 14 ( not F is one-to-one or for a, b being object of A st F . a = F . b holds
a = b )
assume
the ObjectMap of F is one-to-one
; FUNCTOR0:def 7 for a, b being object of A st F . a = F . b holds
a = b
then
[:f,f:] is one-to-one
by A1, FUNCTOR0:10;
then A2:
f is one-to-one
by FUNCTOR0:8;
let a, b be object of A; ( F . a = F . b implies a = b )
assume A3:
F . a = F . b
; a = b
A4:
dom the ObjectMap of F = [:the carrier of A,the carrier of A:]
by FUNCT_2:def 1;
[b,b] in [:the carrier of A,the carrier of A:]
by ZFMISC_1:def 2;
then
the ObjectMap of F . b,b = [:f,f:] . b,b
by A1, A4, FUNCT_4:44;
then A5:
the ObjectMap of F . b,b = [(f . b),(f . b)]
by FUNCT_3:96;
[a,a] in [:the carrier of A,the carrier of A:]
by ZFMISC_1:def 2;
then
the ObjectMap of F . a,a = [:f,f:] . a,a
by A1, A4, FUNCT_4:44;
then A6:
the ObjectMap of F . a,a = [(f . a),(f . a)]
by FUNCT_3:96;
( [(f . a),(f . a)] `1 = f . a & [(f . b),(f . b)] `1 = f . b )
by MCART_1:7;
hence
a = b
by A2, A3, A6, A5, FUNCT_2:25; verum