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

Theorem isdomn3 20630
Description: Nonzero elements form a multiplicative submonoid of any domain. (Contributed by Stefan O'Rear, 11-Sep-2015.)
Hypotheses
Ref Expression
isdomn3.b 𝐵 = (Base‘𝑅)
isdomn3.z 0 = (0g𝑅)
isdomn3.u 𝑈 = (mulGrp‘𝑅)
Assertion
Ref Expression
isdomn3 (𝑅 ∈ Domn ↔ (𝑅 ∈ Ring ∧ (𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈)))

Proof of Theorem isdomn3
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 isdomn3.b . . 3 𝐵 = (Base‘𝑅)
2 eqid 2731 . . 3 (.r𝑅) = (.r𝑅)
3 isdomn3.z . . 3 0 = (0g𝑅)
41, 2, 3isdomn 20620 . 2 (𝑅 ∈ Domn ↔ (𝑅 ∈ NzRing ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))))
5 eqid 2731 . . . . . 6 (1r𝑅) = (1r𝑅)
65, 3isnzr 20429 . . . . 5 (𝑅 ∈ NzRing ↔ (𝑅 ∈ Ring ∧ (1r𝑅) ≠ 0 ))
76anbi1i 624 . . . 4 ((𝑅 ∈ NzRing ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ ((𝑅 ∈ Ring ∧ (1r𝑅) ≠ 0 ) ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))))
8 anass 468 . . . 4 (((𝑅 ∈ Ring ∧ (1r𝑅) ≠ 0 ) ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ (𝑅 ∈ Ring ∧ ((1r𝑅) ≠ 0 ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )))))
97, 8bitri 275 . . 3 ((𝑅 ∈ NzRing ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ (𝑅 ∈ Ring ∧ ((1r𝑅) ≠ 0 ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )))))
101, 5ringidcl 20183 . . . . . . 7 (𝑅 ∈ Ring → (1r𝑅) ∈ 𝐵)
11 eldifsn 4735 . . . . . . . 8 ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ↔ ((1r𝑅) ∈ 𝐵 ∧ (1r𝑅) ≠ 0 ))
1211baibr 536 . . . . . . 7 ((1r𝑅) ∈ 𝐵 → ((1r𝑅) ≠ 0 ↔ (1r𝑅) ∈ (𝐵 ∖ { 0 })))
1310, 12syl 17 . . . . . 6 (𝑅 ∈ Ring → ((1r𝑅) ≠ 0 ↔ (1r𝑅) ∈ (𝐵 ∖ { 0 })))
141, 2ringcl 20168 . . . . . . . . . . . 12 ((𝑅 ∈ Ring ∧ 𝑥𝐵𝑦𝐵) → (𝑥(.r𝑅)𝑦) ∈ 𝐵)
15143expb 1120 . . . . . . . . . . 11 ((𝑅 ∈ Ring ∧ (𝑥𝐵𝑦𝐵)) → (𝑥(.r𝑅)𝑦) ∈ 𝐵)
1615biantrurd 532 . . . . . . . . . 10 ((𝑅 ∈ Ring ∧ (𝑥𝐵𝑦𝐵)) → ((𝑥(.r𝑅)𝑦) ≠ 0 ↔ ((𝑥(.r𝑅)𝑦) ∈ 𝐵 ∧ (𝑥(.r𝑅)𝑦) ≠ 0 )))
17 eldifsn 4735 . . . . . . . . . 10 ((𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }) ↔ ((𝑥(.r𝑅)𝑦) ∈ 𝐵 ∧ (𝑥(.r𝑅)𝑦) ≠ 0 ))
1816, 17bitr4di 289 . . . . . . . . 9 ((𝑅 ∈ Ring ∧ (𝑥𝐵𝑦𝐵)) → ((𝑥(.r𝑅)𝑦) ≠ 0 ↔ (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
1918imbi2d 340 . . . . . . . 8 ((𝑅 ∈ Ring ∧ (𝑥𝐵𝑦𝐵)) → (((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ≠ 0 ) ↔ ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
20192ralbidva 3194 . . . . . . 7 (𝑅 ∈ Ring → (∀𝑥𝐵𝑦𝐵 ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ≠ 0 ) ↔ ∀𝑥𝐵𝑦𝐵 ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
21 con34b 316 . . . . . . . . 9 (((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )) ↔ (¬ (𝑥 = 0𝑦 = 0 ) → ¬ (𝑥(.r𝑅)𝑦) = 0 ))
22 neanior 3021 . . . . . . . . . 10 ((𝑥0𝑦0 ) ↔ ¬ (𝑥 = 0𝑦 = 0 ))
23 df-ne 2929 . . . . . . . . . 10 ((𝑥(.r𝑅)𝑦) ≠ 0 ↔ ¬ (𝑥(.r𝑅)𝑦) = 0 )
2422, 23imbi12i 350 . . . . . . . . 9 (((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ≠ 0 ) ↔ (¬ (𝑥 = 0𝑦 = 0 ) → ¬ (𝑥(.r𝑅)𝑦) = 0 ))
2521, 24bitr4i 278 . . . . . . . 8 (((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )) ↔ ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ≠ 0 ))
26252ralbii 3107 . . . . . . 7 (∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )) ↔ ∀𝑥𝐵𝑦𝐵 ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ≠ 0 ))
27 impexp 450 . . . . . . . . . 10 ((((𝑥𝐵𝑦𝐵) ∧ (𝑥0𝑦0 )) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })) ↔ ((𝑥𝐵𝑦𝐵) → ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
28 an4 656 . . . . . . . . . . . 12 (((𝑥𝐵𝑦𝐵) ∧ (𝑥0𝑦0 )) ↔ ((𝑥𝐵𝑥0 ) ∧ (𝑦𝐵𝑦0 )))
29 eldifsn 4735 . . . . . . . . . . . . 13 (𝑥 ∈ (𝐵 ∖ { 0 }) ↔ (𝑥𝐵𝑥0 ))
30 eldifsn 4735 . . . . . . . . . . . . 13 (𝑦 ∈ (𝐵 ∖ { 0 }) ↔ (𝑦𝐵𝑦0 ))
3129, 30anbi12i 628 . . . . . . . . . . . 12 ((𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })) ↔ ((𝑥𝐵𝑥0 ) ∧ (𝑦𝐵𝑦0 )))
3228, 31bitr4i 278 . . . . . . . . . . 11 (((𝑥𝐵𝑦𝐵) ∧ (𝑥0𝑦0 )) ↔ (𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })))
3332imbi1i 349 . . . . . . . . . 10 ((((𝑥𝐵𝑦𝐵) ∧ (𝑥0𝑦0 )) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })) ↔ ((𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
3427, 33bitr3i 277 . . . . . . . . 9 (((𝑥𝐵𝑦𝐵) → ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))) ↔ ((𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
35342albii 1821 . . . . . . . 8 (∀𝑥𝑦((𝑥𝐵𝑦𝐵) → ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))) ↔ ∀𝑥𝑦((𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
36 r2al 3168 . . . . . . . 8 (∀𝑥𝐵𝑦𝐵 ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })) ↔ ∀𝑥𝑦((𝑥𝐵𝑦𝐵) → ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
37 r2al 3168 . . . . . . . 8 (∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }) ↔ ∀𝑥𝑦((𝑥 ∈ (𝐵 ∖ { 0 }) ∧ 𝑦 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
3835, 36, 373bitr4ri 304 . . . . . . 7 (∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }) ↔ ∀𝑥𝐵𝑦𝐵 ((𝑥0𝑦0 ) → (𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
3920, 26, 383bitr4g 314 . . . . . 6 (𝑅 ∈ Ring → (∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )) ↔ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))
4013, 39anbi12d 632 . . . . 5 (𝑅 ∈ Ring → (((1r𝑅) ≠ 0 ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
41 isdomn3.u . . . . . . 7 𝑈 = (mulGrp‘𝑅)
4241ringmgp 20157 . . . . . 6 (𝑅 ∈ Ring → 𝑈 ∈ Mnd)
4341, 1mgpbas 20063 . . . . . . . . 9 𝐵 = (Base‘𝑈)
4441, 5ringidval 20101 . . . . . . . . 9 (1r𝑅) = (0g𝑈)
4541, 2mgpplusg 20062 . . . . . . . . 9 (.r𝑅) = (+g𝑈)
4643, 44, 45issubm 18711 . . . . . . . 8 (𝑈 ∈ Mnd → ((𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈) ↔ ((𝐵 ∖ { 0 }) ⊆ 𝐵 ∧ (1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
47 3anass 1094 . . . . . . . 8 (((𝐵 ∖ { 0 }) ⊆ 𝐵 ∧ (1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })) ↔ ((𝐵 ∖ { 0 }) ⊆ 𝐵 ∧ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
4846, 47bitrdi 287 . . . . . . 7 (𝑈 ∈ Mnd → ((𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈) ↔ ((𝐵 ∖ { 0 }) ⊆ 𝐵 ∧ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })))))
49 difss 4083 . . . . . . . 8 (𝐵 ∖ { 0 }) ⊆ 𝐵
5049biantrur 530 . . . . . . 7 (((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 })) ↔ ((𝐵 ∖ { 0 }) ⊆ 𝐵 ∧ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
5148, 50bitr4di 289 . . . . . 6 (𝑈 ∈ Mnd → ((𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈) ↔ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
5242, 51syl 17 . . . . 5 (𝑅 ∈ Ring → ((𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈) ↔ ((1r𝑅) ∈ (𝐵 ∖ { 0 }) ∧ ∀𝑥 ∈ (𝐵 ∖ { 0 })∀𝑦 ∈ (𝐵 ∖ { 0 })(𝑥(.r𝑅)𝑦) ∈ (𝐵 ∖ { 0 }))))
5340, 52bitr4d 282 . . . 4 (𝑅 ∈ Ring → (((1r𝑅) ≠ 0 ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ (𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈)))
5453pm5.32i 574 . . 3 ((𝑅 ∈ Ring ∧ ((1r𝑅) ≠ 0 ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 )))) ↔ (𝑅 ∈ Ring ∧ (𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈)))
559, 54bitri 275 . 2 ((𝑅 ∈ NzRing ∧ ∀𝑥𝐵𝑦𝐵 ((𝑥(.r𝑅)𝑦) = 0 → (𝑥 = 0𝑦 = 0 ))) ↔ (𝑅 ∈ Ring ∧ (𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈)))
564, 55bitri 275 1 (𝑅 ∈ Domn ↔ (𝑅 ∈ Ring ∧ (𝐵 ∖ { 0 }) ∈ (SubMnd‘𝑈)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  wo 847  w3a 1086  wal 1539   = wceq 1541  wcel 2111  wne 2928  wral 3047  cdif 3894  wss 3897  {csn 4573  cfv 6481  (class class class)co 7346  Basecbs 17120  .rcmulr 17162  0gc0g 17343  Mndcmnd 18642  SubMndcsubmnd 18690  mulGrpcmgp 20058  1rcur 20099  Ringcrg 20151  NzRingcnzr 20427  Domncdomn 20607
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 1968  ax-7 2009  ax-8 2113  ax-9 2121  ax-10 2144  ax-11 2160  ax-12 2180  ax-ext 2703  ax-sep 5232  ax-nul 5242  ax-pow 5301  ax-pr 5368  ax-un 7668  ax-cnex 11062  ax-resscn 11063  ax-1cn 11064  ax-icn 11065  ax-addcl 11066  ax-addrcl 11067  ax-mulcl 11068  ax-mulrcl 11069  ax-mulcom 11070  ax-addass 11071  ax-mulass 11072  ax-distr 11073  ax-i2m1 11074  ax-1ne0 11075  ax-1rid 11076  ax-rnegex 11077  ax-rrecex 11078  ax-cnre 11079  ax-pre-lttri 11080  ax-pre-lttrn 11081  ax-pre-ltadd 11082  ax-pre-mulgt0 11083
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2535  df-eu 2564  df-clab 2710  df-cleq 2723  df-clel 2806  df-nfc 2881  df-ne 2929  df-nel 3033  df-ral 3048  df-rex 3057  df-rmo 3346  df-reu 3347  df-rab 3396  df-v 3438  df-sbc 3737  df-csb 3846  df-dif 3900  df-un 3902  df-in 3904  df-ss 3914  df-pss 3917  df-nul 4281  df-if 4473  df-pw 4549  df-sn 4574  df-pr 4576  df-op 4580  df-uni 4857  df-iun 4941  df-br 5090  df-opab 5152  df-mpt 5171  df-tr 5197  df-id 5509  df-eprel 5514  df-po 5522  df-so 5523  df-fr 5567  df-we 5569  df-xp 5620  df-rel 5621  df-cnv 5622  df-co 5623  df-dm 5624  df-rn 5625  df-res 5626  df-ima 5627  df-pred 6248  df-ord 6309  df-on 6310  df-lim 6311  df-suc 6312  df-iota 6437  df-fun 6483  df-fn 6484  df-f 6485  df-f1 6486  df-fo 6487  df-f1o 6488  df-fv 6489  df-riota 7303  df-ov 7349  df-oprab 7350  df-mpo 7351  df-om 7797  df-2nd 7922  df-frecs 8211  df-wrecs 8242  df-recs 8291  df-rdg 8329  df-er 8622  df-en 8870  df-dom 8871  df-sdom 8872  df-pnf 11148  df-mnf 11149  df-xr 11150  df-ltxr 11151  df-le 11152  df-sub 11346  df-neg 11347  df-nn 12126  df-2 12188  df-sets 17075  df-slot 17093  df-ndx 17105  df-base 17121  df-plusg 17174  df-0g 17345  df-mgm 18548  df-sgrp 18627  df-mnd 18643  df-submnd 18692  df-mgp 20059  df-ur 20100  df-ring 20153  df-nzr 20428  df-domn 20610
This theorem is referenced by:  fracfld  33274  zringfrac  33519  deg1mhm  43241
  Copyright terms: Public domain W3C validator