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

Theorem lgsvalmod 24958
Description: The Legendre symbol is equivalent to 𝑎↑((𝑝 − 1) / 2), mod 𝑝. This theorem is also called "Euler's criterion", see theorem 9.2 in [ApostolNT] p. 180, or a representation of Euler's criterion using the Legendre symbol, see also lgsqr 24993. (Contributed by Mario Carneiro, 4-Feb-2015.)
Assertion
Ref Expression
lgsvalmod ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴 /L 𝑃) mod 𝑃) = ((𝐴↑((𝑃 − 1) / 2)) mod 𝑃))

Proof of Theorem lgsvalmod
StepHypRef Expression
1 eldifi 3715 . . . . . . . 8 (𝑃 ∈ (ℙ ∖ {2}) → 𝑃 ∈ ℙ)
21adantl 482 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → 𝑃 ∈ ℙ)
3 prmz 15324 . . . . . . 7 (𝑃 ∈ ℙ → 𝑃 ∈ ℤ)
42, 3syl 17 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → 𝑃 ∈ ℤ)
5 lgscl 24953 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ ℤ) → (𝐴 /L 𝑃) ∈ ℤ)
64, 5syldan 487 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴 /L 𝑃) ∈ ℤ)
76zred 11434 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴 /L 𝑃) ∈ ℝ)
8 peano2re 10161 . . . 4 ((𝐴 /L 𝑃) ∈ ℝ → ((𝐴 /L 𝑃) + 1) ∈ ℝ)
97, 8syl 17 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴 /L 𝑃) + 1) ∈ ℝ)
10 oddprm 15450 . . . . . . . 8 (𝑃 ∈ (ℙ ∖ {2}) → ((𝑃 − 1) / 2) ∈ ℕ)
1110adantl 482 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝑃 − 1) / 2) ∈ ℕ)
1211nnnn0d 11303 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝑃 − 1) / 2) ∈ ℕ0)
13 zexpcl 12823 . . . . . 6 ((𝐴 ∈ ℤ ∧ ((𝑃 − 1) / 2) ∈ ℕ0) → (𝐴↑((𝑃 − 1) / 2)) ∈ ℤ)
1412, 13syldan 487 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴↑((𝑃 − 1) / 2)) ∈ ℤ)
1514zred 11434 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴↑((𝑃 − 1) / 2)) ∈ ℝ)
16 peano2re 10161 . . . 4 ((𝐴↑((𝑃 − 1) / 2)) ∈ ℝ → ((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℝ)
1715, 16syl 17 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℝ)
18 neg1rr 11077 . . . 4 -1 ∈ ℝ
1918a1i 11 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → -1 ∈ ℝ)
20 prmnn 15323 . . . . 5 (𝑃 ∈ ℙ → 𝑃 ∈ ℕ)
212, 20syl 17 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → 𝑃 ∈ ℕ)
2221nnrpd 11822 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → 𝑃 ∈ ℝ+)
23 lgsval3 24957 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴 /L 𝑃) = ((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) − 1))
2423eqcomd 2627 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) − 1) = (𝐴 /L 𝑃))
2517, 22modcld 12622 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) ∈ ℝ)
2625recnd 10020 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) ∈ ℂ)
27 ax-1cn 9946 . . . . . . . 8 1 ∈ ℂ
2827a1i 11 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → 1 ∈ ℂ)
297recnd 10020 . . . . . . 7 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴 /L 𝑃) ∈ ℂ)
3026, 28, 29subadd2d 10363 . . . . . 6 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) − 1) = (𝐴 /L 𝑃) ↔ ((𝐴 /L 𝑃) + 1) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃)))
3124, 30mpbid 222 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴 /L 𝑃) + 1) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃))
3231oveq1d 6625 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴 /L 𝑃) + 1) mod 𝑃) = ((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) mod 𝑃))
33 modabs2 12652 . . . . 5 ((((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℝ ∧ 𝑃 ∈ ℝ+) → ((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) mod 𝑃) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃))
3417, 22, 33syl2anc 692 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃) mod 𝑃) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃))
3532, 34eqtrd 2655 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴 /L 𝑃) + 1) mod 𝑃) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃))
36 modadd1 12655 . . 3 (((((𝐴 /L 𝑃) + 1) ∈ ℝ ∧ ((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℝ) ∧ (-1 ∈ ℝ ∧ 𝑃 ∈ ℝ+) ∧ (((𝐴 /L 𝑃) + 1) mod 𝑃) = (((𝐴↑((𝑃 − 1) / 2)) + 1) mod 𝑃)) → ((((𝐴 /L 𝑃) + 1) + -1) mod 𝑃) = ((((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) mod 𝑃))
379, 17, 19, 22, 35, 36syl221anc 1334 . 2 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((((𝐴 /L 𝑃) + 1) + -1) mod 𝑃) = ((((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) mod 𝑃))
389recnd 10020 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴 /L 𝑃) + 1) ∈ ℂ)
39 negsub 10281 . . . . 5 ((((𝐴 /L 𝑃) + 1) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝐴 /L 𝑃) + 1) + -1) = (((𝐴 /L 𝑃) + 1) − 1))
4038, 27, 39sylancl 693 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴 /L 𝑃) + 1) + -1) = (((𝐴 /L 𝑃) + 1) − 1))
41 pncan 10239 . . . . 5 (((𝐴 /L 𝑃) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝐴 /L 𝑃) + 1) − 1) = (𝐴 /L 𝑃))
4229, 27, 41sylancl 693 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴 /L 𝑃) + 1) − 1) = (𝐴 /L 𝑃))
4340, 42eqtrd 2655 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴 /L 𝑃) + 1) + -1) = (𝐴 /L 𝑃))
4443oveq1d 6625 . 2 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((((𝐴 /L 𝑃) + 1) + -1) mod 𝑃) = ((𝐴 /L 𝑃) mod 𝑃))
4517recnd 10020 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℂ)
46 negsub 10281 . . . . 5 ((((𝐴↑((𝑃 − 1) / 2)) + 1) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) = (((𝐴↑((𝑃 − 1) / 2)) + 1) − 1))
4745, 27, 46sylancl 693 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) = (((𝐴↑((𝑃 − 1) / 2)) + 1) − 1))
4815recnd 10020 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (𝐴↑((𝑃 − 1) / 2)) ∈ ℂ)
49 pncan 10239 . . . . 5 (((𝐴↑((𝑃 − 1) / 2)) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝐴↑((𝑃 − 1) / 2)) + 1) − 1) = (𝐴↑((𝑃 − 1) / 2)))
5048, 27, 49sylancl 693 . . . 4 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴↑((𝑃 − 1) / 2)) + 1) − 1) = (𝐴↑((𝑃 − 1) / 2)))
5147, 50eqtrd 2655 . . 3 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → (((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) = (𝐴↑((𝑃 − 1) / 2)))
5251oveq1d 6625 . 2 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((((𝐴↑((𝑃 − 1) / 2)) + 1) + -1) mod 𝑃) = ((𝐴↑((𝑃 − 1) / 2)) mod 𝑃))
5337, 44, 523eqtr3d 2663 1 ((𝐴 ∈ ℤ ∧ 𝑃 ∈ (ℙ ∖ {2})) → ((𝐴 /L 𝑃) mod 𝑃) = ((𝐴↑((𝑃 − 1) / 2)) mod 𝑃))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 384   = wceq 1480  wcel 1987  cdif 3556  {csn 4153  (class class class)co 6610  cc 9886  cr 9887  1c1 9889   + caddc 9891  cmin 10218  -cneg 10219   / cdiv 10636  cn 10972  2c2 11022  0cn0 11244  cz 11329  +crp 11784   mod cmo 12616  cexp 12808  cprime 15320   /L clgs 24936
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1719  ax-4 1734  ax-5 1836  ax-6 1885  ax-7 1932  ax-8 1989  ax-9 1996  ax-10 2016  ax-11 2031  ax-12 2044  ax-13 2245  ax-ext 2601  ax-rep 4736  ax-sep 4746  ax-nul 4754  ax-pow 4808  ax-pr 4872  ax-un 6909  ax-cnex 9944  ax-resscn 9945  ax-1cn 9946  ax-icn 9947  ax-addcl 9948  ax-addrcl 9949  ax-mulcl 9950  ax-mulrcl 9951  ax-mulcom 9952  ax-addass 9953  ax-mulass 9954  ax-distr 9955  ax-i2m1 9956  ax-1ne0 9957  ax-1rid 9958  ax-rnegex 9959  ax-rrecex 9960  ax-cnre 9961  ax-pre-lttri 9962  ax-pre-lttrn 9963  ax-pre-ltadd 9964  ax-pre-mulgt0 9965  ax-pre-sup 9966
This theorem depends on definitions:  df-bi 197  df-or 385  df-an 386  df-3or 1037  df-3an 1038  df-tru 1483  df-ex 1702  df-nf 1707  df-sb 1878  df-eu 2473  df-mo 2474  df-clab 2608  df-cleq 2614  df-clel 2617  df-nfc 2750  df-ne 2791  df-nel 2894  df-ral 2912  df-rex 2913  df-reu 2914  df-rmo 2915  df-rab 2916  df-v 3191  df-sbc 3422  df-csb 3519  df-dif 3562  df-un 3564  df-in 3566  df-ss 3573  df-pss 3575  df-nul 3897  df-if 4064  df-pw 4137  df-sn 4154  df-pr 4156  df-tp 4158  df-op 4160  df-uni 4408  df-int 4446  df-iun 4492  df-br 4619  df-opab 4679  df-mpt 4680  df-tr 4718  df-eprel 4990  df-id 4994  df-po 5000  df-so 5001  df-fr 5038  df-we 5040  df-xp 5085  df-rel 5086  df-cnv 5087  df-co 5088  df-dm 5089  df-rn 5090  df-res 5091  df-ima 5092  df-pred 5644  df-ord 5690  df-on 5691  df-lim 5692  df-suc 5693  df-iota 5815  df-fun 5854  df-fn 5855  df-f 5856  df-f1 5857  df-fo 5858  df-f1o 5859  df-fv 5860  df-riota 6571  df-ov 6613  df-oprab 6614  df-mpt2 6615  df-om 7020  df-1st 7120  df-2nd 7121  df-wrecs 7359  df-recs 7420  df-rdg 7458  df-1o 7512  df-2o 7513  df-oadd 7516  df-er 7694  df-map 7811  df-en 7908  df-dom 7909  df-sdom 7910  df-fin 7911  df-sup 8300  df-inf 8301  df-card 8717  df-cda 8942  df-pnf 10028  df-mnf 10029  df-xr 10030  df-ltxr 10031  df-le 10032  df-sub 10220  df-neg 10221  df-div 10637  df-nn 10973  df-2 11031  df-3 11032  df-n0 11245  df-xnn0 11316  df-z 11330  df-uz 11640  df-q 11741  df-rp 11785  df-fz 12277  df-fzo 12415  df-fl 12541  df-mod 12617  df-seq 12750  df-exp 12809  df-hash 13066  df-cj 13781  df-re 13782  df-im 13783  df-sqrt 13917  df-abs 13918  df-dvds 14919  df-gcd 15152  df-prm 15321  df-phi 15406  df-pc 15477  df-lgs 24937
This theorem is referenced by:  lgsdirprm  24973  lgsne0  24977  lgsqrlem3  24990  gausslemma2d  25016  fmtnoprmfac2lem1  40803
  Copyright terms: Public domain W3C validator