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

Theorem uncfval 18191
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 18172 . . . 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 771 . . . . . . 7 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → 𝑐 = ⟨“𝐶𝐷𝐸”⟩)
54fveq1d 6836 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘1) = (⟨“𝐶𝐷𝐸”⟩‘1))
6 uncfval.c . . . . . . . 8 (𝜑𝐷 ∈ Cat)
7 s3fv1 14845 . . . . . . . 8 (𝐷 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
86, 7syl 17 . . . . . . 7 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
98adantr 480 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘1) = 𝐷)
105, 9eqtrd 2772 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘1) = 𝐷)
114fveq1d 6836 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘2) = (⟨“𝐶𝐷𝐸”⟩‘2))
12 uncfval.d . . . . . . . 8 (𝜑𝐸 ∈ Cat)
13 s3fv2 14846 . . . . . . . 8 (𝐸 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1412, 13syl 17 . . . . . . 7 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1514adantr 480 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘2) = 𝐸)
1611, 15eqtrd 2772 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘2) = 𝐸)
1710, 16oveq12d 7378 . . . 4 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘1) evalF (𝑐‘2)) = (𝐷 evalF 𝐸))
18 simprr 773 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → 𝑓 = 𝐺)
194fveq1d 6836 . . . . . . . 8 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘0) = (⟨“𝐶𝐷𝐸”⟩‘0))
20 uncfval.f . . . . . . . . . . . 12 (𝜑𝐺 ∈ (𝐶 Func (𝐷 FuncCat 𝐸)))
21 funcrcl 17821 . . . . . . . . . . . 12 (𝐺 ∈ (𝐶 Func (𝐷 FuncCat 𝐸)) → (𝐶 ∈ Cat ∧ (𝐷 FuncCat 𝐸) ∈ Cat))
2220, 21syl 17 . . . . . . . . . . 11 (𝜑 → (𝐶 ∈ Cat ∧ (𝐷 FuncCat 𝐸) ∈ Cat))
2322simpld 494 . . . . . . . . . 10 (𝜑𝐶 ∈ Cat)
24 s3fv0 14844 . . . . . . . . . 10 (𝐶 ∈ Cat → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2523, 24syl 17 . . . . . . . . 9 (𝜑 → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2625adantr 480 . . . . . . . 8 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (⟨“𝐶𝐷𝐸”⟩‘0) = 𝐶)
2719, 26eqtrd 2772 . . . . . . 7 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑐‘0) = 𝐶)
2827, 10oveq12d 7378 . . . . . 6 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘0) 1stF (𝑐‘1)) = (𝐶 1stF 𝐷))
2918, 28oveq12d 7378 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (𝑓func ((𝑐‘0) 1stF (𝑐‘1))) = (𝐺func (𝐶 1stF 𝐷)))
3027, 10oveq12d 7378 . . . . 5 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑐‘0) 2ndF (𝑐‘1)) = (𝐶 2ndF 𝐷))
3129, 30oveq12d 7378 . . . 4 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1))) = ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷)))
3217, 31oveq12d 7378 . . 3 ((𝜑 ∧ (𝑐 = ⟨“𝐶𝐷𝐸”⟩ ∧ 𝑓 = 𝐺)) → (((𝑐‘1) evalF (𝑐‘2)) ∘func ((𝑓func ((𝑐‘0) 1stF (𝑐‘1))) ⟨,⟩F ((𝑐‘0) 2ndF (𝑐‘1)))) = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
33 s3cli 14834 . . . 4 ⟨“𝐶𝐷𝐸”⟩ ∈ Word V
34 elex 3451 . . . 4 (⟨“𝐶𝐷𝐸”⟩ ∈ Word V → ⟨“𝐶𝐷𝐸”⟩ ∈ V)
3533, 34mp1i 13 . . 3 (𝜑 → ⟨“𝐶𝐷𝐸”⟩ ∈ V)
3620elexd 3454 . . 3 (𝜑𝐺 ∈ V)
37 ovexd 7395 . . 3 (𝜑 → ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))) ∈ V)
383, 32, 35, 36, 37ovmpod 7512 . 2 (𝜑 → (⟨“𝐶𝐷𝐸”⟩ uncurryF 𝐺) = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
391, 38eqtrid 2784 1 (𝜑𝐹 = ((𝐷 evalF 𝐸) ∘func ((𝐺func (𝐶 1stF 𝐷)) ⟨,⟩F (𝐶 2ndF 𝐷))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395   = wceq 1542  wcel 2114  Vcvv 3430  cfv 6492  (class class class)co 7360  cmpo 7362  0cc0 11029  1c1 11030  2c2 12227  Word cword 14466  ⟨“cs3 14795  Catccat 17621   Func cfunc 17812  func ccofu 17814   FuncCat cfuc 17903   1stF c1stf 18126   2ndF c2ndf 18127   ⟨,⟩F cprf 18128   evalF cevlf 18166   uncurryF cuncf 18168
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-rep 5212  ax-sep 5231  ax-nul 5241  ax-pow 5302  ax-pr 5370  ax-un 7682  ax-cnex 11085  ax-resscn 11086  ax-1cn 11087  ax-icn 11088  ax-addcl 11089  ax-addrcl 11090  ax-mulcl 11091  ax-mulrcl 11092  ax-mulcom 11093  ax-addass 11094  ax-mulass 11095  ax-distr 11096  ax-i2m1 11097  ax-1ne0 11098  ax-1rid 11099  ax-rnegex 11100  ax-rrecex 11101  ax-cnre 11102  ax-pre-lttri 11103  ax-pre-lttrn 11104  ax-pre-ltadd 11105  ax-pre-mulgt0 11106
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3063  df-reu 3344  df-rab 3391  df-v 3432  df-sbc 3730  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-pss 3910  df-nul 4275  df-if 4468  df-pw 4544  df-sn 4569  df-pr 4571  df-op 4575  df-uni 4852  df-int 4891  df-iun 4936  df-br 5087  df-opab 5149  df-mpt 5168  df-tr 5194  df-id 5519  df-eprel 5524  df-po 5532  df-so 5533  df-fr 5577  df-we 5579  df-xp 5630  df-rel 5631  df-cnv 5632  df-co 5633  df-dm 5634  df-rn 5635  df-res 5636  df-ima 5637  df-pred 6259  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-f1o 6499  df-fv 6500  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-1st 7935  df-2nd 7936  df-frecs 8224  df-wrecs 8255  df-recs 8304  df-rdg 8342  df-1o 8398  df-er 8636  df-en 8887  df-dom 8888  df-sdom 8889  df-fin 8890  df-card 9854  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-nn 12166  df-2 12235  df-n0 12429  df-z 12516  df-uz 12780  df-fz 13453  df-fzo 13600  df-hash 14284  df-word 14467  df-concat 14524  df-s1 14550  df-s2 14801  df-s3 14802  df-func 17816  df-uncf 18172
This theorem is referenced by:  uncfcl  18192  uncf1  18193  uncf2  18194
  Copyright terms: Public domain W3C validator