MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  fucass Structured version   Unicode version

Theorem fucass 15184
Description: Associativity of natural transformation composition. (Contributed by Mario Carneiro, 6-Jan-2017.)
Hypotheses
Ref Expression
fucass.q  |-  Q  =  ( C FuncCat  D )
fucass.n  |-  N  =  ( C Nat  D )
fucass.x  |-  .xb  =  (comp `  Q )
fucass.r  |-  ( ph  ->  R  e.  ( F N G ) )
fucass.s  |-  ( ph  ->  S  e.  ( G N H ) )
fucass.t  |-  ( ph  ->  T  e.  ( H N K ) )
Assertion
Ref Expression
fucass  |-  ( ph  ->  ( ( T (
<. G ,  H >.  .xb 
K ) S ) ( <. F ,  G >. 
.xb  K ) R )  =  ( T ( <. F ,  H >. 
.xb  K ) ( S ( <. F ,  G >.  .xb  H ) R ) ) )

Proof of Theorem fucass
Dummy variable  x is distinct from all other variables.
StepHypRef Expression
1 eqid 2460 . . . . 5  |-  ( Base `  D )  =  (
Base `  D )
2 eqid 2460 . . . . 5  |-  ( Hom  `  D )  =  ( Hom  `  D )
3 eqid 2460 . . . . 5  |-  (comp `  D )  =  (comp `  D )
4 fucass.r . . . . . . . . . 10  |-  ( ph  ->  R  e.  ( F N G ) )
5 fucass.n . . . . . . . . . . 11  |-  N  =  ( C Nat  D )
65natrcl 15166 . . . . . . . . . 10  |-  ( R  e.  ( F N G )  ->  ( F  e.  ( C  Func  D )  /\  G  e.  ( C  Func  D
) ) )
74, 6syl 16 . . . . . . . . 9  |-  ( ph  ->  ( F  e.  ( C  Func  D )  /\  G  e.  ( C  Func  D ) ) )
87simpld 459 . . . . . . . 8  |-  ( ph  ->  F  e.  ( C 
Func  D ) )
9 funcrcl 15079 . . . . . . . 8  |-  ( F  e.  ( C  Func  D )  ->  ( C  e.  Cat  /\  D  e. 
Cat ) )
108, 9syl 16 . . . . . . 7  |-  ( ph  ->  ( C  e.  Cat  /\  D  e.  Cat )
)
1110simprd 463 . . . . . 6  |-  ( ph  ->  D  e.  Cat )
1211adantr 465 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  D  e.  Cat )
13 eqid 2460 . . . . . . 7  |-  ( Base `  C )  =  (
Base `  C )
14 relfunc 15078 . . . . . . . 8  |-  Rel  ( C  Func  D )
15 1st2ndbr 6823 . . . . . . . 8  |-  ( ( Rel  ( C  Func  D )  /\  F  e.  ( C  Func  D
) )  ->  ( 1st `  F ) ( C  Func  D )
( 2nd `  F
) )
1614, 8, 15sylancr 663 . . . . . . 7  |-  ( ph  ->  ( 1st `  F
) ( C  Func  D ) ( 2nd `  F
) )
1713, 1, 16funcf1 15082 . . . . . 6  |-  ( ph  ->  ( 1st `  F
) : ( Base `  C ) --> ( Base `  D ) )
1817ffvelrnda 6012 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( 1st `  F ) `  x )  e.  (
Base `  D )
)
197simprd 463 . . . . . . . 8  |-  ( ph  ->  G  e.  ( C 
Func  D ) )
20 1st2ndbr 6823 . . . . . . . 8  |-  ( ( Rel  ( C  Func  D )  /\  G  e.  ( C  Func  D
) )  ->  ( 1st `  G ) ( C  Func  D )
( 2nd `  G
) )
2114, 19, 20sylancr 663 . . . . . . 7  |-  ( ph  ->  ( 1st `  G
) ( C  Func  D ) ( 2nd `  G
) )
2213, 1, 21funcf1 15082 . . . . . 6  |-  ( ph  ->  ( 1st `  G
) : ( Base `  C ) --> ( Base `  D ) )
2322ffvelrnda 6012 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( 1st `  G ) `  x )  e.  (
Base `  D )
)
24 fucass.t . . . . . . . . . 10  |-  ( ph  ->  T  e.  ( H N K ) )
255natrcl 15166 . . . . . . . . . 10  |-  ( T  e.  ( H N K )  ->  ( H  e.  ( C  Func  D )  /\  K  e.  ( C  Func  D
) ) )
2624, 25syl 16 . . . . . . . . 9  |-  ( ph  ->  ( H  e.  ( C  Func  D )  /\  K  e.  ( C  Func  D ) ) )
2726simpld 459 . . . . . . . 8  |-  ( ph  ->  H  e.  ( C 
Func  D ) )
28 1st2ndbr 6823 . . . . . . . 8  |-  ( ( Rel  ( C  Func  D )  /\  H  e.  ( C  Func  D
) )  ->  ( 1st `  H ) ( C  Func  D )
( 2nd `  H
) )
2914, 27, 28sylancr 663 . . . . . . 7  |-  ( ph  ->  ( 1st `  H
) ( C  Func  D ) ( 2nd `  H
) )
3013, 1, 29funcf1 15082 . . . . . 6  |-  ( ph  ->  ( 1st `  H
) : ( Base `  C ) --> ( Base `  D ) )
3130ffvelrnda 6012 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( 1st `  H ) `  x )  e.  (
Base `  D )
)
325, 4nat1st2nd 15167 . . . . . . 7  |-  ( ph  ->  R  e.  ( <.
( 1st `  F
) ,  ( 2nd `  F ) >. N <. ( 1st `  G ) ,  ( 2nd `  G
) >. ) )
3332adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  R  e.  ( <. ( 1st `  F
) ,  ( 2nd `  F ) >. N <. ( 1st `  G ) ,  ( 2nd `  G
) >. ) )
34 simpr 461 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  x  e.  ( Base `  C )
)
355, 33, 13, 2, 34natcl 15169 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( R `  x )  e.  ( ( ( 1st `  F
) `  x )
( Hom  `  D ) ( ( 1st `  G
) `  x )
) )
36 fucass.s . . . . . . . 8  |-  ( ph  ->  S  e.  ( G N H ) )
375, 36nat1st2nd 15167 . . . . . . 7  |-  ( ph  ->  S  e.  ( <.
( 1st `  G
) ,  ( 2nd `  G ) >. N <. ( 1st `  H ) ,  ( 2nd `  H
) >. ) )
3837adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  S  e.  ( <. ( 1st `  G
) ,  ( 2nd `  G ) >. N <. ( 1st `  H ) ,  ( 2nd `  H
) >. ) )
395, 38, 13, 2, 34natcl 15169 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( S `  x )  e.  ( ( ( 1st `  G
) `  x )
( Hom  `  D ) ( ( 1st `  H
) `  x )
) )
4026simprd 463 . . . . . . . 8  |-  ( ph  ->  K  e.  ( C 
Func  D ) )
41 1st2ndbr 6823 . . . . . . . 8  |-  ( ( Rel  ( C  Func  D )  /\  K  e.  ( C  Func  D
) )  ->  ( 1st `  K ) ( C  Func  D )
( 2nd `  K
) )
4214, 40, 41sylancr 663 . . . . . . 7  |-  ( ph  ->  ( 1st `  K
) ( C  Func  D ) ( 2nd `  K
) )
4313, 1, 42funcf1 15082 . . . . . 6  |-  ( ph  ->  ( 1st `  K
) : ( Base `  C ) --> ( Base `  D ) )
4443ffvelrnda 6012 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( 1st `  K ) `  x )  e.  (
Base `  D )
)
455, 24nat1st2nd 15167 . . . . . . 7  |-  ( ph  ->  T  e.  ( <.
( 1st `  H
) ,  ( 2nd `  H ) >. N <. ( 1st `  K ) ,  ( 2nd `  K
) >. ) )
4645adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  T  e.  ( <. ( 1st `  H
) ,  ( 2nd `  H ) >. N <. ( 1st `  K ) ,  ( 2nd `  K
) >. ) )
475, 46, 13, 2, 34natcl 15169 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( T `  x )  e.  ( ( ( 1st `  H
) `  x )
( Hom  `  D ) ( ( 1st `  K
) `  x )
) )
481, 2, 3, 12, 18, 23, 31, 35, 39, 44, 47catass 14930 . . . 4  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( (
( T `  x
) ( <. (
( 1st `  G
) `  x ) ,  ( ( 1st `  H ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( S `
 x ) ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  G ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( R `  x ) )  =  ( ( T `  x ) ( <.
( ( 1st `  F
) `  x ) ,  ( ( 1st `  H ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( ( S `  x ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  G ) `
 x ) >.
(comp `  D )
( ( 1st `  H
) `  x )
) ( R `  x ) ) ) )
49 fucass.q . . . . . 6  |-  Q  =  ( C FuncCat  D )
50 fucass.x . . . . . 6  |-  .xb  =  (comp `  Q )
5136adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  S  e.  ( G N H ) )
5224adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  T  e.  ( H N K ) )
5349, 5, 13, 3, 50, 51, 52, 34fuccoval 15179 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( T ( <. G ,  H >.  .xb  K ) S ) `  x )  =  ( ( T `
 x ) (
<. ( ( 1st `  G
) `  x ) ,  ( ( 1st `  H ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( S `
 x ) ) )
5453oveq1d 6290 . . . 4  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( (
( T ( <. G ,  H >.  .xb 
K ) S ) `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  G ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( R `
 x ) )  =  ( ( ( T `  x ) ( <. ( ( 1st `  G ) `  x
) ,  ( ( 1st `  H ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( S `  x ) ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  G ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( R `
 x ) ) )
554adantr 465 . . . . . 6  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  R  e.  ( F N G ) )
5649, 5, 13, 3, 50, 55, 51, 34fuccoval 15179 . . . . 5  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( S ( <. F ,  G >.  .xb  H ) R ) `  x )  =  ( ( S `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  G ) `  x
) >. (comp `  D
) ( ( 1st `  H ) `  x
) ) ( R `
 x ) ) )
5756oveq2d 6291 . . . 4  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( ( T `  x )
( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  H ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( ( S ( <. F ,  G >. 
.xb  H ) R ) `  x ) )  =  ( ( T `  x ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  H ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( ( S `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  G ) `  x
) >. (comp `  D
) ( ( 1st `  H ) `  x
) ) ( R `
 x ) ) ) )
5848, 54, 573eqtr4d 2511 . . 3  |-  ( (
ph  /\  x  e.  ( Base `  C )
)  ->  ( (
( T ( <. G ,  H >.  .xb 
K ) S ) `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  G ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( R `
 x ) )  =  ( ( T `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  H ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( ( S ( <. F ,  G >.  .xb  H ) R ) `  x ) ) )
5958mpteq2dva 4526 . 2  |-  ( ph  ->  ( x  e.  (
Base `  C )  |->  ( ( ( T ( <. G ,  H >. 
.xb  K ) S ) `  x ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  G ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( R `  x ) ) )  =  ( x  e.  ( Base `  C
)  |->  ( ( T `
 x ) (
<. ( ( 1st `  F
) `  x ) ,  ( ( 1st `  H ) `  x
) >. (comp `  D
) ( ( 1st `  K ) `  x
) ) ( ( S ( <. F ,  G >.  .xb  H ) R ) `  x ) ) ) )
6049, 5, 50, 36, 24fuccocl 15180 . . 3  |-  ( ph  ->  ( T ( <. G ,  H >.  .xb 
K ) S )  e.  ( G N K ) )
6149, 5, 13, 3, 50, 4, 60fucco 15178 . 2  |-  ( ph  ->  ( ( T (
<. G ,  H >.  .xb 
K ) S ) ( <. F ,  G >. 
.xb  K ) R )  =  ( x  e.  ( Base `  C
)  |->  ( ( ( T ( <. G ,  H >.  .xb  K ) S ) `  x ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  G ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( R `  x ) ) ) )
6249, 5, 50, 4, 36fuccocl 15180 . . 3  |-  ( ph  ->  ( S ( <. F ,  G >.  .xb 
H ) R )  e.  ( F N H ) )
6349, 5, 13, 3, 50, 62, 24fucco 15178 . 2  |-  ( ph  ->  ( T ( <. F ,  H >.  .xb 
K ) ( S ( <. F ,  G >. 
.xb  H ) R ) )  =  ( x  e.  ( Base `  C )  |->  ( ( T `  x ) ( <. ( ( 1st `  F ) `  x
) ,  ( ( 1st `  H ) `
 x ) >.
(comp `  D )
( ( 1st `  K
) `  x )
) ( ( S ( <. F ,  G >. 
.xb  H ) R ) `  x ) ) ) )
6459, 61, 633eqtr4d 2511 1  |-  ( ph  ->  ( ( T (
<. G ,  H >.  .xb 
K ) S ) ( <. F ,  G >. 
.xb  K ) R )  =  ( T ( <. F ,  H >. 
.xb  K ) ( S ( <. F ,  G >.  .xb  H ) R ) ) )
Colors of variables: wff setvar class
Syntax hints:    -> wi 4    /\ wa 369    = wceq 1374    e. wcel 1762   <.cop 4026   class class class wbr 4440    |-> cmpt 4498   Rel wrel 4997   ` cfv 5579  (class class class)co 6275   1stc1st 6772   2ndc2nd 6773   Basecbs 14479   Hom chom 14555  compcco 14556   Catccat 14908    Func cfunc 15070   Nat cnat 15157   FuncCat cfuc 15158
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1596  ax-4 1607  ax-5 1675  ax-6 1714  ax-7 1734  ax-8 1764  ax-9 1766  ax-10 1781  ax-11 1786  ax-12 1798  ax-13 1961  ax-ext 2438  ax-rep 4551  ax-sep 4561  ax-nul 4569  ax-pow 4618  ax-pr 4679  ax-un 6567  ax-cnex 9537  ax-resscn 9538  ax-1cn 9539  ax-icn 9540  ax-addcl 9541  ax-addrcl 9542  ax-mulcl 9543  ax-mulrcl 9544  ax-mulcom 9545  ax-addass 9546  ax-mulass 9547  ax-distr 9548  ax-i2m1 9549  ax-1ne0 9550  ax-1rid 9551  ax-rnegex 9552  ax-rrecex 9553  ax-cnre 9554  ax-pre-lttri 9555  ax-pre-lttrn 9556  ax-pre-ltadd 9557  ax-pre-mulgt0 9558
This theorem depends on definitions:  df-bi 185  df-or 370  df-an 371  df-3or 969  df-3an 970  df-tru 1377  df-ex 1592  df-nf 1595  df-sb 1707  df-eu 2272  df-mo 2273  df-clab 2446  df-cleq 2452  df-clel 2455  df-nfc 2610  df-ne 2657  df-nel 2658  df-ral 2812  df-rex 2813  df-reu 2814  df-rab 2816  df-v 3108  df-sbc 3325  df-csb 3429  df-dif 3472  df-un 3474  df-in 3476  df-ss 3483  df-pss 3485  df-nul 3779  df-if 3933  df-pw 4005  df-sn 4021  df-pr 4023  df-tp 4025  df-op 4027  df-uni 4239  df-int 4276  df-iun 4320  df-br 4441  df-opab 4499  df-mpt 4500  df-tr 4534  df-eprel 4784  df-id 4788  df-po 4793  df-so 4794  df-fr 4831  df-we 4833  df-ord 4874  df-on 4875  df-lim 4876  df-suc 4877  df-xp 4998  df-rel 4999  df-cnv 5000  df-co 5001  df-dm 5002  df-rn 5003  df-res 5004  df-ima 5005  df-iota 5542  df-fun 5581  df-fn 5582  df-f 5583  df-f1 5584  df-fo 5585  df-f1o 5586  df-fv 5587  df-riota 6236  df-ov 6278  df-oprab 6279  df-mpt2 6280  df-om 6672  df-1st 6774  df-2nd 6775  df-recs 7032  df-rdg 7066  df-1o 7120  df-oadd 7124  df-er 7301  df-map 7412  df-ixp 7460  df-en 7507  df-dom 7508  df-sdom 7509  df-fin 7510  df-pnf 9619  df-mnf 9620  df-xr 9621  df-ltxr 9622  df-le 9623  df-sub 9796  df-neg 9797  df-nn 10526  df-2 10583  df-3 10584  df-4 10585  df-5 10586  df-6 10587  df-7 10588  df-8 10589  df-9 10590  df-10 10591  df-n0 10785  df-z 10854  df-dec 10966  df-uz 11072  df-fz 11662  df-struct 14481  df-ndx 14482  df-slot 14483  df-base 14484  df-hom 14568  df-cco 14569  df-cat 14912  df-func 15074  df-nat 15159  df-fuc 15160
This theorem is referenced by:  fuccatid  15185
  Copyright terms: Public domain W3C validator