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

Theorem fun11 6423
Description: Two ways of stating that 𝐴 is one-to-one (but not necessarily a function). Each side is equivalent to Definition 6.4(3) of [TakeutiZaring] p. 24, who use the notation "Un2 (A)" for one-to-one (but not necessarily a function). (Contributed by NM, 17-Jan-2006.)
Assertion
Ref Expression
fun11 ((Fun 𝐴 ∧ Fun 𝐴) ↔ ∀𝑥𝑦𝑧𝑤((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)))
Distinct variable group:   𝑥,𝑦,𝑧,𝑤,𝐴

Proof of Theorem fun11
StepHypRef Expression
1 dfbi2 477 . . . . . . . 8 ((𝑥 = 𝑧𝑦 = 𝑤) ↔ ((𝑥 = 𝑧𝑦 = 𝑤) ∧ (𝑦 = 𝑤𝑥 = 𝑧)))
21imbi2i 338 . . . . . . 7 (((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ ((𝑥𝐴𝑦𝑧𝐴𝑤) → ((𝑥 = 𝑧𝑦 = 𝑤) ∧ (𝑦 = 𝑤𝑥 = 𝑧))))
3 pm4.76 521 . . . . . . 7 ((((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ∧ ((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑦 = 𝑤𝑥 = 𝑧))) ↔ ((𝑥𝐴𝑦𝑧𝐴𝑤) → ((𝑥 = 𝑧𝑦 = 𝑤) ∧ (𝑦 = 𝑤𝑥 = 𝑧))))
4 bi2.04 391 . . . . . . . 8 (((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ (𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)))
5 bi2.04 391 . . . . . . . 8 (((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑦 = 𝑤𝑥 = 𝑧)) ↔ (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧)))
64, 5anbi12i 628 . . . . . . 7 ((((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ∧ ((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑦 = 𝑤𝑥 = 𝑧))) ↔ ((𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))))
72, 3, 63bitr2i 301 . . . . . 6 (((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ ((𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))))
872albii 1817 . . . . 5 (∀𝑥𝑦((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ ∀𝑥𝑦((𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))))
9 19.26-2 1868 . . . . 5 (∀𝑥𝑦((𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))) ↔ (∀𝑥𝑦(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ ∀𝑥𝑦(𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))))
10 alcom 2158 . . . . . . 7 (∀𝑥𝑦(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ↔ ∀𝑦𝑥(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)))
11 breq1 5062 . . . . . . . . . . 11 (𝑥 = 𝑧 → (𝑥𝐴𝑦𝑧𝐴𝑦))
1211anbi1d 631 . . . . . . . . . 10 (𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) ↔ (𝑧𝐴𝑦𝑧𝐴𝑤)))
1312imbi1d 344 . . . . . . . . 9 (𝑥 = 𝑧 → (((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ↔ ((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)))
1413equsalvw 2006 . . . . . . . 8 (∀𝑥(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ↔ ((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
1514albii 1816 . . . . . . 7 (∀𝑦𝑥(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ↔ ∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
1610, 15bitri 277 . . . . . 6 (∀𝑥𝑦(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ↔ ∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
17 breq2 5063 . . . . . . . . . 10 (𝑦 = 𝑤 → (𝑥𝐴𝑦𝑥𝐴𝑤))
1817anbi1d 631 . . . . . . . . 9 (𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) ↔ (𝑥𝐴𝑤𝑧𝐴𝑤)))
1918imbi1d 344 . . . . . . . 8 (𝑦 = 𝑤 → (((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧) ↔ ((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
2019equsalvw 2006 . . . . . . 7 (∀𝑦(𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧)) ↔ ((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
2120albii 1816 . . . . . 6 (∀𝑥𝑦(𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧)) ↔ ∀𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
2216, 21anbi12i 628 . . . . 5 ((∀𝑥𝑦(𝑥 = 𝑧 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤)) ∧ ∀𝑥𝑦(𝑦 = 𝑤 → ((𝑥𝐴𝑦𝑧𝐴𝑤) → 𝑥 = 𝑧))) ↔ (∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
238, 9, 223bitri 299 . . . 4 (∀𝑥𝑦((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ (∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
24232albii 1817 . . 3 (∀𝑧𝑤𝑥𝑦((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ ∀𝑧𝑤(∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
25 19.26-2 1868 . . 3 (∀𝑧𝑤(∀𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)) ↔ (∀𝑧𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
2624, 25bitr2i 278 . 2 ((∀𝑧𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)) ↔ ∀𝑧𝑤𝑥𝑦((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)))
27 fun2cnv 6420 . . . 4 (Fun 𝐴 ↔ ∀𝑧∃*𝑦 𝑧𝐴𝑦)
28 breq2 5063 . . . . . 6 (𝑦 = 𝑤 → (𝑧𝐴𝑦𝑧𝐴𝑤))
2928mo4 2646 . . . . 5 (∃*𝑦 𝑧𝐴𝑦 ↔ ∀𝑦𝑤((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
3029albii 1816 . . . 4 (∀𝑧∃*𝑦 𝑧𝐴𝑦 ↔ ∀𝑧𝑦𝑤((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
31 alcom 2158 . . . . 5 (∀𝑦𝑤((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ↔ ∀𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
3231albii 1816 . . . 4 (∀𝑧𝑦𝑤((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ↔ ∀𝑧𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
3327, 30, 323bitri 299 . . 3 (Fun 𝐴 ↔ ∀𝑧𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤))
34 funcnv2 6417 . . . 4 (Fun 𝐴 ↔ ∀𝑤∃*𝑥 𝑥𝐴𝑤)
35 breq1 5062 . . . . . 6 (𝑥 = 𝑧 → (𝑥𝐴𝑤𝑧𝐴𝑤))
3635mo4 2646 . . . . 5 (∃*𝑥 𝑥𝐴𝑤 ↔ ∀𝑥𝑧((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
3736albii 1816 . . . 4 (∀𝑤∃*𝑥 𝑥𝐴𝑤 ↔ ∀𝑤𝑥𝑧((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
38 alcom 2158 . . . . . 6 (∀𝑥𝑧((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧) ↔ ∀𝑧𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
3938albii 1816 . . . . 5 (∀𝑤𝑥𝑧((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧) ↔ ∀𝑤𝑧𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
40 alcom 2158 . . . . 5 (∀𝑤𝑧𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧) ↔ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
4139, 40bitri 277 . . . 4 (∀𝑤𝑥𝑧((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧) ↔ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
4234, 37, 413bitri 299 . . 3 (Fun 𝐴 ↔ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧))
4333, 42anbi12i 628 . 2 ((Fun 𝐴 ∧ Fun 𝐴) ↔ (∀𝑧𝑤𝑦((𝑧𝐴𝑦𝑧𝐴𝑤) → 𝑦 = 𝑤) ∧ ∀𝑧𝑤𝑥((𝑥𝐴𝑤𝑧𝐴𝑤) → 𝑥 = 𝑧)))
44 alrot4 2160 . 2 (∀𝑥𝑦𝑧𝑤((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)) ↔ ∀𝑧𝑤𝑥𝑦((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)))
4526, 43, 443bitr4i 305 1 ((Fun 𝐴 ∧ Fun 𝐴) ↔ ∀𝑥𝑦𝑧𝑤((𝑥𝐴𝑦𝑧𝐴𝑤) → (𝑥 = 𝑧𝑦 = 𝑤)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 398  wal 1531  ∃*wmo 2616   class class class wbr 5059  ccnv 5549  Fun wfun 6344
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1792  ax-4 1806  ax-5 1907  ax-6 1966  ax-7 2011  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2156  ax-12 2172  ax-ext 2793  ax-sep 5196  ax-nul 5203  ax-pr 5322
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3an 1085  df-tru 1536  df-ex 1777  df-nf 1781  df-sb 2066  df-mo 2618  df-eu 2650  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ral 3143  df-rab 3147  df-v 3497  df-dif 3939  df-un 3941  df-in 3943  df-ss 3952  df-nul 4292  df-if 4468  df-sn 4562  df-pr 4564  df-op 4568  df-br 5060  df-opab 5122  df-id 5455  df-xp 5556  df-rel 5557  df-cnv 5558  df-co 5559  df-fun 6352
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator