Users' Mathboxes Mathbox for Alexander van der Vekens < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  ich2exprop Structured version   Visualization version   GIF version

Theorem ich2exprop 43682
Description: If the setvar variables are interchangeable in a wff, there is an ordered pair fulfilling the wff iff there is an unordered pair fulfilling the wff. (Contributed by AV, 16-Jul-2023.)
Assertion
Ref Expression
ich2exprop ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) ↔ ∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑)))
Distinct variable groups:   𝐴,𝑎,𝑏   𝐵,𝑎,𝑏   𝑋,𝑎,𝑏
Allowed substitution hints:   𝜑(𝑎,𝑏)

Proof of Theorem ich2exprop
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 nfv 1915 . . . . 5 𝑎 𝐴𝑋
2 nfv 1915 . . . . 5 𝑎 𝐵𝑋
3 nfich1 43656 . . . . 5 𝑎[𝑎𝑏]𝜑
41, 2, 3nf3an 1902 . . . 4 𝑎(𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑)
5 nfv 1915 . . . . . . 7 𝑎𝐴, 𝐵⟩ = ⟨𝑥, 𝑦
6 nfcv 2977 . . . . . . . 8 𝑎𝑦
7 nfsbc1v 3792 . . . . . . . 8 𝑎[𝑥 / 𝑎]𝜑
86, 7nfsbcw 3794 . . . . . . 7 𝑎[𝑦 / 𝑏][𝑥 / 𝑎]𝜑
95, 8nfan 1900 . . . . . 6 𝑎(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
109nfex 2343 . . . . 5 𝑎𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
1110nfex 2343 . . . 4 𝑎𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
12 nfv 1915 . . . . . 6 𝑏 𝐴𝑋
13 nfv 1915 . . . . . 6 𝑏 𝐵𝑋
14 nfich2 43657 . . . . . 6 𝑏[𝑎𝑏]𝜑
1512, 13, 14nf3an 1902 . . . . 5 𝑏(𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑)
16 nfv 1915 . . . . . . . 8 𝑏𝐴, 𝐵⟩ = ⟨𝑥, 𝑦
17 nfsbc1v 3792 . . . . . . . 8 𝑏[𝑦 / 𝑏][𝑥 / 𝑎]𝜑
1816, 17nfan 1900 . . . . . . 7 𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
1918nfex 2343 . . . . . 6 𝑏𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
2019nfex 2343 . . . . 5 𝑏𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)
21 vex 3497 . . . . . . . . 9 𝑎 ∈ V
22 vex 3497 . . . . . . . . 9 𝑏 ∈ V
23 preq12bg 4784 . . . . . . . . 9 (((𝐴𝑋𝐵𝑋) ∧ (𝑎 ∈ V ∧ 𝑏 ∈ V)) → ({𝐴, 𝐵} = {𝑎, 𝑏} ↔ ((𝐴 = 𝑎𝐵 = 𝑏) ∨ (𝐴 = 𝑏𝐵 = 𝑎))))
2421, 22, 23mpanr12 703 . . . . . . . 8 ((𝐴𝑋𝐵𝑋) → ({𝐴, 𝐵} = {𝑎, 𝑏} ↔ ((𝐴 = 𝑎𝐵 = 𝑏) ∨ (𝐴 = 𝑏𝐵 = 𝑎))))
25243adant3 1128 . . . . . . 7 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → ({𝐴, 𝐵} = {𝑎, 𝑏} ↔ ((𝐴 = 𝑎𝐵 = 𝑏) ∨ (𝐴 = 𝑏𝐵 = 𝑎))))
26 or2expropbilem1 43316 . . . . . . . . 9 ((𝐴𝑋𝐵𝑋) → ((𝐴 = 𝑎𝐵 = 𝑏) → (𝜑 → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
27263adant3 1128 . . . . . . . 8 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → ((𝐴 = 𝑎𝐵 = 𝑏) → (𝜑 → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
28 ichcom 43666 . . . . . . . . . . . . . . 15 ([𝑎𝑏]𝜑 ↔ [𝑏𝑎]𝜑)
2928biimpi 218 . . . . . . . . . . . . . 14 ([𝑎𝑏]𝜑 → [𝑏𝑎]𝜑)
30293ad2ant3 1131 . . . . . . . . . . . . 13 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → [𝑏𝑎]𝜑)
3130adantr 483 . . . . . . . . . . . 12 (((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) ∧ 𝜑) → [𝑏𝑎]𝜑)
3222, 21pm3.2i 473 . . . . . . . . . . . . 13 (𝑏 ∈ V ∧ 𝑎 ∈ V)
3332a1i 11 . . . . . . . . . . . 12 ((𝐴 = 𝑏𝐵 = 𝑎) → (𝑏 ∈ V ∧ 𝑎 ∈ V))
3431, 33anim12i 614 . . . . . . . . . . 11 ((((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) ∧ 𝜑) ∧ (𝐴 = 𝑏𝐵 = 𝑎)) → ([𝑏𝑎]𝜑 ∧ (𝑏 ∈ V ∧ 𝑎 ∈ V)))
35 simpr 487 . . . . . . . . . . . 12 (((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) ∧ 𝜑) → 𝜑)
36 opeq12 4805 . . . . . . . . . . . 12 ((𝐴 = 𝑏𝐵 = 𝑎) → ⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩)
3735, 36anim12ci 615 . . . . . . . . . . 11 ((((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) ∧ 𝜑) ∧ (𝐴 = 𝑏𝐵 = 𝑎)) → (⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩ ∧ 𝜑))
38 nfv 1915 . . . . . . . . . . . 12 𝑥(⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩ ∧ 𝜑)
39 nfv 1915 . . . . . . . . . . . 12 𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩ ∧ 𝜑)
40 opeq12 4805 . . . . . . . . . . . . . . 15 ((𝑥 = 𝑏𝑦 = 𝑎) → ⟨𝑥, 𝑦⟩ = ⟨𝑏, 𝑎⟩)
4140eqeq2d 2832 . . . . . . . . . . . . . 14 ((𝑥 = 𝑏𝑦 = 𝑎) → (⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ↔ ⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩))
4241adantl 484 . . . . . . . . . . . . 13 (([𝑏𝑎]𝜑 ∧ (𝑥 = 𝑏𝑦 = 𝑎)) → (⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ↔ ⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩))
43 dfsbcq 3774 . . . . . . . . . . . . . . . 16 (𝑦 = 𝑎 → ([𝑦 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑))
4443adantl 484 . . . . . . . . . . . . . . 15 ((𝑥 = 𝑏𝑦 = 𝑎) → ([𝑦 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑))
4544adantl 484 . . . . . . . . . . . . . 14 (([𝑏𝑎]𝜑 ∧ (𝑥 = 𝑏𝑦 = 𝑎)) → ([𝑦 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑))
46 sbceq1a 3783 . . . . . . . . . . . . . . . 16 (𝑥 = 𝑏 → ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑))
4746adantr 483 . . . . . . . . . . . . . . 15 ((𝑥 = 𝑏𝑦 = 𝑎) → ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑))
48 df-ich 43655 . . . . . . . . . . . . . . . 16 ([𝑏𝑎]𝜑 ↔ ∀𝑏𝑎([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
49 sbsbc 3776 . . . . . . . . . . . . . . . . . 18 ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
50 sbsbc 3776 . . . . . . . . . . . . . . . . . . . 20 ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
51 sbsbc 3776 . . . . . . . . . . . . . . . . . . . . 21 ([𝑥 / 𝑎]𝜑[𝑥 / 𝑎]𝜑)
5251sbcbii 3829 . . . . . . . . . . . . . . . . . . . 20 ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
5350, 52bitri 277 . . . . . . . . . . . . . . . . . . 19 ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
5453sbcbii 3829 . . . . . . . . . . . . . . . . . 18 ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
5549, 54bitri 277 . . . . . . . . . . . . . . . . 17 ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑[𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑)
56 2sp 2185 . . . . . . . . . . . . . . . . 17 (∀𝑏𝑎([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑) → ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
5755, 56syl5bbr 287 . . . . . . . . . . . . . . . 16 (∀𝑏𝑎([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑) → ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
5848, 57sylbi 219 . . . . . . . . . . . . . . 15 ([𝑏𝑎]𝜑 → ([𝑏 / 𝑥][𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
5947, 58sylan9bbr 513 . . . . . . . . . . . . . 14 (([𝑏𝑎]𝜑 ∧ (𝑥 = 𝑏𝑦 = 𝑎)) → ([𝑎 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
6045, 59bitrd 281 . . . . . . . . . . . . 13 (([𝑏𝑎]𝜑 ∧ (𝑥 = 𝑏𝑦 = 𝑎)) → ([𝑦 / 𝑏][𝑥 / 𝑎]𝜑𝜑))
6142, 60anbi12d 632 . . . . . . . . . . . 12 (([𝑏𝑎]𝜑 ∧ (𝑥 = 𝑏𝑦 = 𝑎)) → ((⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑) ↔ (⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩ ∧ 𝜑)))
6238, 39, 61spc2ed 3602 . . . . . . . . . . 11 (([𝑏𝑎]𝜑 ∧ (𝑏 ∈ V ∧ 𝑎 ∈ V)) → ((⟨𝐴, 𝐵⟩ = ⟨𝑏, 𝑎⟩ ∧ 𝜑) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)))
6334, 37, 62sylc 65 . . . . . . . . . 10 ((((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) ∧ 𝜑) ∧ (𝐴 = 𝑏𝐵 = 𝑎)) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))
6463exp31 422 . . . . . . . . 9 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (𝜑 → ((𝐴 = 𝑏𝐵 = 𝑎) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
6564com23 86 . . . . . . . 8 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → ((𝐴 = 𝑏𝐵 = 𝑎) → (𝜑 → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
6627, 65jaod 855 . . . . . . 7 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (((𝐴 = 𝑎𝐵 = 𝑏) ∨ (𝐴 = 𝑏𝐵 = 𝑎)) → (𝜑 → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
6725, 66sylbid 242 . . . . . 6 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → ({𝐴, 𝐵} = {𝑎, 𝑏} → (𝜑 → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))))
6867impd 413 . . . . 5 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)))
6915, 20, 68exlimd 2218 . . . 4 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)))
704, 11, 69exlimd 2218 . . 3 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) → ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑)))
71 or2expropbilem2 43317 . . 3 (∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑) ↔ ∃𝑥𝑦(⟨𝐴, 𝐵⟩ = ⟨𝑥, 𝑦⟩ ∧ [𝑦 / 𝑏][𝑥 / 𝑎]𝜑))
7270, 71syl6ibr 254 . 2 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) → ∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑)))
73 oppr 43314 . . . . 5 ((𝐴𝑋𝐵𝑋) → (⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ → {𝐴, 𝐵} = {𝑎, 𝑏}))
7473anim1d 612 . . . 4 ((𝐴𝑋𝐵𝑋) → ((⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑) → ({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑)))
75742eximdv 1920 . . 3 ((𝐴𝑋𝐵𝑋) → (∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑) → ∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑)))
76753adant3 1128 . 2 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑) → ∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑)))
7772, 76impbid 214 1 ((𝐴𝑋𝐵𝑋 ∧ [𝑎𝑏]𝜑) → (∃𝑎𝑏({𝐴, 𝐵} = {𝑎, 𝑏} ∧ 𝜑) ↔ ∃𝑎𝑏(⟨𝐴, 𝐵⟩ = ⟨𝑎, 𝑏⟩ ∧ 𝜑)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 398  wo 843  w3a 1083  wal 1535   = wceq 1537  wex 1780  [wsb 2069  wcel 2114  Vcvv 3494  [wsbc 3772  {cpr 4569  cop 4573  [wich 43654
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1970  ax-7 2015  ax-8 2116  ax-9 2124  ax-10 2145  ax-11 2161  ax-12 2177  ax-ext 2793  ax-sep 5203  ax-nul 5210  ax-pr 5330
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3an 1085  df-tru 1540  df-ex 1781  df-nf 1785  df-sb 2070  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-rab 3147  df-v 3496  df-sbc 3773  df-dif 3939  df-un 3941  df-in 3943  df-ss 3952  df-nul 4292  df-if 4468  df-sn 4568  df-pr 4570  df-op 4574  df-ich 43655
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator