ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  enumctlemm GIF version

Theorem enumctlemm 7159
Description: Lemma for enumct 7160. The case where 𝑁 is greater than zero. (Contributed by Jim Kingdon, 13-Mar-2023.)
Hypotheses
Ref Expression
enumctlemm.f (𝜑𝐹:𝑁onto𝐴)
enumctlemm.n (𝜑𝑁 ∈ ω)
enumctlemm.n0 (𝜑 → ∅ ∈ 𝑁)
enumctlemm.g 𝐺 = (𝑘 ∈ ω ↦ if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)))
Assertion
Ref Expression
enumctlemm (𝜑𝐺:ω–onto𝐴)
Distinct variable groups:   𝐴,𝑘   𝑘,𝐹   𝑘,𝑁   𝜑,𝑘
Allowed substitution hint:   𝐺(𝑘)

Proof of Theorem enumctlemm
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 enumctlemm.f . . . . . . 7 (𝜑𝐹:𝑁onto𝐴)
2 fof 5464 . . . . . . 7 (𝐹:𝑁onto𝐴𝐹:𝑁𝐴)
31, 2syl 14 . . . . . 6 (𝜑𝐹:𝑁𝐴)
43ffvelcdmda 5681 . . . . 5 ((𝜑𝑘𝑁) → (𝐹𝑘) ∈ 𝐴)
54adantlr 477 . . . 4 (((𝜑𝑘 ∈ ω) ∧ 𝑘𝑁) → (𝐹𝑘) ∈ 𝐴)
6 enumctlemm.n0 . . . . . 6 (𝜑 → ∅ ∈ 𝑁)
73, 6ffvelcdmd 5682 . . . . 5 (𝜑 → (𝐹‘∅) ∈ 𝐴)
87ad2antrr 488 . . . 4 (((𝜑𝑘 ∈ ω) ∧ ¬ 𝑘𝑁) → (𝐹‘∅) ∈ 𝐴)
9 simpr 110 . . . . 5 ((𝜑𝑘 ∈ ω) → 𝑘 ∈ ω)
10 enumctlemm.n . . . . . 6 (𝜑𝑁 ∈ ω)
1110adantr 276 . . . . 5 ((𝜑𝑘 ∈ ω) → 𝑁 ∈ ω)
12 nndcel 6540 . . . . 5 ((𝑘 ∈ ω ∧ 𝑁 ∈ ω) → DECID 𝑘𝑁)
139, 11, 12syl2anc 411 . . . 4 ((𝜑𝑘 ∈ ω) → DECID 𝑘𝑁)
145, 8, 13ifcldadc 3582 . . 3 ((𝜑𝑘 ∈ ω) → if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)) ∈ 𝐴)
15 enumctlemm.g . . 3 𝐺 = (𝑘 ∈ ω ↦ if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)))
1614, 15fmptd 5700 . 2 (𝜑𝐺:ω⟶𝐴)
17 foelrn 5783 . . . . . 6 ((𝐹:𝑁onto𝐴𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐹𝑥))
181, 17sylan 283 . . . . 5 ((𝜑𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐹𝑥))
19 eleq1w 2250 . . . . . . . . . . 11 (𝑘 = 𝑥 → (𝑘𝑁𝑥𝑁))
20 fveq2 5542 . . . . . . . . . . 11 (𝑘 = 𝑥 → (𝐹𝑘) = (𝐹𝑥))
2119, 20ifbieq1d 3575 . . . . . . . . . 10 (𝑘 = 𝑥 → if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)) = if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)))
22 simpr 110 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → 𝑥𝑁)
2310adantr 276 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → 𝑁 ∈ ω)
24 elnn 4630 . . . . . . . . . . 11 ((𝑥𝑁𝑁 ∈ ω) → 𝑥 ∈ ω)
2522, 23, 24syl2anc 411 . . . . . . . . . 10 ((𝜑𝑥𝑁) → 𝑥 ∈ ω)
2622iftrued 3560 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)) = (𝐹𝑥))
273ffvelcdmda 5681 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → (𝐹𝑥) ∈ 𝐴)
2826, 27eqeltrd 2266 . . . . . . . . . 10 ((𝜑𝑥𝑁) → if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)) ∈ 𝐴)
2915, 21, 25, 28fvmptd3 5639 . . . . . . . . 9 ((𝜑𝑥𝑁) → (𝐺𝑥) = if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)))
3029, 26eqtrd 2222 . . . . . . . 8 ((𝜑𝑥𝑁) → (𝐺𝑥) = (𝐹𝑥))
3130eqeq2d 2201 . . . . . . 7 ((𝜑𝑥𝑁) → (𝑦 = (𝐺𝑥) ↔ 𝑦 = (𝐹𝑥)))
3231rexbidva 2487 . . . . . 6 (𝜑 → (∃𝑥𝑁 𝑦 = (𝐺𝑥) ↔ ∃𝑥𝑁 𝑦 = (𝐹𝑥)))
3332adantr 276 . . . . 5 ((𝜑𝑦𝐴) → (∃𝑥𝑁 𝑦 = (𝐺𝑥) ↔ ∃𝑥𝑁 𝑦 = (𝐹𝑥)))
3418, 33mpbird 167 . . . 4 ((𝜑𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐺𝑥))
35 omelon 4633 . . . . . . 7 ω ∈ On
3635onelssi 4454 . . . . . 6 (𝑁 ∈ ω → 𝑁 ⊆ ω)
37 ssrexv 3240 . . . . . 6 (𝑁 ⊆ ω → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
3810, 36, 373syl 17 . . . . 5 (𝜑 → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
3938adantr 276 . . . 4 ((𝜑𝑦𝐴) → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
4034, 39mpd 13 . . 3 ((𝜑𝑦𝐴) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥))
4140ralrimiva 2563 . 2 (𝜑 → ∀𝑦𝐴𝑥 ∈ ω 𝑦 = (𝐺𝑥))
42 dffo3 5693 . 2 (𝐺:ω–onto𝐴 ↔ (𝐺:ω⟶𝐴 ∧ ∀𝑦𝐴𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
4316, 41, 42sylanbrc 417 1 (𝜑𝐺:ω–onto𝐴)
Colors of variables: wff set class
Syntax hints:  ¬ wn 3  wi 4  wa 104  wb 105  DECID wdc 835   = wceq 1364  wcel 2160  wral 2468  wrex 2469  wss 3149  c0 3442  ifcif 3553  cmpt 4086  ωcom 4614  wf 5238  ontowfo 5240  cfv 5242
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 615  ax-in2 616  ax-io 710  ax-5 1458  ax-7 1459  ax-gen 1460  ax-ie1 1504  ax-ie2 1505  ax-8 1515  ax-10 1516  ax-11 1517  ax-i12 1518  ax-bndl 1520  ax-4 1521  ax-17 1537  ax-i9 1541  ax-ial 1545  ax-i5r 1546  ax-13 2162  ax-14 2163  ax-ext 2171  ax-sep 4143  ax-nul 4151  ax-pow 4199  ax-pr 4234  ax-un 4458  ax-setind 4561  ax-iinf 4612
This theorem depends on definitions:  df-bi 117  df-dc 836  df-3or 981  df-3an 982  df-tru 1367  df-nf 1472  df-sb 1774  df-eu 2041  df-mo 2042  df-clab 2176  df-cleq 2182  df-clel 2185  df-nfc 2321  df-ne 2361  df-ral 2473  df-rex 2474  df-rab 2477  df-v 2758  df-sbc 2982  df-csb 3077  df-dif 3151  df-un 3153  df-in 3155  df-ss 3162  df-nul 3443  df-if 3554  df-pw 3599  df-sn 3620  df-pr 3621  df-op 3623  df-uni 3832  df-int 3867  df-br 4026  df-opab 4087  df-mpt 4088  df-tr 4124  df-id 4318  df-iord 4391  df-on 4393  df-suc 4396  df-iom 4615  df-xp 4657  df-rel 4658  df-cnv 4659  df-co 4660  df-dm 4661  df-rn 4662  df-res 4663  df-ima 4664  df-iota 5203  df-fun 5244  df-fn 5245  df-f 5246  df-fo 5248  df-fv 5250
This theorem is referenced by:  enumct  7160
  Copyright terms: Public domain W3C validator