let C be Category; :: thesis: for a being Object of C
for F being Function of {} ,the carrier' of C holds
( a is_a_product_wrt F iff a is terminal )

let a be Object of C; :: thesis: for F being Function of {} ,the carrier' of C holds
( a is_a_product_wrt F iff a is terminal )

let F be Function of {} ,the carrier' of C; :: thesis: ( a is_a_product_wrt F iff a is terminal )
thus ( a is_a_product_wrt F implies a is terminal ) :: thesis: ( a is terminal implies a is_a_product_wrt F )
proof
assume A1: a is_a_product_wrt F ; :: thesis: a is terminal
let b be Object of C; :: according to CAT_1:def 15 :: thesis: ( not Hom b,a = {} & ex b1 being Morphism of b,a st
for b2 being Morphism of b,a holds b1 = b2 )

consider F9 being Projections_family of b, {} ;
cods F = {} ;
then consider h being Morphism of C such that
A2: h in Hom b,a and
A3: for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) by A1, Def15;
thus Hom b,a <> {} by A2; :: thesis: ex b1 being Morphism of b,a st
for b2 being Morphism of b,a holds b1 = b2

reconsider f = h as Morphism of b,a by A2, CAT_1:def 7;
take f ; :: thesis: for b1 being Morphism of b,a holds f = b1
let g be Morphism of b,a; :: thesis: f = g
A4: for x being set st x in {} holds
(F /. x) * g = F9 /. x ;
g in Hom b,a by A2, CAT_1:def 7;
hence f = g by A3, A4; :: thesis: verum
end;
assume A5: a is terminal ; :: thesis: a is_a_product_wrt F
thus F is Projections_family of a, {} by Th46; :: according to CAT_3:def 15 :: thesis: for b being Object of C
for F9 being Projections_family of b, {} st cods F = cods F9 holds
ex h being Morphism of C st
( h in Hom b,a & ( for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) ) )

let b be Object of C; :: thesis: for F9 being Projections_family of b, {} st cods F = cods F9 holds
ex h being Morphism of C st
( h in Hom b,a & ( for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) ) )

consider h being Morphism of b,a such that
A6: for g being Morphism of b,a holds h = g by A5, CAT_1:def 15;
let F9 be Projections_family of b, {} ; :: thesis: ( cods F = cods F9 implies ex h being Morphism of C st
( h in Hom b,a & ( for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) ) ) )

assume cods F = cods F9 ; :: thesis: ex h being Morphism of C st
( h in Hom b,a & ( for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) ) )

take h ; :: thesis: ( h in Hom b,a & ( for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) ) )

Hom b,a <> {} by A5, CAT_1:def 15;
hence h in Hom b,a by CAT_1:def 7; :: thesis: for k being Morphism of C st k in Hom b,a holds
( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k )

let k be Morphism of C; :: thesis: ( k in Hom b,a implies ( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) )

assume k in Hom b,a ; :: thesis: ( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k )

then k is Morphism of b,a by CAT_1:def 7;
hence ( ( for x being set st x in {} holds
(F /. x) * k = F9 /. x ) iff h = k ) by A6; :: thesis: verum