Documentation

Mathlib.Init.Set

Sets #

This file sets up the theory of sets whose elements have a given type.

Main definitions #

Given a type X and a predicate p : X → Prop:

Implementation issues #

As in Lean 3, Set X := X → Prop

I didn't call this file Data.Set.Basic because it contains core Lean 3 stuff which happens before mathlib3's data.set.basic . This file is a port of the core Lean 3 file lib/lean/library/init/data/set.lean.

def Set (α : Type u) :

A set is a collection of elements of some type α.

Although Set is defined as α → Prop, this is an implementation detail which should not be relied on. Instead, setOf and membership of a set () should be used to convert between sets and predicates.

Equations
Instances For
    def setOf {α : Type u} (p : αProp) :
    Set α

    Turn a predicate p : α → Prop into a set, also written as {x | p x}

    Equations
    Instances For
      def Set.Mem {α : Type u_1} (a : α) (s : Set α) :

      Membership in a set

      Equations
      Instances For
        instance Set.instMembershipSet {α : Type u_1} :
        Membership α (Set α)
        Equations
        • Set.instMembershipSet = { mem := Set.Mem }
        theorem Set.ext {α : Type u_1} {a : Set α} {b : Set α} (h : ∀ (x : α), x a x b) :
        a = b
        def Set.Subset {α : Type u_1} (s₁ : Set α) (s₂ : Set α) :
        Equations
        Instances For
          instance Set.instLESet {α : Type u_1} :
          LE (Set α)

          Porting note: we introduce before to help the unifier when applying lattice theorems to subset hypotheses.

          Equations
          • Set.instLESet = { le := Set.Subset }
          instance Set.instHasSubsetSet {α : Type u_1} :
          Equations
          • Set.instHasSubsetSet = { Subset := fun (x x_1 : Set α) => x x_1 }
          Equations
          • Set.instEmptyCollectionSet = { emptyCollection := fun (x : α) => False }
          Equations
          • One or more equations did not get rendered due to their size.
          Instances For
            Equations
            • One or more equations did not get rendered due to their size.
            Instances For

              { f x y | (x : X) (y : Y) } is notation for the set of elements f x y constructed from the binders x and y, equivalent to {z : Z | ∃ x y, f x y = z}.

              If f x y is a single identifier, it must be parenthesized to avoid ambiguity with {x | p x}; for instance, {(x) | (x : Nat) (y : Nat) (_hxy : x = y^2)}.

              Equations
              • One or more equations did not get rendered due to their size.
              Instances For
                def Set.univ {α : Type u_1} :
                Set α
                Equations
                • Set.univ = {_a : α | True}
                Instances For
                  def Set.insert {α : Type u_1} (a : α) (s : Set α) :
                  Set α
                  Equations
                  Instances For
                    instance Set.instInsertSet {α : Type u_1} :
                    Insert α (Set α)
                    Equations
                    • Set.instInsertSet = { insert := Set.insert }
                    def Set.singleton {α : Type u_1} (a : α) :
                    Set α
                    Equations
                    Instances For
                      instance Set.instSingletonSet {α : Type u_1} :
                      Singleton α (Set α)
                      Equations
                      • Set.instSingletonSet = { singleton := Set.singleton }
                      def Set.union {α : Type u_1} (s₁ : Set α) (s₂ : Set α) :
                      Set α
                      Equations
                      Instances For
                        instance Set.instUnionSet {α : Type u_1} :
                        Union (Set α)
                        Equations
                        • Set.instUnionSet = { union := Set.union }
                        def Set.inter {α : Type u_1} (s₁ : Set α) (s₂ : Set α) :
                        Set α
                        Equations
                        Instances For
                          instance Set.instInterSet {α : Type u_1} :
                          Inter (Set α)
                          Equations
                          • Set.instInterSet = { inter := Set.inter }
                          def Set.compl {α : Type u_1} (s : Set α) :
                          Set α
                          Equations
                          Instances For
                            def Set.diff {α : Type u_1} (s : Set α) (t : Set α) :
                            Set α
                            Equations
                            Instances For
                              instance Set.instSDiffSet {α : Type u_1} :
                              SDiff (Set α)
                              Equations
                              • Set.instSDiffSet = { sdiff := Set.diff }
                              def Set.powerset {α : Type u_1} (s : Set α) :
                              Set (Set α)
                              Equations
                              Instances For
                                def Set.image {α : Type u_1} {β : Type u_2} (f : αβ) (s : Set α) :
                                Set β
                                Equations
                                Instances For
                                  Equations
                                  def Set.Nonempty {α : Type u_1} (s : Set α) :

                                  The property s.Nonempty expresses the fact that the set s is not empty. It should be used in theorem assumptions instead of ∃ x, x ∈ s or s ≠ ∅ as it gives access to a nice API thanks to the dot notation.

                                  Equations
                                  Instances For