The lattice of invariant submodules #
In this file we defined the type Module.End.invtSubmodule
, associated to a linear endomorphism of
a module. Its utility stems primarily from those occasions on which we wish to take advantage of the
lattice structure of invariant submodules.
See also Mathlib.Algebra.Polynomial.Module.AEval
.
def
Module.End.invtSubmodule
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
:
Sublattice (Submodule R M)
Given an endomorphism, f
of some module, this is the sublattice of all f
-invariant
submodules.
Equations
- f.invtSubmodule = { carrier := {p : Submodule R M | p ≤ Submodule.comap f p}, supClosed' := ⋯, infClosed' := ⋯ }
Instances For
theorem
Module.End.mem_invtSubmodule
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
{p : Submodule R M}
:
p ∈ f.invtSubmodule ↔ p ≤ Submodule.comap f p
@[simp]
theorem
Module.End.invtSubmodule.top_mem
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
:
@[simp]
theorem
Module.End.invtSubmodule.bot_mem
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
:
instance
Module.End.invtSubmodule.instBoundedOrderSubtypeSubmoduleMemSublattice
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
:
BoundedOrder ↥f.invtSubmodule
@[simp]
theorem
Module.End.invtSubmodule.zero
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
:
invtSubmodule 0 = ⊤
@[simp]
theorem
Module.End.invtSubmodule.id
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
:
@[simp]
theorem
Module.End.invtSubmodule.codisjoint_mk_iff
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
{p q : Submodule R M}
(hp : p ∈ f.invtSubmodule)
(hq : q ∈ f.invtSubmodule)
:
Codisjoint ⟨p, hp⟩ ⟨q, hq⟩ ↔ Codisjoint p q
theorem
Module.End.invtSubmodule.codisjoint_iff
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
{p q : ↥f.invtSubmodule}
:
Codisjoint p q ↔ Codisjoint ↑p ↑q
theorem
Module.End.invtSubmodule.map_subtype_mem_of_mem_invtSubmodule
{R : Type u_1}
{M : Type u_2}
[Semiring R]
[AddCommMonoid M]
[Module R M]
(f : End R M)
{p : Submodule R M}
(hp : p ∈ f.invtSubmodule)
{q : Submodule R ↥p}
(hq : q ∈ invtSubmodule (LinearMap.restrict f hp))
:
Submodule.map p.subtype q ∈ f.invtSubmodule