let C be Cartesian_category; :: thesis: for a being Object of C holds
( (lambda a) * (lambda' a) = id a & (lambda' a) * (lambda a) = id (([1] C) [x] a) & (rho a) * (rho' a) = id a & (rho' a) * (rho a) = id (a [x] ([1] C)) )

let a be Object of C; :: thesis: ( (lambda a) * (lambda' a) = id a & (lambda' a) * (lambda a) = id (([1] C) [x] a) & (rho a) * (rho' a) = id a & (rho' a) * (rho a) = id (a [x] ([1] C)) )
A1: (term a) * (pr2 (([1] C),a)) = pr1 (([1] C),a) by Th12;
A2: ( Hom (a,([1] C)) <> {} & Hom (a,a) <> {} ) by Th13;
hence id a = (lambda a) * (lambda' a) by Def10; :: thesis: ( (lambda' a) * (lambda a) = id (([1] C) [x] a) & (rho a) * (rho' a) = id a & (rho' a) * (rho a) = id (a [x] ([1] C)) )
A3: Hom ((([1] C) [x] a),a) <> {} by Th19;
then (id a) * (pr2 (([1] C),a)) = pr2 (([1] C),a) by CAT_1:28;
then <:(term a),(id a):> * (pr2 (([1] C),a)) = <:(pr1 (([1] C),a)),(pr2 (([1] C),a)):> by A2, A3, A1, Th25;
hence id (([1] C) [x] a) = (lambda' a) * (lambda a) by Th24; :: thesis: ( (rho a) * (rho' a) = id a & (rho' a) * (rho a) = id (a [x] ([1] C)) )
thus id a = (rho a) * (rho' a) by A2, Def10; :: thesis: (rho' a) * (rho a) = id (a [x] ([1] C))
A4: (term a) * (pr1 (a,([1] C))) = pr2 (a,([1] C)) by Th12;
A5: Hom ((a [x] ([1] C)),a) <> {} by Th19;
then (id a) * (pr1 (a,([1] C))) = pr1 (a,([1] C)) by CAT_1:28;
then <:(id a),(term a):> * (pr1 (a,([1] C))) = <:(pr1 (a,([1] C))),(pr2 (a,([1] C))):> by A2, A5, A4, Th25;
hence (rho' a) * (rho a) = id (a [x] ([1] C)) by Th24; :: thesis: verum