Users' Mathboxes Mathbox for Zhi Wang < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  iinfconstbas Structured version   Visualization version   GIF version

Theorem iinfconstbas 49687
Description: The discrete category is the indexed intersection of all subcategories with the same base. (Contributed by Zhi Wang, 1-Nov-2025.)
Hypotheses
Ref Expression
discsubc.j 𝐽 = (𝑥𝑆, 𝑦𝑆 ↦ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
discsubc.b 𝐵 = (Base‘𝐶)
discsubc.i 𝐼 = (Id‘𝐶)
discsubc.s (𝜑𝑆𝐵)
discsubc.c (𝜑𝐶 ∈ Cat)
iinfconstbas.a (𝜑𝐴 = ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
Assertion
Ref Expression
iinfconstbas (𝜑𝐽 = (𝑧 𝐴 dom 𝐴 (𝑧)))
Distinct variable groups:   𝑥,𝑆,𝑦   𝑥,𝐼,𝑦   ,𝐽,𝑗   𝑆,,𝑗   𝐴,,𝑥,𝑦,𝑧   ,𝐼   𝑧,𝑆   𝜑,,𝑥,𝑦
Allowed substitution hints:   𝜑(𝑧,𝑗)   𝐴(𝑗)   𝐵(𝑥,𝑦,𝑧,,𝑗)   𝐶(𝑥,𝑦,𝑧,,𝑗)   𝐼(𝑧,𝑗)   𝐽(𝑥,𝑦,𝑧)

Proof of Theorem iinfconstbas
StepHypRef Expression
1 discsubc.j . . 3 𝐽 = (𝑥𝑆, 𝑦𝑆 ↦ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2 discsubc.b . . . . . . . 8 𝐵 = (Base‘𝐶)
3 discsubc.i . . . . . . . 8 𝐼 = (Id‘𝐶)
4 discsubc.s . . . . . . . 8 (𝜑𝑆𝐵)
5 discsubc.c . . . . . . . 8 (𝜑𝐶 ∈ Cat)
6 iinfconstbas.a . . . . . . . 8 (𝜑𝐴 = ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
71, 2, 3, 4, 5, 6iinfconstbaslem 49686 . . . . . . 7 (𝜑𝐽𝐴)
87ne0d 4294 . . . . . 6 (𝜑𝐴 ≠ ∅)
9 iinconst 4960 . . . . . 6 (𝐴 ≠ ∅ → 𝐴 𝑆 = 𝑆)
108, 9syl 17 . . . . 5 (𝜑 𝐴 𝑆 = 𝑆)
1110eqcomd 2768 . . . 4 (𝜑𝑆 = 𝐴 𝑆)
1211adantr 484 . . . 4 ((𝜑𝑥𝑆) → 𝑆 = 𝐴 𝑆)
137adantr 484 . . . . . 6 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → 𝐽𝐴)
14 simpr 488 . . . . . . . 8 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → = 𝐽)
1514oveqd 7413 . . . . . . 7 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝑦) = (𝑥𝐽𝑦))
16 snex 5396 . . . . . . . . . 10 {(𝐼𝑥)} ∈ V
17 0ex 5257 . . . . . . . . . 10 ∅ ∈ V
1816, 17ifex 4531 . . . . . . . . 9 if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ∈ V
191ovmpt4g 7543 . . . . . . . . 9 ((𝑥𝑆𝑦𝑆 ∧ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ∈ V) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2018, 19mp3an3 1471 . . . . . . . 8 ((𝑥𝑆𝑦𝑆) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2120ad2antlr 737 . . . . . . 7 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2215, 21eqtrd 2797 . . . . . 6 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
23 sseq1 3961 . . . . . . 7 ({(𝐼𝑥)} = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) → ({(𝐼𝑥)} ⊆ (𝑥𝑦) ↔ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦)))
24 sseq1 3961 . . . . . . 7 (∅ = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) → (∅ ⊆ (𝑥𝑦) ↔ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦)))
25 simpr 488 . . . . . . . . . . . . . 14 ((𝜑𝐴) → 𝐴)
266adantr 484 . . . . . . . . . . . . . 14 ((𝜑𝐴) → 𝐴 = ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
2725, 26eleqtrd 2864 . . . . . . . . . . . . 13 ((𝜑𝐴) → ∈ ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
2827elin1d 4156 . . . . . . . . . . . 12 ((𝜑𝐴) → ∈ (Subcat‘𝐶))
2928adantlr 725 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → ∈ (Subcat‘𝐶))
3027elin2d 4157 . . . . . . . . . . . . 13 ((𝜑𝐴) → ∈ {𝑗𝑗 Fn (𝑆 × 𝑆)})
31 vex 3458 . . . . . . . . . . . . . 14 ∈ V
32 fneq1 6612 . . . . . . . . . . . . . 14 (𝑗 = → (𝑗 Fn (𝑆 × 𝑆) ↔ Fn (𝑆 × 𝑆)))
3331, 32elab 3638 . . . . . . . . . . . . 13 ( ∈ {𝑗𝑗 Fn (𝑆 × 𝑆)} ↔ Fn (𝑆 × 𝑆))
3430, 33sylib 220 . . . . . . . . . . . 12 ((𝜑𝐴) → Fn (𝑆 × 𝑆))
3534adantlr 725 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → Fn (𝑆 × 𝑆))
36 simplrl 786 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → 𝑥𝑆)
3729, 35, 36, 3subcidcl 17877 . . . . . . . . . 10 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → (𝐼𝑥) ∈ (𝑥𝑥))
3837adantr 484 . . . . . . . . 9 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝐼𝑥) ∈ (𝑥𝑥))
39 simpr 488 . . . . . . . . . 10 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → 𝑥 = 𝑦)
4039oveq2d 7412 . . . . . . . . 9 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝑥𝑥) = (𝑥𝑦))
4138, 40eleqtrd 2864 . . . . . . . 8 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝐼𝑥) ∈ (𝑥𝑦))
4241snssd 4745 . . . . . . 7 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → {(𝐼𝑥)} ⊆ (𝑥𝑦))
43 0ss 4354 . . . . . . . 8 ∅ ⊆ (𝑥𝑦)
4443a1i 11 . . . . . . 7 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ ¬ 𝑥 = 𝑦) → ∅ ⊆ (𝑥𝑦))
4523, 24, 42, 44ifbothda 4519 . . . . . 6 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦))
4613, 22, 45iinglb 49443 . . . . 5 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → 𝐴 (𝑥𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
4746eqcomd 2768 . . . 4 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) = 𝐴 (𝑥𝑦))
4811, 12, 47mpoeq123dva 7470 . . 3 (𝜑 → (𝑥𝑆, 𝑦𝑆 ↦ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅)) = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
491, 48eqtrid 2809 . 2 (𝜑𝐽 = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
50 eqid 2762 . . . 4 (Homf𝐶) = (Homf𝐶)
5128, 50subcssc 17873 . . 3 ((𝜑𝐴) → cat (Homf𝐶))
52 eqidd 2763 . . 3 (𝜑 → (𝑧 𝐴 dom 𝐴 (𝑧)) = (𝑧 𝐴 dom 𝐴 (𝑧)))
53 dmdm 49674 . . . 4 ( Fn (𝑆 × 𝑆) → 𝑆 = dom dom )
5434, 53syl 17 . . 3 ((𝜑𝐴) → 𝑆 = dom dom )
55 nfv 1934 . . 3 𝜑
568, 51, 52, 54, 55iinfssclem1 49675 . 2 (𝜑 → (𝑧 𝐴 dom 𝐴 (𝑧)) = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
5749, 56eqtr4d 2800 1 (𝜑𝐽 = (𝑧 𝐴 dom 𝐴 (𝑧)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 399   = wceq 1560  wcel 2142  {cab 2740  wne 2957  Vcvv 3454  cin 3903  wss 3904  c0 4285  ifcif 4480  {csn 4582   ciin 4950  cmpt 5181   × cxp 5645  dom cdm 5647   Fn wfn 6516  cfv 6521  (class class class)co 7396  cmpo 7398  Basecbs 17245  Catccat 17696  Idccid 17697  Homf chomf 17698  Subcatcsubc 17842
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1815  ax-4 1829  ax-5 1930  ax-6 1987  ax-7 2028  ax-8 2144  ax-9 2152  ax-10 2175  ax-11 2191  ax-12 2212  ax-ext 2734  ax-rep 5227  ax-sep 5246  ax-nul 5256  ax-pow 5322  ax-pr 5390  ax-un 7718
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3an 1100  df-tru 1563  df-fal 1573  df-ex 1800  df-nf 1804  df-sb 2091  df-mo 2566  df-eu 2596  df-clab 2741  df-cleq 2754  df-clel 2837  df-nfc 2911  df-ne 2958  df-ral 3077  df-rex 3087  df-rmo 3367  df-reu 3368  df-rab 3415  df-v 3456  df-sbc 3745  df-csb 3853  df-dif 3907  df-un 3909  df-in 3911  df-ss 3921  df-nul 4286  df-if 4481  df-pw 4557  df-sn 4583  df-pr 4585  df-op 4589  df-uni 4866  df-iun 4951  df-iin 4952  df-br 5101  df-opab 5163  df-mpt 5182  df-id 5542  df-xp 5653  df-rel 5654  df-cnv 5655  df-co 5656  df-dm 5657  df-rn 5658  df-res 5659  df-ima 5660  df-iota 6477  df-fun 6523  df-fn 6524  df-f 6525  df-f1 6526  df-fo 6527  df-f1o 6528  df-fv 6529  df-riota 7353  df-ov 7399  df-oprab 7400  df-mpo 7401  df-1st 7970  df-2nd 7971  df-pm 8811  df-ixp 8880  df-cat 17700  df-cid 17701  df-homf 17702  df-ssc 17843  df-subc 17845
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator