Basic properties of sets #
Sets in Lean are homogeneous; all their elements have the same type. Sets whose elements
have type X are thus defined as Set X := X → Prop. Note that this function need not
be decidable. The definition is in the module Mathlib/Data/Set/Defs.lean.
This file provides some basic definitions related to sets and functions not present in the
definitions file, as well as extra lemmas for functions defined in the definitions file and
Mathlib/Data/Set/Operations.lean (empty set, univ, union, intersection, insert, singleton and
powerset).
Note that a set is a term, not a type. There is a coercion from Set α to Type* sending
s to the corresponding subtype ↥s.
See also the file SetTheory/ZFC.lean, which contains an encoding of ZFC set theory in Lean.
Main definitions #
Notation used here:
Definitions in the file:
- Nonempty s : Prop: the predicate- s ≠ ∅. Note that this is the preferred way to express the fact that- shas an element (see the Implementation Notes).
- inclusion s₁ s₂ : ↥s₁ → ↥s₂: the map- ↥s₁ → ↥s₂induced by an inclusion- s₁ ⊆ s₂.
Implementation notes #
- s.Nonemptyis to be preferred to- s ≠ ∅or- ∃ x, x ∈ s. It has the advantage that the- s.Nonemptydot notation can be used.
- For - s : Set α, do not use- Subtype s. Instead use- ↥sor- (s : Type*)or- s.
Tags #
set, sets, subset, subsets, union, intersection, insert, singleton, powerset
Set coercion to a type #
Equations
- One or more equations did not get rendered due to their size.
Alias of the reverse direction of Set.le_iff_subset.
Alias of the forward direction of Set.le_iff_subset.
Alias of the reverse direction of Set.lt_iff_ssubset.
Alias of the forward direction of Set.lt_iff_ssubset.
Equations
- instCoeTCElem s = { coe := fun (x : ↑s) => ↑x }
Equations
- Set.instInhabited = { default := ∅ }
Subset and strict subset relations #
Equations
Equations
Equations
Equations
Alias of Set.notMem_subset.
Definition of strict subsets s ⊂ t and basic properties. #
Alias of Set.notMem_empty.
Alias of Set.not_notMem.
Non-empty sets #
Alias of the reverse direction of Set.nonempty_coe_sort.
Extract a witness from s.Nonempty. This function might be used instead of case analysis
on the argument. Note that it makes a proof depend on the Classical.choice axiom.
Equations
- h.some = Classical.choose h
Instances For
Lemmas about the empty set #
Alias of Set.eq_empty_iff_forall_notMem.
Alias of Set.eq_empty_of_forall_notMem.
See also Set.nonempty_iff_ne_empty.
See also Set.not_nonempty_iff_eq_empty.
See also nonempty_iff_ne_empty'.
See also not_nonempty_iff_eq_empty'.
Alias of the reverse direction of Set.empty_ssubset.
Universal set. #
In Lean @univ α (or univ : Set α) is the set that contains all elements of type α.
Mathematically it is the same as α but it has a different type.
Alias of the forward direction of Set.univ_subset_iff.
Alias of Set.ne_univ_iff_exists_notMem.
Alias of Set.not_subset_iff_exists_mem_notMem.
Lemmas about union #
Lemmas about intersection #
Distributivity laws #
Lemmas about sets defined as {x ∈ s | p x}. #
Powerset #
Sets defined as an if-then-else #
Decidability instances for sets #
Equations
- s.decidableCompl a = inferInstanceAs (Decidable (a ∉ s))
Equations
Equations
- Set.decidableUniv a = isTrue ⋯
Given a predicate p : α → Prop, produces an equivalence between
Set {a : α // p a} and {s : Set α // ∀ a ∈ s, p a}.
Equations
- One or more equations did not get rendered due to their size.