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

Theorem mo3 2564
Description: Alternate definition of the at-most-one quantifier. Definition of [BellMachover] p. 460, except that definition has the side condition that 𝑦 not occur in 𝜑 in place of our hypothesis. (Contributed by NM, 8-Mar-1995.) (Proof shortened by Wolf Lammen, 18-Aug-2019.) Remove dependency on ax-13 2372. (Revised by BJ and WL, 29-Jan-2023.)
Hypothesis
Ref Expression
mo3.nf 𝑦𝜑
Assertion
Ref Expression
mo3 (∃*𝑥𝜑 ↔ ∀𝑥𝑦((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
Distinct variable group:   𝑥,𝑦
Allowed substitution hints:   𝜑(𝑥,𝑦)

Proof of Theorem mo3
Dummy variable 𝑧 is distinct from all other variables.
StepHypRef Expression
1 nfmo1 2557 . . 3 𝑥∃*𝑥𝜑
2 mo3.nf . . . . 5 𝑦𝜑
32nfmov 2560 . . . 4 𝑦∃*𝑥𝜑
4 df-mo 2540 . . . . 5 (∃*𝑥𝜑 ↔ ∃𝑧𝑥(𝜑𝑥 = 𝑧))
5 sp 2178 . . . . . . . 8 (∀𝑥(𝜑𝑥 = 𝑧) → (𝜑𝑥 = 𝑧))
6 spsbim 2076 . . . . . . . . 9 (∀𝑥(𝜑𝑥 = 𝑧) → ([𝑦 / 𝑥]𝜑 → [𝑦 / 𝑥]𝑥 = 𝑧))
7 equsb3 2103 . . . . . . . . 9 ([𝑦 / 𝑥]𝑥 = 𝑧𝑦 = 𝑧)
86, 7syl6ib 250 . . . . . . . 8 (∀𝑥(𝜑𝑥 = 𝑧) → ([𝑦 / 𝑥]𝜑𝑦 = 𝑧))
95, 8anim12d 608 . . . . . . 7 (∀𝑥(𝜑𝑥 = 𝑧) → ((𝜑 ∧ [𝑦 / 𝑥]𝜑) → (𝑥 = 𝑧𝑦 = 𝑧)))
10 equtr2 2031 . . . . . . 7 ((𝑥 = 𝑧𝑦 = 𝑧) → 𝑥 = 𝑦)
119, 10syl6 35 . . . . . 6 (∀𝑥(𝜑𝑥 = 𝑧) → ((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
1211exlimiv 1934 . . . . 5 (∃𝑧𝑥(𝜑𝑥 = 𝑧) → ((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
134, 12sylbi 216 . . . 4 (∃*𝑥𝜑 → ((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
143, 13alrimi 2209 . . 3 (∃*𝑥𝜑 → ∀𝑦((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
151, 14alrimi 2209 . 2 (∃*𝑥𝜑 → ∀𝑥𝑦((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
16 nfs1v 2155 . . . . . . . 8 𝑥[𝑦 / 𝑥]𝜑
17 pm3.21 471 . . . . . . . . 9 ([𝑦 / 𝑥]𝜑 → (𝜑 → (𝜑 ∧ [𝑦 / 𝑥]𝜑)))
1817imim1d 82 . . . . . . . 8 ([𝑦 / 𝑥]𝜑 → (((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → (𝜑𝑥 = 𝑦)))
1916, 18alimd 2208 . . . . . . 7 ([𝑦 / 𝑥]𝜑 → (∀𝑥((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → ∀𝑥(𝜑𝑥 = 𝑦)))
2019com12 32 . . . . . 6 (∀𝑥((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → ([𝑦 / 𝑥]𝜑 → ∀𝑥(𝜑𝑥 = 𝑦)))
2120aleximi 1835 . . . . 5 (∀𝑦𝑥((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → (∃𝑦[𝑦 / 𝑥]𝜑 → ∃𝑦𝑥(𝜑𝑥 = 𝑦)))
222sb8ev 2353 . . . . 5 (∃𝑥𝜑 ↔ ∃𝑦[𝑦 / 𝑥]𝜑)
232mof 2563 . . . . 5 (∃*𝑥𝜑 ↔ ∃𝑦𝑥(𝜑𝑥 = 𝑦))
2421, 22, 233imtr4g 295 . . . 4 (∀𝑦𝑥((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → (∃𝑥𝜑 → ∃*𝑥𝜑))
25 moabs 2543 . . . 4 (∃*𝑥𝜑 ↔ (∃𝑥𝜑 → ∃*𝑥𝜑))
2624, 25sylibr 233 . . 3 (∀𝑦𝑥((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → ∃*𝑥𝜑)
2726alcoms 2157 . 2 (∀𝑥𝑦((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦) → ∃*𝑥𝜑)
2815, 27impbii 208 1 (∃*𝑥𝜑 ↔ ∀𝑥𝑦((𝜑 ∧ [𝑦 / 𝑥]𝜑) → 𝑥 = 𝑦))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 395  wal 1537  wex 1783  wnf 1787  [wsb 2068  ∃*wmo 2538
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1799  ax-4 1813  ax-5 1914  ax-6 1972  ax-7 2012  ax-10 2139  ax-11 2156  ax-12 2173
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-tru 1542  df-ex 1784  df-nf 1788  df-sb 2069  df-mo 2540
This theorem is referenced by:  mo  2565  mo4f  2567  eu2  2611  2mo  2650  rmo3f  3664  rmo3  3818  isarep2  6507  mo5f  30738  bnj580  32793  pm14.12  41928
  Copyright terms: Public domain W3C validator