Users' Mathboxes Mathbox for Richard Penner < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  naddcnffo Structured version   Visualization version   GIF version

Theorem naddcnffo 41281
Description: Addition of Cantor normal forms is a function onto Cantor normal forms. (Contributed by RP, 2-Jan-2025.)
Assertion
Ref Expression
naddcnffo ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ( ∘f +o ↾ (𝑆 × 𝑆)):(𝑆 × 𝑆)–onto𝑆)

Proof of Theorem naddcnffo
Dummy variables 𝑓 𝑔 𝑧 𝑥 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 naddcnff 41279 . 2 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ( ∘f +o ↾ (𝑆 × 𝑆)):(𝑆 × 𝑆)⟶𝑆)
2 simpr 485 . . . 4 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → 𝑓𝑆)
3 peano1 7781 . . . . . . . . 9 ∅ ∈ ω
4 fconst6g 6700 . . . . . . . . 9 (∅ ∈ ω → (𝑋 × {∅}):𝑋⟶ω)
53, 4mp1i 13 . . . . . . . 8 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑋 × {∅}):𝑋⟶ω)
6 simpl 483 . . . . . . . . 9 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → 𝑋 ∈ On)
73a1i 11 . . . . . . . . 9 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ∅ ∈ ω)
86, 7fczfsuppd 9222 . . . . . . . 8 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑋 × {∅}) finSupp ∅)
9 simpr 485 . . . . . . . . . 10 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → 𝑆 = dom (ω CNF 𝑋))
109eleq2d 2822 . . . . . . . . 9 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ((𝑋 × {∅}) ∈ 𝑆 ↔ (𝑋 × {∅}) ∈ dom (ω CNF 𝑋)))
11 eqid 2736 . . . . . . . . . 10 dom (ω CNF 𝑋) = dom (ω CNF 𝑋)
12 omelon 9481 . . . . . . . . . . 11 ω ∈ On
1312a1i 11 . . . . . . . . . 10 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ω ∈ On)
1411, 13, 6cantnfs 9501 . . . . . . . . 9 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ((𝑋 × {∅}) ∈ dom (ω CNF 𝑋) ↔ ((𝑋 × {∅}):𝑋⟶ω ∧ (𝑋 × {∅}) finSupp ∅)))
1510, 14bitrd 278 . . . . . . . 8 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ((𝑋 × {∅}) ∈ 𝑆 ↔ ((𝑋 × {∅}):𝑋⟶ω ∧ (𝑋 × {∅}) finSupp ∅)))
165, 8, 15mpbir2and 710 . . . . . . 7 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑋 × {∅}) ∈ 𝑆)
1716adantr 481 . . . . . 6 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → (𝑋 × {∅}) ∈ 𝑆)
18 simpl 483 . . . . . . . . . 10 ((𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆) → 𝑓𝑆)
1918adantl 482 . . . . . . . . 9 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → 𝑓𝑆)
20 simpr 485 . . . . . . . . . 10 ((𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆) → (𝑋 × {∅}) ∈ 𝑆)
2120adantl 482 . . . . . . . . 9 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → (𝑋 × {∅}) ∈ 𝑆)
2219, 21ovresd 7480 . . . . . . . 8 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅})) = (𝑓f +o (𝑋 × {∅})))
239eleq2d 2822 . . . . . . . . . . . . . . 15 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑓𝑆𝑓 ∈ dom (ω CNF 𝑋)))
2411, 13, 6cantnfs 9501 . . . . . . . . . . . . . . 15 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑓 ∈ dom (ω CNF 𝑋) ↔ (𝑓:𝑋⟶ω ∧ 𝑓 finSupp ∅)))
2523, 24bitrd 278 . . . . . . . . . . . . . 14 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑓𝑆 ↔ (𝑓:𝑋⟶ω ∧ 𝑓 finSupp ∅)))
2625biimpd 228 . . . . . . . . . . . . 13 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → (𝑓𝑆 → (𝑓:𝑋⟶ω ∧ 𝑓 finSupp ∅)))
27 simpl 483 . . . . . . . . . . . . 13 ((𝑓:𝑋⟶ω ∧ 𝑓 finSupp ∅) → 𝑓:𝑋⟶ω)
2818, 26, 27syl56 36 . . . . . . . . . . . 12 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ((𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆) → 𝑓:𝑋⟶ω))
2928imp 407 . . . . . . . . . . 11 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → 𝑓:𝑋⟶ω)
3029ffnd 6638 . . . . . . . . . 10 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → 𝑓 Fn 𝑋)
31 fnconstg 6699 . . . . . . . . . . 11 (∅ ∈ ω → (𝑋 × {∅}) Fn 𝑋)
323, 31mp1i 13 . . . . . . . . . 10 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → (𝑋 × {∅}) Fn 𝑋)
336adantr 481 . . . . . . . . . 10 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → 𝑋 ∈ On)
34 inidm 4162 . . . . . . . . . 10 (𝑋𝑋) = 𝑋
3530, 32, 33, 33, 34offn 7587 . . . . . . . . 9 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → (𝑓f +o (𝑋 × {∅})) Fn 𝑋)
3630adantr 481 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → 𝑓 Fn 𝑋)
373, 31mp1i 13 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → (𝑋 × {∅}) Fn 𝑋)
38 simplll 772 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → 𝑋 ∈ On)
39 simpr 485 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → 𝑥𝑋)
40 fnfvof 7591 . . . . . . . . . . 11 (((𝑓 Fn 𝑋 ∧ (𝑋 × {∅}) Fn 𝑋) ∧ (𝑋 ∈ On ∧ 𝑥𝑋)) → ((𝑓f +o (𝑋 × {∅}))‘𝑥) = ((𝑓𝑥) +o ((𝑋 × {∅})‘𝑥)))
4136, 37, 38, 39, 40syl22anc 836 . . . . . . . . . 10 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ((𝑓f +o (𝑋 × {∅}))‘𝑥) = ((𝑓𝑥) +o ((𝑋 × {∅})‘𝑥)))
423a1i 11 . . . . . . . . . . . 12 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ∅ ∈ ω)
43 fvconst2g 7116 . . . . . . . . . . . 12 ((∅ ∈ ω ∧ 𝑥𝑋) → ((𝑋 × {∅})‘𝑥) = ∅)
4442, 39, 43syl2anc 584 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ((𝑋 × {∅})‘𝑥) = ∅)
4544oveq2d 7332 . . . . . . . . . 10 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ((𝑓𝑥) +o ((𝑋 × {∅})‘𝑥)) = ((𝑓𝑥) +o ∅))
4629ffvelcdmda 7000 . . . . . . . . . . 11 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → (𝑓𝑥) ∈ ω)
47 nnon 7764 . . . . . . . . . . 11 ((𝑓𝑥) ∈ ω → (𝑓𝑥) ∈ On)
48 oa0 8395 . . . . . . . . . . 11 ((𝑓𝑥) ∈ On → ((𝑓𝑥) +o ∅) = (𝑓𝑥))
4946, 47, 483syl 18 . . . . . . . . . 10 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ((𝑓𝑥) +o ∅) = (𝑓𝑥))
5041, 45, 493eqtrd 2780 . . . . . . . . 9 ((((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) ∧ 𝑥𝑋) → ((𝑓f +o (𝑋 × {∅}))‘𝑥) = (𝑓𝑥))
5135, 30, 50eqfnfvd 6951 . . . . . . . 8 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → (𝑓f +o (𝑋 × {∅})) = 𝑓)
5222, 51eqtr2d 2777 . . . . . . 7 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ (𝑓𝑆 ∧ (𝑋 × {∅}) ∈ 𝑆)) → 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅})))
5352expr 457 . . . . . 6 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → ((𝑋 × {∅}) ∈ 𝑆𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅}))))
5417, 53jcai 517 . . . . 5 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → ((𝑋 × {∅}) ∈ 𝑆𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅}))))
55 oveq2 7324 . . . . . 6 (𝑧 = (𝑋 × {∅}) → (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧) = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅})))
5655rspceeqv 3583 . . . . 5 (((𝑋 × {∅}) ∈ 𝑆𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))(𝑋 × {∅}))) → ∃𝑧𝑆 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
5754, 56syl 17 . . . 4 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → ∃𝑧𝑆 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
58 oveq1 7323 . . . . . . 7 (𝑔 = 𝑓 → (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧) = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
5958eqeq2d 2747 . . . . . 6 (𝑔 = 𝑓 → (𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧) ↔ 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧)))
6059rexbidv 3171 . . . . 5 (𝑔 = 𝑓 → (∃𝑧𝑆 𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧) ↔ ∃𝑧𝑆 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧)))
6160rspcev 3569 . . . 4 ((𝑓𝑆 ∧ ∃𝑧𝑆 𝑓 = (𝑓( ∘f +o ↾ (𝑆 × 𝑆))𝑧)) → ∃𝑔𝑆𝑧𝑆 𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
622, 57, 61syl2anc 584 . . 3 (((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) ∧ 𝑓𝑆) → ∃𝑔𝑆𝑧𝑆 𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
6362ralrimiva 3139 . 2 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ∀𝑓𝑆𝑔𝑆𝑧𝑆 𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧))
64 foov 7487 . 2 (( ∘f +o ↾ (𝑆 × 𝑆)):(𝑆 × 𝑆)–onto𝑆 ↔ (( ∘f +o ↾ (𝑆 × 𝑆)):(𝑆 × 𝑆)⟶𝑆 ∧ ∀𝑓𝑆𝑔𝑆𝑧𝑆 𝑓 = (𝑔( ∘f +o ↾ (𝑆 × 𝑆))𝑧)))
651, 63, 64sylanbrc 583 1 ((𝑋 ∈ On ∧ 𝑆 = dom (ω CNF 𝑋)) → ( ∘f +o ↾ (𝑆 × 𝑆)):(𝑆 × 𝑆)–onto𝑆)
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 396   = wceq 1540  wcel 2105  wral 3061  wrex 3070  c0 4266  {csn 4570   class class class wbr 5086   × cxp 5605  dom cdm 5607  cres 5609  Oncon0 6288   Fn wfn 6460  wf 6461  ontowfo 6463  cfv 6465  (class class class)co 7316  f cof 7572  ωcom 7758   +o coa 8342   finSupp cfsupp 9204   CNF ccnf 9496
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1912  ax-6 1970  ax-7 2010  ax-8 2107  ax-9 2115  ax-10 2136  ax-11 2153  ax-12 2170  ax-ext 2707  ax-rep 5223  ax-sep 5237  ax-nul 5244  ax-pow 5302  ax-pr 5366  ax-un 7629  ax-inf2 9476
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 845  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1781  df-nf 1785  df-sb 2067  df-mo 2538  df-eu 2567  df-clab 2714  df-cleq 2728  df-clel 2814  df-nfc 2886  df-ne 2941  df-ral 3062  df-rex 3071  df-reu 3350  df-rab 3404  df-v 3442  df-sbc 3726  df-csb 3842  df-dif 3899  df-un 3901  df-in 3903  df-ss 3913  df-pss 3915  df-nul 4267  df-if 4471  df-pw 4546  df-sn 4571  df-pr 4573  df-op 4577  df-uni 4850  df-iun 4938  df-br 5087  df-opab 5149  df-mpt 5170  df-tr 5204  df-id 5506  df-eprel 5512  df-po 5520  df-so 5521  df-fr 5562  df-we 5564  df-xp 5613  df-rel 5614  df-cnv 5615  df-co 5616  df-dm 5617  df-rn 5618  df-res 5619  df-ima 5620  df-pred 6224  df-ord 6291  df-on 6292  df-lim 6293  df-suc 6294  df-iota 6417  df-fun 6467  df-fn 6468  df-f 6469  df-f1 6470  df-fo 6471  df-f1o 6472  df-fv 6473  df-ov 7319  df-oprab 7320  df-mpo 7321  df-of 7574  df-om 7759  df-1st 7877  df-2nd 7878  df-supp 8026  df-frecs 8145  df-wrecs 8176  df-recs 8250  df-rdg 8289  df-seqom 8327  df-1o 8345  df-oadd 8349  df-map 8666  df-en 8783  df-fin 8786  df-fsupp 9205  df-cnf 9497
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator