Adjoining a zero to a group #
This file proves that one can adjoin a new zero element to a group and get a group with zero.
Main definitions #
WithZero.map'
: theMonoidWithZero
homomorphismWithZero α →* WithZero β
induced by a monoid homomorphismf : α →* β
.
Equations
- WithZero.one = { one := ↑One.one }
Equations
theorem
WithZero.unzero_mul
{α : Type u_1}
[Mul α]
{x y : WithZero α}
(hxy : x * y ≠ 0)
:
WithZero.unzero hxy = WithZero.unzero ⋯ * WithZero.unzero ⋯
Equations
Equations
Equations
Coercion as a monoid hom.
Equations
- WithZero.coeMonoidHom = { toFun := WithZero.coe, map_one' := ⋯, map_mul' := ⋯ }
Instances For
@[simp]
theorem
WithZero.coeMonoidHom_apply
{α : Type u_1}
[MulOneClass α]
(a✝ : α)
:
WithZero.coeMonoidHom a✝ = ↑a✝
theorem
WithZero.monoidWithZeroHom_ext
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
⦃f g : WithZero α →*₀ β⦄
(h : (↑f).comp WithZero.coeMonoidHom = (↑g).comp WithZero.coeMonoidHom)
:
f = g
noncomputable def
WithZero.lift'
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
:
The (multiplicative) universal property of WithZero
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
WithZero.lift'_symm_apply_apply
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
(F : WithZero α →*₀ β)
(a✝ : α)
:
(WithZero.lift'.symm F) a✝ = F ↑a✝
theorem
WithZero.lift'_zero
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
(f : α →* β)
:
(WithZero.lift' f) 0 = 0
@[simp]
theorem
WithZero.lift'_coe
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
(f : α →* β)
(x : α)
:
(WithZero.lift' f) ↑x = f x
theorem
WithZero.lift'_unique
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulZeroOneClass β]
(f : WithZero α →*₀ β)
:
f = WithZero.lift' ((↑f).comp WithZero.coeMonoidHom)
noncomputable def
WithZero.map'
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulOneClass β]
(f : α →* β)
:
The MonoidWithZero
homomorphism WithZero α →* WithZero β
induced by a monoid homomorphism
f : α →* β
.
Equations
- WithZero.map' f = WithZero.lift' (WithZero.coeMonoidHom.comp f)
Instances For
theorem
WithZero.map'_zero
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulOneClass β]
(f : α →* β)
:
(WithZero.map' f) 0 = 0
@[simp]
theorem
WithZero.map'_coe
{α : Type u_1}
{β : Type u_2}
[MulOneClass α]
[MulOneClass β]
(f : α →* β)
(x : α)
:
(WithZero.map' f) ↑x = ↑(f x)
@[simp]
theorem
WithZero.map'_id
{β : Type u_2}
[MulOneClass β]
:
↑(WithZero.map' (MonoidHom.id β)) = MonoidHom.id (WithZero β)
theorem
WithZero.map'_map'
{α : Type u_1}
{β : Type u_2}
{γ : Type u_3}
[MulOneClass α]
[MulOneClass β]
[MulOneClass γ]
(f : α →* β)
(g : β →* γ)
(x : WithZero α)
:
(WithZero.map' g) ((WithZero.map' f) x) = (WithZero.map' (g.comp f)) x
@[simp]
theorem
WithZero.map'_comp
{α : Type u_1}
{β : Type u_2}
{γ : Type u_3}
[MulOneClass α]
[MulOneClass β]
[MulOneClass γ]
(f : α →* β)
(g : β →* γ)
:
WithZero.map' (g.comp f) = (WithZero.map' g).comp (WithZero.map' f)
Equations
Equations
Extend the inverse operation on α
to WithZero α
by sending 0
to 0
.
Equations
- WithZero.inv = { inv := fun (a : WithZero α) => Option.map (fun (x : α) => x⁻¹) a }
Equations
Equations
- WithZero.div = { div := Option.map₂ fun (x1 x2 : α) => x1 / x2 }
Equations
- WithZero.divInvMonoid = DivInvMonoid.mk ⋯ (fun (n : ℤ) (a : WithZero α) => a ^ n) ⋯ ⋯ ⋯
Equations
Equations
Equations
Equations
If α
is a group then WithZero α
is a group with zero.
Equations
- WithZero.groupWithZero = GroupWithZero.mk ⋯ DivInvMonoid.zpow ⋯ ⋯ ⋯ ⋯ ⋯
Any group is isomorphic to the units of itself adjoined with 0
.
Equations
- WithZero.unitsWithZeroEquiv = { toFun := fun (a : (WithZero α)ˣ) => WithZero.unzero ⋯, invFun := fun (a : α) => Units.mk0 ↑a ⋯, left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }
Instances For
def
WithZero.withZeroUnitsEquiv
{G : Type u_4}
[GroupWithZero G]
[DecidablePred fun (a : G) => a = 0]
:
Any group with zero is isomorphic to adjoining 0
to the units of itself.
Equations
- One or more equations did not get rendered due to their size.
Instances For
noncomputable def
MulEquiv.withZero
{α : Type u_1}
{β : Type u_2}
[Group α]
[Group β]
(e : α ≃* β)
:
A version of Equiv.optionCongr
for WithZero
.
Equations
- e.withZero = { toFun := ⇑(WithZero.map' e.toMonoidHom), invFun := ⇑(WithZero.map' e.symm.toMonoidHom), left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }
Instances For
noncomputable def
MulEquiv.unzero
{α : Type u_1}
{β : Type u_2}
[Group α]
[Group β]
(e : WithZero α ≃* WithZero β)
:
α ≃* β
The inverse of MulEquiv.withZero
.
Equations
- e.unzero = { toFun := fun (x : α) => WithZero.unzero ⋯, invFun := fun (x : β) => WithZero.unzero ⋯, left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }