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

Theorem curry2 8044
Description: Composition with (1st ↾ (V × {𝐶})) turns any binary operation 𝐹 with a constant second operand into a function 𝐺 of the first operand only. This transformation is called "currying". (If this becomes frequently used, we can introduce a new notation for the hypothesis.) (Contributed by NM, 16-Dec-2008.)
Hypothesis
Ref Expression
curry2.1 𝐺 = (𝐹(1st ↾ (V × {𝐶})))
Assertion
Ref Expression
curry2 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → 𝐺 = (𝑥𝐴 ↦ (𝑥𝐹𝐶)))
Distinct variable groups:   𝑥,𝐴   𝑥,𝐵   𝑥,𝐶   𝑥,𝐹   𝑥,𝐺

Proof of Theorem curry2
StepHypRef Expression
1 fnfun 6607 . . . . 5 (𝐹 Fn (𝐴 × 𝐵) → Fun 𝐹)
2 1stconst 8037 . . . . . 6 (𝐶𝐵 → (1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V)
3 dff1o3 6795 . . . . . . 7 ((1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V ↔ ((1st ↾ (V × {𝐶})):(V × {𝐶})–onto→V ∧ Fun (1st ↾ (V × {𝐶}))))
43simprbi 497 . . . . . 6 ((1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V → Fun (1st ↾ (V × {𝐶})))
52, 4syl 17 . . . . 5 (𝐶𝐵 → Fun (1st ↾ (V × {𝐶})))
6 funco 6546 . . . . 5 ((Fun 𝐹 ∧ Fun (1st ↾ (V × {𝐶}))) → Fun (𝐹(1st ↾ (V × {𝐶}))))
71, 5, 6syl2an 596 . . . 4 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → Fun (𝐹(1st ↾ (V × {𝐶}))))
8 dmco 6211 . . . . 5 dom (𝐹(1st ↾ (V × {𝐶}))) = ((1st ↾ (V × {𝐶})) “ dom 𝐹)
9 fndm 6610 . . . . . . . 8 (𝐹 Fn (𝐴 × 𝐵) → dom 𝐹 = (𝐴 × 𝐵))
109adantr 481 . . . . . . 7 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → dom 𝐹 = (𝐴 × 𝐵))
1110imaeq2d 6018 . . . . . 6 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → ((1st ↾ (V × {𝐶})) “ dom 𝐹) = ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)))
12 imacnvcnv 6163 . . . . . . . . 9 ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)) = ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵))
13 df-ima 5651 . . . . . . . . 9 ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)) = ran ((1st ↾ (V × {𝐶})) ↾ (𝐴 × 𝐵))
14 resres 5955 . . . . . . . . . 10 ((1st ↾ (V × {𝐶})) ↾ (𝐴 × 𝐵)) = (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵)))
1514rneqi 5897 . . . . . . . . 9 ran ((1st ↾ (V × {𝐶})) ↾ (𝐴 × 𝐵)) = ran (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵)))
1612, 13, 153eqtri 2763 . . . . . . . 8 ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)) = ran (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵)))
17 inxp 5793 . . . . . . . . . . . . 13 ((V × {𝐶}) ∩ (𝐴 × 𝐵)) = ((V ∩ 𝐴) × ({𝐶} ∩ 𝐵))
18 incom 4166 . . . . . . . . . . . . . . 15 (V ∩ 𝐴) = (𝐴 ∩ V)
19 inv1 4359 . . . . . . . . . . . . . . 15 (𝐴 ∩ V) = 𝐴
2018, 19eqtri 2759 . . . . . . . . . . . . . 14 (V ∩ 𝐴) = 𝐴
2120xpeq1i 5664 . . . . . . . . . . . . 13 ((V ∩ 𝐴) × ({𝐶} ∩ 𝐵)) = (𝐴 × ({𝐶} ∩ 𝐵))
2217, 21eqtri 2759 . . . . . . . . . . . 12 ((V × {𝐶}) ∩ (𝐴 × 𝐵)) = (𝐴 × ({𝐶} ∩ 𝐵))
23 snssi 4773 . . . . . . . . . . . . . 14 (𝐶𝐵 → {𝐶} ⊆ 𝐵)
24 df-ss 3930 . . . . . . . . . . . . . 14 ({𝐶} ⊆ 𝐵 ↔ ({𝐶} ∩ 𝐵) = {𝐶})
2523, 24sylib 217 . . . . . . . . . . . . 13 (𝐶𝐵 → ({𝐶} ∩ 𝐵) = {𝐶})
2625xpeq2d 5668 . . . . . . . . . . . 12 (𝐶𝐵 → (𝐴 × ({𝐶} ∩ 𝐵)) = (𝐴 × {𝐶}))
2722, 26eqtrid 2783 . . . . . . . . . . 11 (𝐶𝐵 → ((V × {𝐶}) ∩ (𝐴 × 𝐵)) = (𝐴 × {𝐶}))
2827reseq2d 5942 . . . . . . . . . 10 (𝐶𝐵 → (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵))) = (1st ↾ (𝐴 × {𝐶})))
2928rneqd 5898 . . . . . . . . 9 (𝐶𝐵 → ran (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵))) = ran (1st ↾ (𝐴 × {𝐶})))
30 1stconst 8037 . . . . . . . . . 10 (𝐶𝐵 → (1st ↾ (𝐴 × {𝐶})):(𝐴 × {𝐶})–1-1-onto𝐴)
31 f1ofo 6796 . . . . . . . . . 10 ((1st ↾ (𝐴 × {𝐶})):(𝐴 × {𝐶})–1-1-onto𝐴 → (1st ↾ (𝐴 × {𝐶})):(𝐴 × {𝐶})–onto𝐴)
32 forn 6764 . . . . . . . . . 10 ((1st ↾ (𝐴 × {𝐶})):(𝐴 × {𝐶})–onto𝐴 → ran (1st ↾ (𝐴 × {𝐶})) = 𝐴)
3330, 31, 323syl 18 . . . . . . . . 9 (𝐶𝐵 → ran (1st ↾ (𝐴 × {𝐶})) = 𝐴)
3429, 33eqtrd 2771 . . . . . . . 8 (𝐶𝐵 → ran (1st ↾ ((V × {𝐶}) ∩ (𝐴 × 𝐵))) = 𝐴)
3516, 34eqtrid 2783 . . . . . . 7 (𝐶𝐵 → ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)) = 𝐴)
3635adantl 482 . . . . . 6 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → ((1st ↾ (V × {𝐶})) “ (𝐴 × 𝐵)) = 𝐴)
3711, 36eqtrd 2771 . . . . 5 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → ((1st ↾ (V × {𝐶})) “ dom 𝐹) = 𝐴)
388, 37eqtrid 2783 . . . 4 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → dom (𝐹(1st ↾ (V × {𝐶}))) = 𝐴)
39 curry2.1 . . . . . 6 𝐺 = (𝐹(1st ↾ (V × {𝐶})))
4039fneq1i 6604 . . . . 5 (𝐺 Fn 𝐴 ↔ (𝐹(1st ↾ (V × {𝐶}))) Fn 𝐴)
41 df-fn 6504 . . . . 5 ((𝐹(1st ↾ (V × {𝐶}))) Fn 𝐴 ↔ (Fun (𝐹(1st ↾ (V × {𝐶}))) ∧ dom (𝐹(1st ↾ (V × {𝐶}))) = 𝐴))
4240, 41bitri 274 . . . 4 (𝐺 Fn 𝐴 ↔ (Fun (𝐹(1st ↾ (V × {𝐶}))) ∧ dom (𝐹(1st ↾ (V × {𝐶}))) = 𝐴))
437, 38, 42sylanbrc 583 . . 3 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → 𝐺 Fn 𝐴)
44 dffn5 6906 . . 3 (𝐺 Fn 𝐴𝐺 = (𝑥𝐴 ↦ (𝐺𝑥)))
4543, 44sylib 217 . 2 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → 𝐺 = (𝑥𝐴 ↦ (𝐺𝑥)))
4639fveq1i 6848 . . . . 5 (𝐺𝑥) = ((𝐹(1st ↾ (V × {𝐶})))‘𝑥)
47 dff1o4 6797 . . . . . . . . 9 ((1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V ↔ ((1st ↾ (V × {𝐶})) Fn (V × {𝐶}) ∧ (1st ↾ (V × {𝐶})) Fn V))
482, 47sylib 217 . . . . . . . 8 (𝐶𝐵 → ((1st ↾ (V × {𝐶})) Fn (V × {𝐶}) ∧ (1st ↾ (V × {𝐶})) Fn V))
4948simprd 496 . . . . . . 7 (𝐶𝐵(1st ↾ (V × {𝐶})) Fn V)
50 vex 3450 . . . . . . 7 𝑥 ∈ V
51 fvco2 6943 . . . . . . 7 (((1st ↾ (V × {𝐶})) Fn V ∧ 𝑥 ∈ V) → ((𝐹(1st ↾ (V × {𝐶})))‘𝑥) = (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)))
5249, 50, 51sylancl 586 . . . . . 6 (𝐶𝐵 → ((𝐹(1st ↾ (V × {𝐶})))‘𝑥) = (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)))
5352ad2antlr 725 . . . . 5 (((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) ∧ 𝑥𝐴) → ((𝐹(1st ↾ (V × {𝐶})))‘𝑥) = (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)))
5446, 53eqtrid 2783 . . . 4 (((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) ∧ 𝑥𝐴) → (𝐺𝑥) = (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)))
552adantr 481 . . . . . . . . 9 ((𝐶𝐵𝑥𝐴) → (1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V)
5650a1i 11 . . . . . . . . . 10 ((𝐶𝐵𝑥𝐴) → 𝑥 ∈ V)
57 snidg 4625 . . . . . . . . . . 11 (𝐶𝐵𝐶 ∈ {𝐶})
5857adantr 481 . . . . . . . . . 10 ((𝐶𝐵𝑥𝐴) → 𝐶 ∈ {𝐶})
5956, 58opelxpd 5676 . . . . . . . . 9 ((𝐶𝐵𝑥𝐴) → ⟨𝑥, 𝐶⟩ ∈ (V × {𝐶}))
6055, 59jca 512 . . . . . . . 8 ((𝐶𝐵𝑥𝐴) → ((1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V ∧ ⟨𝑥, 𝐶⟩ ∈ (V × {𝐶})))
6150a1i 11 . . . . . . . . . . . 12 (𝐶𝐵𝑥 ∈ V)
6261, 57opelxpd 5676 . . . . . . . . . . 11 (𝐶𝐵 → ⟨𝑥, 𝐶⟩ ∈ (V × {𝐶}))
6362fvresd 6867 . . . . . . . . . 10 (𝐶𝐵 → ((1st ↾ (V × {𝐶}))‘⟨𝑥, 𝐶⟩) = (1st ‘⟨𝑥, 𝐶⟩))
6463adantr 481 . . . . . . . . 9 ((𝐶𝐵𝑥𝐴) → ((1st ↾ (V × {𝐶}))‘⟨𝑥, 𝐶⟩) = (1st ‘⟨𝑥, 𝐶⟩))
65 op1stg 7938 . . . . . . . . . 10 ((𝑥𝐴𝐶𝐵) → (1st ‘⟨𝑥, 𝐶⟩) = 𝑥)
6665ancoms 459 . . . . . . . . 9 ((𝐶𝐵𝑥𝐴) → (1st ‘⟨𝑥, 𝐶⟩) = 𝑥)
6764, 66eqtrd 2771 . . . . . . . 8 ((𝐶𝐵𝑥𝐴) → ((1st ↾ (V × {𝐶}))‘⟨𝑥, 𝐶⟩) = 𝑥)
68 f1ocnvfv 7229 . . . . . . . 8 (((1st ↾ (V × {𝐶})):(V × {𝐶})–1-1-onto→V ∧ ⟨𝑥, 𝐶⟩ ∈ (V × {𝐶})) → (((1st ↾ (V × {𝐶}))‘⟨𝑥, 𝐶⟩) = 𝑥 → ((1st ↾ (V × {𝐶}))‘𝑥) = ⟨𝑥, 𝐶⟩))
6960, 67, 68sylc 65 . . . . . . 7 ((𝐶𝐵𝑥𝐴) → ((1st ↾ (V × {𝐶}))‘𝑥) = ⟨𝑥, 𝐶⟩)
7069fveq2d 6851 . . . . . 6 ((𝐶𝐵𝑥𝐴) → (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)) = (𝐹‘⟨𝑥, 𝐶⟩))
7170adantll 712 . . . . 5 (((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) ∧ 𝑥𝐴) → (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)) = (𝐹‘⟨𝑥, 𝐶⟩))
72 df-ov 7365 . . . . 5 (𝑥𝐹𝐶) = (𝐹‘⟨𝑥, 𝐶⟩)
7371, 72eqtr4di 2789 . . . 4 (((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) ∧ 𝑥𝐴) → (𝐹‘((1st ↾ (V × {𝐶}))‘𝑥)) = (𝑥𝐹𝐶))
7454, 73eqtrd 2771 . . 3 (((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) ∧ 𝑥𝐴) → (𝐺𝑥) = (𝑥𝐹𝐶))
7574mpteq2dva 5210 . 2 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → (𝑥𝐴 ↦ (𝐺𝑥)) = (𝑥𝐴 ↦ (𝑥𝐹𝐶)))
7645, 75eqtrd 2771 1 ((𝐹 Fn (𝐴 × 𝐵) ∧ 𝐶𝐵) → 𝐺 = (𝑥𝐴 ↦ (𝑥𝐹𝐶)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 396   = wceq 1541  wcel 2106  Vcvv 3446  cin 3912  wss 3913  {csn 4591  cop 4597  cmpt 5193   × cxp 5636  ccnv 5637  dom cdm 5638  ran crn 5639  cres 5640  cima 5641  ccom 5642  Fun wfun 6495   Fn wfn 6496  ontowfo 6499  1-1-ontowf1o 6500  cfv 6501  (class class class)co 7362  1st c1st 7924
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 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2702  ax-sep 5261  ax-nul 5268  ax-pr 5389  ax-un 7677
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2533  df-eu 2562  df-clab 2709  df-cleq 2723  df-clel 2809  df-nfc 2884  df-ne 2940  df-ral 3061  df-rex 3070  df-rab 3406  df-v 3448  df-sbc 3743  df-csb 3859  df-dif 3916  df-un 3918  df-in 3920  df-ss 3930  df-nul 4288  df-if 4492  df-sn 4592  df-pr 4594  df-op 4598  df-uni 4871  df-iun 4961  df-br 5111  df-opab 5173  df-mpt 5194  df-id 5536  df-xp 5644  df-rel 5645  df-cnv 5646  df-co 5647  df-dm 5648  df-rn 5649  df-res 5650  df-ima 5651  df-iota 6453  df-fun 6503  df-fn 6504  df-f 6505  df-f1 6506  df-fo 6507  df-f1o 6508  df-fv 6509  df-ov 7365  df-1st 7926  df-2nd 7927
This theorem is referenced by:  curry2f  8045  curry2val  8046
  Copyright terms: Public domain W3C validator