Bases of topologies. Countability axioms. #
A topological basis on a topological space t is a collection of sets,
such that all open sets can be generated as unions of these sets, without the need to take
finite intersections of them. This file introduces a framework for dealing with these collections,
and also what more we can say under certain countability conditions on bases,
which are referred to as first- and second-countable.
We also briefly cover the theory of separable spaces, which are those with a countable, dense
subset. If a space is second-countable, and also has a countably generated uniformity filter
(for example, if t is a metric space), it will automatically be separable (and indeed, these
conditions are equivalent in this case).
Main definitions #
- TopologicalSpace.IsTopologicalBasis s: The topological space- thas basis- s.
- TopologicalSpace.SeparableSpace α: The topological space- thas a countable, dense subset.
- TopologicalSpace.IsSeparable s: The set- sis contained in the closure of a countable set.
- FirstCountableTopology α: A topology in which- 𝓝 xis countably generated for every- x.
- SecondCountableTopology α: A topology which has a topological basis which is countable.
Main results #
- TopologicalSpace.FirstCountableTopology.tendsto_subseq: In a first-countable space, cluster points are limits of subsequences.
- TopologicalSpace.SecondCountableTopology.isOpen_iUnion_countable: In a second-countable space, the union of arbitrarily-many open sets is equal to a sub-union of only countably many of these sets.
- TopologicalSpace.SecondCountableTopology.countable_cover_nhds: Consider- f : α → Set αwith the property that- f x ∈ 𝓝 xfor all- x. Then there is some countable set- swhose image covers the space.
Implementation Notes #
For our applications we are interested that there exists a countable basis, but we do not need the
concrete basis itself. This allows us to declare these type classes as Prop to use them as mixins.
TODO: #
More fine grained instances for FirstCountableTopology,
TopologicalSpace.SeparableSpace, and more.
A topological basis is one that satisfies the necessary conditions so that it suffices to take unions of the basis sets to get a topology (without taking finite intersections as well).
- For every point - x, the set of- t ∈ ssuch that- x ∈ tis directed downwards.
- The sets from - scover the whole space.
- eq_generateFrom : t = TopologicalSpace.generateFrom sThe topology is generated by sets from s.
Instances For
For every point x, the set of t ∈ s such that x ∈ t is directed downwards.
The sets from s cover the whole space.
The topology is generated by sets from s.
If a family of sets s generates the topology, then intersections of finite
subcollections of s form a topological basis.
If a family of open sets s is such that every open neighbourhood contains some
member of s, then s is a topological basis.
A set s is in the neighbourhood of a iff there is some basis set t, which
contains a and is itself contained in s.
Any open set is the union of the basis sets contained in it.
A point a is in the closure of s iff all basis sets containing a intersect s.
A set is dense iff it has non-trivial intersection with all basis sets.
A separable space is one with a countable dense subset, available through
TopologicalSpace.exists_countable_dense. If α is also known to be nonempty, then
TopologicalSpace.denseSeq provides a sequence ℕ → α with dense range, see
TopologicalSpace.denseRange_denseSeq.
If α is a uniform space with countably generated uniformity filter (e.g., an EMetricSpace), then
this condition is equivalent to SecondCountableTopology α. In this case the
latter should be used as a typeclass argument in theorems because Lean can automatically deduce
TopologicalSpace.SeparableSpace from SecondCountableTopology but it can't
deduce SecondCountableTopology from TopologicalSpace.SeparableSpace.
Porting note (#11215): TODO: the previous paragraph describes the state of the art in Lean 3. We can have instance cycles in Lean 4 but we might want to postpone adding them till after the port.
- There exists a countable dense set. 
Instances
There exists a countable dense set.
A nonempty separable space admits a sequence with dense range. Instead of running cases on the
conclusion of this lemma, you might want to use TopologicalSpace.denseSeq and
TopologicalSpace.denseRange_denseSeq.
If α might be empty, then TopologicalSpace.exists_countable_dense is the main way to use
separability of α.
A dense sequence in a non-empty separable topological space.
If α might be empty, then TopologicalSpace.exists_countable_dense is the main way to use
separability of α.
Equations
Instances For
The sequence TopologicalSpace.denseSeq α has dense range.
Equations
- ⋯ = ⋯
If f has a dense range and its domain is countable, then its codomain is a separable space.
See also DenseRange.separableSpace.
Alias of TopologicalSpace.SeparableSpace.of_denseRange.
If f has a dense range and its domain is countable, then its codomain is a separable space.
See also DenseRange.separableSpace.
If α is a separable space and f : α → β is a continuous map with dense range, then β is
a separable space as well. E.g., the completion of a separable uniform space is separable.
The product of two separable spaces is a separable space.
Equations
- ⋯ = ⋯
The product of a countable family of separable spaces is a separable space.
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
A topological space with discrete topology is separable iff it is countable.
In a separable space, a family of nonempty disjoint open sets is countable.
In a separable space, a family of nonempty disjoint open sets is countable.
In a separable space, a family of disjoint sets with nonempty interiors is countable.
A set s in a topological space is separable if it is contained in the closure of a countable
set c. Beware that this definition does not require that c is contained in s (to express the
latter, use TopologicalSpace.SeparableSpace s or
TopologicalSpace.IsSeparable (univ : Set s)). In metric spaces, the two definitions are
equivalent, see TopologicalSpace.IsSeparable.separableSpace.
Instances For
Alias of the reverse direction of TopologicalSpace.isSeparable_closure.
Alias of TopologicalSpace.IsSeparable.of_subtype.
Let s be a dense set in a topological space α with partial order structure. If s is a
separable space (e.g., if α has a second countable topology), then there exists a countable
dense subset t ⊆ s such that t contains bottom/top element of α when they exist and belong
to s. For a dense subset containing neither bot nor top elements, see
Dense.exists_countable_dense_subset_no_bot_top.
Equations
- ⋯ = ⋯
If α is a separable topological space with a partial order, then there exists a countable
dense set s : Set α that contains those of both bottom and top elements of α that actually
exist. For a dense set containing neither bot nor top elements, see
exists_countable_dense_no_bot_top.
A first-countable space is one in which every point has a countable neighborhood basis.
- nhds_generated_countable : ∀ (a : α), (nhds a).IsCountablyGeneratedThe filter 𝓝 ais countably generated for all pointsa.
Instances
The filter 𝓝 a is countably generated for all points a.
If β is a first-countable space, then its induced topology via f on α is also
first-countable.
Equations
- ⋯ = ⋯
In a first-countable space, a cluster point x of a sequence
is the limit of some subsequence.
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
A second-countable space is one with a countable basis.
- is_open_generated_countable : ∃ (b : Set (Set α)), b.Countable ∧ t = TopologicalSpace.generateFrom bThere exists a countable set of sets that generates the topology. 
Instances
There exists a countable set of sets that generates the topology.
Equations
- ⋯ = ⋯
A countable topological basis of α.
Equations
- TopologicalSpace.countableBasis α = ⋯.choose
Instances For
Equations
- TopologicalSpace.encodableCountableBasis α = ⋯.toEncodable
Equations
- ⋯ = ⋯
If β is a second-countable space, then its induced topology via
f on α is also second-countable.
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
Equations
- ⋯ = ⋯
A countable open cover induces a second-countable topology if all open covers are themselves second countable.
In a second-countable space, an open set, given as a union of open sets,
is equal to the union of countably many of those sets.
In particular, any open covering of α has a countable subcover: α is a Lindelöf space.
In a topological space with second countable topology, if f is a function that sends each
point x to a neighborhood of x, then for some countable set s, the neighborhoods f x,
x ∈ s, cover the whole space.
In a disjoint union space Σ i, E i, one can form a topological basis by taking the union of
topological bases on each of the parts of the space.
A countable disjoint union of second countable spaces is second countable.
Equations
- ⋯ = ⋯
In a sum space α ⊕ β, one can form a topological basis by taking the union of
topological bases on each of the two components.
A sum type of two second countable spaces is second countable.
Equations
- ⋯ = ⋯
The image of a topological basis under an open quotient map is a topological basis.
A second countable space is mapped by an open quotient map to a second countable space.
The image of a topological basis "downstairs" in an open quotient is a topological basis.
An open quotient of a second countable space is second countable.