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

Theorem isdrng2 20711
Description: A division ring can equivalently be defined as a ring such that the nonzero elements form a group under multiplication (from which it follows that this is the same group as the group of units). (Contributed by Mario Carneiro, 2-Dec-2014.)
Hypotheses
Ref Expression
isdrng2.b 𝐵 = (Base‘𝑅)
isdrng2.z 0 = (0g𝑅)
isdrng2.g 𝐺 = ((mulGrp‘𝑅) ↾s (𝐵 ∖ { 0 }))
Assertion
Ref Expression
isdrng2 (𝑅 ∈ DivRing ↔ (𝑅 ∈ Ring ∧ 𝐺 ∈ Grp))

Proof of Theorem isdrng2
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 isdrng2.b . . 3 𝐵 = (Base‘𝑅)
2 eqid 2737 . . 3 (Unit‘𝑅) = (Unit‘𝑅)
3 isdrng2.z . . 3 0 = (0g𝑅)
41, 2, 3isdrng 20701 . 2 (𝑅 ∈ DivRing ↔ (𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })))
5 oveq2 7368 . . . . . . 7 ((Unit‘𝑅) = (𝐵 ∖ { 0 }) → ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) = ((mulGrp‘𝑅) ↾s (𝐵 ∖ { 0 })))
65adantl 481 . . . . . 6 ((𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })) → ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) = ((mulGrp‘𝑅) ↾s (𝐵 ∖ { 0 })))
7 isdrng2.g . . . . . 6 𝐺 = ((mulGrp‘𝑅) ↾s (𝐵 ∖ { 0 }))
86, 7eqtr4di 2790 . . . . 5 ((𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })) → ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) = 𝐺)
9 eqid 2737 . . . . . . 7 ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) = ((mulGrp‘𝑅) ↾s (Unit‘𝑅))
102, 9unitgrp 20354 . . . . . 6 (𝑅 ∈ Ring → ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) ∈ Grp)
1110adantr 480 . . . . 5 ((𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })) → ((mulGrp‘𝑅) ↾s (Unit‘𝑅)) ∈ Grp)
128, 11eqeltrrd 2838 . . . 4 ((𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })) → 𝐺 ∈ Grp)
131, 2unitcl 20346 . . . . . . . . 9 (𝑥 ∈ (Unit‘𝑅) → 𝑥𝐵)
1413adantl 481 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → 𝑥𝐵)
15 difss 4077 . . . . . . . . . . . . . . 15 (𝐵 ∖ { 0 }) ⊆ 𝐵
16 eqid 2737 . . . . . . . . . . . . . . . . 17 (mulGrp‘𝑅) = (mulGrp‘𝑅)
1716, 1mgpbas 20117 . . . . . . . . . . . . . . . 16 𝐵 = (Base‘(mulGrp‘𝑅))
187, 17ressbas2 17199 . . . . . . . . . . . . . . 15 ((𝐵 ∖ { 0 }) ⊆ 𝐵 → (𝐵 ∖ { 0 }) = (Base‘𝐺))
1915, 18ax-mp 5 . . . . . . . . . . . . . 14 (𝐵 ∖ { 0 }) = (Base‘𝐺)
20 eqid 2737 . . . . . . . . . . . . . 14 (0g𝐺) = (0g𝐺)
2119, 20grpidcl 18932 . . . . . . . . . . . . 13 (𝐺 ∈ Grp → (0g𝐺) ∈ (𝐵 ∖ { 0 }))
2221ad2antlr 728 . . . . . . . . . . . 12 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (0g𝐺) ∈ (𝐵 ∖ { 0 }))
23 eldifsn 4730 . . . . . . . . . . . 12 ((0g𝐺) ∈ (𝐵 ∖ { 0 }) ↔ ((0g𝐺) ∈ 𝐵 ∧ (0g𝐺) ≠ 0 ))
2422, 23sylib 218 . . . . . . . . . . 11 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → ((0g𝐺) ∈ 𝐵 ∧ (0g𝐺) ≠ 0 ))
2524simprd 495 . . . . . . . . . 10 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (0g𝐺) ≠ 0 )
26 simpll 767 . . . . . . . . . . 11 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → 𝑅 ∈ Ring)
2722eldifad 3902 . . . . . . . . . . 11 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (0g𝐺) ∈ 𝐵)
28 simpr 484 . . . . . . . . . . 11 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → 𝑥 ∈ (Unit‘𝑅))
29 eqid 2737 . . . . . . . . . . . 12 (/r𝑅) = (/r𝑅)
30 eqid 2737 . . . . . . . . . . . 12 (.r𝑅) = (.r𝑅)
311, 2, 29, 30dvrcan1 20380 . . . . . . . . . . 11 ((𝑅 ∈ Ring ∧ (0g𝐺) ∈ 𝐵𝑥 ∈ (Unit‘𝑅)) → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅)𝑥) = (0g𝐺))
3226, 27, 28, 31syl3anc 1374 . . . . . . . . . 10 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅)𝑥) = (0g𝐺))
331, 2, 29dvrcl 20375 . . . . . . . . . . . 12 ((𝑅 ∈ Ring ∧ (0g𝐺) ∈ 𝐵𝑥 ∈ (Unit‘𝑅)) → ((0g𝐺)(/r𝑅)𝑥) ∈ 𝐵)
3426, 27, 28, 33syl3anc 1374 . . . . . . . . . . 11 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → ((0g𝐺)(/r𝑅)𝑥) ∈ 𝐵)
351, 30, 3ringrz 20266 . . . . . . . . . . 11 ((𝑅 ∈ Ring ∧ ((0g𝐺)(/r𝑅)𝑥) ∈ 𝐵) → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅) 0 ) = 0 )
3626, 34, 35syl2anc 585 . . . . . . . . . 10 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅) 0 ) = 0 )
3725, 32, 363netr4d 3010 . . . . . . . . 9 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅)𝑥) ≠ (((0g𝐺)(/r𝑅)𝑥)(.r𝑅) 0 ))
38 oveq2 7368 . . . . . . . . . 10 (𝑥 = 0 → (((0g𝐺)(/r𝑅)𝑥)(.r𝑅)𝑥) = (((0g𝐺)(/r𝑅)𝑥)(.r𝑅) 0 ))
3938necon3i 2965 . . . . . . . . 9 ((((0g𝐺)(/r𝑅)𝑥)(.r𝑅)𝑥) ≠ (((0g𝐺)(/r𝑅)𝑥)(.r𝑅) 0 ) → 𝑥0 )
4037, 39syl 17 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → 𝑥0 )
41 eldifsn 4730 . . . . . . . 8 (𝑥 ∈ (𝐵 ∖ { 0 }) ↔ (𝑥𝐵𝑥0 ))
4214, 40, 41sylanbrc 584 . . . . . . 7 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (Unit‘𝑅)) → 𝑥 ∈ (𝐵 ∖ { 0 }))
4342ex 412 . . . . . 6 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (𝑥 ∈ (Unit‘𝑅) → 𝑥 ∈ (𝐵 ∖ { 0 })))
4443ssrdv 3928 . . . . 5 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (Unit‘𝑅) ⊆ (𝐵 ∖ { 0 }))
45 eldifi 4072 . . . . . . . . 9 (𝑥 ∈ (𝐵 ∖ { 0 }) → 𝑥𝐵)
4645adantl 481 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥𝐵)
47 eqid 2737 . . . . . . . . . . 11 (invg𝐺) = (invg𝐺)
4819, 47grpinvcl 18954 . . . . . . . . . 10 ((𝐺 ∈ Grp ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → ((invg𝐺)‘𝑥) ∈ (𝐵 ∖ { 0 }))
4948adantll 715 . . . . . . . . 9 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → ((invg𝐺)‘𝑥) ∈ (𝐵 ∖ { 0 }))
5049eldifad 3902 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → ((invg𝐺)‘𝑥) ∈ 𝐵)
51 eqid 2737 . . . . . . . . 9 (∥r𝑅) = (∥r𝑅)
521, 51, 30dvdsrmul 20335 . . . . . . . 8 ((𝑥𝐵 ∧ ((invg𝐺)‘𝑥) ∈ 𝐵) → 𝑥(∥r𝑅)(((invg𝐺)‘𝑥)(.r𝑅)𝑥))
5346, 50, 52syl2anc 585 . . . . . . 7 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥(∥r𝑅)(((invg𝐺)‘𝑥)(.r𝑅)𝑥))
541fvexi 6848 . . . . . . . . . . 11 𝐵 ∈ V
55 difexg 5266 . . . . . . . . . . 11 (𝐵 ∈ V → (𝐵 ∖ { 0 }) ∈ V)
5616, 30mgpplusg 20116 . . . . . . . . . . . 12 (.r𝑅) = (+g‘(mulGrp‘𝑅))
577, 56ressplusg 17245 . . . . . . . . . . 11 ((𝐵 ∖ { 0 }) ∈ V → (.r𝑅) = (+g𝐺))
5854, 55, 57mp2b 10 . . . . . . . . . 10 (.r𝑅) = (+g𝐺)
5919, 58, 20, 47grplinv 18956 . . . . . . . . 9 ((𝐺 ∈ Grp ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (((invg𝐺)‘𝑥)(.r𝑅)𝑥) = (0g𝐺))
6059adantll 715 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (((invg𝐺)‘𝑥)(.r𝑅)𝑥) = (0g𝐺))
61 eqid 2737 . . . . . . . . . . . . 13 (1r𝑅) = (1r𝑅)
621, 61ringidcl 20237 . . . . . . . . . . . 12 (𝑅 ∈ Ring → (1r𝑅) ∈ 𝐵)
631, 30, 61ringlidm 20241 . . . . . . . . . . . 12 ((𝑅 ∈ Ring ∧ (1r𝑅) ∈ 𝐵) → ((1r𝑅)(.r𝑅)(1r𝑅)) = (1r𝑅))
6462, 63mpdan 688 . . . . . . . . . . 11 (𝑅 ∈ Ring → ((1r𝑅)(.r𝑅)(1r𝑅)) = (1r𝑅))
6564adantr 480 . . . . . . . . . 10 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → ((1r𝑅)(.r𝑅)(1r𝑅)) = (1r𝑅))
66 simpr 484 . . . . . . . . . . 11 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → 𝐺 ∈ Grp)
672, 611unit 20345 . . . . . . . . . . . . 13 (𝑅 ∈ Ring → (1r𝑅) ∈ (Unit‘𝑅))
6867adantr 480 . . . . . . . . . . . 12 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (1r𝑅) ∈ (Unit‘𝑅))
6944, 68sseldd 3923 . . . . . . . . . . 11 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (1r𝑅) ∈ (𝐵 ∖ { 0 }))
7019, 58, 20grpid 18942 . . . . . . . . . . 11 ((𝐺 ∈ Grp ∧ (1r𝑅) ∈ (𝐵 ∖ { 0 })) → (((1r𝑅)(.r𝑅)(1r𝑅)) = (1r𝑅) ↔ (0g𝐺) = (1r𝑅)))
7166, 69, 70syl2anc 585 . . . . . . . . . 10 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (((1r𝑅)(.r𝑅)(1r𝑅)) = (1r𝑅) ↔ (0g𝐺) = (1r𝑅)))
7265, 71mpbid 232 . . . . . . . . 9 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (0g𝐺) = (1r𝑅))
7372adantr 480 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (0g𝐺) = (1r𝑅))
7460, 73eqtrd 2772 . . . . . . 7 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (((invg𝐺)‘𝑥)(.r𝑅)𝑥) = (1r𝑅))
7553, 74breqtrd 5112 . . . . . 6 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥(∥r𝑅)(1r𝑅))
76 eqid 2737 . . . . . . . . . 10 (oppr𝑅) = (oppr𝑅)
7776, 1opprbas 20314 . . . . . . . . 9 𝐵 = (Base‘(oppr𝑅))
78 eqid 2737 . . . . . . . . 9 (∥r‘(oppr𝑅)) = (∥r‘(oppr𝑅))
79 eqid 2737 . . . . . . . . 9 (.r‘(oppr𝑅)) = (.r‘(oppr𝑅))
8077, 78, 79dvdsrmul 20335 . . . . . . . 8 ((𝑥𝐵 ∧ ((invg𝐺)‘𝑥) ∈ 𝐵) → 𝑥(∥r‘(oppr𝑅))(((invg𝐺)‘𝑥)(.r‘(oppr𝑅))𝑥))
8146, 50, 80syl2anc 585 . . . . . . 7 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥(∥r‘(oppr𝑅))(((invg𝐺)‘𝑥)(.r‘(oppr𝑅))𝑥))
821, 30, 76, 79opprmul 20311 . . . . . . . 8 (((invg𝐺)‘𝑥)(.r‘(oppr𝑅))𝑥) = (𝑥(.r𝑅)((invg𝐺)‘𝑥))
8319, 58, 20, 47grprinv 18957 . . . . . . . . . 10 ((𝐺 ∈ Grp ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)((invg𝐺)‘𝑥)) = (0g𝐺))
8483adantll 715 . . . . . . . . 9 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)((invg𝐺)‘𝑥)) = (0g𝐺))
8584, 73eqtrd 2772 . . . . . . . 8 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (𝑥(.r𝑅)((invg𝐺)‘𝑥)) = (1r𝑅))
8682, 85eqtrid 2784 . . . . . . 7 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → (((invg𝐺)‘𝑥)(.r‘(oppr𝑅))𝑥) = (1r𝑅))
8781, 86breqtrd 5112 . . . . . 6 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥(∥r‘(oppr𝑅))(1r𝑅))
882, 61, 51, 76, 78isunit 20344 . . . . . 6 (𝑥 ∈ (Unit‘𝑅) ↔ (𝑥(∥r𝑅)(1r𝑅) ∧ 𝑥(∥r‘(oppr𝑅))(1r𝑅)))
8975, 87, 88sylanbrc 584 . . . . 5 (((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) ∧ 𝑥 ∈ (𝐵 ∖ { 0 })) → 𝑥 ∈ (Unit‘𝑅))
9044, 89eqelssd 3944 . . . 4 ((𝑅 ∈ Ring ∧ 𝐺 ∈ Grp) → (Unit‘𝑅) = (𝐵 ∖ { 0 }))
9112, 90impbida 801 . . 3 (𝑅 ∈ Ring → ((Unit‘𝑅) = (𝐵 ∖ { 0 }) ↔ 𝐺 ∈ Grp))
9291pm5.32i 574 . 2 ((𝑅 ∈ Ring ∧ (Unit‘𝑅) = (𝐵 ∖ { 0 })) ↔ (𝑅 ∈ Ring ∧ 𝐺 ∈ Grp))
934, 92bitri 275 1 (𝑅 ∈ DivRing ↔ (𝑅 ∈ Ring ∧ 𝐺 ∈ Grp))
Colors of variables: wff setvar class
Syntax hints:  wb 206  wa 395   = wceq 1542  wcel 2114  wne 2933  Vcvv 3430  cdif 3887  wss 3890  {csn 4568   class class class wbr 5086  cfv 6492  (class class class)co 7360  Basecbs 17170  s cress 17191  +gcplusg 17211  .rcmulr 17212  0gc0g 17393  Grpcgrp 18900  invgcminusg 18901  mulGrpcmgp 20112  1rcur 20153  Ringcrg 20205  opprcoppr 20307  rcdsr 20325  Unitcui 20326  /rcdvr 20371  DivRingcdr 20697
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 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-rep 5212  ax-sep 5231  ax-nul 5241  ax-pow 5302  ax-pr 5370  ax-un 7682  ax-cnex 11085  ax-resscn 11086  ax-1cn 11087  ax-icn 11088  ax-addcl 11089  ax-addrcl 11090  ax-mulcl 11091  ax-mulrcl 11092  ax-mulcom 11093  ax-addass 11094  ax-mulass 11095  ax-distr 11096  ax-i2m1 11097  ax-1ne0 11098  ax-1rid 11099  ax-rnegex 11100  ax-rrecex 11101  ax-cnre 11102  ax-pre-lttri 11103  ax-pre-lttrn 11104  ax-pre-ltadd 11105  ax-pre-mulgt0 11106
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3063  df-rmo 3343  df-reu 3344  df-rab 3391  df-v 3432  df-sbc 3730  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-pss 3910  df-nul 4275  df-if 4468  df-pw 4544  df-sn 4569  df-pr 4571  df-op 4575  df-uni 4852  df-iun 4936  df-br 5087  df-opab 5149  df-mpt 5168  df-tr 5194  df-id 5519  df-eprel 5524  df-po 5532  df-so 5533  df-fr 5577  df-we 5579  df-xp 5630  df-rel 5631  df-cnv 5632  df-co 5633  df-dm 5634  df-rn 5635  df-res 5636  df-ima 5637  df-pred 6259  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-f1o 6499  df-fv 6500  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-1st 7935  df-2nd 7936  df-tpos 8169  df-frecs 8224  df-wrecs 8255  df-recs 8304  df-rdg 8342  df-er 8636  df-en 8887  df-dom 8888  df-sdom 8889  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-nn 12166  df-2 12235  df-3 12236  df-sets 17125  df-slot 17143  df-ndx 17155  df-base 17171  df-ress 17192  df-plusg 17224  df-mulr 17225  df-0g 17395  df-mgm 18599  df-sgrp 18678  df-mnd 18694  df-grp 18903  df-minusg 18904  df-cmn 19748  df-abl 19749  df-mgp 20113  df-rng 20125  df-ur 20154  df-ring 20207  df-oppr 20308  df-dvdsr 20328  df-unit 20329  df-invr 20359  df-dvr 20372  df-drng 20699
This theorem is referenced by:  drngmgp  20713  isdrngd  20733  isdrngdOLD  20735  subdrgint  20771
  Copyright terms: Public domain W3C validator