![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > eucalgf | Structured version Visualization version GIF version |
Description: Domain and codomain of the step function 𝐸 for Euclid's Algorithm. (Contributed by Paul Chapman, 31-Mar-2011.) (Revised by Mario Carneiro, 28-May-2014.) |
Ref | Expression |
---|---|
eucalgval.1 | ⊢ 𝐸 = (𝑥 ∈ ℕ0, 𝑦 ∈ ℕ0 ↦ if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩)) |
Ref | Expression |
---|---|
eucalgf | ⊢ 𝐸:(ℕ0 × ℕ0)⟶(ℕ0 × ℕ0) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | nnne0 12250 | . . . . . . . . 9 ⊢ (𝑦 ∈ ℕ → 𝑦 ≠ 0) | |
2 | 1 | adantl 482 | . . . . . . . 8 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → 𝑦 ≠ 0) |
3 | 2 | neneqd 2945 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → ¬ 𝑦 = 0) |
4 | 3 | iffalsed 4539 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) = ⟨𝑦, (𝑥 mod 𝑦)⟩) |
5 | nnnn0 12483 | . . . . . . . 8 ⊢ (𝑦 ∈ ℕ → 𝑦 ∈ ℕ0) | |
6 | 5 | adantl 482 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → 𝑦 ∈ ℕ0) |
7 | nn0z 12587 | . . . . . . . 8 ⊢ (𝑥 ∈ ℕ0 → 𝑥 ∈ ℤ) | |
8 | zmodcl 13860 | . . . . . . . 8 ⊢ ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝑥 mod 𝑦) ∈ ℕ0) | |
9 | 7, 8 | sylan 580 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → (𝑥 mod 𝑦) ∈ ℕ0) |
10 | 6, 9 | opelxpd 5715 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → ⟨𝑦, (𝑥 mod 𝑦)⟩ ∈ (ℕ0 × ℕ0)) |
11 | 4, 10 | eqeltrd 2833 | . . . . 5 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0)) |
12 | 11 | adantlr 713 | . . . 4 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0)) |
13 | iftrue 4534 | . . . . . 6 ⊢ (𝑦 = 0 → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) = ⟨𝑥, 𝑦⟩) | |
14 | 13 | adantl 482 | . . . . 5 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) = ⟨𝑥, 𝑦⟩) |
15 | opelxpi 5713 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → ⟨𝑥, 𝑦⟩ ∈ (ℕ0 × ℕ0)) | |
16 | 15 | adantr 481 | . . . . 5 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → ⟨𝑥, 𝑦⟩ ∈ (ℕ0 × ℕ0)) |
17 | 14, 16 | eqeltrd 2833 | . . . 4 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0)) |
18 | simpr 485 | . . . . 5 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → 𝑦 ∈ ℕ0) | |
19 | elnn0 12478 | . . . . 5 ⊢ (𝑦 ∈ ℕ0 ↔ (𝑦 ∈ ℕ ∨ 𝑦 = 0)) | |
20 | 18, 19 | sylib 217 | . . . 4 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → (𝑦 ∈ ℕ ∨ 𝑦 = 0)) |
21 | 12, 17, 20 | mpjaodan 957 | . . 3 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0)) |
22 | 21 | rgen2 3197 | . 2 ⊢ ∀𝑥 ∈ ℕ0 ∀𝑦 ∈ ℕ0 if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0) |
23 | eucalgval.1 | . . 3 ⊢ 𝐸 = (𝑥 ∈ ℕ0, 𝑦 ∈ ℕ0 ↦ if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩)) | |
24 | 23 | fmpo 8056 | . 2 ⊢ (∀𝑥 ∈ ℕ0 ∀𝑦 ∈ ℕ0 if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩) ∈ (ℕ0 × ℕ0) ↔ 𝐸:(ℕ0 × ℕ0)⟶(ℕ0 × ℕ0)) |
25 | 22, 24 | mpbi 229 | 1 ⊢ 𝐸:(ℕ0 × ℕ0)⟶(ℕ0 × ℕ0) |
Colors of variables: wff setvar class |
Syntax hints: ∧ wa 396 ∨ wo 845 = wceq 1541 ∈ wcel 2106 ≠ wne 2940 ∀wral 3061 ifcif 4528 ⟨cop 4634 × cxp 5674 ⟶wf 6539 (class class class)co 7411 ∈ cmpo 7413 0cc0 11112 ℕcn 12216 ℕ0cn0 12476 ℤcz 12562 mod cmo 13838 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1797 ax-4 1811 ax-5 1913 ax-6 1971 ax-7 2011 ax-8 2108 ax-9 2116 ax-10 2137 ax-11 2154 ax-12 2171 ax-ext 2703 ax-sep 5299 ax-nul 5306 ax-pow 5363 ax-pr 5427 ax-un 7727 ax-cnex 11168 ax-resscn 11169 ax-1cn 11170 ax-icn 11171 ax-addcl 11172 ax-addrcl 11173 ax-mulcl 11174 ax-mulrcl 11175 ax-mulcom 11176 ax-addass 11177 ax-mulass 11178 ax-distr 11179 ax-i2m1 11180 ax-1ne0 11181 ax-1rid 11182 ax-rnegex 11183 ax-rrecex 11184 ax-cnre 11185 ax-pre-lttri 11186 ax-pre-lttrn 11187 ax-pre-ltadd 11188 ax-pre-mulgt0 11189 ax-pre-sup 11190 |
This theorem depends on definitions: df-bi 206 df-an 397 df-or 846 df-3or 1088 df-3an 1089 df-tru 1544 df-fal 1554 df-ex 1782 df-nf 1786 df-sb 2068 df-mo 2534 df-eu 2563 df-clab 2710 df-cleq 2724 df-clel 2810 df-nfc 2885 df-ne 2941 df-nel 3047 df-ral 3062 df-rex 3071 df-rmo 3376 df-reu 3377 df-rab 3433 df-v 3476 df-sbc 3778 df-csb 3894 df-dif 3951 df-un 3953 df-in 3955 df-ss 3965 df-pss 3967 df-nul 4323 df-if 4529 df-pw 4604 df-sn 4629 df-pr 4631 df-op 4635 df-uni 4909 df-iun 4999 df-br 5149 df-opab 5211 df-mpt 5232 df-tr 5266 df-id 5574 df-eprel 5580 df-po 5588 df-so 5589 df-fr 5631 df-we 5633 df-xp 5682 df-rel 5683 df-cnv 5684 df-co 5685 df-dm 5686 df-rn 5687 df-res 5688 df-ima 5689 df-pred 6300 df-ord 6367 df-on 6368 df-lim 6369 df-suc 6370 df-iota 6495 df-fun 6545 df-fn 6546 df-f 6547 df-f1 6548 df-fo 6549 df-f1o 6550 df-fv 6551 df-riota 7367 df-ov 7414 df-oprab 7415 df-mpo 7416 df-om 7858 df-1st 7977 df-2nd 7978 df-frecs 8268 df-wrecs 8299 df-recs 8373 df-rdg 8412 df-er 8705 df-en 8942 df-dom 8943 df-sdom 8944 df-sup 9439 df-inf 9440 df-pnf 11254 df-mnf 11255 df-xr 11256 df-ltxr 11257 df-le 11258 df-sub 11450 df-neg 11451 df-div 11876 df-nn 12217 df-n0 12477 df-z 12563 df-uz 12827 df-rp 12979 df-fl 13761 df-mod 13839 |
This theorem is referenced by: eucalgcvga 16527 eucalg 16528 |
Copyright terms: Public domain | W3C validator |