MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  uncfval Structured version   Visualization version   GIF version

Theorem uncfval 18304
Description: Value of the uncurry functor, which is the reverse of the curry functor, taking 𝐺:𝐶⟶(𝐷𝐸) to uncurryF (𝐺):𝐶 × 𝐷𝐸. (Contributed by Mario Carneiro, 13-Jan-2017.)
Hypotheses
Ref Expression
uncfval.g 𝐹 = (⟨“𝐶𝐷𝐸”⟩ uncurryF 𝐺)
uncfval.c (𝜑𝐷 ∈ Cat)
uncfval.d (𝜑𝐸 ∈ Cat)
uncfval.f (𝜑𝐺 ∈ (𝐶 Func (𝐷 FuncCat 𝐸)))
Assertion
Ref Expression
uncfval (𝜑𝐹 = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))

Proof of Theorem uncfval
Dummy variables 𝑓 𝑐 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 uncfval.g . 2 𝐹 = (⟨“𝐶𝐷𝐸”⟩ uncurryF 𝐺)
2 df-uncf 18285 . . . 4 uncurryF = (𝑐 ∈ V, 𝑓 ∈ V ↦ (((𝑐‘1) evalF (𝑐‘2)) ∘func ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1)))))
32a1i 11 . . 3 (𝜑 → uncurryF = (𝑐 ∈ V, 𝑓 ∈ V ↦ (((𝑐‘1) evalF (𝑐‘2)) ∘func ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1))))))
4 simprl 770 . . . . . . 7 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → 𝑐 = ⟨“𝐶𝐷𝐸”⟩)
54fveq1d 6922 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘1) = (⟨“𝐶𝐷𝐸”⟩‘1))
6 uncfval.c . . . . . . . 8 (𝜑𝐷 ∈ Cat)
7 s3fv1 14941 . . . . . . . 8 (𝐷 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
86, 7syl 17 . . . . . . 7 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
98adantr 480 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
105, 9eqtrd 2780 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘1) = 𝐷)
114fveq1d 6922 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘2) = (⟨“𝐶𝐷𝐸”⟩‘2))
12 uncfval.d . . . . . . . 8 (𝜑𝐸 ∈ Cat)
13 s3fv2 14942 . . . . . . . 8 (𝐸 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1412, 13syl 17 . . . . . . 7 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1514adantr 480 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1611, 15eqtrd 2780 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘2) = 𝐸)
1710, 16oveq12d 7466 . . . 4 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘1) evalF (𝑐‘2)) = (𝐷 evalF 𝐸))
18 simprr 772 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → 𝑓 = 𝐺)
194fveq1d 6922 . . . . . . . 8 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘0) = (⟨“𝐶𝐷𝐸”⟩‘0))
20 uncfval.f . . . . . . . . . . . 12 (𝜑𝐺 ∈ (𝐶 Func (𝐷 FuncCat 𝐸)))
21 funcrcl 17927 . . . . . . . . . . . 12 (𝐺 ∈ (𝐶 Func (𝐷 FuncCat 𝐸)) → (𝐶 ∈ Cat ∧ (𝐷 FuncCat 𝐸) ∈ Cat))
2220, 21syl 17 . . . . . . . . . . 11 (𝜑 → (𝐶 ∈ Cat ∧ (𝐷 FuncCat 𝐸) ∈ Cat))
2322simpld 494 . . . . . . . . . 10 (𝜑𝐶 ∈ Cat)
24 s3fv0 14940 . . . . . . . . . 10 (𝐶 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2523, 24syl 17 . . . . . . . . 9 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2625adantr 480 . . . . . . . 8 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2719, 26eqtrd 2780 . . . . . . 7 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘0) = 𝐶)
2827, 10oveq12d 7466 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘0) 1stF (𝑐‘1)) = (𝐶 1stF 𝐷))
2918, 28oveq12d 7466 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑓func ((𝑐‘0) 1stF (𝑐‘1))) = (𝐺func (𝐶 1stF 𝐷)))
3027, 10oveq12d 7466 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘0) 2ndF (𝑐‘1)) = (𝐶 2ndF 𝐷))
3129, 30oveq12d 7466 . . . 4 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1))) = ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷)))
3217, 31oveq12d 7466 . . 3 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (((𝑐‘1) evalF (𝑐‘2)) ∘func ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1)))) = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
33 s3cli 14930 . . . 4 ⟨“𝐶𝐷𝐸”⟩ ∈ Word V
34 elex 3509 . . . 4 (⟨“𝐶𝐷𝐸”⟩ ∈ Word V → ⟨“𝐶𝐷𝐸”⟩ ∈ V)
3533, 34mp1i 13 . . 3 (𝜑 → ⟨“𝐶𝐷𝐸”⟩ ∈ V)
3620elexd 3512 . . 3 (𝜑𝐺 ∈ V)
37 ovexd 7483 . . 3 (𝜑 → ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))) ∈ V)
383, 32, 35, 36, 37ovmpod 7602 . 2 (𝜑 → (⟨“𝐶𝐷𝐸”⟩ uncurryF 𝐺) = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
391, 38eqtrid 2792 1 (𝜑𝐹 = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395   = wceq 1537  wcel 2108  Vcvv 3488  cfv 6573  (class class class)co 7448  cmpo 7450  0cc0 11184  1c1 11185  2c2 12348  Word cword 14562  ⟨“cs3 14891  Catccat 17722   Func cfunc 17918  func ccofu 17920   FuncCat cfuc 18010   1stF c1stf 18238   2ndF c2ndf 18239   ⟨,⟩F cprf 18240   evalF cevlf 18279   uncurryF cuncf 18281
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1793  ax-4 1807  ax-5 1909  ax-6 1967  ax-7 2007  ax-8 2110  ax-9 2118  ax-10 2141  ax-11 2158  ax-12 2178  ax-ext 2711  ax-rep 5303  ax-sep 5317  ax-nul 5324  ax-pow 5383  ax-pr 5447  ax-un 7770  ax-cnex 11240  ax-resscn 11241  ax-1cn 11242  ax-icn 11243  ax-addcl 11244  ax-addrcl 11245  ax-mulcl 11246  ax-mulrcl 11247  ax-mulcom 11248  ax-addass 11249  ax-mulass 11250  ax-distr 11251  ax-i2m1 11252  ax-1ne0 11253  ax-1rid 11254  ax-rnegex 11255  ax-rrecex 11256  ax-cnre 11257  ax-pre-lttri 11258  ax-pre-lttrn 11259  ax-pre-ltadd 11260  ax-pre-mulgt0 11261
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 847  df-3or 1088  df-3an 1089  df-tru 1540  df-fal 1550  df-ex 1778  df-nf 1782  df-sb 2065  df-mo 2543  df-eu 2572  df-clab 2718  df-cleq 2732  df-clel 2819  df-nfc 2895  df-ne 2947  df-nel 3053  df-ral 3068  df-rex 3077  df-reu 3389  df-rab 3444  df-v 3490  df-sbc 3805  df-csb 3922  df-dif 3979  df-un 3981  df-in 3983  df-ss 3993  df-pss 3996  df-nul 4353  df-if 4549  df-pw 4624  df-sn 4649  df-pr 4651  df-op 4655  df-uni 4932  df-int 4971  df-iun 5017  df-br 5167  df-opab 5229  df-mpt 5250  df-tr 5284  df-id 5593  df-eprel 5599  df-po 5607  df-so 5608  df-fr 5652  df-we 5654  df-xp 5706  df-rel 5707  df-cnv 5708  df-co 5709  df-dm 5710  df-rn 5711  df-res 5712  df-ima 5713  df-pred 6332  df-ord 6398  df-on 6399  df-lim 6400  df-suc 6401  df-iota 6525  df-fun 6575  df-fn 6576  df-f 6577  df-f1 6578  df-fo 6579  df-f1o 6580  df-fv 6581  df-riota 7404  df-ov 7451  df-oprab 7452  df-mpo 7453  df-om 7904  df-1st 8030  df-2nd 8031  df-frecs 8322  df-wrecs 8353  df-recs 8427  df-rdg 8466  df-1o 8522  df-er 8763  df-en 9004  df-dom 9005  df-sdom 9006  df-fin 9007  df-card 10008  df-pnf 11326  df-mnf 11327  df-xr 11328  df-ltxr 11329  df-le 11330  df-sub 11522  df-neg 11523  df-nn 12294  df-2 12356  df-n0 12554  df-z 12640  df-uz 12904  df-fz 13568  df-fzo 13712  df-hash 14380  df-word 14563  df-concat 14619  df-s1 14644  df-s2 14897  df-s3 14898  df-func 17922  df-uncf 18285
This theorem is referenced by:  uncfcl  18305  uncf1  18306  uncf2  18307
  Copyright terms: Public domain W3C validator