| 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 12183 | . . . . . . . . 9 ⊢ (𝑦 ∈ ℕ → 𝑦 ≠ 0) | |
| 2 | 1 | adantl 481 | . . . . . . . 8 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → 𝑦 ≠ 0) |
| 3 | 2 | neneqd 2938 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → ¬ 𝑦 = 0) |
| 4 | 3 | iffalsed 4491 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) = 〈𝑦, (𝑥 mod 𝑦)〉) |
| 5 | nnnn0 12412 | . . . . . . . 8 ⊢ (𝑦 ∈ ℕ → 𝑦 ∈ ℕ0) | |
| 6 | 5 | adantl 481 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → 𝑦 ∈ ℕ0) |
| 7 | nn0z 12516 | . . . . . . . 8 ⊢ (𝑥 ∈ ℕ0 → 𝑥 ∈ ℤ) | |
| 8 | zmodcl 13815 | . . . . . . . 8 ⊢ ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝑥 mod 𝑦) ∈ ℕ0) | |
| 9 | 7, 8 | sylan 581 | . . . . . . 7 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → (𝑥 mod 𝑦) ∈ ℕ0) |
| 10 | 6, 9 | opelxpd 5664 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → 〈𝑦, (𝑥 mod 𝑦)〉 ∈ (ℕ0 × ℕ0)) |
| 11 | 4, 10 | eqeltrd 2837 | . . . . 5 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0)) |
| 12 | 11 | adantlr 716 | . . . 4 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 ∈ ℕ) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0)) |
| 13 | iftrue 4486 | . . . . . 6 ⊢ (𝑦 = 0 → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) = 〈𝑥, 𝑦〉) | |
| 14 | 13 | adantl 481 | . . . . 5 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) = 〈𝑥, 𝑦〉) |
| 15 | opelxpi 5662 | . . . . . 6 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → 〈𝑥, 𝑦〉 ∈ (ℕ0 × ℕ0)) | |
| 16 | 15 | adantr 480 | . . . . 5 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → 〈𝑥, 𝑦〉 ∈ (ℕ0 × ℕ0)) |
| 17 | 14, 16 | eqeltrd 2837 | . . . 4 ⊢ (((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) ∧ 𝑦 = 0) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0)) |
| 18 | simpr 484 | . . . . 5 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → 𝑦 ∈ ℕ0) | |
| 19 | elnn0 12407 | . . . . 5 ⊢ (𝑦 ∈ ℕ0 ↔ (𝑦 ∈ ℕ ∨ 𝑦 = 0)) | |
| 20 | 18, 19 | sylib 218 | . . . 4 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → (𝑦 ∈ ℕ ∨ 𝑦 = 0)) |
| 21 | 12, 17, 20 | mpjaodan 961 | . . 3 ⊢ ((𝑥 ∈ ℕ0 ∧ 𝑦 ∈ ℕ0) → if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0)) |
| 22 | 21 | rgen2 3177 | . 2 ⊢ ∀𝑥 ∈ ℕ0 ∀𝑦 ∈ ℕ0 if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0) |
| 23 | eucalgval.1 | . . 3 ⊢ 𝐸 = (𝑥 ∈ ℕ0, 𝑦 ∈ ℕ0 ↦ if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉)) | |
| 24 | 23 | fmpo 8014 | . 2 ⊢ (∀𝑥 ∈ ℕ0 ∀𝑦 ∈ ℕ0 if(𝑦 = 0, 〈𝑥, 𝑦〉, 〈𝑦, (𝑥 mod 𝑦)〉) ∈ (ℕ0 × ℕ0) ↔ 𝐸:(ℕ0 × ℕ0)⟶(ℕ0 × ℕ0)) |
| 25 | 22, 24 | mpbi 230 | 1 ⊢ 𝐸:(ℕ0 × ℕ0)⟶(ℕ0 × ℕ0) |
| Colors of variables: wff setvar class |
| Syntax hints: ∧ wa 395 ∨ wo 848 = wceq 1542 ∈ wcel 2114 ≠ wne 2933 ∀wral 3052 ifcif 4480 〈cop 4587 × cxp 5623 ⟶wf 6489 (class class class)co 7360 ∈ cmpo 7362 0cc0 11030 ℕcn 12149 ℕ0cn0 12405 ℤcz 12492 mod cmo 13793 |
| 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 1912 ax-6 1969 ax-7 2010 ax-8 2116 ax-9 2124 ax-10 2147 ax-11 2163 ax-12 2185 ax-ext 2709 ax-sep 5242 ax-nul 5252 ax-pow 5311 ax-pr 5378 ax-un 7682 ax-cnex 11086 ax-resscn 11087 ax-1cn 11088 ax-icn 11089 ax-addcl 11090 ax-addrcl 11091 ax-mulcl 11092 ax-mulrcl 11093 ax-mulcom 11094 ax-addass 11095 ax-mulass 11096 ax-distr 11097 ax-i2m1 11098 ax-1ne0 11099 ax-1rid 11100 ax-rnegex 11101 ax-rrecex 11102 ax-cnre 11103 ax-pre-lttri 11104 ax-pre-lttrn 11105 ax-pre-ltadd 11106 ax-pre-mulgt0 11107 ax-pre-sup 11108 |
| This theorem depends on definitions: df-bi 207 df-an 396 df-or 849 df-3or 1088 df-3an 1089 df-tru 1545 df-fal 1555 df-ex 1782 df-nf 1786 df-sb 2069 df-mo 2540 df-eu 2570 df-clab 2716 df-cleq 2729 df-clel 2812 df-nfc 2886 df-ne 2934 df-nel 3038 df-ral 3053 df-rex 3062 df-rmo 3351 df-reu 3352 df-rab 3401 df-v 3443 df-sbc 3742 df-csb 3851 df-dif 3905 df-un 3907 df-in 3909 df-ss 3919 df-pss 3922 df-nul 4287 df-if 4481 df-pw 4557 df-sn 4582 df-pr 4584 df-op 4588 df-uni 4865 df-iun 4949 df-br 5100 df-opab 5162 df-mpt 5181 df-tr 5207 df-id 5520 df-eprel 5525 df-po 5533 df-so 5534 df-fr 5578 df-we 5580 df-xp 5631 df-rel 5632 df-cnv 5633 df-co 5634 df-dm 5635 df-rn 5636 df-res 5637 df-ima 5638 df-pred 6260 df-ord 6321 df-on 6322 df-lim 6323 df-suc 6324 df-iota 6449 df-fun 6495 df-fn 6496 df-f 6497 df-f1 6498 df-fo 6499 df-f1o 6500 df-fv 6501 df-riota 7317 df-ov 7363 df-oprab 7364 df-mpo 7365 df-om 7811 df-1st 7935 df-2nd 7936 df-frecs 8225 df-wrecs 8256 df-recs 8305 df-rdg 8343 df-er 8637 df-en 8888 df-dom 8889 df-sdom 8890 df-sup 9349 df-inf 9350 df-pnf 11172 df-mnf 11173 df-xr 11174 df-ltxr 11175 df-le 11176 df-sub 11370 df-neg 11371 df-div 11799 df-nn 12150 df-n0 12406 df-z 12493 df-uz 12756 df-rp 12910 df-fl 13716 df-mod 13794 |
| This theorem is referenced by: eucalgcvga 16517 eucalg 16518 |
| Copyright terms: Public domain | W3C validator |