scilib documentation

ring_theory.noetherian

Noetherian rings and modules #

THIS FILE IS SYNCHRONIZED WITH MATHLIB4. Any changes to this file require a corresponding PR to mathlib4.

The following are equivalent for a module M over a ring R:

  1. Every increasing chain of submodules M₁ ⊆ M₂ ⊆ M₃ ⊆ ⋯ eventually stabilises.
  2. Every submodule is finitely generated.

A module satisfying these equivalent conditions is said to be a Noetherian R-module. A ring is a Noetherian ring if it is Noetherian as a module over itself.

(Note that we do not assume yet that our rings are commutative, so perhaps this should be called "left Noetherian". To avoid cumbersome names once we specialize to the commutative case, we don't make this explicit in the declaration names.)

Main definitions #

Let R be a ring and let M and P be R-modules. Let N be an R-submodule of M.

Main statements #

Note that the Hilbert basis theorem, that if a commutative ring R is Noetherian then so is R[X], is proved in ring_theory.polynomial.

References #

Tags #

Noetherian, noetherian, Noetherian ring, Noetherian module, noetherian ring, noetherian module

@[class]
structure is_noetherian (R : Type u_1) (M : Type u_2) [semiring R] [add_comm_monoid M] [module R M] :
Prop

is_noetherian R M is the proposition that M is a Noetherian R-module, implemented as the predicate that all R-submodules of M are finitely generated.

Instances of this typeclass
theorem is_noetherian_def {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
is_noetherian R M (s : submodule R M), s.fg

An R-module is Noetherian iff all its submodules are finitely-generated.

theorem is_noetherian_submodule {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] {N : submodule R M} :
is_noetherian R N (s : submodule R M), s N s.fg
theorem is_noetherian_submodule_left {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] {N : submodule R M} :
is_noetherian R N (s : submodule R M), (N s).fg
theorem is_noetherian_submodule_right {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] {N : submodule R M} :
is_noetherian R N (s : submodule R M), (s N).fg
@[protected, instance]
def is_noetherian_submodule' {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] [is_noetherian R M] (N : submodule R M) :
theorem is_noetherian_of_le {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] {s t : submodule R M} [ht : is_noetherian R t] (h : s t) :
theorem is_noetherian_of_surjective {R : Type u_1} (M : Type u_2) {P : Type u_3} [semiring R] [add_comm_monoid M] [add_comm_monoid P] [module R M] [module R P] (f : M →ₗ[R] P) (hf : linear_map.range f = ) [is_noetherian R M] :
theorem is_noetherian_of_linear_equiv {R : Type u_1} {M : Type u_2} {P : Type u_3} [semiring R] [add_comm_monoid M] [add_comm_monoid P] [module R M] [module R P] (f : M ≃ₗ[R] P) [is_noetherian R M] :
theorem is_noetherian_top_iff {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
theorem is_noetherian_of_injective {R : Type u_1} {M : Type u_2} {P : Type u_3} [semiring R] [add_comm_monoid M] [add_comm_monoid P] [module R M] [module R P] [is_noetherian R P] (f : M →ₗ[R] P) (hf : function.injective f) :
theorem fg_of_injective {R : Type u_1} {M : Type u_2} {P : Type u_3} [semiring R] [add_comm_monoid M] [add_comm_monoid P] [module R M] [module R P] [is_noetherian R P] {N : submodule R M} (f : M →ₗ[R] P) (hf : function.injective f) :
N.fg
@[protected, instance]
def module.is_noetherian.finite (R : Type u_1) (M : Type u_2) [semiring R] [add_comm_monoid M] [module R M] [is_noetherian R M] :
theorem module.finite.of_injective {R : Type u_1} {M : Type u_2} {N : Type u_3} [semiring R] [add_comm_monoid M] [add_comm_monoid N] [module R M] [module R N] [is_noetherian R N] (f : M →ₗ[R] N) (hf : function.injective f) :
theorem is_noetherian_of_ker_bot {R : Type u_1} {M : Type u_2} {P : Type u_3} [ring R] [add_comm_group M] [add_comm_group P] [module R M] [module R P] [is_noetherian R P] (f : M →ₗ[R] P) (hf : linear_map.ker f = ) :
theorem fg_of_ker_bot {R : Type u_1} {M : Type u_2} {P : Type u_3} [ring R] [add_comm_group M] [add_comm_group P] [module R M] [module R P] [is_noetherian R P] {N : submodule R M} (f : M →ₗ[R] P) (hf : linear_map.ker f = ) :
N.fg
@[protected, instance]
def is_noetherian_prod {R : Type u_1} {M : Type u_2} {P : Type u_3} [ring R] [add_comm_group M] [add_comm_group P] [module R M] [module R P] [is_noetherian R M] [is_noetherian R P] :
@[protected, instance]
def is_noetherian_pi {R : Type u_1} {ι : Type u_2} {M : ι Type u_3} [ring R] [Π (i : ι), add_comm_group (M i)] [Π (i : ι), module R (M i)] [finite ι] [ (i : ι), is_noetherian R (M i)] :
is_noetherian R (Π (i : ι), M i)
@[protected, instance]
def is_noetherian_pi' {R : Type u_1} {ι : Type u_2} {M : Type u_3} [ring R] [add_comm_group M] [module R M] [finite ι] [is_noetherian R M] :
is_noetherian R M)

A version of is_noetherian_pi for non-dependent functions. We need this instance because sometimes Lean fails to apply the dependent version in non-dependent settings (e.g., it fails to prove that ι → ℝ is finite dimensional over ).

theorem is_noetherian_iff_well_founded {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
theorem is_noetherian_iff_fg_well_founded {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
theorem well_founded_submodule_gt (R : Type u_1) (M : Type u_2) [semiring R] [add_comm_monoid M] [module R M] [is_noetherian R M] :
theorem set_has_maximal_iff_noetherian {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
( (a : set (submodule R M)), a.nonempty ( (M' : submodule R M) (H : M' a), (I : submodule R M), I a ¬M' < I)) is_noetherian R M

A module is Noetherian iff every nonempty set of submodules has a maximal submodule among them.

theorem monotone_stabilizes_iff_noetherian {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] :
( (f : →o submodule R M), (n : ), (m : ), n m f n = f m) is_noetherian R M

A module is Noetherian iff every increasing chain of submodules stabilizes.

theorem is_noetherian.induction {R : Type u_1} {M : Type u_2} [semiring R] [add_comm_monoid M] [module R M] [is_noetherian R M] {P : submodule R M Prop} (hgt : (I : submodule R M), ( (J : submodule R M), J > I P J) P I) (I : submodule R M) :
P I

If ∀ I > J, P I implies P J, then P holds for all submodules.

theorem finite_of_linear_independent {R : Type u_1} {M : Type u_2} [ring R] [add_comm_group M] [module R M] [nontrivial R] [is_noetherian R M] {s : set M} (hs : linear_independent R coe) :
theorem is_noetherian_of_range_eq_ker {R : Type u_1} {M : Type u_2} {P : Type u_3} {N : Type w} [ring R] [add_comm_group M] [module R M] [add_comm_group N] [module R N] [add_comm_group P] [module R P] [is_noetherian R M] [is_noetherian R P] (f : M →ₗ[R] N) (g : N →ₗ[R] P) (hf : function.injective f) (hg : function.surjective g) (h : linear_map.range f = linear_map.ker g) :

If the first and final modules in a short exact sequence are noetherian, then the middle module is also noetherian.

theorem is_noetherian.exists_endomorphism_iterate_ker_inf_range_eq_bot {R : Type u_1} {M : Type u_2} [ring R] [add_comm_group M] [module R M] [I : is_noetherian R M] (f : M →ₗ[R] M) :

For any endomorphism of a Noetherian module, there is some nontrivial iterate with disjoint kernel and range.

Any surjective endomorphism of a Noetherian module is injective.

Any surjective endomorphism of a Noetherian module is bijective.

theorem is_noetherian.disjoint_partial_sups_eventually_bot {R : Type u_1} {M : Type u_2} [ring R] [add_comm_group M] [module R M] [I : is_noetherian R M] (f : submodule R M) (h : (n : ), disjoint ((partial_sups f) n) (f (n + 1))) :
(n : ), (m : ), n m f m =

A sequence f of submodules of a noetherian module, with f (n+1) disjoint from the supremum of f 0, ..., f n, is eventually zero.

noncomputable def is_noetherian.equiv_punit_of_prod_injective {R : Type u_1} {M : Type u_2} {N : Type w} [ring R] [add_comm_group M] [module R M] [add_comm_group N] [module R N] [is_noetherian R M] (f : M × N →ₗ[R] M) (i : function.injective f) :

If M ⊕ N embeds into M, for M noetherian over R, then N is trivial.

Equations
@[reducible]
def is_noetherian_ring (R : Type u_1) [semiring R] :
Prop

A (semi)ring is Noetherian if it is Noetherian as a module over itself, i.e. all its ideals are finitely generated.

Equations
theorem is_noetherian_ring_iff_ideal_fg (R : Type u_1) [semiring R] :
is_noetherian_ring R (I : ideal R), I.fg

A ring is Noetherian if and only if all its ideals are finitely-generated.

@[protected, instance]
def is_noetherian_of_finite (R : Type u_1) (M : Type u_2) [finite M] [semiring R] [add_comm_monoid M] [module R M] :
@[protected, instance]
def is_noetherian_of_subsingleton (R : Type u_1) (M : Type u_2) [subsingleton R] [semiring R] [add_comm_monoid M] [module R M] :

Modules over the trivial ring are Noetherian.

theorem is_noetherian_of_submodule_of_noetherian (R : Type u_1) (M : Type u_2) [semiring R] [add_comm_monoid M] [module R M] (N : submodule R M) (h : is_noetherian R M) :
@[protected, instance]
def submodule.quotient.is_noetherian {R : Type u_1} [ring R] {M : Type u_2} [add_comm_group M] [module R M] (N : submodule R M) [h : is_noetherian R M] :
theorem is_noetherian_of_tower (R : Type u_1) {S : Type u_2} {M : Type u_3} [semiring R] [semiring S] [add_comm_monoid M] [has_smul R S] [module S M] [module R M] [is_scalar_tower R S M] (h : is_noetherian R M) :

If M / S / R is a scalar tower, and M / R is Noetherian, then M / S is also noetherian.

theorem is_noetherian_of_fg_of_noetherian {R : Type u_1} {M : Type u_2} [ring R] [add_comm_group M] [module R M] (N : submodule R M) [is_noetherian_ring R] (hN : N.fg) :
theorem is_noetherian_of_fg_of_noetherian' {R : Type u_1} {M : Type u_2} [ring R] [add_comm_group M] [module R M] [is_noetherian_ring R] (h : .fg) :
theorem is_noetherian_span_of_finite (R : Type u_1) {M : Type u_2} [ring R] [add_comm_group M] [module R M] [is_noetherian_ring R] {A : set M} (hA : A.finite) :

In a module over a noetherian ring, the submodule generated by finitely many vectors is noetherian.

theorem is_noetherian_ring_of_surjective (R : Type u_1) [ring R] (S : Type u_2) [ring S] (f : R →+* S) (hf : function.surjective f) [H : is_noetherian_ring R] :
@[protected, instance]
def is_noetherian_ring_range {R : Type u_1} [ring R] {S : Type u_2} [ring S] (f : R →+* S) [is_noetherian_ring R] :
theorem is_noetherian_ring_of_ring_equiv (R : Type u_1) [ring R] {S : Type u_2} [ring S] (f : R ≃+* S) [is_noetherian_ring R] :