Metamath Proof Explorer


Theorem ofdivdiv2

Description: Function analogue of divdiv2 . (Contributed by Steve Rodriguez, 23-Nov-2015)

Ref Expression
Assertion ofdivdiv2 ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → ( 𝐹f / ( 𝐺f / 𝐻 ) ) = ( ( 𝐹f · 𝐻 ) ∘f / 𝐺 ) )

Proof

Step Hyp Ref Expression
1 simpll ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐴𝑉 )
2 simplr ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐹 : 𝐴 ⟶ ℂ )
3 2 ffnd ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐹 Fn 𝐴 )
4 simprl ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) )
5 4 ffnd ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐺 Fn 𝐴 )
6 simprr ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) )
7 6 ffnd ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → 𝐻 Fn 𝐴 )
8 inidm ( 𝐴𝐴 ) = 𝐴
9 5 7 1 1 8 offn ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → ( 𝐺f / 𝐻 ) Fn 𝐴 )
10 3 7 1 1 8 offn ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → ( 𝐹f · 𝐻 ) Fn 𝐴 )
11 10 5 1 1 8 offn ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → ( ( 𝐹f · 𝐻 ) ∘f / 𝐺 ) Fn 𝐴 )
12 eqidd ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( 𝐹𝑥 ) = ( 𝐹𝑥 ) )
13 eqidd ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐺f / 𝐻 ) ‘ 𝑥 ) = ( ( 𝐺f / 𝐻 ) ‘ 𝑥 ) )
14 ffvelrn ( ( 𝐹 : 𝐴 ⟶ ℂ ∧ 𝑥𝐴 ) → ( 𝐹𝑥 ) ∈ ℂ )
15 2 14 sylan ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( 𝐹𝑥 ) ∈ ℂ )
16 ffvelrn ( ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝑥𝐴 ) → ( 𝐺𝑥 ) ∈ ( ℂ ∖ { 0 } ) )
17 eldifsn ( ( 𝐺𝑥 ) ∈ ( ℂ ∖ { 0 } ) ↔ ( ( 𝐺𝑥 ) ∈ ℂ ∧ ( 𝐺𝑥 ) ≠ 0 ) )
18 16 17 sylib ( ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝑥𝐴 ) → ( ( 𝐺𝑥 ) ∈ ℂ ∧ ( 𝐺𝑥 ) ≠ 0 ) )
19 4 18 sylan ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐺𝑥 ) ∈ ℂ ∧ ( 𝐺𝑥 ) ≠ 0 ) )
20 ffvelrn ( ( 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝑥𝐴 ) → ( 𝐻𝑥 ) ∈ ( ℂ ∖ { 0 } ) )
21 eldifsn ( ( 𝐻𝑥 ) ∈ ( ℂ ∖ { 0 } ) ↔ ( ( 𝐻𝑥 ) ∈ ℂ ∧ ( 𝐻𝑥 ) ≠ 0 ) )
22 20 21 sylib ( ( 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝑥𝐴 ) → ( ( 𝐻𝑥 ) ∈ ℂ ∧ ( 𝐻𝑥 ) ≠ 0 ) )
23 6 22 sylan ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐻𝑥 ) ∈ ℂ ∧ ( 𝐻𝑥 ) ≠ 0 ) )
24 divdiv2 ( ( ( 𝐹𝑥 ) ∈ ℂ ∧ ( ( 𝐺𝑥 ) ∈ ℂ ∧ ( 𝐺𝑥 ) ≠ 0 ) ∧ ( ( 𝐻𝑥 ) ∈ ℂ ∧ ( 𝐻𝑥 ) ≠ 0 ) ) → ( ( 𝐹𝑥 ) / ( ( 𝐺𝑥 ) / ( 𝐻𝑥 ) ) ) = ( ( ( 𝐹𝑥 ) · ( 𝐻𝑥 ) ) / ( 𝐺𝑥 ) ) )
25 15 19 23 24 syl3anc ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐹𝑥 ) / ( ( 𝐺𝑥 ) / ( 𝐻𝑥 ) ) ) = ( ( ( 𝐹𝑥 ) · ( 𝐻𝑥 ) ) / ( 𝐺𝑥 ) ) )
26 eqidd ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( 𝐺𝑥 ) = ( 𝐺𝑥 ) )
27 eqidd ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( 𝐻𝑥 ) = ( 𝐻𝑥 ) )
28 5 7 1 1 8 26 27 ofval ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐺f / 𝐻 ) ‘ 𝑥 ) = ( ( 𝐺𝑥 ) / ( 𝐻𝑥 ) ) )
29 28 oveq2d ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐹𝑥 ) / ( ( 𝐺f / 𝐻 ) ‘ 𝑥 ) ) = ( ( 𝐹𝑥 ) / ( ( 𝐺𝑥 ) / ( 𝐻𝑥 ) ) ) )
30 3 7 1 1 8 12 27 ofval ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐹f · 𝐻 ) ‘ 𝑥 ) = ( ( 𝐹𝑥 ) · ( 𝐻𝑥 ) ) )
31 10 5 1 1 8 30 26 ofval ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( ( 𝐹f · 𝐻 ) ∘f / 𝐺 ) ‘ 𝑥 ) = ( ( ( 𝐹𝑥 ) · ( 𝐻𝑥 ) ) / ( 𝐺𝑥 ) ) )
32 25 29 31 3eqtr4d ( ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) ∧ 𝑥𝐴 ) → ( ( 𝐹𝑥 ) / ( ( 𝐺f / 𝐻 ) ‘ 𝑥 ) ) = ( ( ( 𝐹f · 𝐻 ) ∘f / 𝐺 ) ‘ 𝑥 ) )
33 1 3 9 11 12 13 32 offveq ( ( ( 𝐴𝑉𝐹 : 𝐴 ⟶ ℂ ) ∧ ( 𝐺 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ∧ 𝐻 : 𝐴 ⟶ ( ℂ ∖ { 0 } ) ) ) → ( 𝐹f / ( 𝐺f / 𝐻 ) ) = ( ( 𝐹f · 𝐻 ) ∘f / 𝐺 ) )