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 49556
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 49555 . . . . . . 7 (𝜑𝐽𝐴)
87ne0d 4270 . . . . . 6 (𝜑𝐴 ≠ ∅)
9 iinconst 4932 . . . . . 6 (𝐴 ≠ ∅ → 𝐴 𝑆 = 𝑆)
108, 9syl 17 . . . . 5 (𝜑 𝐴 𝑆 = 𝑆)
1110eqcomd 2745 . . . 4 (𝜑𝑆 = 𝐴 𝑆)
1211adantr 481 . . . 4 ((𝜑𝑥𝑆) → 𝑆 = 𝐴 𝑆)
137adantr 481 . . . . . 6 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → 𝐽𝐴)
14 simpr 485 . . . . . . . 8 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → = 𝐽)
1514oveqd 7373 . . . . . . 7 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝑦) = (𝑥𝐽𝑦))
16 snex 5368 . . . . . . . . . 10 {(𝐼𝑥)} ∈ V
17 0ex 5229 . . . . . . . . . 10 ∅ ∈ V
1816, 17ifex 4505 . . . . . . . . 9 if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ∈ V
191ovmpt4g 7503 . . . . . . . . 9 ((𝑥𝑆𝑦𝑆 ∧ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ∈ V) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2018, 19mp3an3 1458 . . . . . . . 8 ((𝑥𝑆𝑦𝑆) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2120ad2antlr 733 . . . . . . 7 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝐽𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
2215, 21eqtrd 2774 . . . . . 6 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ = 𝐽) → (𝑥𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
23 sseq1 3940 . . . . . . 7 ({(𝐼𝑥)} = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) → ({(𝐼𝑥)} ⊆ (𝑥𝑦) ↔ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦)))
24 sseq1 3940 . . . . . . 7 (∅ = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) → (∅ ⊆ (𝑥𝑦) ↔ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦)))
25 simpr 485 . . . . . . . . . . . . . 14 ((𝜑𝐴) → 𝐴)
266adantr 481 . . . . . . . . . . . . . 14 ((𝜑𝐴) → 𝐴 = ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
2725, 26eleqtrd 2841 . . . . . . . . . . . . 13 ((𝜑𝐴) → ∈ ((Subcat‘𝐶) ∩ {𝑗𝑗 Fn (𝑆 × 𝑆)}))
2827elin1d 4133 . . . . . . . . . . . 12 ((𝜑𝐴) → ∈ (Subcat‘𝐶))
2928adantlr 721 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → ∈ (Subcat‘𝐶))
3027elin2d 4134 . . . . . . . . . . . . 13 ((𝜑𝐴) → ∈ {𝑗𝑗 Fn (𝑆 × 𝑆)})
31 vex 3435 . . . . . . . . . . . . . 14 ∈ V
32 fneq1 6576 . . . . . . . . . . . . . 14 (𝑗 = → (𝑗 Fn (𝑆 × 𝑆) ↔ Fn (𝑆 × 𝑆)))
3331, 32elab 3617 . . . . . . . . . . . . 13 ( ∈ {𝑗𝑗 Fn (𝑆 × 𝑆)} ↔ Fn (𝑆 × 𝑆))
3430, 33sylib 219 . . . . . . . . . . . 12 ((𝜑𝐴) → Fn (𝑆 × 𝑆))
3534adantlr 721 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → Fn (𝑆 × 𝑆))
36 simplrl 782 . . . . . . . . . . 11 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → 𝑥𝑆)
3729, 35, 36, 3subcidcl 17802 . . . . . . . . . 10 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → (𝐼𝑥) ∈ (𝑥𝑥))
3837adantr 481 . . . . . . . . 9 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝐼𝑥) ∈ (𝑥𝑥))
39 simpr 485 . . . . . . . . . 10 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → 𝑥 = 𝑦)
4039oveq2d 7372 . . . . . . . . 9 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝑥𝑥) = (𝑥𝑦))
4138, 40eleqtrd 2841 . . . . . . . 8 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → (𝐼𝑥) ∈ (𝑥𝑦))
4241snssd 4718 . . . . . . 7 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ 𝑥 = 𝑦) → {(𝐼𝑥)} ⊆ (𝑥𝑦))
43 0ss 4328 . . . . . . . 8 ∅ ⊆ (𝑥𝑦)
4443a1i 11 . . . . . . 7 ((((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) ∧ ¬ 𝑥 = 𝑦) → ∅ ⊆ (𝑥𝑦))
4523, 24, 42, 44ifbothda 4493 . . . . . 6 (((𝜑 ∧ (𝑥𝑆𝑦𝑆)) ∧ 𝐴) → if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) ⊆ (𝑥𝑦))
4613, 22, 45iinglb 49312 . . . . 5 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → 𝐴 (𝑥𝑦) = if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅))
4746eqcomd 2745 . . . 4 ((𝜑 ∧ (𝑥𝑆𝑦𝑆)) → if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅) = 𝐴 (𝑥𝑦))
4811, 12, 47mpoeq123dva 7430 . . 3 (𝜑 → (𝑥𝑆, 𝑦𝑆 ↦ if(𝑥 = 𝑦, {(𝐼𝑥)}, ∅)) = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
491, 48eqtrid 2786 . 2 (𝜑𝐽 = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
50 eqid 2739 . . . 4 (Homf𝐶) = (Homf𝐶)
5128, 50subcssc 17798 . . 3 ((𝜑𝐴) → cat (Homf𝐶))
52 eqidd 2740 . . 3 (𝜑 → (𝑧 𝐴 dom 𝐴 (𝑧)) = (𝑧 𝐴 dom 𝐴 (𝑧)))
53 dmdm 49543 . . . 4 ( Fn (𝑆 × 𝑆) → 𝑆 = dom dom )
5434, 53syl 17 . . 3 ((𝜑𝐴) → 𝑆 = dom dom )
55 nfv 1921 . . 3 𝜑
568, 51, 52, 54, 55iinfssclem1 49544 . 2 (𝜑 → (𝑧 𝐴 dom 𝐴 (𝑧)) = (𝑥 𝐴 𝑆, 𝑦 𝐴 𝑆 𝐴 (𝑥𝑦)))
5749, 56eqtr4d 2777 1 (𝜑𝐽 = (𝑧 𝐴 dom 𝐴 (𝑧)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 396   = wceq 1547  wcel 2119  {cab 2717  wne 2934  Vcvv 3431  cin 3882  wss 3883  c0 4261  ifcif 4454  {csn 4555   ciin 4922  cmpt 5153   × cxp 5616  dom cdm 5618   Fn wfn 6480  cfv 6485  (class class class)co 7356  cmpo 7358  Basecbs 17170  Catccat 17621  Idccid 17622  Homf chomf 17623  Subcatcsubc 17767
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1802  ax-4 1816  ax-5 1917  ax-6 1974  ax-7 2015  ax-8 2121  ax-9 2129  ax-10 2152  ax-11 2168  ax-12 2189  ax-ext 2711  ax-rep 5199  ax-sep 5218  ax-nul 5228  ax-pow 5294  ax-pr 5362  ax-un 7678
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 854  df-3an 1094  df-tru 1550  df-fal 1560  df-ex 1787  df-nf 1791  df-sb 2074  df-mo 2543  df-eu 2573  df-clab 2718  df-cleq 2731  df-clel 2814  df-nfc 2888  df-ne 2935  df-ral 3054  df-rex 3064  df-rmo 3344  df-reu 3345  df-rab 3392  df-v 3433  df-sbc 3724  df-csb 3832  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-nul 4262  df-if 4455  df-pw 4531  df-sn 4556  df-pr 4558  df-op 4562  df-uni 4839  df-iun 4923  df-iin 4924  df-br 5073  df-opab 5135  df-mpt 5154  df-id 5513  df-xp 5624  df-rel 5625  df-cnv 5626  df-co 5627  df-dm 5628  df-rn 5629  df-res 5630  df-ima 5631  df-iota 6441  df-fun 6487  df-fn 6488  df-f 6489  df-f1 6490  df-fo 6491  df-f1o 6492  df-fv 6493  df-riota 7313  df-ov 7359  df-oprab 7360  df-mpo 7361  df-1st 7931  df-2nd 7932  df-pm 8766  df-ixp 8836  df-cat 17625  df-cid 17626  df-homf 17627  df-ssc 17768  df-subc 17770
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator