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

Theorem bezoutlemle 12145
Description: Lemma for Bézout's identity. The number satisfying the greatest common divisor condition is the largest number which divides both 𝐴 and 𝐵. (Contributed by Mario Carneiro and Jim Kingdon, 9-Jan-2022.)
Hypotheses
Ref Expression
bezoutlemgcd.1 (𝜑𝐴 ∈ ℤ)
bezoutlemgcd.2 (𝜑𝐵 ∈ ℤ)
bezoutlemgcd.3 (𝜑𝐷 ∈ ℕ0)
bezoutlemgcd.4 (𝜑 → ∀𝑧 ∈ ℤ (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)))
bezoutlemgcd.5 (𝜑 → ¬ (𝐴 = 0 ∧ 𝐵 = 0))
Assertion
Ref Expression
bezoutlemle (𝜑 → ∀𝑧 ∈ ℤ ((𝑧𝐴𝑧𝐵) → 𝑧𝐷))
Distinct variable groups:   𝑧,𝐷   𝑧,𝐴   𝑧,𝐵   𝜑,𝑧

Proof of Theorem bezoutlemle
Dummy variable 𝑤 is distinct from all other variables.
StepHypRef Expression
1 simpr 110 . . . . 5 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (𝑧𝐴𝑧𝐵))
2 breq1 4032 . . . . . . . 8 (𝑧 = 𝑤 → (𝑧𝐷𝑤𝐷))
3 breq1 4032 . . . . . . . . 9 (𝑧 = 𝑤 → (𝑧𝐴𝑤𝐴))
4 breq1 4032 . . . . . . . . 9 (𝑧 = 𝑤 → (𝑧𝐵𝑤𝐵))
53, 4anbi12d 473 . . . . . . . 8 (𝑧 = 𝑤 → ((𝑧𝐴𝑧𝐵) ↔ (𝑤𝐴𝑤𝐵)))
62, 5bibi12d 235 . . . . . . 7 (𝑧 = 𝑤 → ((𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)) ↔ (𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵))))
7 equcom 1717 . . . . . . 7 (𝑧 = 𝑤𝑤 = 𝑧)
8 bicom 140 . . . . . . 7 (((𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)) ↔ (𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵))) ↔ ((𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵)) ↔ (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵))))
96, 7, 83imtr3i 200 . . . . . 6 (𝑤 = 𝑧 → ((𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵)) ↔ (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵))))
10 bezoutlemgcd.4 . . . . . . . 8 (𝜑 → ∀𝑧 ∈ ℤ (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)))
116cbvralv 2726 . . . . . . . 8 (∀𝑧 ∈ ℤ (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)) ↔ ∀𝑤 ∈ ℤ (𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵)))
1210, 11sylib 122 . . . . . . 7 (𝜑 → ∀𝑤 ∈ ℤ (𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵)))
1312ad2antrr 488 . . . . . 6 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → ∀𝑤 ∈ ℤ (𝑤𝐷 ↔ (𝑤𝐴𝑤𝐵)))
14 simplr 528 . . . . . 6 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝑧 ∈ ℤ)
159, 13, 14rspcdva 2869 . . . . 5 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)))
161, 15mpbird 167 . . . 4 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝑧𝐷)
17 bezoutlemgcd.3 . . . . . . 7 (𝜑𝐷 ∈ ℕ0)
1817ad2antrr 488 . . . . . 6 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐷 ∈ ℕ0)
19 bezoutlemgcd.5 . . . . . . . . 9 (𝜑 → ¬ (𝐴 = 0 ∧ 𝐵 = 0))
2019ad2antrr 488 . . . . . . . 8 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → ¬ (𝐴 = 0 ∧ 𝐵 = 0))
21 breq1 4032 . . . . . . . . . . . 12 (𝑧 = 0 → (𝑧𝐷 ↔ 0 ∥ 𝐷))
22 breq1 4032 . . . . . . . . . . . . 13 (𝑧 = 0 → (𝑧𝐴 ↔ 0 ∥ 𝐴))
23 breq1 4032 . . . . . . . . . . . . 13 (𝑧 = 0 → (𝑧𝐵 ↔ 0 ∥ 𝐵))
2422, 23anbi12d 473 . . . . . . . . . . . 12 (𝑧 = 0 → ((𝑧𝐴𝑧𝐵) ↔ (0 ∥ 𝐴 ∧ 0 ∥ 𝐵)))
2521, 24bibi12d 235 . . . . . . . . . . 11 (𝑧 = 0 → ((𝑧𝐷 ↔ (𝑧𝐴𝑧𝐵)) ↔ (0 ∥ 𝐷 ↔ (0 ∥ 𝐴 ∧ 0 ∥ 𝐵))))
26 0zd 9329 . . . . . . . . . . 11 (𝜑 → 0 ∈ ℤ)
2725, 10, 26rspcdva 2869 . . . . . . . . . 10 (𝜑 → (0 ∥ 𝐷 ↔ (0 ∥ 𝐴 ∧ 0 ∥ 𝐵)))
2827ad2antrr 488 . . . . . . . . 9 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (0 ∥ 𝐷 ↔ (0 ∥ 𝐴 ∧ 0 ∥ 𝐵)))
2918nn0zd 9437 . . . . . . . . . 10 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐷 ∈ ℤ)
30 0dvds 11954 . . . . . . . . . 10 (𝐷 ∈ ℤ → (0 ∥ 𝐷𝐷 = 0))
3129, 30syl 14 . . . . . . . . 9 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (0 ∥ 𝐷𝐷 = 0))
32 bezoutlemgcd.1 . . . . . . . . . . . 12 (𝜑𝐴 ∈ ℤ)
3332ad2antrr 488 . . . . . . . . . . 11 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐴 ∈ ℤ)
34 0dvds 11954 . . . . . . . . . . 11 (𝐴 ∈ ℤ → (0 ∥ 𝐴𝐴 = 0))
3533, 34syl 14 . . . . . . . . . 10 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (0 ∥ 𝐴𝐴 = 0))
36 bezoutlemgcd.2 . . . . . . . . . . . 12 (𝜑𝐵 ∈ ℤ)
3736ad2antrr 488 . . . . . . . . . . 11 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐵 ∈ ℤ)
38 0dvds 11954 . . . . . . . . . . 11 (𝐵 ∈ ℤ → (0 ∥ 𝐵𝐵 = 0))
3937, 38syl 14 . . . . . . . . . 10 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (0 ∥ 𝐵𝐵 = 0))
4035, 39anbi12d 473 . . . . . . . . 9 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → ((0 ∥ 𝐴 ∧ 0 ∥ 𝐵) ↔ (𝐴 = 0 ∧ 𝐵 = 0)))
4128, 31, 403bitr3d 218 . . . . . . . 8 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (𝐷 = 0 ↔ (𝐴 = 0 ∧ 𝐵 = 0)))
4220, 41mtbird 674 . . . . . . 7 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → ¬ 𝐷 = 0)
4342neqned 2371 . . . . . 6 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐷 ≠ 0)
44 elnnne0 9254 . . . . . 6 (𝐷 ∈ ℕ ↔ (𝐷 ∈ ℕ0𝐷 ≠ 0))
4518, 43, 44sylanbrc 417 . . . . 5 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝐷 ∈ ℕ)
46 dvdsle 11986 . . . . 5 ((𝑧 ∈ ℤ ∧ 𝐷 ∈ ℕ) → (𝑧𝐷𝑧𝐷))
4714, 45, 46syl2anc 411 . . . 4 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → (𝑧𝐷𝑧𝐷))
4816, 47mpd 13 . . 3 (((𝜑𝑧 ∈ ℤ) ∧ (𝑧𝐴𝑧𝐵)) → 𝑧𝐷)
4948ex 115 . 2 ((𝜑𝑧 ∈ ℤ) → ((𝑧𝐴𝑧𝐵) → 𝑧𝐷))
5049ralrimiva 2567 1 (𝜑 → ∀𝑧 ∈ ℤ ((𝑧𝐴𝑧𝐵) → 𝑧𝐷))
Colors of variables: wff set class
Syntax hints:  ¬ wn 3  wi 4  wa 104  wb 105   = wceq 1364  wcel 2164  wne 2364  wral 2472   class class class wbr 4029  0cc0 7872  cle 8055  cn 8982  0cn0 9240  cz 9317  cdvds 11930
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 615  ax-in2 616  ax-io 710  ax-5 1458  ax-7 1459  ax-gen 1460  ax-ie1 1504  ax-ie2 1505  ax-8 1515  ax-10 1516  ax-11 1517  ax-i12 1518  ax-bndl 1520  ax-4 1521  ax-17 1537  ax-i9 1541  ax-ial 1545  ax-i5r 1546  ax-13 2166  ax-14 2167  ax-ext 2175  ax-sep 4147  ax-pow 4203  ax-pr 4238  ax-un 4464  ax-setind 4569  ax-cnex 7963  ax-resscn 7964  ax-1cn 7965  ax-1re 7966  ax-icn 7967  ax-addcl 7968  ax-addrcl 7969  ax-mulcl 7970  ax-mulrcl 7971  ax-addcom 7972  ax-mulcom 7973  ax-addass 7974  ax-mulass 7975  ax-distr 7976  ax-i2m1 7977  ax-0lt1 7978  ax-1rid 7979  ax-0id 7980  ax-rnegex 7981  ax-precex 7982  ax-cnre 7983  ax-pre-ltirr 7984  ax-pre-ltwlin 7985  ax-pre-lttrn 7986  ax-pre-apti 7987  ax-pre-ltadd 7988  ax-pre-mulgt0 7989  ax-pre-mulext 7990
This theorem depends on definitions:  df-bi 117  df-3or 981  df-3an 982  df-tru 1367  df-fal 1370  df-nf 1472  df-sb 1774  df-eu 2045  df-mo 2046  df-clab 2180  df-cleq 2186  df-clel 2189  df-nfc 2325  df-ne 2365  df-nel 2460  df-ral 2477  df-rex 2478  df-reu 2479  df-rmo 2480  df-rab 2481  df-v 2762  df-sbc 2986  df-csb 3081  df-dif 3155  df-un 3157  df-in 3159  df-ss 3166  df-nul 3447  df-pw 3603  df-sn 3624  df-pr 3625  df-op 3627  df-uni 3836  df-int 3871  df-iun 3914  df-br 4030  df-opab 4091  df-mpt 4092  df-id 4324  df-po 4327  df-iso 4328  df-xp 4665  df-rel 4666  df-cnv 4667  df-co 4668  df-dm 4669  df-rn 4670  df-res 4671  df-ima 4672  df-iota 5215  df-fun 5256  df-fn 5257  df-f 5258  df-fv 5262  df-riota 5873  df-ov 5921  df-oprab 5922  df-mpo 5923  df-1st 6193  df-2nd 6194  df-pnf 8056  df-mnf 8057  df-xr 8058  df-ltxr 8059  df-le 8060  df-sub 8192  df-neg 8193  df-reap 8594  df-ap 8601  df-div 8692  df-inn 8983  df-n0 9241  df-z 9318  df-q 9685  df-dvds 11931
This theorem is referenced by:  bezoutlemsup  12146
  Copyright terms: Public domain W3C validator