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

Theorem reuprg0 4641
Description: Convert a restricted existential uniqueness over a pair to a disjunction of conjunctions. (Contributed by AV, 2-Apr-2023.)
Hypotheses
Ref Expression
reuprg.1 (𝑥 = 𝐴 → (𝜑𝜓))
reuprg.2 (𝑥 = 𝐵 → (𝜑𝜒))
Assertion
Ref Expression
reuprg0 ((𝐴𝑉𝐵𝑊) → (∃!𝑥 ∈ {𝐴, 𝐵}𝜑 ↔ ((𝜓 ∧ (𝜒𝐴 = 𝐵)) ∨ (𝜒 ∧ (𝜓𝐴 = 𝐵)))))
Distinct variable groups:   𝑥,𝐴   𝑥,𝐵   𝜓,𝑥   𝜒,𝑥
Allowed substitution hints:   𝜑(𝑥)   𝑉(𝑥)   𝑊(𝑥)

Proof of Theorem reuprg0
Dummy variables 𝑤 𝑐 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 nfsbc1v 3795 . . 3 𝑥[𝑐 / 𝑥]𝜑
2 nfsbc1v 3795 . . 3 𝑥[𝑤 / 𝑥]𝜑
3 sbceq1a 3786 . . 3 (𝑥 = 𝑤 → (𝜑[𝑤 / 𝑥]𝜑))
4 dfsbcq 3777 . . 3 (𝑤 = 𝑐 → ([𝑤 / 𝑥]𝜑[𝑐 / 𝑥]𝜑))
51, 2, 3, 4reu8nf 3863 . 2 (∃!𝑥 ∈ {𝐴, 𝐵}𝜑 ↔ ∃𝑥 ∈ {𝐴, 𝐵} (𝜑 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐)))
6 nfv 1914 . . . . 5 𝑥𝜓
7 nfcv 2980 . . . . . 6 𝑥{𝐴, 𝐵}
8 nfv 1914 . . . . . . 7 𝑥 𝐴 = 𝑐
91, 8nfim 1896 . . . . . 6 𝑥([𝑐 / 𝑥]𝜑𝐴 = 𝑐)
107, 9nfralw 3228 . . . . 5 𝑥𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)
116, 10nfan 1899 . . . 4 𝑥(𝜓 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐))
12 nfv 1914 . . . . 5 𝑥𝜒
13 nfv 1914 . . . . . . 7 𝑥 𝐵 = 𝑐
141, 13nfim 1896 . . . . . 6 𝑥([𝑐 / 𝑥]𝜑𝐵 = 𝑐)
157, 14nfralw 3228 . . . . 5 𝑥𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)
1612, 15nfan 1899 . . . 4 𝑥(𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐))
17 reuprg.1 . . . . 5 (𝑥 = 𝐴 → (𝜑𝜓))
18 eqeq1 2828 . . . . . . 7 (𝑥 = 𝐴 → (𝑥 = 𝑐𝐴 = 𝑐))
1918imbi2d 343 . . . . . 6 (𝑥 = 𝐴 → (([𝑐 / 𝑥]𝜑𝑥 = 𝑐) ↔ ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)))
2019ralbidv 3200 . . . . 5 (𝑥 = 𝐴 → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐) ↔ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)))
2117, 20anbi12d 632 . . . 4 (𝑥 = 𝐴 → ((𝜑 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐)) ↔ (𝜓 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐))))
22 reuprg.2 . . . . 5 (𝑥 = 𝐵 → (𝜑𝜒))
23 eqeq1 2828 . . . . . . 7 (𝑥 = 𝐵 → (𝑥 = 𝑐𝐵 = 𝑐))
2423imbi2d 343 . . . . . 6 (𝑥 = 𝐵 → (([𝑐 / 𝑥]𝜑𝑥 = 𝑐) ↔ ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)))
2524ralbidv 3200 . . . . 5 (𝑥 = 𝐵 → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐) ↔ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)))
2622, 25anbi12d 632 . . . 4 (𝑥 = 𝐵 → ((𝜑 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐)) ↔ (𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐))))
2711, 16, 21, 26rexprgf 4634 . . 3 ((𝐴𝑉𝐵𝑊) → (∃𝑥 ∈ {𝐴, 𝐵} (𝜑 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐)) ↔ ((𝜓 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)) ∨ (𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)))))
28 dfsbcq 3777 . . . . . . . 8 (𝑐 = 𝐴 → ([𝑐 / 𝑥]𝜑[𝐴 / 𝑥]𝜑))
29 eqeq2 2836 . . . . . . . 8 (𝑐 = 𝐴 → (𝐴 = 𝑐𝐴 = 𝐴))
3028, 29imbi12d 347 . . . . . . 7 (𝑐 = 𝐴 → (([𝑐 / 𝑥]𝜑𝐴 = 𝑐) ↔ ([𝐴 / 𝑥]𝜑𝐴 = 𝐴)))
31 dfsbcq 3777 . . . . . . . 8 (𝑐 = 𝐵 → ([𝑐 / 𝑥]𝜑[𝐵 / 𝑥]𝜑))
32 eqeq2 2836 . . . . . . . 8 (𝑐 = 𝐵 → (𝐴 = 𝑐𝐴 = 𝐵))
3331, 32imbi12d 347 . . . . . . 7 (𝑐 = 𝐵 → (([𝑐 / 𝑥]𝜑𝐴 = 𝑐) ↔ ([𝐵 / 𝑥]𝜑𝐴 = 𝐵)))
3430, 33ralprg 4635 . . . . . 6 ((𝐴𝑉𝐵𝑊) → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐) ↔ (([𝐴 / 𝑥]𝜑𝐴 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐴 = 𝐵))))
35 eqidd 2825 . . . . . . . 8 ([𝐴 / 𝑥]𝜑𝐴 = 𝐴)
3635biantrur 533 . . . . . . 7 (([𝐵 / 𝑥]𝜑𝐴 = 𝐵) ↔ (([𝐴 / 𝑥]𝜑𝐴 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐴 = 𝐵)))
3722sbcieg 3813 . . . . . . . . 9 (𝐵𝑊 → ([𝐵 / 𝑥]𝜑𝜒))
3837adantl 484 . . . . . . . 8 ((𝐴𝑉𝐵𝑊) → ([𝐵 / 𝑥]𝜑𝜒))
3938imbi1d 344 . . . . . . 7 ((𝐴𝑉𝐵𝑊) → (([𝐵 / 𝑥]𝜑𝐴 = 𝐵) ↔ (𝜒𝐴 = 𝐵)))
4036, 39syl5bbr 287 . . . . . 6 ((𝐴𝑉𝐵𝑊) → ((([𝐴 / 𝑥]𝜑𝐴 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐴 = 𝐵)) ↔ (𝜒𝐴 = 𝐵)))
4134, 40bitrd 281 . . . . 5 ((𝐴𝑉𝐵𝑊) → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐) ↔ (𝜒𝐴 = 𝐵)))
4241anbi2d 630 . . . 4 ((𝐴𝑉𝐵𝑊) → ((𝜓 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)) ↔ (𝜓 ∧ (𝜒𝐴 = 𝐵))))
43 eqeq2 2836 . . . . . . . . 9 (𝑐 = 𝐴 → (𝐵 = 𝑐𝐵 = 𝐴))
4428, 43imbi12d 347 . . . . . . . 8 (𝑐 = 𝐴 → (([𝑐 / 𝑥]𝜑𝐵 = 𝑐) ↔ ([𝐴 / 𝑥]𝜑𝐵 = 𝐴)))
45 eqeq2 2836 . . . . . . . . 9 (𝑐 = 𝐵 → (𝐵 = 𝑐𝐵 = 𝐵))
4631, 45imbi12d 347 . . . . . . . 8 (𝑐 = 𝐵 → (([𝑐 / 𝑥]𝜑𝐵 = 𝑐) ↔ ([𝐵 / 𝑥]𝜑𝐵 = 𝐵)))
4744, 46ralprg 4635 . . . . . . 7 ((𝐴𝑉𝐵𝑊) → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐) ↔ (([𝐴 / 𝑥]𝜑𝐵 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐵 = 𝐵))))
48 eqidd 2825 . . . . . . . . 9 ([𝐵 / 𝑥]𝜑𝐵 = 𝐵)
4948biantru 532 . . . . . . . 8 (([𝐴 / 𝑥]𝜑𝐵 = 𝐴) ↔ (([𝐴 / 𝑥]𝜑𝐵 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐵 = 𝐵)))
5017sbcieg 3813 . . . . . . . . . 10 (𝐴𝑉 → ([𝐴 / 𝑥]𝜑𝜓))
5150adantr 483 . . . . . . . . 9 ((𝐴𝑉𝐵𝑊) → ([𝐴 / 𝑥]𝜑𝜓))
5251imbi1d 344 . . . . . . . 8 ((𝐴𝑉𝐵𝑊) → (([𝐴 / 𝑥]𝜑𝐵 = 𝐴) ↔ (𝜓𝐵 = 𝐴)))
5349, 52syl5bbr 287 . . . . . . 7 ((𝐴𝑉𝐵𝑊) → ((([𝐴 / 𝑥]𝜑𝐵 = 𝐴) ∧ ([𝐵 / 𝑥]𝜑𝐵 = 𝐵)) ↔ (𝜓𝐵 = 𝐴)))
5447, 53bitrd 281 . . . . . 6 ((𝐴𝑉𝐵𝑊) → (∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐) ↔ (𝜓𝐵 = 𝐴)))
5554anbi2d 630 . . . . 5 ((𝐴𝑉𝐵𝑊) → ((𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)) ↔ (𝜒 ∧ (𝜓𝐵 = 𝐴))))
56 eqcom 2831 . . . . . . 7 (𝐵 = 𝐴𝐴 = 𝐵)
5756imbi2i 338 . . . . . 6 ((𝜓𝐵 = 𝐴) ↔ (𝜓𝐴 = 𝐵))
5857anbi2i 624 . . . . 5 ((𝜒 ∧ (𝜓𝐵 = 𝐴)) ↔ (𝜒 ∧ (𝜓𝐴 = 𝐵)))
5955, 58syl6bb 289 . . . 4 ((𝐴𝑉𝐵𝑊) → ((𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐)) ↔ (𝜒 ∧ (𝜓𝐴 = 𝐵))))
6042, 59orbi12d 915 . . 3 ((𝐴𝑉𝐵𝑊) → (((𝜓 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐴 = 𝑐)) ∨ (𝜒 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝐵 = 𝑐))) ↔ ((𝜓 ∧ (𝜒𝐴 = 𝐵)) ∨ (𝜒 ∧ (𝜓𝐴 = 𝐵)))))
6127, 60bitrd 281 . 2 ((𝐴𝑉𝐵𝑊) → (∃𝑥 ∈ {𝐴, 𝐵} (𝜑 ∧ ∀𝑐 ∈ {𝐴, 𝐵} ([𝑐 / 𝑥]𝜑𝑥 = 𝑐)) ↔ ((𝜓 ∧ (𝜒𝐴 = 𝐵)) ∨ (𝜒 ∧ (𝜓𝐴 = 𝐵)))))
625, 61syl5bb 285 1 ((𝐴𝑉𝐵𝑊) → (∃!𝑥 ∈ {𝐴, 𝐵}𝜑 ↔ ((𝜓 ∧ (𝜒𝐴 = 𝐵)) ∨ (𝜒 ∧ (𝜓𝐴 = 𝐵)))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 398  wo 843   = wceq 1536  wcel 2113  wral 3141  wrex 3142  ∃!wreu 3143  [wsbc 3775  {cpr 4572
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1969  ax-7 2014  ax-8 2115  ax-9 2123  ax-10 2144  ax-11 2160  ax-12 2176  ax-ext 2796
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3an 1085  df-tru 1539  df-ex 1780  df-nf 1784  df-sb 2069  df-mo 2621  df-eu 2653  df-clab 2803  df-cleq 2817  df-clel 2896  df-nfc 2966  df-ral 3146  df-rex 3147  df-reu 3148  df-v 3499  df-sbc 3776  df-un 3944  df-sn 4571  df-pr 4573
This theorem is referenced by:  reuprg  4642
  Copyright terms: Public domain W3C validator