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

Theorem isfuncd 15714
Description: Deduce that an operation is a functor of categories. (Contributed by Mario Carneiro, 4-Jan-2017.)
Hypotheses
Ref Expression
isfunc.b  |-  B  =  ( Base `  D
)
isfunc.c  |-  C  =  ( Base `  E
)
isfunc.h  |-  H  =  ( Hom  `  D
)
isfunc.j  |-  J  =  ( Hom  `  E
)
isfunc.1  |-  .1.  =  ( Id `  D )
isfunc.i  |-  I  =  ( Id `  E
)
isfunc.x  |-  .x.  =  (comp `  D )
isfunc.o  |-  O  =  (comp `  E )
isfunc.d  |-  ( ph  ->  D  e.  Cat )
isfunc.e  |-  ( ph  ->  E  e.  Cat )
isfuncd.1  |-  ( ph  ->  F : B --> C )
isfuncd.2  |-  ( ph  ->  G  Fn  ( B  X.  B ) )
isfuncd.3  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B ) )  -> 
( x G y ) : ( x H y ) --> ( ( F `  x
) J ( F `
 y ) ) )
isfuncd.4  |-  ( (
ph  /\  x  e.  B )  ->  (
( x G x ) `  (  .1.  `  x ) )  =  ( I `  ( F `  x )
) )
isfuncd.5  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B  /\  z  e.  B )  /\  (
m  e.  ( x H y )  /\  n  e.  ( y H z ) ) )  ->  ( (
x G z ) `
 ( n (
<. x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) )
Assertion
Ref Expression
isfuncd  |-  ( ph  ->  F ( D  Func  E ) G )
Distinct variable groups:    m, n, x, y, z, B    D, m, n, x, y, z   
m, E, n, x, y, z    m, H, n, x, y, z   
m, F, n, x, y, z    m, G, n, x, y, z   
x, J, y, z    ph, m, n, x, y, z
Allowed substitution hints:    C( x, y, z, m, n)    .x. ( x, y, z, m, n)    .1. ( x, y, z, m, n)    I( x, y, z, m, n)    J( m, n)    O( x, y, z, m, n)

Proof of Theorem isfuncd
StepHypRef Expression
1 isfuncd.1 . 2  |-  ( ph  ->  F : B --> C )
2 isfuncd.2 . . . 4  |-  ( ph  ->  G  Fn  ( B  X.  B ) )
3 isfunc.b . . . . . 6  |-  B  =  ( Base `  D
)
4 fvex 5882 . . . . . 6  |-  ( Base `  D )  e.  _V
53, 4eqeltri 2504 . . . . 5  |-  B  e. 
_V
65, 5xpex 6600 . . . 4  |-  ( B  X.  B )  e. 
_V
7 fnex 6138 . . . 4  |-  ( ( G  Fn  ( B  X.  B )  /\  ( B  X.  B
)  e.  _V )  ->  G  e.  _V )
82, 6, 7sylancl 666 . . 3  |-  ( ph  ->  G  e.  _V )
9 isfuncd.3 . . . . . 6  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B ) )  -> 
( x G y ) : ( x H y ) --> ( ( F `  x
) J ( F `
 y ) ) )
10 ovex 6324 . . . . . . 7  |-  ( ( F `  x ) J ( F `  y ) )  e. 
_V
11 ovex 6324 . . . . . . 7  |-  ( x H y )  e. 
_V
1210, 11elmap 7499 . . . . . 6  |-  ( ( x G y )  e.  ( ( ( F `  x ) J ( F `  y ) )  ^m  ( x H y ) )  <->  ( x G y ) : ( x H y ) --> ( ( F `
 x ) J ( F `  y
) ) )
139, 12sylibr 215 . . . . 5  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B ) )  -> 
( x G y )  e.  ( ( ( F `  x
) J ( F `
 y ) )  ^m  ( x H y ) ) )
1413ralrimivva 2844 . . . 4  |-  ( ph  ->  A. x  e.  B  A. y  e.  B  ( x G y )  e.  ( ( ( F `  x
) J ( F `
 y ) )  ^m  ( x H y ) ) )
15 fveq2 5872 . . . . . . 7  |-  ( z  =  <. x ,  y
>.  ->  ( G `  z )  =  ( G `  <. x ,  y >. )
)
16 df-ov 6299 . . . . . . 7  |-  ( x G y )  =  ( G `  <. x ,  y >. )
1715, 16syl6eqr 2479 . . . . . 6  |-  ( z  =  <. x ,  y
>.  ->  ( G `  z )  =  ( x G y ) )
18 vex 3081 . . . . . . . . . 10  |-  x  e. 
_V
19 vex 3081 . . . . . . . . . 10  |-  y  e. 
_V
2018, 19op1std 6808 . . . . . . . . 9  |-  ( z  =  <. x ,  y
>.  ->  ( 1st `  z
)  =  x )
2120fveq2d 5876 . . . . . . . 8  |-  ( z  =  <. x ,  y
>.  ->  ( F `  ( 1st `  z ) )  =  ( F `
 x ) )
2218, 19op2ndd 6809 . . . . . . . . 9  |-  ( z  =  <. x ,  y
>.  ->  ( 2nd `  z
)  =  y )
2322fveq2d 5876 . . . . . . . 8  |-  ( z  =  <. x ,  y
>.  ->  ( F `  ( 2nd `  z ) )  =  ( F `
 y ) )
2421, 23oveq12d 6314 . . . . . . 7  |-  ( z  =  <. x ,  y
>.  ->  ( ( F `
 ( 1st `  z
) ) J ( F `  ( 2nd `  z ) ) )  =  ( ( F `
 x ) J ( F `  y
) ) )
25 fveq2 5872 . . . . . . . 8  |-  ( z  =  <. x ,  y
>.  ->  ( H `  z )  =  ( H `  <. x ,  y >. )
)
26 df-ov 6299 . . . . . . . 8  |-  ( x H y )  =  ( H `  <. x ,  y >. )
2725, 26syl6eqr 2479 . . . . . . 7  |-  ( z  =  <. x ,  y
>.  ->  ( H `  z )  =  ( x H y ) )
2824, 27oveq12d 6314 . . . . . 6  |-  ( z  =  <. x ,  y
>.  ->  ( ( ( F `  ( 1st `  z ) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `
 z ) )  =  ( ( ( F `  x ) J ( F `  y ) )  ^m  ( x H y ) ) )
2917, 28eleq12d 2502 . . . . 5  |-  ( z  =  <. x ,  y
>.  ->  ( ( G `
 z )  e.  ( ( ( F `
 ( 1st `  z
) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `  z ) )  <->  ( x G y )  e.  ( ( ( F `
 x ) J ( F `  y
) )  ^m  (
x H y ) ) ) )
3029ralxp 4987 . . . 4  |-  ( A. z  e.  ( B  X.  B ) ( G `
 z )  e.  ( ( ( F `
 ( 1st `  z
) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `  z ) )  <->  A. x  e.  B  A. y  e.  B  ( x G y )  e.  ( ( ( F `
 x ) J ( F `  y
) )  ^m  (
x H y ) ) )
3114, 30sylibr 215 . . 3  |-  ( ph  ->  A. z  e.  ( B  X.  B ) ( G `  z
)  e.  ( ( ( F `  ( 1st `  z ) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `  z )
) )
32 elixp2 7525 . . 3  |-  ( G  e.  X_ z  e.  ( B  X.  B ) ( ( ( F `
 ( 1st `  z
) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `  z ) )  <->  ( G  e.  _V  /\  G  Fn  ( B  X.  B
)  /\  A. z  e.  ( B  X.  B
) ( G `  z )  e.  ( ( ( F `  ( 1st `  z ) ) J ( F `
 ( 2nd `  z
) ) )  ^m  ( H `  z ) ) ) )
338, 2, 31, 32syl3anbrc 1189 . 2  |-  ( ph  ->  G  e.  X_ z  e.  ( B  X.  B
) ( ( ( F `  ( 1st `  z ) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `
 z ) ) )
34 isfuncd.4 . . . 4  |-  ( (
ph  /\  x  e.  B )  ->  (
( x G x ) `  (  .1.  `  x ) )  =  ( I `  ( F `  x )
) )
35 isfuncd.5 . . . . . . . . 9  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B  /\  z  e.  B )  /\  (
m  e.  ( x H y )  /\  n  e.  ( y H z ) ) )  ->  ( (
x G z ) `
 ( n (
<. x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) )
36353expia 1207 . . . . . . . 8  |-  ( (
ph  /\  ( x  e.  B  /\  y  e.  B  /\  z  e.  B ) )  -> 
( ( m  e.  ( x H y )  /\  n  e.  ( y H z ) )  ->  (
( x G z ) `  ( n ( <. x ,  y
>.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n
) ( <. ( F `  x ) ,  ( F `  y ) >. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) )
37363exp2 1223 . . . . . . 7  |-  ( ph  ->  ( x  e.  B  ->  ( y  e.  B  ->  ( z  e.  B  ->  ( ( m  e.  ( x H y )  /\  n  e.  ( y H z ) )  ->  (
( x G z ) `  ( n ( <. x ,  y
>.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n
) ( <. ( F `  x ) ,  ( F `  y ) >. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) ) ) ) )
3837imp43 598 . . . . . 6  |-  ( ( ( ph  /\  x  e.  B )  /\  (
y  e.  B  /\  z  e.  B )
)  ->  ( (
m  e.  ( x H y )  /\  n  e.  ( y H z ) )  ->  ( ( x G z ) `  ( n ( <.
x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) )
3938ralrimivv 2843 . . . . 5  |-  ( ( ( ph  /\  x  e.  B )  /\  (
y  e.  B  /\  z  e.  B )
)  ->  A. m  e.  ( x H y ) A. n  e.  ( y H z ) ( ( x G z ) `  ( n ( <.
x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) )
4039ralrimivva 2844 . . . 4  |-  ( (
ph  /\  x  e.  B )  ->  A. y  e.  B  A. z  e.  B  A. m  e.  ( x H y ) A. n  e.  ( y H z ) ( ( x G z ) `  ( n ( <.
x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) )
4134, 40jca 534 . . 3  |-  ( (
ph  /\  x  e.  B )  ->  (
( ( x G x ) `  (  .1.  `  x ) )  =  ( I `  ( F `  x ) )  /\  A. y  e.  B  A. z  e.  B  A. m  e.  ( x H y ) A. n  e.  ( y H z ) ( ( x G z ) `  ( n ( <.
x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) )
4241ralrimiva 2837 . 2  |-  ( ph  ->  A. x  e.  B  ( ( ( x G x ) `  (  .1.  `  x )
)  =  ( I `
 ( F `  x ) )  /\  A. y  e.  B  A. z  e.  B  A. m  e.  ( x H y ) A. n  e.  ( y H z ) ( ( x G z ) `  ( n ( <. x ,  y
>.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n
) ( <. ( F `  x ) ,  ( F `  y ) >. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) )
43 isfunc.c . . 3  |-  C  =  ( Base `  E
)
44 isfunc.h . . 3  |-  H  =  ( Hom  `  D
)
45 isfunc.j . . 3  |-  J  =  ( Hom  `  E
)
46 isfunc.1 . . 3  |-  .1.  =  ( Id `  D )
47 isfunc.i . . 3  |-  I  =  ( Id `  E
)
48 isfunc.x . . 3  |-  .x.  =  (comp `  D )
49 isfunc.o . . 3  |-  O  =  (comp `  E )
50 isfunc.d . . 3  |-  ( ph  ->  D  e.  Cat )
51 isfunc.e . . 3  |-  ( ph  ->  E  e.  Cat )
523, 43, 44, 45, 46, 47, 48, 49, 50, 51isfunc 15713 . 2  |-  ( ph  ->  ( F ( D 
Func  E ) G  <->  ( F : B --> C  /\  G  e.  X_ z  e.  ( B  X.  B ) ( ( ( F `
 ( 1st `  z
) ) J ( F `  ( 2nd `  z ) ) )  ^m  ( H `  z ) )  /\  A. x  e.  B  ( ( ( x G x ) `  (  .1.  `  x ) )  =  ( I `  ( F `  x ) )  /\  A. y  e.  B  A. z  e.  B  A. m  e.  ( x H y ) A. n  e.  ( y H z ) ( ( x G z ) `  ( n ( <.
x ,  y >.  .x.  z ) m ) )  =  ( ( ( y G z ) `  n ) ( <. ( F `  x ) ,  ( F `  y )
>. O ( F `  z ) ) ( ( x G y ) `  m ) ) ) ) ) )
531, 33, 42, 52mpbir3and 1188 1  |-  ( ph  ->  F ( D  Func  E ) G )
Colors of variables: wff setvar class
Syntax hints:    -> wi 4    /\ wa 370    /\ w3a 982    = wceq 1437    e. wcel 1867   A.wral 2773   _Vcvv 3078   <.cop 3999   class class class wbr 4417    X. cxp 4843    Fn wfn 5587   -->wf 5588   ` cfv 5592  (class class class)co 6296   1stc1st 6796   2ndc2nd 6797    ^m cmap 7471   X_cixp 7521   Basecbs 15073   Hom chom 15153  compcco 15154   Catccat 15514   Idccid 15515    Func cfunc 15703
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1665  ax-4 1678  ax-5 1748  ax-6 1794  ax-7 1838  ax-8 1869  ax-9 1871  ax-10 1886  ax-11 1891  ax-12 1904  ax-13 2052  ax-ext 2398  ax-rep 4529  ax-sep 4539  ax-nul 4547  ax-pow 4594  ax-pr 4652  ax-un 6588
This theorem depends on definitions:  df-bi 188  df-or 371  df-an 372  df-3an 984  df-tru 1440  df-ex 1660  df-nf 1664  df-sb 1787  df-eu 2267  df-mo 2268  df-clab 2406  df-cleq 2412  df-clel 2415  df-nfc 2570  df-ne 2618  df-ral 2778  df-rex 2779  df-reu 2780  df-rab 2782  df-v 3080  df-sbc 3297  df-csb 3393  df-dif 3436  df-un 3438  df-in 3440  df-ss 3447  df-nul 3759  df-if 3907  df-pw 3978  df-sn 3994  df-pr 3996  df-op 4000  df-uni 4214  df-iun 4295  df-br 4418  df-opab 4476  df-mpt 4477  df-id 4760  df-xp 4851  df-rel 4852  df-cnv 4853  df-co 4854  df-dm 4855  df-rn 4856  df-res 4857  df-ima 4858  df-iota 5556  df-fun 5594  df-fn 5595  df-f 5596  df-f1 5597  df-fo 5598  df-f1o 5599  df-fv 5600  df-ov 6299  df-oprab 6300  df-mpt2 6301  df-1st 6798  df-2nd 6799  df-map 7473  df-ixp 7522  df-func 15707
This theorem is referenced by:  funcoppc  15724  funcres  15745  catcisolem  15945  funcestrcsetc  15978  funcsetcestrc  15993  1stfcl  16026  2ndfcl  16027  prfcl  16032  evlfcl  16051  curf1cl  16057  curfcl  16061  hofcl  16088  funcringcsetcALTV2  38818  funcringcsetcALTV  38841
  Copyright terms: Public domain W3C validator