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

Theorem ralxpmap 8577
Description: Quantification over functions in terms of quantification over values and punctured functions. (Contributed by Stefan O'Rear, 27-Feb-2015.) (Revised by Stefan O'Rear, 5-May-2015.)
Hypothesis
Ref Expression
ralxpmap.j (𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) → (𝜑𝜓))
Assertion
Ref Expression
ralxpmap (𝐽𝑇 → (∀𝑓 ∈ (𝑆m 𝑇)𝜑 ↔ ∀𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝜓))
Distinct variable groups:   𝜑,𝑔,𝑦   𝜓,𝑓   𝑓,𝐽,𝑔,𝑦   𝑆,𝑓,𝑔,𝑦   𝑇,𝑓,𝑔,𝑦
Allowed substitution hints:   𝜑(𝑓)   𝜓(𝑦,𝑔)

Proof of Theorem ralxpmap
StepHypRef Expression
1 vex 3412 . . 3 𝑔 ∈ V
2 snex 5324 . . 3 {⟨𝐽, 𝑦⟩} ∈ V
31, 2unex 7531 . 2 (𝑔 ∪ {⟨𝐽, 𝑦⟩}) ∈ V
4 simpr 488 . . . . . . 7 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑓 ∈ (𝑆m 𝑇))
5 elmapex 8529 . . . . . . . . 9 (𝑓 ∈ (𝑆m 𝑇) → (𝑆 ∈ V ∧ 𝑇 ∈ V))
65adantl 485 . . . . . . . 8 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑆 ∈ V ∧ 𝑇 ∈ V))
7 elmapg 8521 . . . . . . . 8 ((𝑆 ∈ V ∧ 𝑇 ∈ V) → (𝑓 ∈ (𝑆m 𝑇) ↔ 𝑓:𝑇𝑆))
86, 7syl 17 . . . . . . 7 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑓 ∈ (𝑆m 𝑇) ↔ 𝑓:𝑇𝑆))
94, 8mpbid 235 . . . . . 6 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑓:𝑇𝑆)
10 simpl 486 . . . . . 6 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝐽𝑇)
119, 10ffvelrnd 6905 . . . . 5 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑓𝐽) ∈ 𝑆)
12 difss 4046 . . . . . . 7 (𝑇 ∖ {𝐽}) ⊆ 𝑇
13 fssres 6585 . . . . . . 7 ((𝑓:𝑇𝑆 ∧ (𝑇 ∖ {𝐽}) ⊆ 𝑇) → (𝑓 ↾ (𝑇 ∖ {𝐽})):(𝑇 ∖ {𝐽})⟶𝑆)
149, 12, 13sylancl 589 . . . . . 6 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑓 ↾ (𝑇 ∖ {𝐽})):(𝑇 ∖ {𝐽})⟶𝑆)
155simpld 498 . . . . . . . 8 (𝑓 ∈ (𝑆m 𝑇) → 𝑆 ∈ V)
1615adantl 485 . . . . . . 7 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑆 ∈ V)
176simprd 499 . . . . . . . 8 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑇 ∈ V)
1817difexd 5222 . . . . . . 7 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑇 ∖ {𝐽}) ∈ V)
1916, 18elmapd 8522 . . . . . 6 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∈ (𝑆m (𝑇 ∖ {𝐽})) ↔ (𝑓 ↾ (𝑇 ∖ {𝐽})):(𝑇 ∖ {𝐽})⟶𝑆))
2014, 19mpbird 260 . . . . 5 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → (𝑓 ↾ (𝑇 ∖ {𝐽})) ∈ (𝑆m (𝑇 ∖ {𝐽})))
219ffnd 6546 . . . . . 6 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑓 Fn 𝑇)
22 fnsnsplit 6999 . . . . . 6 ((𝑓 Fn 𝑇𝐽𝑇) → 𝑓 = ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∪ {⟨𝐽, (𝑓𝐽)⟩}))
2321, 10, 22syl2anc 587 . . . . 5 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → 𝑓 = ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∪ {⟨𝐽, (𝑓𝐽)⟩}))
24 opeq2 4785 . . . . . . . . 9 (𝑦 = (𝑓𝐽) → ⟨𝐽, 𝑦⟩ = ⟨𝐽, (𝑓𝐽)⟩)
2524sneqd 4553 . . . . . . . 8 (𝑦 = (𝑓𝐽) → {⟨𝐽, 𝑦⟩} = {⟨𝐽, (𝑓𝐽)⟩})
2625uneq2d 4077 . . . . . . 7 (𝑦 = (𝑓𝐽) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}) = (𝑔 ∪ {⟨𝐽, (𝑓𝐽)⟩}))
2726eqeq2d 2748 . . . . . 6 (𝑦 = (𝑓𝐽) → (𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) ↔ 𝑓 = (𝑔 ∪ {⟨𝐽, (𝑓𝐽)⟩})))
28 uneq1 4070 . . . . . . 7 (𝑔 = (𝑓 ↾ (𝑇 ∖ {𝐽})) → (𝑔 ∪ {⟨𝐽, (𝑓𝐽)⟩}) = ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∪ {⟨𝐽, (𝑓𝐽)⟩}))
2928eqeq2d 2748 . . . . . 6 (𝑔 = (𝑓 ↾ (𝑇 ∖ {𝐽})) → (𝑓 = (𝑔 ∪ {⟨𝐽, (𝑓𝐽)⟩}) ↔ 𝑓 = ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∪ {⟨𝐽, (𝑓𝐽)⟩})))
3027, 29rspc2ev 3549 . . . . 5 (((𝑓𝐽) ∈ 𝑆 ∧ (𝑓 ↾ (𝑇 ∖ {𝐽})) ∈ (𝑆m (𝑇 ∖ {𝐽})) ∧ 𝑓 = ((𝑓 ↾ (𝑇 ∖ {𝐽})) ∪ {⟨𝐽, (𝑓𝐽)⟩})) → ∃𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}))
3111, 20, 23, 30syl3anc 1373 . . . 4 ((𝐽𝑇𝑓 ∈ (𝑆m 𝑇)) → ∃𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}))
3231ex 416 . . 3 (𝐽𝑇 → (𝑓 ∈ (𝑆m 𝑇) → ∃𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩})))
33 elmapi 8530 . . . . . . . . . 10 (𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})) → 𝑔:(𝑇 ∖ {𝐽})⟶𝑆)
3433ad2antll 729 . . . . . . . . 9 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → 𝑔:(𝑇 ∖ {𝐽})⟶𝑆)
35 f1osng 6701 . . . . . . . . . . . 12 ((𝐽𝑇𝑦 ∈ V) → {⟨𝐽, 𝑦⟩}:{𝐽}–1-1-onto→{𝑦})
36 f1of 6661 . . . . . . . . . . . 12 ({⟨𝐽, 𝑦⟩}:{𝐽}–1-1-onto→{𝑦} → {⟨𝐽, 𝑦⟩}:{𝐽}⟶{𝑦})
3735, 36syl 17 . . . . . . . . . . 11 ((𝐽𝑇𝑦 ∈ V) → {⟨𝐽, 𝑦⟩}:{𝐽}⟶{𝑦})
3837elvd 3415 . . . . . . . . . 10 (𝐽𝑇 → {⟨𝐽, 𝑦⟩}:{𝐽}⟶{𝑦})
3938adantr 484 . . . . . . . . 9 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → {⟨𝐽, 𝑦⟩}:{𝐽}⟶{𝑦})
40 disjdifr 4387 . . . . . . . . . 10 ((𝑇 ∖ {𝐽}) ∩ {𝐽}) = ∅
4140a1i 11 . . . . . . . . 9 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ((𝑇 ∖ {𝐽}) ∩ {𝐽}) = ∅)
42 fun 6581 . . . . . . . . 9 (((𝑔:(𝑇 ∖ {𝐽})⟶𝑆 ∧ {⟨𝐽, 𝑦⟩}:{𝐽}⟶{𝑦}) ∧ ((𝑇 ∖ {𝐽}) ∩ {𝐽}) = ∅) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}):((𝑇 ∖ {𝐽}) ∪ {𝐽})⟶(𝑆 ∪ {𝑦}))
4334, 39, 41, 42syl21anc 838 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}):((𝑇 ∖ {𝐽}) ∪ {𝐽})⟶(𝑆 ∪ {𝑦}))
44 uncom 4067 . . . . . . . . . 10 ((𝑇 ∖ {𝐽}) ∪ {𝐽}) = ({𝐽} ∪ (𝑇 ∖ {𝐽}))
45 simpl 486 . . . . . . . . . . . 12 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → 𝐽𝑇)
4645snssd 4722 . . . . . . . . . . 11 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → {𝐽} ⊆ 𝑇)
47 undif 4396 . . . . . . . . . . 11 ({𝐽} ⊆ 𝑇 ↔ ({𝐽} ∪ (𝑇 ∖ {𝐽})) = 𝑇)
4846, 47sylib 221 . . . . . . . . . 10 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ({𝐽} ∪ (𝑇 ∖ {𝐽})) = 𝑇)
4944, 48eqtrid 2789 . . . . . . . . 9 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ((𝑇 ∖ {𝐽}) ∪ {𝐽}) = 𝑇)
5049feq2d 6531 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ((𝑔 ∪ {⟨𝐽, 𝑦⟩}):((𝑇 ∖ {𝐽}) ∪ {𝐽})⟶(𝑆 ∪ {𝑦}) ↔ (𝑔 ∪ {⟨𝐽, 𝑦⟩}):𝑇⟶(𝑆 ∪ {𝑦})))
5143, 50mpbid 235 . . . . . . 7 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}):𝑇⟶(𝑆 ∪ {𝑦}))
52 ssidd 3924 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → 𝑆𝑆)
53 snssi 4721 . . . . . . . . 9 (𝑦𝑆 → {𝑦} ⊆ 𝑆)
5453ad2antrl 728 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → {𝑦} ⊆ 𝑆)
5552, 54unssd 4100 . . . . . . 7 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑆 ∪ {𝑦}) ⊆ 𝑆)
5651, 55fssd 6563 . . . . . 6 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}):𝑇𝑆)
57 elmapex 8529 . . . . . . . . 9 (𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})) → (𝑆 ∈ V ∧ (𝑇 ∖ {𝐽}) ∈ V))
5857ad2antll 729 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑆 ∈ V ∧ (𝑇 ∖ {𝐽}) ∈ V))
5958simpld 498 . . . . . . 7 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → 𝑆 ∈ V)
60 ssun1 4086 . . . . . . . 8 𝑇 ⊆ (𝑇 ∪ {𝐽})
61 undif1 4390 . . . . . . . . 9 ((𝑇 ∖ {𝐽}) ∪ {𝐽}) = (𝑇 ∪ {𝐽})
6258simprd 499 . . . . . . . . . 10 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑇 ∖ {𝐽}) ∈ V)
63 snex 5324 . . . . . . . . . 10 {𝐽} ∈ V
64 unexg 7534 . . . . . . . . . 10 (((𝑇 ∖ {𝐽}) ∈ V ∧ {𝐽} ∈ V) → ((𝑇 ∖ {𝐽}) ∪ {𝐽}) ∈ V)
6562, 63, 64sylancl 589 . . . . . . . . 9 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ((𝑇 ∖ {𝐽}) ∪ {𝐽}) ∈ V)
6661, 65eqeltrrid 2843 . . . . . . . 8 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑇 ∪ {𝐽}) ∈ V)
67 ssexg 5216 . . . . . . . 8 ((𝑇 ⊆ (𝑇 ∪ {𝐽}) ∧ (𝑇 ∪ {𝐽}) ∈ V) → 𝑇 ∈ V)
6860, 66, 67sylancr 590 . . . . . . 7 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → 𝑇 ∈ V)
6959, 68elmapd 8522 . . . . . 6 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → ((𝑔 ∪ {⟨𝐽, 𝑦⟩}) ∈ (𝑆m 𝑇) ↔ (𝑔 ∪ {⟨𝐽, 𝑦⟩}):𝑇𝑆))
7056, 69mpbird 260 . . . . 5 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑔 ∪ {⟨𝐽, 𝑦⟩}) ∈ (𝑆m 𝑇))
71 eleq1 2825 . . . . 5 (𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) → (𝑓 ∈ (𝑆m 𝑇) ↔ (𝑔 ∪ {⟨𝐽, 𝑦⟩}) ∈ (𝑆m 𝑇)))
7270, 71syl5ibrcom 250 . . . 4 ((𝐽𝑇 ∧ (𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽})))) → (𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) → 𝑓 ∈ (𝑆m 𝑇)))
7372rexlimdvva 3213 . . 3 (𝐽𝑇 → (∃𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) → 𝑓 ∈ (𝑆m 𝑇)))
7432, 73impbid 215 . 2 (𝐽𝑇 → (𝑓 ∈ (𝑆m 𝑇) ↔ ∃𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩})))
75 ralxpmap.j . . 3 (𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩}) → (𝜑𝜓))
7675adantl 485 . 2 ((𝐽𝑇𝑓 = (𝑔 ∪ {⟨𝐽, 𝑦⟩})) → (𝜑𝜓))
773, 74, 76ralxpxfr2d 3553 1 (𝐽𝑇 → (∀𝑓 ∈ (𝑆m 𝑇)𝜑 ↔ ∀𝑦𝑆𝑔 ∈ (𝑆m (𝑇 ∖ {𝐽}))𝜓))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 209  wa 399   = wceq 1543  wcel 2110  wral 3061  wrex 3062  Vcvv 3408  cdif 3863  cun 3864  cin 3865  wss 3866  c0 4237  {csn 4541  cop 4547  cres 5553   Fn wfn 6375  wf 6376  1-1-ontowf1o 6379  cfv 6380  (class class class)co 7213  m cmap 8508
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1976  ax-7 2016  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2158  ax-12 2175  ax-ext 2708  ax-sep 5192  ax-nul 5199  ax-pow 5258  ax-pr 5322  ax-un 7523
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2071  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2729  df-clel 2816  df-nfc 2886  df-ne 2941  df-ral 3066  df-rex 3067  df-reu 3068  df-rab 3070  df-v 3410  df-sbc 3695  df-csb 3812  df-dif 3869  df-un 3871  df-in 3873  df-ss 3883  df-nul 4238  df-if 4440  df-pw 4515  df-sn 4542  df-pr 4544  df-op 4548  df-uni 4820  df-iun 4906  df-br 5054  df-opab 5116  df-mpt 5136  df-id 5455  df-xp 5557  df-rel 5558  df-cnv 5559  df-co 5560  df-dm 5561  df-rn 5562  df-res 5563  df-ima 5564  df-iota 6338  df-fun 6382  df-fn 6383  df-f 6384  df-f1 6385  df-fo 6386  df-f1o 6387  df-fv 6388  df-ov 7216  df-oprab 7217  df-mpo 7218  df-1st 7761  df-2nd 7762  df-map 8510
This theorem is referenced by:  islindf4  20800
  Copyright terms: Public domain W3C validator