Intuitionistic Logic Explorer |
< Previous
Next >
Nearby theorems |
||
Mirrors > Home > ILE Home > Th. List > eulerth | 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 12089 | . . . . . . . 8 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ) | |
2 | 1 | nnnn0d 9143 | . . . . . . 7 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ0) |
3 | hashfz1 10657 | . . . . . . 7 ⊢ ((ϕ‘𝑁) ∈ ℕ0 → (♯‘(1...(ϕ‘𝑁))) = (ϕ‘𝑁)) | |
4 | 2, 3 | syl 14 | . . . . . 6 ⊢ (𝑁 ∈ ℕ → (♯‘(1...(ϕ‘𝑁))) = (ϕ‘𝑁)) |
5 | dfphi2 12094 | . . . . . 6 ⊢ (𝑁 ∈ ℕ → (ϕ‘𝑁) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) | |
6 | 4, 5 | eqtrd 2190 | . . . . 5 ⊢ (𝑁 ∈ ℕ → (♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) |
7 | 6 | 3ad2ant1 1003 | . . . 4 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) |
8 | 1zzd 9194 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 1 ∈ ℤ) | |
9 | 1 | 3ad2ant1 1003 | . . . . . . 7 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℕ) |
10 | 9 | nnzd 9285 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℤ) |
11 | 8, 10 | fzfigd 10330 | . . . . 5 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (1...(ϕ‘𝑁)) ∈ Fin) |
12 | id 19 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1)) | |
13 | oveq1 5831 | . . . . . . . 8 ⊢ (𝑘 = 𝑦 → (𝑘 gcd 𝑁) = (𝑦 gcd 𝑁)) | |
14 | 13 | eqeq1d 2166 | . . . . . . 7 ⊢ (𝑘 = 𝑦 → ((𝑘 gcd 𝑁) = 1 ↔ (𝑦 gcd 𝑁) = 1)) |
15 | 14 | cbvrabv 2711 | . . . . . 6 ⊢ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} = {𝑦 ∈ (0..^𝑁) ∣ (𝑦 gcd 𝑁) = 1} |
16 | 12, 15 | eulerthlemfi 12102 | . . . . 5 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ∈ Fin) |
17 | hashen 10658 | . . . . 5 ⊢ (((1...(ϕ‘𝑁)) ∈ Fin ∧ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ∈ Fin) → ((♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) ↔ (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) | |
18 | 11, 16, 17 | syl2anc 409 | . . . 4 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((♯‘(1...(ϕ‘𝑁))) = (♯‘{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) ↔ (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1})) |
19 | 7, 18 | mpbid 146 | . . 3 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) |
20 | bren 6692 | . . 3 ⊢ ((1...(ϕ‘𝑁)) ≈ {𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1} ↔ ∃𝑓 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) | |
21 | 19, 20 | sylib 121 | . 2 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ∃𝑓 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) |
22 | simpl 108 | . . 3 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → (𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1)) | |
23 | simpr 109 | . . 3 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) | |
24 | 22, 15, 23 | eulerthlemth 12106 | . 2 ⊢ (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝑓:(1...(ϕ‘𝑁))–1-1-onto→{𝑘 ∈ (0..^𝑁) ∣ (𝑘 gcd 𝑁) = 1}) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁)) |
25 | 21, 24 | exlimddv 1878 | 1 ⊢ ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁)) |
Colors of variables: wff set class |
Syntax hints: → wi 4 ∧ wa 103 ↔ wb 104 ∧ w3a 963 = wceq 1335 ∃wex 1472 ∈ wcel 2128 {crab 2439 class class class wbr 3965 –1-1-onto→wf1o 5169 ‘cfv 5170 (class class class)co 5824 ≈ cen 6683 Fincfn 6685 0cc0 7732 1c1 7733 ℕcn 8833 ℕ0cn0 9090 ℤcz 9167 ...cfz 9912 ..^cfzo 10041 mod cmo 10221 ↑cexp 10418 ♯chash 10649 gcd cgcd 11828 ϕcphi 12083 |
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 604 ax-in2 605 ax-io 699 ax-5 1427 ax-7 1428 ax-gen 1429 ax-ie1 1473 ax-ie2 1474 ax-8 1484 ax-10 1485 ax-11 1486 ax-i12 1487 ax-bndl 1489 ax-4 1490 ax-17 1506 ax-i9 1510 ax-ial 1514 ax-i5r 1515 ax-13 2130 ax-14 2131 ax-ext 2139 ax-coll 4079 ax-sep 4082 ax-nul 4090 ax-pow 4135 ax-pr 4169 ax-un 4393 ax-setind 4496 ax-iinf 4547 ax-cnex 7823 ax-resscn 7824 ax-1cn 7825 ax-1re 7826 ax-icn 7827 ax-addcl 7828 ax-addrcl 7829 ax-mulcl 7830 ax-mulrcl 7831 ax-addcom 7832 ax-mulcom 7833 ax-addass 7834 ax-mulass 7835 ax-distr 7836 ax-i2m1 7837 ax-0lt1 7838 ax-1rid 7839 ax-0id 7840 ax-rnegex 7841 ax-precex 7842 ax-cnre 7843 ax-pre-ltirr 7844 ax-pre-ltwlin 7845 ax-pre-lttrn 7846 ax-pre-apti 7847 ax-pre-ltadd 7848 ax-pre-mulgt0 7849 ax-pre-mulext 7850 ax-arch 7851 ax-caucvg 7852 |
This theorem depends on definitions: df-bi 116 df-stab 817 df-dc 821 df-3or 964 df-3an 965 df-tru 1338 df-fal 1341 df-nf 1441 df-sb 1743 df-eu 2009 df-mo 2010 df-clab 2144 df-cleq 2150 df-clel 2153 df-nfc 2288 df-ne 2328 df-nel 2423 df-ral 2440 df-rex 2441 df-reu 2442 df-rmo 2443 df-rab 2444 df-v 2714 df-sbc 2938 df-csb 3032 df-dif 3104 df-un 3106 df-in 3108 df-ss 3115 df-nul 3395 df-if 3506 df-pw 3545 df-sn 3566 df-pr 3567 df-op 3569 df-uni 3773 df-int 3808 df-iun 3851 df-br 3966 df-opab 4026 df-mpt 4027 df-tr 4063 df-id 4253 df-po 4256 df-iso 4257 df-iord 4326 df-on 4328 df-ilim 4329 df-suc 4331 df-iom 4550 df-xp 4592 df-rel 4593 df-cnv 4594 df-co 4595 df-dm 4596 df-rn 4597 df-res 4598 df-ima 4599 df-iota 5135 df-fun 5172 df-fn 5173 df-f 5174 df-f1 5175 df-fo 5176 df-f1o 5177 df-fv 5178 df-isom 5179 df-riota 5780 df-ov 5827 df-oprab 5828 df-mpo 5829 df-1st 6088 df-2nd 6089 df-recs 6252 df-irdg 6317 df-frec 6338 df-1o 6363 df-oadd 6367 df-er 6480 df-en 6686 df-dom 6687 df-fin 6688 df-sup 6928 df-pnf 7914 df-mnf 7915 df-xr 7916 df-ltxr 7917 df-le 7918 df-sub 8048 df-neg 8049 df-reap 8450 df-ap 8457 df-div 8546 df-inn 8834 df-2 8892 df-3 8893 df-4 8894 df-n0 9091 df-z 9168 df-uz 9440 df-q 9529 df-rp 9561 df-fz 9913 df-fzo 10042 df-fl 10169 df-mod 10222 df-seqfrec 10345 df-exp 10419 df-ihash 10650 df-cj 10742 df-re 10743 df-im 10744 df-rsqrt 10898 df-abs 10899 df-clim 11176 df-proddc 11448 df-dvds 11684 df-gcd 11829 df-phi 12085 |
This theorem is referenced by: fermltl 12108 prmdiv 12109 odzcllem 12116 odzphi 12120 |
Copyright terms: Public domain | W3C validator |