Users' Mathboxes Mathbox for Scott Fenton < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  xpord2pred Structured version   Visualization version   GIF version

Theorem xpord2pred 33359
Description: Calculate the predecessor class in frxp2 33358. (Contributed by Scott Fenton, 22-Aug-2024.)
Hypothesis
Ref Expression
xpord2.1 𝑇 = {⟨𝑥, 𝑦⟩ ∣ (𝑥 ∈ (𝐴 × 𝐵) ∧ 𝑦 ∈ (𝐴 × 𝐵) ∧ (((1st𝑥)𝑅(1st𝑦) ∨ (1st𝑥) = (1st𝑦)) ∧ ((2nd𝑥)𝑆(2nd𝑦) ∨ (2nd𝑥) = (2nd𝑦)) ∧ 𝑥𝑦))}
Assertion
Ref Expression
xpord2pred ((𝑋𝐴𝑌𝐵) → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑌⟩) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌})) ∖ {⟨𝑋, 𝑌⟩}))
Distinct variable groups:   𝑥,𝐴,𝑦   𝑥,𝐵,𝑦   𝑥,𝑅,𝑦   𝑥,𝑆,𝑦
Allowed substitution hints:   𝑇(𝑥,𝑦)   𝑋(𝑥,𝑦)   𝑌(𝑥,𝑦)

Proof of Theorem xpord2pred
Dummy variables 𝑎 𝑏 𝑐 𝑑 𝑒 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 opeq1 4764 . . . 4 (𝑎 = 𝑋 → ⟨𝑎, 𝑏⟩ = ⟨𝑋, 𝑏⟩)
2 predeq3 6135 . . . 4 (⟨𝑎, 𝑏⟩ = ⟨𝑋, 𝑏⟩ → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) = Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩))
31, 2syl 17 . . 3 (𝑎 = 𝑋 → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) = Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩))
4 predeq3 6135 . . . . . 6 (𝑎 = 𝑋 → Pred(𝑅, 𝐴, 𝑎) = Pred(𝑅, 𝐴, 𝑋))
5 sneq 4535 . . . . . 6 (𝑎 = 𝑋 → {𝑎} = {𝑋})
64, 5uneq12d 4071 . . . . 5 (𝑎 = 𝑋 → (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) = (Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}))
76xpeq1d 5557 . . . 4 (𝑎 = 𝑋 → ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) = ((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})))
81sneqd 4537 . . . 4 (𝑎 = 𝑋 → {⟨𝑎, 𝑏⟩} = {⟨𝑋, 𝑏⟩})
97, 8difeq12d 4031 . . 3 (𝑎 = 𝑋 → (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑋, 𝑏⟩}))
103, 9eqeq12d 2774 . 2 (𝑎 = 𝑋 → (Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) = (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) ↔ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑋, 𝑏⟩})))
11 opeq2 4766 . . . 4 (𝑏 = 𝑌 → ⟨𝑋, 𝑏⟩ = ⟨𝑋, 𝑌⟩)
12 predeq3 6135 . . . 4 (⟨𝑋, 𝑏⟩ = ⟨𝑋, 𝑌⟩ → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩) = Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑌⟩))
1311, 12syl 17 . . 3 (𝑏 = 𝑌 → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩) = Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑌⟩))
14 predeq3 6135 . . . . . 6 (𝑏 = 𝑌 → Pred(𝑆, 𝐵, 𝑏) = Pred(𝑆, 𝐵, 𝑌))
15 sneq 4535 . . . . . 6 (𝑏 = 𝑌 → {𝑏} = {𝑌})
1614, 15uneq12d 4071 . . . . 5 (𝑏 = 𝑌 → (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏}) = (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌}))
1716xpeq2d 5558 . . . 4 (𝑏 = 𝑌 → ((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) = ((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌})))
1811sneqd 4537 . . . 4 (𝑏 = 𝑌 → {⟨𝑋, 𝑏⟩} = {⟨𝑋, 𝑌⟩})
1917, 18difeq12d 4031 . . 3 (𝑏 = 𝑌 → (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑋, 𝑏⟩}) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌})) ∖ {⟨𝑋, 𝑌⟩}))
2013, 19eqeq12d 2774 . 2 (𝑏 = 𝑌 → (Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑏⟩) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑋, 𝑏⟩}) ↔ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑌⟩) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌})) ∖ {⟨𝑋, 𝑌⟩})))
21 predel 6148 . . . . 5 (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) → 𝑒 ∈ (𝐴 × 𝐵))
2221a1i 11 . . . 4 ((𝑎𝐴𝑏𝐵) → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) → 𝑒 ∈ (𝐴 × 𝐵)))
23 eldifi 4034 . . . . 5 (𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) → 𝑒 ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})))
24 predss 6138 . . . . . . . . 9 Pred(𝑅, 𝐴, 𝑎) ⊆ 𝐴
2524a1i 11 . . . . . . . 8 (𝑎𝐴 → Pred(𝑅, 𝐴, 𝑎) ⊆ 𝐴)
26 snssi 4701 . . . . . . . 8 (𝑎𝐴 → {𝑎} ⊆ 𝐴)
2725, 26unssd 4093 . . . . . . 7 (𝑎𝐴 → (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ⊆ 𝐴)
28 predss 6138 . . . . . . . . 9 Pred(𝑆, 𝐵, 𝑏) ⊆ 𝐵
2928a1i 11 . . . . . . . 8 (𝑏𝐵 → Pred(𝑆, 𝐵, 𝑏) ⊆ 𝐵)
30 snssi 4701 . . . . . . . 8 (𝑏𝐵 → {𝑏} ⊆ 𝐵)
3129, 30unssd 4093 . . . . . . 7 (𝑏𝐵 → (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏}) ⊆ 𝐵)
32 xpss12 5543 . . . . . . 7 (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ⊆ 𝐴 ∧ (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏}) ⊆ 𝐵) → ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ⊆ (𝐴 × 𝐵))
3327, 31, 32syl2an 598 . . . . . 6 ((𝑎𝐴𝑏𝐵) → ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ⊆ (𝐴 × 𝐵))
3433sseld 3893 . . . . 5 ((𝑎𝐴𝑏𝐵) → (𝑒 ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) → 𝑒 ∈ (𝐴 × 𝐵)))
3523, 34syl5 34 . . . 4 ((𝑎𝐴𝑏𝐵) → (𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) → 𝑒 ∈ (𝐴 × 𝐵)))
36 elxp2 5552 . . . . 5 (𝑒 ∈ (𝐴 × 𝐵) ↔ ∃𝑐𝐴𝑑𝐵 𝑒 = ⟨𝑐, 𝑑⟩)
37 opex 5328 . . . . . . . . 9 𝑎, 𝑏⟩ ∈ V
38 opex 5328 . . . . . . . . . 10 𝑐, 𝑑⟩ ∈ V
3938elpred 6144 . . . . . . . . 9 (⟨𝑎, 𝑏⟩ ∈ V → (⟨𝑐, 𝑑⟩ ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ (⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵) ∧ ⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩)))
4037, 39ax-mp 5 . . . . . . . 8 (⟨𝑐, 𝑑⟩ ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ (⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵) ∧ ⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩))
41 opelxpi 5565 . . . . . . . . . . 11 ((𝑐𝐴𝑑𝐵) → ⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵))
4241adantl 485 . . . . . . . . . 10 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → ⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵))
4342biantrurd 536 . . . . . . . . 9 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩ ↔ (⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵) ∧ ⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩)))
44 xpord2.1 . . . . . . . . . . 11 𝑇 = {⟨𝑥, 𝑦⟩ ∣ (𝑥 ∈ (𝐴 × 𝐵) ∧ 𝑦 ∈ (𝐴 × 𝐵) ∧ (((1st𝑥)𝑅(1st𝑦) ∨ (1st𝑥) = (1st𝑦)) ∧ ((2nd𝑥)𝑆(2nd𝑦) ∨ (2nd𝑥) = (2nd𝑦)) ∧ 𝑥𝑦))}
4544xpord2lem 33356 . . . . . . . . . 10 (⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩ ↔ ((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))))
46 eldif 3870 . . . . . . . . . . . . 13 (⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) ↔ (⟨𝑐, 𝑑⟩ ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∧ ¬ ⟨𝑐, 𝑑⟩ ∈ {⟨𝑎, 𝑏⟩}))
47 opelxp 5564 . . . . . . . . . . . . . . 15 (⟨𝑐, 𝑑⟩ ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ↔ (𝑐 ∈ (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ∧ 𝑑 ∈ (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})))
48 elun 4056 . . . . . . . . . . . . . . . . 17 (𝑐 ∈ (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ↔ (𝑐 ∈ Pred(𝑅, 𝐴, 𝑎) ∨ 𝑐 ∈ {𝑎}))
49 vex 3413 . . . . . . . . . . . . . . . . . . . 20 𝑐 ∈ V
5049elpred 6144 . . . . . . . . . . . . . . . . . . 19 (𝑎 ∈ V → (𝑐 ∈ Pred(𝑅, 𝐴, 𝑎) ↔ (𝑐𝐴𝑐𝑅𝑎)))
5150elv 3415 . . . . . . . . . . . . . . . . . 18 (𝑐 ∈ Pred(𝑅, 𝐴, 𝑎) ↔ (𝑐𝐴𝑐𝑅𝑎))
52 velsn 4541 . . . . . . . . . . . . . . . . . 18 (𝑐 ∈ {𝑎} ↔ 𝑐 = 𝑎)
5351, 52orbi12i 912 . . . . . . . . . . . . . . . . 17 ((𝑐 ∈ Pred(𝑅, 𝐴, 𝑎) ∨ 𝑐 ∈ {𝑎}) ↔ ((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎))
5448, 53bitri 278 . . . . . . . . . . . . . . . 16 (𝑐 ∈ (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ↔ ((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎))
55 elun 4056 . . . . . . . . . . . . . . . . 17 (𝑑 ∈ (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏}) ↔ (𝑑 ∈ Pred(𝑆, 𝐵, 𝑏) ∨ 𝑑 ∈ {𝑏}))
56 vex 3413 . . . . . . . . . . . . . . . . . . . 20 𝑑 ∈ V
5756elpred 6144 . . . . . . . . . . . . . . . . . . 19 (𝑏 ∈ V → (𝑑 ∈ Pred(𝑆, 𝐵, 𝑏) ↔ (𝑑𝐵𝑑𝑆𝑏)))
5857elv 3415 . . . . . . . . . . . . . . . . . 18 (𝑑 ∈ Pred(𝑆, 𝐵, 𝑏) ↔ (𝑑𝐵𝑑𝑆𝑏))
59 velsn 4541 . . . . . . . . . . . . . . . . . 18 (𝑑 ∈ {𝑏} ↔ 𝑑 = 𝑏)
6058, 59orbi12i 912 . . . . . . . . . . . . . . . . 17 ((𝑑 ∈ Pred(𝑆, 𝐵, 𝑏) ∨ 𝑑 ∈ {𝑏}) ↔ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏))
6155, 60bitri 278 . . . . . . . . . . . . . . . 16 (𝑑 ∈ (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏}) ↔ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏))
6254, 61anbi12i 629 . . . . . . . . . . . . . . 15 ((𝑐 ∈ (Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) ∧ 𝑑 ∈ (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ↔ (((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)))
6347, 62bitri 278 . . . . . . . . . . . . . 14 (⟨𝑐, 𝑑⟩ ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ↔ (((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)))
6438elsn 4540 . . . . . . . . . . . . . . . 16 (⟨𝑐, 𝑑⟩ ∈ {⟨𝑎, 𝑏⟩} ↔ ⟨𝑐, 𝑑⟩ = ⟨𝑎, 𝑏⟩)
6564notbii 323 . . . . . . . . . . . . . . 15 (¬ ⟨𝑐, 𝑑⟩ ∈ {⟨𝑎, 𝑏⟩} ↔ ¬ ⟨𝑐, 𝑑⟩ = ⟨𝑎, 𝑏⟩)
66 df-ne 2952 . . . . . . . . . . . . . . 15 (⟨𝑐, 𝑑⟩ ≠ ⟨𝑎, 𝑏⟩ ↔ ¬ ⟨𝑐, 𝑑⟩ = ⟨𝑎, 𝑏⟩)
6749, 56opthne 5346 . . . . . . . . . . . . . . 15 (⟨𝑐, 𝑑⟩ ≠ ⟨𝑎, 𝑏⟩ ↔ (𝑐𝑎𝑑𝑏))
6865, 66, 673bitr2i 302 . . . . . . . . . . . . . 14 (¬ ⟨𝑐, 𝑑⟩ ∈ {⟨𝑎, 𝑏⟩} ↔ (𝑐𝑎𝑑𝑏))
6963, 68anbi12i 629 . . . . . . . . . . . . 13 ((⟨𝑐, 𝑑⟩ ∈ ((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∧ ¬ ⟨𝑐, 𝑑⟩ ∈ {⟨𝑎, 𝑏⟩}) ↔ ((((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)) ∧ (𝑐𝑎𝑑𝑏)))
7046, 69bitri 278 . . . . . . . . . . . 12 (⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) ↔ ((((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)) ∧ (𝑐𝑎𝑑𝑏)))
71 simprl 770 . . . . . . . . . . . . . . . 16 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → 𝑐𝐴)
7271biantrurd 536 . . . . . . . . . . . . . . 15 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (𝑐𝑅𝑎 ↔ (𝑐𝐴𝑐𝑅𝑎)))
7372orbi1d 914 . . . . . . . . . . . . . 14 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → ((𝑐𝑅𝑎𝑐 = 𝑎) ↔ ((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎)))
74 simprr 772 . . . . . . . . . . . . . . . 16 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → 𝑑𝐵)
7574biantrurd 536 . . . . . . . . . . . . . . 15 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (𝑑𝑆𝑏 ↔ (𝑑𝐵𝑑𝑆𝑏)))
7675orbi1d 914 . . . . . . . . . . . . . 14 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → ((𝑑𝑆𝑏𝑑 = 𝑏) ↔ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)))
7773, 763anbi12d 1434 . . . . . . . . . . . . 13 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)) ↔ (((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))))
78 df-3an 1086 . . . . . . . . . . . . 13 ((((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)) ↔ ((((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)) ∧ (𝑐𝑎𝑑𝑏)))
7977, 78bitr2di 291 . . . . . . . . . . . 12 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (((((𝑐𝐴𝑐𝑅𝑎) ∨ 𝑐 = 𝑎) ∧ ((𝑑𝐵𝑑𝑆𝑏) ∨ 𝑑 = 𝑏)) ∧ (𝑐𝑎𝑑𝑏)) ↔ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))))
8070, 79syl5bb 286 . . . . . . . . . . 11 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) ↔ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))))
81 pm3.22 463 . . . . . . . . . . . . 13 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → ((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵)))
8281biantrurd 536 . . . . . . . . . . . 12 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)) ↔ (((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵)) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)))))
83 df-3an 1086 . . . . . . . . . . . 12 (((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))) ↔ (((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵)) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))))
8482, 83bitr4di 292 . . . . . . . . . . 11 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)) ↔ ((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏)))))
8580, 84bitr2d 283 . . . . . . . . . 10 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (((𝑐𝐴𝑑𝐵) ∧ (𝑎𝐴𝑏𝐵) ∧ ((𝑐𝑅𝑎𝑐 = 𝑎) ∧ (𝑑𝑆𝑏𝑑 = 𝑏) ∧ (𝑐𝑎𝑑𝑏))) ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
8645, 85syl5bb 286 . . . . . . . . 9 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩ ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
8743, 86bitr3d 284 . . . . . . . 8 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → ((⟨𝑐, 𝑑⟩ ∈ (𝐴 × 𝐵) ∧ ⟨𝑐, 𝑑𝑇𝑎, 𝑏⟩) ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
8840, 87syl5bb 286 . . . . . . 7 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (⟨𝑐, 𝑑⟩ ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
89 eleq1 2839 . . . . . . . 8 (𝑒 = ⟨𝑐, 𝑑⟩ → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ ⟨𝑐, 𝑑⟩ ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩)))
90 eleq1 2839 . . . . . . . 8 (𝑒 = ⟨𝑐, 𝑑⟩ → (𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}) ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
9189, 90bibi12d 349 . . . . . . 7 (𝑒 = ⟨𝑐, 𝑑⟩ → ((𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ 𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})) ↔ (⟨𝑐, 𝑑⟩ ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ ⟨𝑐, 𝑑⟩ ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}))))
9288, 91syl5ibrcom 250 . . . . . 6 (((𝑎𝐴𝑏𝐵) ∧ (𝑐𝐴𝑑𝐵)) → (𝑒 = ⟨𝑐, 𝑑⟩ → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ 𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}))))
9392rexlimdvva 3218 . . . . 5 ((𝑎𝐴𝑏𝐵) → (∃𝑐𝐴𝑑𝐵 𝑒 = ⟨𝑐, 𝑑⟩ → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ 𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}))))
9436, 93syl5bi 245 . . . 4 ((𝑎𝐴𝑏𝐵) → (𝑒 ∈ (𝐴 × 𝐵) → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ 𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}))))
9522, 35, 94pm5.21ndd 384 . . 3 ((𝑎𝐴𝑏𝐵) → (𝑒 ∈ Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) ↔ 𝑒 ∈ (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩})))
9695eqrdv 2756 . 2 ((𝑎𝐴𝑏𝐵) → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑎, 𝑏⟩) = (((Pred(𝑅, 𝐴, 𝑎) ∪ {𝑎}) × (Pred(𝑆, 𝐵, 𝑏) ∪ {𝑏})) ∖ {⟨𝑎, 𝑏⟩}))
9710, 20, 96vtocl2ga 3495 1 ((𝑋𝐴𝑌𝐵) → Pred(𝑇, (𝐴 × 𝐵), ⟨𝑋, 𝑌⟩) = (((Pred(𝑅, 𝐴, 𝑋) ∪ {𝑋}) × (Pred(𝑆, 𝐵, 𝑌) ∪ {𝑌})) ∖ {⟨𝑋, 𝑌⟩}))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 209  wa 399  wo 844  w3a 1084   = wceq 1538  wcel 2111  wne 2951  wrex 3071  Vcvv 3409  cdif 3857  cun 3858  wss 3860  {csn 4525  cop 4531   class class class wbr 5036  {copab 5098   × cxp 5526  Predcpred 6130  cfv 6340  1st c1st 7697  2nd c2nd 7698
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 1911  ax-6 1970  ax-7 2015  ax-8 2113  ax-9 2121  ax-10 2142  ax-11 2158  ax-12 2175  ax-ext 2729  ax-sep 5173  ax-nul 5180  ax-pr 5302  ax-un 7465
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 845  df-3an 1086  df-tru 1541  df-fal 1551  df-ex 1782  df-nf 1786  df-sb 2070  df-mo 2557  df-eu 2588  df-clab 2736  df-cleq 2750  df-clel 2830  df-nfc 2901  df-ne 2952  df-ral 3075  df-rex 3076  df-rab 3079  df-v 3411  df-sbc 3699  df-dif 3863  df-un 3865  df-in 3867  df-ss 3877  df-nul 4228  df-if 4424  df-sn 4526  df-pr 4528  df-op 4532  df-uni 4802  df-br 5037  df-opab 5099  df-mpt 5117  df-id 5434  df-xp 5534  df-rel 5535  df-cnv 5536  df-co 5537  df-dm 5538  df-rn 5539  df-res 5540  df-ima 5541  df-pred 6131  df-iota 6299  df-fun 6342  df-fv 6348  df-1st 7699  df-2nd 7700
This theorem is referenced by:  sexp2  33360  xpord2ind  33361  on2recsov  33424  noxpordpred  33692
  Copyright terms: Public domain W3C validator