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

Theorem enumctlemm 7175
Description: Lemma for enumct 7176. 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 5477 . . . . . . 7 (𝐹:𝑁onto𝐴𝐹:𝑁𝐴)
31, 2syl 14 . . . . . 6 (𝜑𝐹:𝑁𝐴)
43ffvelcdmda 5694 . . . . 5 ((𝜑𝑘𝑁) → (𝐹𝑘) ∈ 𝐴)
54adantlr 477 . . . 4 (((𝜑𝑘 ∈ ω) ∧ 𝑘𝑁) → (𝐹𝑘) ∈ 𝐴)
6 enumctlemm.n0 . . . . . 6 (𝜑 → ∅ ∈ 𝑁)
73, 6ffvelcdmd 5695 . . . . 5 (𝜑 → (𝐹‘∅) ∈ 𝐴)
87ad2antrr 488 . . . 4 (((𝜑𝑘 ∈ ω) ∧ ¬ 𝑘𝑁) → (𝐹‘∅) ∈ 𝐴)
9 simpr 110 . . . . 5 ((𝜑𝑘 ∈ ω) → 𝑘 ∈ ω)
10 enumctlemm.n . . . . . 6 (𝜑𝑁 ∈ ω)
1110adantr 276 . . . . 5 ((𝜑𝑘 ∈ ω) → 𝑁 ∈ ω)
12 nndcel 6555 . . . . 5 ((𝑘 ∈ ω ∧ 𝑁 ∈ ω) → DECID 𝑘𝑁)
139, 11, 12syl2anc 411 . . . 4 ((𝜑𝑘 ∈ ω) → DECID 𝑘𝑁)
145, 8, 13ifcldadc 3587 . . 3 ((𝜑𝑘 ∈ ω) → if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)) ∈ 𝐴)
15 enumctlemm.g . . 3 𝐺 = (𝑘 ∈ ω ↦ if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)))
1614, 15fmptd 5713 . 2 (𝜑𝐺:ω⟶𝐴)
17 foelrn 5796 . . . . . 6 ((𝐹:𝑁onto𝐴𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐹𝑥))
181, 17sylan 283 . . . . 5 ((𝜑𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐹𝑥))
19 eleq1w 2254 . . . . . . . . . . 11 (𝑘 = 𝑥 → (𝑘𝑁𝑥𝑁))
20 fveq2 5555 . . . . . . . . . . 11 (𝑘 = 𝑥 → (𝐹𝑘) = (𝐹𝑥))
2119, 20ifbieq1d 3580 . . . . . . . . . 10 (𝑘 = 𝑥 → if(𝑘𝑁, (𝐹𝑘), (𝐹‘∅)) = if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)))
22 simpr 110 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → 𝑥𝑁)
2310adantr 276 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → 𝑁 ∈ ω)
24 elnn 4639 . . . . . . . . . . 11 ((𝑥𝑁𝑁 ∈ ω) → 𝑥 ∈ ω)
2522, 23, 24syl2anc 411 . . . . . . . . . 10 ((𝜑𝑥𝑁) → 𝑥 ∈ ω)
2622iftrued 3565 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)) = (𝐹𝑥))
273ffvelcdmda 5694 . . . . . . . . . . 11 ((𝜑𝑥𝑁) → (𝐹𝑥) ∈ 𝐴)
2826, 27eqeltrd 2270 . . . . . . . . . 10 ((𝜑𝑥𝑁) → if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)) ∈ 𝐴)
2915, 21, 25, 28fvmptd3 5652 . . . . . . . . 9 ((𝜑𝑥𝑁) → (𝐺𝑥) = if(𝑥𝑁, (𝐹𝑥), (𝐹‘∅)))
3029, 26eqtrd 2226 . . . . . . . 8 ((𝜑𝑥𝑁) → (𝐺𝑥) = (𝐹𝑥))
3130eqeq2d 2205 . . . . . . 7 ((𝜑𝑥𝑁) → (𝑦 = (𝐺𝑥) ↔ 𝑦 = (𝐹𝑥)))
3231rexbidva 2491 . . . . . 6 (𝜑 → (∃𝑥𝑁 𝑦 = (𝐺𝑥) ↔ ∃𝑥𝑁 𝑦 = (𝐹𝑥)))
3332adantr 276 . . . . 5 ((𝜑𝑦𝐴) → (∃𝑥𝑁 𝑦 = (𝐺𝑥) ↔ ∃𝑥𝑁 𝑦 = (𝐹𝑥)))
3418, 33mpbird 167 . . . 4 ((𝜑𝑦𝐴) → ∃𝑥𝑁 𝑦 = (𝐺𝑥))
35 omelon 4642 . . . . . . 7 ω ∈ On
3635onelssi 4461 . . . . . 6 (𝑁 ∈ ω → 𝑁 ⊆ ω)
37 ssrexv 3245 . . . . . 6 (𝑁 ⊆ ω → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
3810, 36, 373syl 17 . . . . 5 (𝜑 → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
3938adantr 276 . . . 4 ((𝜑𝑦𝐴) → (∃𝑥𝑁 𝑦 = (𝐺𝑥) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥)))
4034, 39mpd 13 . . 3 ((𝜑𝑦𝐴) → ∃𝑥 ∈ ω 𝑦 = (𝐺𝑥))
4140ralrimiva 2567 . 2 (𝜑 → ∀𝑦𝐴𝑥 ∈ ω 𝑦 = (𝐺𝑥))
42 dffo3 5706 . 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 2164  wral 2472  wrex 2473  wss 3154  c0 3447  ifcif 3558  cmpt 4091  ωcom 4623  wf 5251  ontowfo 5253  cfv 5255
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 2166  ax-14 2167  ax-ext 2175  ax-sep 4148  ax-nul 4156  ax-pow 4204  ax-pr 4239  ax-un 4465  ax-setind 4570  ax-iinf 4621
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 2045  df-mo 2046  df-clab 2180  df-cleq 2186  df-clel 2189  df-nfc 2325  df-ne 2365  df-ral 2477  df-rex 2478  df-rab 2481  df-v 2762  df-sbc 2987  df-csb 3082  df-dif 3156  df-un 3158  df-in 3160  df-ss 3167  df-nul 3448  df-if 3559  df-pw 3604  df-sn 3625  df-pr 3626  df-op 3628  df-uni 3837  df-int 3872  df-br 4031  df-opab 4092  df-mpt 4093  df-tr 4129  df-id 4325  df-iord 4398  df-on 4400  df-suc 4403  df-iom 4624  df-xp 4666  df-rel 4667  df-cnv 4668  df-co 4669  df-dm 4670  df-rn 4671  df-res 4672  df-ima 4673  df-iota 5216  df-fun 5257  df-fn 5258  df-f 5259  df-fo 5261  df-fv 5263
This theorem is referenced by:  enumct  7176
  Copyright terms: Public domain W3C validator