MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  gcddiv Structured version   Visualization version   GIF version

Theorem gcddiv 15758
Description: Division law for GCD. (Contributed by Scott Fenton, 18-Apr-2014.) (Revised by Mario Carneiro, 19-Apr-2014.)
Assertion
Ref Expression
gcddiv (((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) ∧ (𝐶𝐴𝐶𝐵)) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶)))

Proof of Theorem gcddiv
Dummy variables 𝑎 𝑏 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 nnz 11820 . . . . . . 7 (𝐶 ∈ ℕ → 𝐶 ∈ ℤ)
213ad2ant3 1115 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝐶 ∈ ℤ)
3 simp1 1116 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝐴 ∈ ℤ)
4 divides 15472 . . . . . 6 ((𝐶 ∈ ℤ ∧ 𝐴 ∈ ℤ) → (𝐶𝐴 ↔ ∃𝑎 ∈ ℤ (𝑎 · 𝐶) = 𝐴))
52, 3, 4syl2anc 576 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (𝐶𝐴 ↔ ∃𝑎 ∈ ℤ (𝑎 · 𝐶) = 𝐴))
6 simp2 1117 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝐵 ∈ ℤ)
7 divides 15472 . . . . . 6 ((𝐶 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝐶𝐵 ↔ ∃𝑏 ∈ ℤ (𝑏 · 𝐶) = 𝐵))
82, 6, 7syl2anc 576 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (𝐶𝐵 ↔ ∃𝑏 ∈ ℤ (𝑏 · 𝐶) = 𝐵))
95, 8anbi12d 621 . . . 4 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝐶𝐴𝐶𝐵) ↔ (∃𝑎 ∈ ℤ (𝑎 · 𝐶) = 𝐴 ∧ ∃𝑏 ∈ ℤ (𝑏 · 𝐶) = 𝐵)))
10 reeanv 3308 . . . 4 (∃𝑎 ∈ ℤ ∃𝑏 ∈ ℤ ((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) ↔ (∃𝑎 ∈ ℤ (𝑎 · 𝐶) = 𝐴 ∧ ∃𝑏 ∈ ℤ (𝑏 · 𝐶) = 𝐵))
119, 10syl6bbr 281 . . 3 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝐶𝐴𝐶𝐵) ↔ ∃𝑎 ∈ ℤ ∃𝑏 ∈ ℤ ((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵)))
12 gcdcl 15718 . . . . . . . . . . . 12 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ) → (𝑎 gcd 𝑏) ∈ ℕ0)
1312nn0cnd 11772 . . . . . . . . . . 11 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ) → (𝑎 gcd 𝑏) ∈ ℂ)
14133adant3 1112 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (𝑎 gcd 𝑏) ∈ ℂ)
15 nncn 11450 . . . . . . . . . . 11 (𝐶 ∈ ℕ → 𝐶 ∈ ℂ)
16153ad2ant3 1115 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝐶 ∈ ℂ)
17 nnne0 11477 . . . . . . . . . . 11 (𝐶 ∈ ℕ → 𝐶 ≠ 0)
18173ad2ant3 1115 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝐶 ≠ 0)
1914, 16, 18divcan4d 11225 . . . . . . . . 9 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (((𝑎 gcd 𝑏) · 𝐶) / 𝐶) = (𝑎 gcd 𝑏))
20 nnnn0 11718 . . . . . . . . . . 11 (𝐶 ∈ ℕ → 𝐶 ∈ ℕ0)
21 mulgcdr 15757 . . . . . . . . . . 11 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ0) → ((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) = ((𝑎 gcd 𝑏) · 𝐶))
2220, 21syl3an3 1145 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) = ((𝑎 gcd 𝑏) · 𝐶))
2322oveq1d 6993 . . . . . . . . 9 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) / 𝐶) = (((𝑎 gcd 𝑏) · 𝐶) / 𝐶))
24 zcn 11801 . . . . . . . . . . . 12 (𝑎 ∈ ℤ → 𝑎 ∈ ℂ)
25243ad2ant1 1113 . . . . . . . . . . 11 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝑎 ∈ ℂ)
2625, 16, 18divcan4d 11225 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝑎 · 𝐶) / 𝐶) = 𝑎)
27 zcn 11801 . . . . . . . . . . . 12 (𝑏 ∈ ℤ → 𝑏 ∈ ℂ)
28273ad2ant2 1114 . . . . . . . . . . 11 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → 𝑏 ∈ ℂ)
2928, 16, 18divcan4d 11225 . . . . . . . . . 10 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝑏 · 𝐶) / 𝐶) = 𝑏)
3026, 29oveq12d 6996 . . . . . . . . 9 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (((𝑎 · 𝐶) / 𝐶) gcd ((𝑏 · 𝐶) / 𝐶)) = (𝑎 gcd 𝑏))
3119, 23, 303eqtr4d 2824 . . . . . . . 8 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) / 𝐶) = (((𝑎 · 𝐶) / 𝐶) gcd ((𝑏 · 𝐶) / 𝐶)))
32 oveq12 6987 . . . . . . . . . 10 (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) = (𝐴 gcd 𝐵))
3332oveq1d 6993 . . . . . . . . 9 (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → (((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) / 𝐶) = ((𝐴 gcd 𝐵) / 𝐶))
34 oveq1 6985 . . . . . . . . . 10 ((𝑎 · 𝐶) = 𝐴 → ((𝑎 · 𝐶) / 𝐶) = (𝐴 / 𝐶))
35 oveq1 6985 . . . . . . . . . 10 ((𝑏 · 𝐶) = 𝐵 → ((𝑏 · 𝐶) / 𝐶) = (𝐵 / 𝐶))
3634, 35oveqan12d 6997 . . . . . . . . 9 (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → (((𝑎 · 𝐶) / 𝐶) gcd ((𝑏 · 𝐶) / 𝐶)) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶)))
3733, 36eqeq12d 2793 . . . . . . . 8 (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((((𝑎 · 𝐶) gcd (𝑏 · 𝐶)) / 𝐶) = (((𝑎 · 𝐶) / 𝐶) gcd ((𝑏 · 𝐶) / 𝐶)) ↔ ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
3831, 37syl5ibcom 237 . . . . . . 7 ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
39383expa 1098 . . . . . 6 (((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ) ∧ 𝐶 ∈ ℕ) → (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
4039expcom 406 . . . . 5 (𝐶 ∈ ℕ → ((𝑎 ∈ ℤ ∧ 𝑏 ∈ ℤ) → (((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶)))))
4140rexlimdvv 3238 . . . 4 (𝐶 ∈ ℕ → (∃𝑎 ∈ ℤ ∃𝑏 ∈ ℤ ((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
42413ad2ant3 1115 . . 3 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → (∃𝑎 ∈ ℤ ∃𝑏 ∈ ℤ ((𝑎 · 𝐶) = 𝐴 ∧ (𝑏 · 𝐶) = 𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
4311, 42sylbid 232 . 2 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) → ((𝐶𝐴𝐶𝐵) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶))))
4443imp 398 1 (((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝐶 ∈ ℕ) ∧ (𝐶𝐴𝐶𝐵)) → ((𝐴 gcd 𝐵) / 𝐶) = ((𝐴 / 𝐶) gcd (𝐵 / 𝐶)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 198  wa 387  w3a 1068   = wceq 1507  wcel 2050  wne 2967  wrex 3089   class class class wbr 4930  (class class class)co 6978  cc 10335  0cc0 10337   · cmul 10342   / cdiv 11100  cn 11441  0cn0 11710  cz 11796  cdvds 15470   gcd cgcd 15706
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1758  ax-4 1772  ax-5 1869  ax-6 1928  ax-7 1965  ax-8 2052  ax-9 2059  ax-10 2079  ax-11 2093  ax-12 2106  ax-13 2301  ax-ext 2750  ax-sep 5061  ax-nul 5068  ax-pow 5120  ax-pr 5187  ax-un 7281  ax-cnex 10393  ax-resscn 10394  ax-1cn 10395  ax-icn 10396  ax-addcl 10397  ax-addrcl 10398  ax-mulcl 10399  ax-mulrcl 10400  ax-mulcom 10401  ax-addass 10402  ax-mulass 10403  ax-distr 10404  ax-i2m1 10405  ax-1ne0 10406  ax-1rid 10407  ax-rnegex 10408  ax-rrecex 10409  ax-cnre 10410  ax-pre-lttri 10411  ax-pre-lttrn 10412  ax-pre-ltadd 10413  ax-pre-mulgt0 10414  ax-pre-sup 10415
This theorem depends on definitions:  df-bi 199  df-an 388  df-or 834  df-3or 1069  df-3an 1070  df-tru 1510  df-ex 1743  df-nf 1747  df-sb 2016  df-mo 2547  df-eu 2583  df-clab 2759  df-cleq 2771  df-clel 2846  df-nfc 2918  df-ne 2968  df-nel 3074  df-ral 3093  df-rex 3094  df-reu 3095  df-rmo 3096  df-rab 3097  df-v 3417  df-sbc 3684  df-csb 3789  df-dif 3834  df-un 3836  df-in 3838  df-ss 3845  df-pss 3847  df-nul 4181  df-if 4352  df-pw 4425  df-sn 4443  df-pr 4445  df-tp 4447  df-op 4449  df-uni 4714  df-iun 4795  df-br 4931  df-opab 4993  df-mpt 5010  df-tr 5032  df-id 5313  df-eprel 5318  df-po 5327  df-so 5328  df-fr 5367  df-we 5369  df-xp 5414  df-rel 5415  df-cnv 5416  df-co 5417  df-dm 5418  df-rn 5419  df-res 5420  df-ima 5421  df-pred 5988  df-ord 6034  df-on 6035  df-lim 6036  df-suc 6037  df-iota 6154  df-fun 6192  df-fn 6193  df-f 6194  df-f1 6195  df-fo 6196  df-f1o 6197  df-fv 6198  df-riota 6939  df-ov 6981  df-oprab 6982  df-mpo 6983  df-om 7399  df-2nd 7504  df-wrecs 7752  df-recs 7814  df-rdg 7852  df-er 8091  df-en 8309  df-dom 8310  df-sdom 8311  df-sup 8703  df-inf 8704  df-pnf 10478  df-mnf 10479  df-xr 10480  df-ltxr 10481  df-le 10482  df-sub 10674  df-neg 10675  df-div 11101  df-nn 11442  df-2 11506  df-3 11507  df-n0 11711  df-z 11797  df-uz 12062  df-rp 12208  df-fl 12980  df-mod 13056  df-seq 13188  df-exp 13248  df-cj 14322  df-re 14323  df-im 14324  df-sqrt 14458  df-abs 14459  df-dvds 15471  df-gcd 15707
This theorem is referenced by:  sqgcd  15768  divgcdodd  15913  divnumden  15947  hashgcdlem  15984  pythagtriplem19  16029  expgcd  38615
  Copyright terms: Public domain W3C validator