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

Theorem lgsabs1 27223
Description: The Legendre symbol is nonzero (and hence equal to 1 or -1) precisely when the arguments are coprime. (Contributed by Mario Carneiro, 5-Feb-2015.)
Assertion
Ref Expression
lgsabs1 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) = 1 ↔ (𝐴 gcd 𝑁) = 1))

Proof of Theorem lgsabs1
StepHypRef Expression
1 lgscl 27198 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (𝐴 /L 𝑁) ∈ ℤ)
21zcnd 12615 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (𝐴 /L 𝑁) ∈ ℂ)
32abscld 15381 . . 3 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (abs‘(𝐴 /L 𝑁)) ∈ ℝ)
4 1re 11150 . . 3 1 ∈ ℝ
5 letri3 11235 . . 3 (((abs‘(𝐴 /L 𝑁)) ∈ ℝ ∧ 1 ∈ ℝ) → ((abs‘(𝐴 /L 𝑁)) = 1 ↔ ((abs‘(𝐴 /L 𝑁)) ≤ 1 ∧ 1 ≤ (abs‘(𝐴 /L 𝑁)))))
63, 4, 5sylancl 586 . 2 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) = 1 ↔ ((abs‘(𝐴 /L 𝑁)) ≤ 1 ∧ 1 ≤ (abs‘(𝐴 /L 𝑁)))))
7 lgsle1 27199 . . 3 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (abs‘(𝐴 /L 𝑁)) ≤ 1)
87biantrurd 532 . 2 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (1 ≤ (abs‘(𝐴 /L 𝑁)) ↔ ((abs‘(𝐴 /L 𝑁)) ≤ 1 ∧ 1 ≤ (abs‘(𝐴 /L 𝑁)))))
9 nnne0 12196 . . . 4 ((abs‘(𝐴 /L 𝑁)) ∈ ℕ → (abs‘(𝐴 /L 𝑁)) ≠ 0)
10 nn0abscl 15254 . . . . . . . 8 ((𝐴 /L 𝑁) ∈ ℤ → (abs‘(𝐴 /L 𝑁)) ∈ ℕ0)
111, 10syl 17 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (abs‘(𝐴 /L 𝑁)) ∈ ℕ0)
12 elnn0 12420 . . . . . . 7 ((abs‘(𝐴 /L 𝑁)) ∈ ℕ0 ↔ ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ∨ (abs‘(𝐴 /L 𝑁)) = 0))
1311, 12sylib 218 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ∨ (abs‘(𝐴 /L 𝑁)) = 0))
1413ord 864 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (¬ (abs‘(𝐴 /L 𝑁)) ∈ ℕ → (abs‘(𝐴 /L 𝑁)) = 0))
1514necon1ad 2942 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ≠ 0 → (abs‘(𝐴 /L 𝑁)) ∈ ℕ))
169, 15impbid2 226 . . 3 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ↔ (abs‘(𝐴 /L 𝑁)) ≠ 0))
17 elnnnn0c 12463 . . . . 5 ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ↔ ((abs‘(𝐴 /L 𝑁)) ∈ ℕ0 ∧ 1 ≤ (abs‘(𝐴 /L 𝑁))))
1817baib 535 . . . 4 ((abs‘(𝐴 /L 𝑁)) ∈ ℕ0 → ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ↔ 1 ≤ (abs‘(𝐴 /L 𝑁))))
1911, 18syl 17 . . 3 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ∈ ℕ ↔ 1 ≤ (abs‘(𝐴 /L 𝑁))))
20 abs00 15231 . . . . . 6 ((𝐴 /L 𝑁) ∈ ℂ → ((abs‘(𝐴 /L 𝑁)) = 0 ↔ (𝐴 /L 𝑁) = 0))
2120necon3bid 2969 . . . . 5 ((𝐴 /L 𝑁) ∈ ℂ → ((abs‘(𝐴 /L 𝑁)) ≠ 0 ↔ (𝐴 /L 𝑁) ≠ 0))
222, 21syl 17 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ≠ 0 ↔ (𝐴 /L 𝑁) ≠ 0))
23 lgsne0 27222 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((𝐴 /L 𝑁) ≠ 0 ↔ (𝐴 gcd 𝑁) = 1))
2422, 23bitrd 279 . . 3 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) ≠ 0 ↔ (𝐴 gcd 𝑁) = 1))
2516, 19, 243bitr3d 309 . 2 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → (1 ≤ (abs‘(𝐴 /L 𝑁)) ↔ (𝐴 gcd 𝑁) = 1))
266, 8, 253bitr2d 307 1 ((𝐴 ∈ ℤ ∧ 𝑁 ∈ ℤ) → ((abs‘(𝐴 /L 𝑁)) = 1 ↔ (𝐴 gcd 𝑁) = 1))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  wo 847   = wceq 1540  wcel 2109  wne 2925   class class class wbr 5102  cfv 6499  (class class class)co 7369  cc 11042  cr 11043  0cc0 11044  1c1 11045  cle 11185  cn 12162  0cn0 12418  cz 12505  abscabs 15176   gcd cgcd 16440   /L clgs 27181
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2701  ax-rep 5229  ax-sep 5246  ax-nul 5256  ax-pow 5315  ax-pr 5382  ax-un 7691  ax-cnex 11100  ax-resscn 11101  ax-1cn 11102  ax-icn 11103  ax-addcl 11104  ax-addrcl 11105  ax-mulcl 11106  ax-mulrcl 11107  ax-mulcom 11108  ax-addass 11109  ax-mulass 11110  ax-distr 11111  ax-i2m1 11112  ax-1ne0 11113  ax-1rid 11114  ax-rnegex 11115  ax-rrecex 11116  ax-cnre 11117  ax-pre-lttri 11118  ax-pre-lttrn 11119  ax-pre-ltadd 11120  ax-pre-mulgt0 11121  ax-pre-sup 11122
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2533  df-eu 2562  df-clab 2708  df-cleq 2721  df-clel 2803  df-nfc 2878  df-ne 2926  df-nel 3030  df-ral 3045  df-rex 3054  df-rmo 3351  df-reu 3352  df-rab 3403  df-v 3446  df-sbc 3751  df-csb 3860  df-dif 3914  df-un 3916  df-in 3918  df-ss 3928  df-pss 3931  df-nul 4293  df-if 4485  df-pw 4561  df-sn 4586  df-pr 4588  df-op 4592  df-uni 4868  df-int 4907  df-iun 4953  df-br 5103  df-opab 5165  df-mpt 5184  df-tr 5210  df-id 5526  df-eprel 5531  df-po 5539  df-so 5540  df-fr 5584  df-we 5586  df-xp 5637  df-rel 5638  df-cnv 5639  df-co 5640  df-dm 5641  df-rn 5642  df-res 5643  df-ima 5644  df-pred 6262  df-ord 6323  df-on 6324  df-lim 6325  df-suc 6326  df-iota 6452  df-fun 6501  df-fn 6502  df-f 6503  df-f1 6504  df-fo 6505  df-f1o 6506  df-fv 6507  df-riota 7326  df-ov 7372  df-oprab 7373  df-mpo 7374  df-om 7823  df-1st 7947  df-2nd 7948  df-frecs 8237  df-wrecs 8268  df-recs 8317  df-rdg 8355  df-1o 8411  df-2o 8412  df-oadd 8415  df-er 8648  df-en 8896  df-dom 8897  df-sdom 8898  df-fin 8899  df-sup 9369  df-inf 9370  df-dju 9830  df-card 9868  df-pnf 11186  df-mnf 11187  df-xr 11188  df-ltxr 11189  df-le 11190  df-sub 11383  df-neg 11384  df-div 11812  df-nn 12163  df-2 12225  df-3 12226  df-n0 12419  df-xnn0 12492  df-z 12506  df-uz 12770  df-q 12884  df-rp 12928  df-fz 13445  df-fzo 13592  df-fl 13730  df-mod 13808  df-seq 13943  df-exp 14003  df-hash 14272  df-cj 15041  df-re 15042  df-im 15043  df-sqrt 15177  df-abs 15178  df-dvds 16199  df-gcd 16441  df-prm 16618  df-phi 16712  df-pc 16784  df-lgs 27182
This theorem is referenced by:  lgssq  27224  lgssq2  27225  lgsquad3  27274
  Copyright terms: Public domain W3C validator