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

Theorem gcdass 16571
Description: Associative law for gcd operator. Theorem 1.4(b) in [ApostolNT] p. 16. (Contributed by Scott Fenton, 2-Apr-2014.) (Revised by Mario Carneiro, 19-Apr-2014.)
Assertion
Ref Expression
gcdass ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = (𝑁 gcd (𝑀 gcd 𝑃)))

Proof of Theorem gcdass
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 anass 472 . . 3 (((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0) ↔ (𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)))
2 anass 472 . . . . 5 (((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃) ↔ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃)))
32rabbii 3418 . . . 4 {𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)} = {𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}
43supeq1i 9386 . . 3 sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )
51, 4ifbieq2i 4503 . 2 if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )) = if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < ))
6 gcdcl 16530 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℕ0)
763adant3 1144 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℕ0)
87nn0zd 12586 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℤ)
9 simp3 1150 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → 𝑃 ∈ ℤ)
10 gcdval 16520 . . . 4 (((𝑁 gcd 𝑀) ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
118, 9, 10syl2anc 593 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
12 gcdeq0 16541 . . . . . . 7 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → ((𝑁 gcd 𝑀) = 0 ↔ (𝑁 = 0 ∧ 𝑀 = 0)))
13123adant3 1144 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) = 0 ↔ (𝑁 = 0 ∧ 𝑀 = 0)))
1413anbi1d 640 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0) ↔ ((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0)))
1514bicomd 225 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0) ↔ ((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0)))
16 simpr 488 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑥 ∈ ℤ)
17 simpl1 1204 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑁 ∈ ℤ)
18 simpl2 1205 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑀 ∈ ℤ)
19 dvdsgcdb 16569 . . . . . . . 8 ((𝑥 ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → ((𝑥𝑁𝑥𝑀) ↔ 𝑥 ∥ (𝑁 gcd 𝑀)))
2016, 17, 18, 19syl3anc 1389 . . . . . . 7 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑁𝑥𝑀) ↔ 𝑥 ∥ (𝑁 gcd 𝑀)))
2120anbi1d 640 . . . . . 6 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → (((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃) ↔ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)))
2221rabbidva 3419 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → {𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)} = {𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)})
2322supeq1d 9385 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < ))
2415, 23ifbieq2d 4504 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
2511, 24eqtr4d 2799 . 2 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
26 simp1 1148 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → 𝑁 ∈ ℤ)
27 gcdcl 16530 . . . . . 6 ((𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℕ0)
28273adant1 1142 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℕ0)
2928nn0zd 12586 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℤ)
30 gcdval 16520 . . . 4 ((𝑁 ∈ ℤ ∧ (𝑀 gcd 𝑃) ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
3126, 29, 30syl2anc 593 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
32 gcdeq0 16541 . . . . . . 7 ((𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑀 gcd 𝑃) = 0 ↔ (𝑀 = 0 ∧ 𝑃 = 0)))
33323adant1 1142 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑀 gcd 𝑃) = 0 ↔ (𝑀 = 0 ∧ 𝑃 = 0)))
3433anbi2d 639 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0) ↔ (𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0))))
3534bicomd 225 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)) ↔ (𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0)))
36 simpl3 1206 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑃 ∈ ℤ)
37 dvdsgcdb 16569 . . . . . . . 8 ((𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑥𝑀𝑥𝑃) ↔ 𝑥 ∥ (𝑀 gcd 𝑃)))
3816, 18, 36, 37syl3anc 1389 . . . . . . 7 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑀𝑥𝑃) ↔ 𝑥 ∥ (𝑀 gcd 𝑃)))
3938anbi2d 639 . . . . . 6 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃)) ↔ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))))
4039rabbidva 3419 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → {𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))} = {𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))})
4140supeq1d 9385 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < ))
4235, 41ifbieq2d 4504 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
4331, 42eqtr4d 2799 . 2 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )))
445, 25, 433eqtr4a 2822 1 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = (𝑁 gcd (𝑀 gcd 𝑃)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 399  w3a 1097   = wceq 1559  wcel 2141  {crab 3413  ifcif 4477   class class class wbr 5097  (class class class)co 7390  supcsup 9379  cr 11065  0cc0 11066   < clt 11209  0cn0 12474  cz 12561  cdvds 16276   gcd cgcd 16518
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1814  ax-4 1828  ax-5 1929  ax-6 1986  ax-7 2027  ax-8 2143  ax-9 2151  ax-10 2174  ax-11 2190  ax-12 2211  ax-ext 2733  ax-sep 5243  ax-nul 5253  ax-pow 5319  ax-pr 5387  ax-un 7712  ax-cnex 11122  ax-resscn 11123  ax-1cn 11124  ax-icn 11125  ax-addcl 11126  ax-addrcl 11127  ax-mulcl 11128  ax-mulrcl 11129  ax-mulcom 11130  ax-addass 11131  ax-mulass 11132  ax-distr 11133  ax-i2m1 11134  ax-1ne0 11135  ax-1rid 11136  ax-rnegex 11137  ax-rrecex 11138  ax-cnre 11139  ax-pre-lttri 11140  ax-pre-lttrn 11141  ax-pre-ltadd 11142  ax-pre-mulgt0 11143  ax-pre-sup 11144
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3or 1098  df-3an 1099  df-tru 1562  df-fal 1572  df-ex 1799  df-nf 1803  df-sb 2090  df-mo 2565  df-eu 2595  df-clab 2740  df-cleq 2753  df-clel 2836  df-nfc 2910  df-ne 2957  df-nel 3061  df-ral 3076  df-rex 3086  df-rmo 3366  df-reu 3367  df-rab 3414  df-v 3455  df-sbc 3743  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4284  df-if 4478  df-pw 4554  df-sn 4580  df-pr 4582  df-op 4586  df-uni 4863  df-iun 4948  df-br 5098  df-opab 5160  df-mpt 5179  df-tr 5205  df-id 5538  df-eprel 5543  df-po 5551  df-so 5552  df-fr 5596  df-we 5598  df-xp 5649  df-rel 5650  df-cnv 5651  df-co 5652  df-dm 5653  df-rn 5654  df-res 5655  df-ima 5656  df-pred 6282  df-ord 6343  df-on 6344  df-lim 6345  df-suc 6346  df-iota 6471  df-fun 6517  df-fn 6518  df-f 6519  df-f1 6520  df-fo 6521  df-f1o 6522  df-fv 6523  df-riota 7347  df-ov 7393  df-oprab 7394  df-mpo 7395  df-om 7841  df-2nd 7965  df-frecs 8255  df-wrecs 8286  df-recs 8335  df-rdg 8374  df-er 8671  df-en 8921  df-dom 8922  df-sdom 8923  df-sup 9381  df-inf 9382  df-pnf 11211  df-mnf 11212  df-xr 11213  df-ltxr 11214  df-le 11215  df-sub 11409  df-neg 11410  df-div 11838  df-nn 12204  df-2 12273  df-3 12274  df-n0 12475  df-z 12562  df-uz 12833  df-rp 12987  df-fl 13795  df-mod 13873  df-seq 14008  df-exp 14068  df-cj 15116  df-re 15117  df-im 15118  df-sqrt 15252  df-abs 15253  df-dvds 16277  df-gcd 16519
This theorem is referenced by:  rpmulgcd  16581  coprimeprodsq  16834  gcd32  36059  gcdabsorb  36060  flt4lem7  43201
  Copyright terms: Public domain W3C validator