Documentation

Mathlib.Topology.Algebra.Ring.Basic

Topological (semi)rings #

A topological (semi)ring is a (semi)ring equipped with a topology such that all operations are continuous. Besides this definition, this file proves that the topological closure of a subring (resp. an ideal) is a subring (resp. an ideal) and defines products and quotients of topological (semi)rings.

Main Results #

If R is a ring with a continuous multiplication, then negation is continuous as well since it is just multiplication with -1.

If R is a ring which is a topological semiring, then it is automatically a topological ring. This exists so that one can place a topological ring structure on R without explicitly proving continuous_neg.

@[instance 50]
Equations
  • =

The (topological-space) closure of a subsemiring of a topological semiring is itself a subsemiring.

Equations
  • s.topologicalClosure = { carrier := closure s, mul_mem' := , one_mem' := , add_mem' := , zero_mem' := }
@[simp]
theorem Subsemiring.topologicalClosure_coe {α : Type u_1} [TopologicalSpace α] [Semiring α] [TopologicalSemiring α] (s : Subsemiring α) :
s.topologicalClosure = closure s
theorem Subsemiring.le_topologicalClosure {α : Type u_1} [TopologicalSpace α] [Semiring α] [TopologicalSemiring α] (s : Subsemiring α) :
s s.topologicalClosure
theorem Subsemiring.isClosed_topologicalClosure {α : Type u_1} [TopologicalSpace α] [Semiring α] [TopologicalSemiring α] (s : Subsemiring α) :
IsClosed s.topologicalClosure
theorem Subsemiring.topologicalClosure_minimal {α : Type u_1} [TopologicalSpace α] [Semiring α] [TopologicalSemiring α] (s : Subsemiring α) {t : Subsemiring α} (h : s t) (ht : IsClosed t) :
s.topologicalClosure t
def Subsemiring.commSemiringTopologicalClosure {α : Type u_1} [TopologicalSpace α] [Semiring α] [TopologicalSemiring α] [T2Space α] (s : Subsemiring α) (hs : ∀ (x y : s), x * y = y * x) :
CommSemiring s.topologicalClosure

If a subsemiring of a topological semiring is commutative, then so is its topological closure.

Equations

The product topology on the cartesian product of two topological semirings makes the product into a topological semiring.

Equations
  • =

The product topology on the cartesian product of two topological rings makes the product into a topological ring.

Equations
  • =
instance instContinuousAddForallOfTopologicalSemiring {β : Type u_2} {C : βType u_3} [(b : β) → TopologicalSpace (C b)] [(b : β) → NonUnitalNonAssocSemiring (C b)] [∀ (b : β), TopologicalSemiring (C b)] :
ContinuousAdd ((b : β) → C b)
Equations
  • =
instance Pi.instTopologicalSemiring {β : Type u_2} {C : βType u_3} [(b : β) → TopologicalSpace (C b)] [(b : β) → NonUnitalNonAssocSemiring (C b)] [∀ (b : β), TopologicalSemiring (C b)] :
TopologicalSemiring ((b : β) → C b)
Equations
  • =
instance Pi.instTopologicalRing {β : Type u_2} {C : βType u_3} [(b : β) → TopologicalSpace (C b)] [(b : β) → NonUnitalNonAssocRing (C b)] [∀ (b : β), TopologicalRing (C b)] :
TopologicalRing ((b : β) → C b)
Equations
  • =
theorem TopologicalRing.of_addGroup_of_nhds_zero {R : Type u_2} [NonUnitalNonAssocRing R] [TopologicalSpace R] [TopologicalAddGroup R] (hmul : Filter.Tendsto (Function.uncurry fun (x1 x2 : R) => x1 * x2) (nhds 0 ×ˢ nhds 0) (nhds 0)) (hmul_left : ∀ (x₀ : R), Filter.Tendsto (fun (x : R) => x₀ * x) (nhds 0) (nhds 0)) (hmul_right : ∀ (x₀ : R), Filter.Tendsto (fun (x : R) => x * x₀) (nhds 0) (nhds 0)) :
theorem TopologicalRing.of_nhds_zero {R : Type u_2} [NonUnitalNonAssocRing R] [TopologicalSpace R] (hadd : Filter.Tendsto (Function.uncurry fun (x1 x2 : R) => x1 + x2) (nhds 0 ×ˢ nhds 0) (nhds 0)) (hneg : Filter.Tendsto (fun (x : R) => -x) (nhds 0) (nhds 0)) (hmul : Filter.Tendsto (Function.uncurry fun (x1 x2 : R) => x1 * x2) (nhds 0 ×ˢ nhds 0) (nhds 0)) (hmul_left : ∀ (x₀ : R), Filter.Tendsto (fun (x : R) => x₀ * x) (nhds 0) (nhds 0)) (hmul_right : ∀ (x₀ : R), Filter.Tendsto (fun (x : R) => x * x₀) (nhds 0) (nhds 0)) (hleft : ∀ (x₀ : R), nhds x₀ = Filter.map (fun (x : R) => x₀ + x) (nhds 0)) :

In a topological semiring, the left-multiplication AddMonoidHom is continuous.

In a topological semiring, the right-multiplication AddMonoidHom is continuous.

Equations
  • =

The (topological-space) closure of a subring of a topological ring is itself a subring.

Equations
  • S.topologicalClosure = { carrier := closure S, mul_mem' := , one_mem' := , add_mem' := , zero_mem' := , neg_mem' := }
theorem Subring.le_topologicalClosure {α : Type u_1} [TopologicalSpace α] [Ring α] [TopologicalRing α] (s : Subring α) :
s s.topologicalClosure
theorem Subring.isClosed_topologicalClosure {α : Type u_1} [TopologicalSpace α] [Ring α] [TopologicalRing α] (s : Subring α) :
IsClosed s.topologicalClosure
theorem Subring.topologicalClosure_minimal {α : Type u_1} [TopologicalSpace α] [Ring α] [TopologicalRing α] (s : Subring α) {t : Subring α} (h : s t) (ht : IsClosed t) :
s.topologicalClosure t
def Subring.commRingTopologicalClosure {α : Type u_1} [TopologicalSpace α] [Ring α] [TopologicalRing α] [T2Space α] (s : Subring α) (hs : ∀ (x y : s), x * y = y * x) :
CommRing s.topologicalClosure

If a subring of a topological ring is commutative, then so is its topological closure.

Equations

Lattice of ring topologies #

We define a type class RingTopology α which endows a ring α with a topology such that all ring operations are continuous.

Ring topologies on a fixed ring α are ordered, by reverse inclusion. They form a complete lattice, with the discrete topology and the indiscrete topology.

Any function f : α → β induces coinduced f : TopologicalSpace α → RingTopology β.

A ring topology on a ring α is a topology for which addition, negation and multiplication are continuous.

    Instances For
    Equations
    • RingTopology.inhabited = { default := let x := ; { toTopologicalSpace := x, toTopologicalRing := } }
    theorem RingTopology.toTopologicalSpace_injective {α : Type u_1} [Ring α] :
    Function.Injective RingTopology.toTopologicalSpace
    theorem RingTopology.ext {α : Type u_1} [Ring α] {f : RingTopology α} {g : RingTopology α} (h : TopologicalSpace.IsOpen = TopologicalSpace.IsOpen) :
    f = g

    The ordering on ring topologies on the ring α. t ≤ s if every set open in s is also open in t (t is finer than s).

    Equations

    Ring topologies on α form a complete lattice, with the discrete topology and the indiscrete topology.

    The infimum of a collection of ring topologies is the topology generated by all their open sets (which is a ring topology).

    The supremum of two ring topologies s and t is the infimum of the family of all ring topologies contained in the intersection of s and t.

    Equations
    Equations
    def RingTopology.coinduced {α : Type u_2} {β : Type u_3} [t : TopologicalSpace α] [Ring β] (f : αβ) :

    Given f : α → β and a topology on α, the coinduced ring topology on β is the finest topology such that f is continuous and β is a topological ring.

    Equations
    theorem RingTopology.coinduced_continuous {α : Type u_2} {β : Type u_3} [t : TopologicalSpace α] [Ring β] (f : αβ) :

    The forgetful functor from ring topologies on a to additive group topologies on a.

    Equations
    • t.toAddGroupTopology = { toTopologicalSpace := t.toTopologicalSpace, toTopologicalAddGroup := }

    The order embedding from ring topologies on a to additive group topologies on a.

    Equations
    def AbsoluteValue.comp {R : Type u_1} {S : Type u_2} {T : Type u_3} [Semiring T] [Semiring R] [OrderedSemiring S] (v : AbsoluteValue R S) {f : T →+* R} (hf : Function.Injective f) :

    Construct an absolute value on a semiring T from an absolute value on a semiring R and an injective ring homomorphism f : T →+* R

    Equations
    • v.comp hf = { toMulHom := v.comp f, nonneg' := , eq_zero' := , add_le' := }