ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  gcdass GIF version

Theorem gcdass 11610
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 396 . . 3 (((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0) ↔ (𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)))
2 anass 396 . . . . . 6 (((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃) ↔ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃)))
32a1i 9 . . . . 5 (𝑥 ∈ ℤ → (((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃) ↔ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))))
43rabbiia 2643 . . . 4 {𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)} = {𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}
54supeq1i 6841 . . 3 sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )
61, 5ifbieq2i 3463 . 2 if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )) = if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < ))
7 gcdcl 11562 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℕ0)
873adant3 984 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℕ0)
98nn0zd 9125 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd 𝑀) ∈ ℤ)
10 simp3 966 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → 𝑃 ∈ ℤ)
11 gcdval 11555 . . . 4 (((𝑁 gcd 𝑀) ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
129, 10, 11syl2anc 406 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
13 gcdeq0 11572 . . . . . . 7 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → ((𝑁 gcd 𝑀) = 0 ↔ (𝑁 = 0 ∧ 𝑀 = 0)))
14133adant3 984 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) = 0 ↔ (𝑁 = 0 ∧ 𝑀 = 0)))
1514anbi1d 458 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0) ↔ ((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0)))
1615bicomd 140 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0) ↔ ((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0)))
17 simpr 109 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑥 ∈ ℤ)
18 simpl1 967 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑁 ∈ ℤ)
19 simpl2 968 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑀 ∈ ℤ)
20 dvdsgcdb 11608 . . . . . . . 8 ((𝑥 ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → ((𝑥𝑁𝑥𝑀) ↔ 𝑥 ∥ (𝑁 gcd 𝑀)))
2117, 18, 19, 20syl3anc 1199 . . . . . . 7 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑁𝑥𝑀) ↔ 𝑥 ∥ (𝑁 gcd 𝑀)))
2221anbi1d 458 . . . . . 6 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → (((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃) ↔ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)))
2322rabbidva 2646 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → {𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)} = {𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)})
2423supeq1d 6840 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < ))
2516, 24ifbieq2d 3464 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )) = if(((𝑁 gcd 𝑀) = 0 ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥 ∥ (𝑁 gcd 𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
2612, 25eqtr4d 2151 . 2 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = if(((𝑁 = 0 ∧ 𝑀 = 0) ∧ 𝑃 = 0), 0, sup({𝑥 ∈ ℤ ∣ ((𝑥𝑁𝑥𝑀) ∧ 𝑥𝑃)}, ℝ, < )))
27 simp1 964 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → 𝑁 ∈ ℤ)
28 gcdcl 11562 . . . . . 6 ((𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℕ0)
29283adant1 982 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℕ0)
3029nn0zd 9125 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑀 gcd 𝑃) ∈ ℤ)
31 gcdval 11555 . . . 4 ((𝑁 ∈ ℤ ∧ (𝑀 gcd 𝑃) ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
3227, 30, 31syl2anc 406 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
33 gcdeq0 11572 . . . . . . 7 ((𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑀 gcd 𝑃) = 0 ↔ (𝑀 = 0 ∧ 𝑃 = 0)))
34333adant1 982 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑀 gcd 𝑃) = 0 ↔ (𝑀 = 0 ∧ 𝑃 = 0)))
3534anbi2d 457 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0) ↔ (𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0))))
3635bicomd 140 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)) ↔ (𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0)))
37 simpl3 969 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → 𝑃 ∈ ℤ)
38 dvdsgcdb 11608 . . . . . . . 8 ((𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑥𝑀𝑥𝑃) ↔ 𝑥 ∥ (𝑀 gcd 𝑃)))
3917, 19, 37, 38syl3anc 1199 . . . . . . 7 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑀𝑥𝑃) ↔ 𝑥 ∥ (𝑀 gcd 𝑃)))
4039anbi2d 457 . . . . . 6 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) ∧ 𝑥 ∈ ℤ) → ((𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃)) ↔ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))))
4140rabbidva 2646 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → {𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))} = {𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))})
4241supeq1d 6840 . . . 4 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < ) = sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < ))
4336, 42ifbieq2d 3464 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )) = if((𝑁 = 0 ∧ (𝑀 gcd 𝑃) = 0), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁𝑥 ∥ (𝑀 gcd 𝑃))}, ℝ, < )))
4432, 43eqtr4d 2151 . 2 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝑁 gcd (𝑀 gcd 𝑃)) = if((𝑁 = 0 ∧ (𝑀 = 0 ∧ 𝑃 = 0)), 0, sup({𝑥 ∈ ℤ ∣ (𝑥𝑁 ∧ (𝑥𝑀𝑥𝑃))}, ℝ, < )))
456, 26, 443eqtr4a 2174 1 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑃 ∈ ℤ) → ((𝑁 gcd 𝑀) gcd 𝑃) = (𝑁 gcd (𝑀 gcd 𝑃)))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 103  wb 104  w3a 945   = wceq 1314  wcel 1463  {crab 2395  ifcif 3442   class class class wbr 3897  (class class class)co 5740  supcsup 6835  cr 7583  0cc0 7584   < clt 7764  0cn0 8931  cz 9008  cdvds 11400   gcd cgcd 11542
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 105  ax-ia2 106  ax-ia3 107  ax-in1 586  ax-in2 587  ax-io 681  ax-5 1406  ax-7 1407  ax-gen 1408  ax-ie1 1452  ax-ie2 1453  ax-8 1465  ax-10 1466  ax-11 1467  ax-i12 1468  ax-bndl 1469  ax-4 1470  ax-13 1474  ax-14 1475  ax-17 1489  ax-i9 1493  ax-ial 1497  ax-i5r 1498  ax-ext 2097  ax-coll 4011  ax-sep 4014  ax-nul 4022  ax-pow 4066  ax-pr 4099  ax-un 4323  ax-setind 4420  ax-iinf 4470  ax-cnex 7675  ax-resscn 7676  ax-1cn 7677  ax-1re 7678  ax-icn 7679  ax-addcl 7680  ax-addrcl 7681  ax-mulcl 7682  ax-mulrcl 7683  ax-addcom 7684  ax-mulcom 7685  ax-addass 7686  ax-mulass 7687  ax-distr 7688  ax-i2m1 7689  ax-0lt1 7690  ax-1rid 7691  ax-0id 7692  ax-rnegex 7693  ax-precex 7694  ax-cnre 7695  ax-pre-ltirr 7696  ax-pre-ltwlin 7697  ax-pre-lttrn 7698  ax-pre-apti 7699  ax-pre-ltadd 7700  ax-pre-mulgt0 7701  ax-pre-mulext 7702  ax-arch 7703  ax-caucvg 7704
This theorem depends on definitions:  df-bi 116  df-stab 799  df-dc 803  df-3or 946  df-3an 947  df-tru 1317  df-fal 1320  df-nf 1420  df-sb 1719  df-eu 1978  df-mo 1979  df-clab 2102  df-cleq 2108  df-clel 2111  df-nfc 2245  df-ne 2284  df-nel 2379  df-ral 2396  df-rex 2397  df-reu 2398  df-rmo 2399  df-rab 2400  df-v 2660  df-sbc 2881  df-csb 2974  df-dif 3041  df-un 3043  df-in 3045  df-ss 3052  df-nul 3332  df-if 3443  df-pw 3480  df-sn 3501  df-pr 3502  df-op 3504  df-uni 3705  df-int 3740  df-iun 3783  df-br 3898  df-opab 3958  df-mpt 3959  df-tr 3995  df-id 4183  df-po 4186  df-iso 4187  df-iord 4256  df-on 4258  df-ilim 4259  df-suc 4261  df-iom 4473  df-xp 4513  df-rel 4514  df-cnv 4515  df-co 4516  df-dm 4517  df-rn 4518  df-res 4519  df-ima 4520  df-iota 5056  df-fun 5093  df-fn 5094  df-f 5095  df-f1 5096  df-fo 5097  df-f1o 5098  df-fv 5099  df-riota 5696  df-ov 5743  df-oprab 5744  df-mpo 5745  df-1st 6004  df-2nd 6005  df-recs 6168  df-frec 6254  df-sup 6837  df-pnf 7766  df-mnf 7767  df-xr 7768  df-ltxr 7769  df-le 7770  df-sub 7899  df-neg 7900  df-reap 8300  df-ap 8307  df-div 8396  df-inn 8681  df-2 8739  df-3 8740  df-4 8741  df-n0 8932  df-z 9009  df-uz 9279  df-q 9364  df-rp 9394  df-fz 9742  df-fzo 9871  df-fl 9994  df-mod 10047  df-seqfrec 10170  df-exp 10244  df-cj 10565  df-re 10566  df-im 10567  df-rsqrt 10721  df-abs 10722  df-dvds 11401  df-gcd 11543
This theorem is referenced by:  rpmulgcd  11621
  Copyright terms: Public domain W3C validator