let Z be open Subset of REAL ; :: thesis: for f1, f2 being PartFunc of REAL ,REAL st f1 is_differentiable_on 2,Z & f2 is_differentiable_on 2,Z holds
(diff (f1 (#) f2),Z) . 2 = ((((diff f1,Z) . 2) (#) f2) + (2 (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
let f1, f2 be PartFunc of REAL ,REAL ; :: thesis: ( f1 is_differentiable_on 2,Z & f2 is_differentiable_on 2,Z implies (diff (f1 (#) f2),Z) . 2 = ((((diff f1,Z) . 2) (#) f2) + (2 (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2)) )
assume that
A1:
f1 is_differentiable_on 2,Z
and
A2:
f2 is_differentiable_on 2,Z
; :: thesis: (diff (f1 (#) f2),Z) . 2 = ((((diff f1,Z) . 2) (#) f2) + (2 (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
A3:
0 <= 2 - 1
;
then A4:
(diff f1,Z) . 0 is_differentiable_on Z
by A1, TAYLOR_1:def 6;
f1 | Z is_differentiable_on Z
by A4, TAYLOR_1:def 5;
then A6:
f1 is_differentiable_on Z
by ThB1;
A7:
(diff f2,Z) . 0 is_differentiable_on Z
by A2, A3, TAYLOR_1:def 6;
f2 | Z is_differentiable_on Z
by A7, TAYLOR_1:def 5;
then A8:
f2 is_differentiable_on Z
by ThB1;
then A9:
f1 (#) f2 is_differentiable_on Z
by A6, FDIFF_2:20;
A10:
1 <= 2 - 1
;
A12: (diff f1,Z) . 1 =
(diff f1,Z) . (1 + 0 )
.=
((diff f1,Z) . 0 ) `| Z
by TAYLOR_1:def 5
.=
(f1 | Z) `| Z
by TAYLOR_1:def 5
.=
f1 `| Z
by A6, FDIFF_2:16
;
A13:
f1 `| Z is_differentiable_on Z
by A1, A12, A10, TAYLOR_1:def 6;
then B1:
(f1 `| Z) (#) f2 is_differentiable_on Z
by A8, FDIFF_2:20;
A15: (diff f2,Z) . 1 =
(diff f2,Z) . (1 + 0 )
.=
((diff f2,Z) . 0 ) `| Z
by TAYLOR_1:def 5
.=
(f2 | Z) `| Z
by TAYLOR_1:def 5
.=
f2 `| Z
by A8, FDIFF_2:16
;
A16:
f2 `| Z is_differentiable_on Z
by A2, A10, A15, TAYLOR_1:def 6;
then A17:
f1 (#) (f2 `| Z) is_differentiable_on Z
by A6, FDIFF_2:20;
A18: (diff f1,Z) . 2 =
(diff f1,Z) . (1 + 1)
.=
((diff f1,Z) . (1 + 0 )) `| Z
by TAYLOR_1:def 5
.=
(((diff f1,Z) . 0 ) `| Z) `| Z
by TAYLOR_1:def 5
.=
((f1 | Z) `| Z) `| Z
by TAYLOR_1:def 5
.=
(f1 `| Z) `| Z
by A6, FDIFF_2:16
;
A19: (diff f2,Z) . 2 =
(diff f2,Z) . (1 + 1)
.=
((diff f2,Z) . (1 + 0 )) `| Z
by TAYLOR_1:def 5
.=
(((diff f2,Z) . 0 ) `| Z) `| Z
by TAYLOR_1:def 5
.=
((f2 | Z) `| Z) `| Z
by TAYLOR_1:def 5
.=
(f2 `| Z) `| Z
by A8, FDIFF_2:16
;
(diff (f1 (#) f2),Z) . 2 =
(diff (f1 (#) f2),Z) . (1 + 1)
.=
((diff (f1 (#) f2),Z) . (1 + 0 )) `| Z
by TAYLOR_1:def 5
.=
(((diff (f1 (#) f2),Z) . 0 ) `| Z) `| Z
by TAYLOR_1:def 5
.=
(((f1 (#) f2) | Z) `| Z) `| Z
by TAYLOR_1:def 5
.=
((f1 (#) f2) `| Z) `| Z
by A9, FDIFF_2:16
.=
(((f1 `| Z) (#) f2) + (f1 (#) (f2 `| Z))) `| Z
by A8, A6, FDIFF_2:20
.=
(((f1 `| Z) (#) f2) `| Z) + ((f1 (#) (f2 `| Z)) `| Z)
by A17, B1, FDIFF_2:17
.=
((((f1 `| Z) `| Z) (#) f2) + ((f1 `| Z) (#) (f2 `| Z))) + ((f1 (#) (f2 `| Z)) `| Z)
by A13, A8, FDIFF_2:20
.=
((((diff f1,Z) . 2) (#) f2) + ((f1 `| Z) (#) (f2 `| Z))) + (((f1 `| Z) (#) (f2 `| Z)) + (f1 (#) ((diff f2,Z) . 2)))
by A18, A19, A6, A16, FDIFF_2:20
.=
(((((diff f1,Z) . 2) (#) f2) + ((f1 `| Z) (#) (f2 `| Z))) + ((f1 `| Z) (#) (f2 `| Z))) + (f1 (#) ((diff f2,Z) . 2))
by RFUNCT_1:19
.=
((((diff f1,Z) . 2) (#) f2) + (((f1 `| Z) (#) (f2 `| Z)) + ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
by RFUNCT_1:19
.=
((((diff f1,Z) . 2) (#) f2) + ((1 (#) ((f1 `| Z) (#) (f2 `| Z))) + ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
by RFUNCT_1:33
.=
((((diff f1,Z) . 2) (#) f2) + ((1 (#) ((f1 `| Z) (#) (f2 `| Z))) + (1 (#) ((f1 `| Z) (#) (f2 `| Z))))) + (f1 (#) ((diff f2,Z) . 2))
by RFUNCT_1:33
.=
((((diff f1,Z) . 2) (#) f2) + ((1 + 1) (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
by ThB2
.=
((((diff f1,Z) . 2) (#) f2) + (2 (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
;
hence
(diff (f1 (#) f2),Z) . 2 = ((((diff f1,Z) . 2) (#) f2) + (2 (#) ((f1 `| Z) (#) (f2 `| Z)))) + (f1 (#) ((diff f2,Z) . 2))
; :: thesis: verum