Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
||
Mirrors > Home > MPE Home > Th. List > eulerth | Structured version Visualization version GIF version |
Description: Euler's theorem, a generalization of Fermat's little theorem. If 𝐴 and 𝑁 are coprime, then 𝐴↑ϕ(𝑁)≡1 (mod 𝑁). This is Metamath 100 proof #10. Also called Euler-Fermat theorem, see theorem 5.17 in [ApostolNT] p. 113. (Contributed by Mario Carneiro, 28-Feb-2014.) |
Ref | Expression |
---|---|
eulerth | ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁)) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | phicl 16094 | . . . . . . . 8 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ) | |
2 | 1 | nnnn0d 11943 | . . . . . . 7 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ0) |
3 | hashfz1 13694 | . . . . . . 7 ⊢ ((ϕ‘𝑁) ∈ ℕ0 → (♯‘(1...(ϕ‘𝑁))) = (ϕ‘𝑁)) | |
4 | 2, 3 | syl 17 | . . . . . 6 ⊢ (𝑁 ∈ ℕ → (♯‘(1...(ϕ‘𝑁))) = (ϕ‘𝑁)) |
5 | dfphi2 16099 | . . . . . 6 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) | |
6 | 4, 5 | eqtrd 2853 | . . . . 5 ⊢ (𝑁 ∈ ℕ → (♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) |
7 | 6 | 3ad2ant1 1125 | . . . 4 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) |
8 | fzfi 13328 | . . . . 5 ⊢ (1...(ϕ‘𝑁)) ∈ Fin | |
9 | fzofi 13330 | . . . . . 6 ⊢ (0..^𝑁) ∈ Fin | |
10 | ssrab2 4053 | . . . . . 6 ⊢ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ⊆ (0..^𝑁) | |
11 | ssfi 8726 | . . . . . 6 ⊢ (((0..^𝑁) ∈ Fin ∧ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ⊆ (0..^𝑁)) → {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ∈ Fin) | |
12 | 9, 10, 11 | mp2an 688 | . . . . 5 ⊢ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ∈ Fin |
13 | hashen 13695 | . . . . 5 ⊢ (((1...(ϕ‘𝑁)) ∈ Fin ∧ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ∈ Fin) → ((♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) ↔ (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) | |
14 | 8, 12, 13 | mp2an 688 | . . . 4 ⊢ ((♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) ↔ (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) |
15 | 7, 14 | sylib 219 | . . 3 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) |
16 | bren 8506 | . . 3 ⊢ ((1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ↔ ∃𝑓 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) | |
17 | 15, 16 | sylib 219 | . 2 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ∃𝑓 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) |
18 | simpl 483 | . . 3 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → (𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1)) | |
19 | oveq1 7152 | . . . . 5 ⊢ (𝑘 = 𝑦 → (𝑘 gcd 𝑁) = (𝑦 gcd 𝑁)) | |
20 | 19 | eqeq1d 2820 | . . . 4 ⊢ (𝑘 = 𝑦 → ((𝑘 gcd 𝑁) = 1 ↔ (𝑦 gcd 𝑁) = 1)) |
21 | 20 | cbvrabv 3489 | . . 3 ⊢ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} = {𝑦 ∈ (0..^𝑁) ∣ (𝑦 gcd 𝑁) = 1} |
22 | eqid 2818 | . . 3 ⊢ (1...(ϕ‘𝑁)) = (1...(ϕ‘𝑁)) | |
23 | simpr 485 | . . 3 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) | |
24 | fveq2 6663 | . . . . . 6 ⊢ (𝑘 = 𝑥 → (𝑓‘𝑘) = (𝑓‘𝑥)) | |
25 | 24 | oveq2d 7161 | . . . . 5 ⊢ (𝑘 = 𝑥 → (𝐴 · (𝑓‘𝑘)) = (𝐴 · (𝑓‘𝑥))) |
26 | 25 | oveq1d 7160 | . . . 4 ⊢ (𝑘 = 𝑥 → ((𝐴 · (𝑓‘𝑘)) mod 𝑁) = ((𝐴 · (𝑓‘𝑥)) mod 𝑁)) |
27 | 26 | cbvmptv 5160 | . . 3 ⊢ (𝑘 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝑓‘𝑘)) mod 𝑁)) = (𝑥 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝑓‘𝑥)) mod 𝑁)) |
28 | 18, 21, 22, 23, 27 | eulerthlem2 16107 | . 2 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁)) |
29 | 17, 28 | exlimddv 1927 | 1 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁)) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ↔ wb 207 ∧ wa 396 ∧ w3a 1079 = wceq 1528 ∃wex 1771 ∈ wcel 2105 {crab 3139 ⊆ wss 3933 class class class wbr 5057 ↦ cmpt 5137 –1-1-onto→wf1o 6347 ‘cfv 6348 (class class class)co 7145 ≈ cen 8494 Fincfn 8497 0cc0 10525 1c1 10526 · cmul 10530 ℕcn 11626 ℕ0cn0 11885 ℤcz 11969 ...cfz 12880 ..^cfzo 13021 mod cmo 13225 ↑cexp 13417 ♯chash 13678 gcd cgcd 15831 ϕcphi 16089 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1787 ax-4 1801 ax-5 1902 ax-6 1961 ax-7 2006 ax-8 2107 ax-9 2115 ax-10 2136 ax-11 2151 ax-12 2167 ax-ext 2790 ax-rep 5181 ax-sep 5194 ax-nul 5201 ax-pow 5257 ax-pr 5320 ax-un 7450 ax-cnex 10581 ax-resscn 10582 ax-1cn 10583 ax-icn 10584 ax-addcl 10585 ax-addrcl 10586 ax-mulcl 10587 ax-mulrcl 10588 ax-mulcom 10589 ax-addass 10590 ax-mulass 10591 ax-distr 10592 ax-i2m1 10593 ax-1ne0 10594 ax-1rid 10595 ax-rnegex 10596 ax-rrecex 10597 ax-cnre 10598 ax-pre-lttri 10599 ax-pre-lttrn 10600 ax-pre-ltadd 10601 ax-pre-mulgt0 10602 ax-pre-sup 10603 |
This theorem depends on definitions: df-bi 208 df-an 397 df-or 842 df-3or 1080 df-3an 1081 df-tru 1531 df-ex 1772 df-nf 1776 df-sb 2061 df-mo 2615 df-eu 2647 df-clab 2797 df-cleq 2811 df-clel 2890 df-nfc 2960 df-ne 3014 df-nel 3121 df-ral 3140 df-rex 3141 df-reu 3142 df-rmo 3143 df-rab 3144 df-v 3494 df-sbc 3770 df-csb 3881 df-dif 3936 df-un 3938 df-in 3940 df-ss 3949 df-pss 3951 df-nul 4289 df-if 4464 df-pw 4537 df-sn 4558 df-pr 4560 df-tp 4562 df-op 4564 df-uni 4831 df-int 4868 df-iun 4912 df-br 5058 df-opab 5120 df-mpt 5138 df-tr 5164 df-id 5453 df-eprel 5458 df-po 5467 df-so 5468 df-fr 5507 df-we 5509 df-xp 5554 df-rel 5555 df-cnv 5556 df-co 5557 df-dm 5558 df-rn 5559 df-res 5560 df-ima 5561 df-pred 6141 df-ord 6187 df-on 6188 df-lim 6189 df-suc 6190 df-iota 6307 df-fun 6350 df-fn 6351 df-f 6352 df-f1 6353 df-fo 6354 df-f1o 6355 df-fv 6356 df-riota 7103 df-ov 7148 df-oprab 7149 df-mpo 7150 df-om 7570 df-1st 7678 df-2nd 7679 df-wrecs 7936 df-recs 7997 df-rdg 8035 df-1o 8091 df-oadd 8095 df-er 8278 df-map 8397 df-en 8498 df-dom 8499 df-sdom 8500 df-fin 8501 df-sup 8894 df-inf 8895 df-card 9356 df-pnf 10665 df-mnf 10666 df-xr 10667 df-ltxr 10668 df-le 10669 df-sub 10860 df-neg 10861 df-div 11286 df-nn 11627 df-2 11688 df-3 11689 df-n0 11886 df-xnn0 11956 df-z 11970 df-uz 12232 df-rp 12378 df-fz 12881 df-fzo 13022 df-fl 13150 df-mod 13226 df-seq 13358 df-exp 13418 df-hash 13679 df-cj 14446 df-re 14447 df-im 14448 df-sqrt 14582 df-abs 14583 df-dvds 15596 df-gcd 15832 df-phi 16091 |
This theorem is referenced by: fermltl 16109 prmdiv 16110 odzcllem 16117 odzphi 16121 vfermltl 16126 lgslem1 25800 lgsqrlem2 25850 |
Copyright terms: Public domain | W3C validator |