Documentation

Mathlib.Data.Set.Finite.Basic

Finite sets #

This file provides Fintype instances for many set constructions. It also proves basic facts about finite sets and gives ways to manipulate Set.Finite expressions.

Note that the instances in this file are selected somewhat arbitrarily on the basis of them not needing any imports beyond Data.Fintype.Card (which is required by Finite.ofFinset); they can certainly be organized better.

Main definitions #

Implementation #

A finite set is defined to be a set whose coercion to a type has a Finite instance.

There are two components to finiteness constructions. The first is Fintype instances for each construction. This gives a way to actually compute a Finset that represents the set, and these may be accessed using set.toFinset. This gets the Finset in the correct form, since otherwise Finset.univ : Finset s is a Finset for the subtype for s. The second component is "constructors" for Set.Finite that give proofs that Fintype instances exist classically given other Set.Finite proofs. Unlike the Fintype instances, these do not use any decidability instances since they do not compute anything.

Tags #

finite sets

theorem Set.finite_def {α : Type u} {s : Set α} :
theorem Set.Finite.nonempty_fintype {α : Type u} {s : Set α} :
s.FiniteNonempty (Fintype s)

Alias of the forward direction of Set.finite_def.

theorem Set.Finite.ofFinset {α : Type u} {p : Set α} (s : Finset α) (H : ∀ (x : α), x s x p) :

Construct a Finite instance for a Set from a Finset with the same elements.

noncomputable def Set.Finite.fintype {α : Type u} {s : Set α} (h : s.Finite) :
Fintype s

A finite set coerced to a type is a Fintype. This is the Fintype projection for a Set.Finite.

Note that because Finite isn't a typeclass, this definition will not fire if it is made into an instance

Equations
Instances For
    noncomputable def Set.Finite.toFinset {α : Type u} {s : Set α} (h : s.Finite) :

    Using choice, get the Finset that represents this Set.

    Equations
    Instances For
      theorem Set.Finite.toFinset_eq_toFinset {α : Type u} {s : Set α} [Fintype s] (h : s.Finite) :
      @[simp]
      theorem Set.toFinite_toFinset {α : Type u} (s : Set α) [Fintype s] :
      theorem Set.Finite.exists_finset {α : Type u} {s : Set α} (h : s.Finite) :
      ∃ (s' : Finset α), ∀ (a : α), a s' a s
      theorem Set.Finite.exists_finset_coe {α : Type u} {s : Set α} (h : s.Finite) :
      ∃ (s' : Finset α), s' = s

      Finite sets can be lifted to finsets.

      Basic properties of Set.Finite.toFinset #

      @[simp]
      theorem Set.Finite.mem_toFinset {α : Type u} {s : Set α} {a : α} (hs : s.Finite) :
      a hs.toFinset a s
      @[simp]
      theorem Set.Finite.coe_toFinset {α : Type u} {s : Set α} (hs : s.Finite) :
      hs.toFinset = s
      @[simp]
      theorem Set.Finite.toFinset_nonempty {α : Type u} {s : Set α} (hs : s.Finite) :
      theorem Set.Finite.coeSort_toFinset {α : Type u} {s : Set α} (hs : s.Finite) :
      hs.toFinset = s

      Note that this is an equality of types not holding definitionally. Use wisely.

      def Set.Finite.subtypeEquivToFinset {α : Type u} {s : Set α} (hs : s.Finite) :
      { x : α // x s } { x : α // x hs.toFinset }

      The identity map, bundled as an equivalence between the subtypes of s : Set α and of h.toFinset : Finset α, where h is a proof of finiteness of s.

      Equations
      Instances For
        @[simp]
        theorem Set.Finite.subtypeEquivToFinset_apply_coe {α : Type u} {s : Set α} (hs : s.Finite) (a : { a : α // a s }) :
        (hs.subtypeEquivToFinset a) = a
        @[simp]
        theorem Set.Finite.subtypeEquivToFinset_symm_apply_coe {α : Type u} {s : Set α} (hs : s.Finite) (b : { b : α // b hs.toFinset }) :
        (hs.subtypeEquivToFinset.symm b) = b
        @[simp]
        theorem Set.Finite.toFinset_inj {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        hs.toFinset = ht.toFinset s = t
        @[simp]
        theorem Set.Finite.toFinset_subset {α : Type u} {s : Set α} {hs : s.Finite} {t : Finset α} :
        hs.toFinset t s t
        @[simp]
        theorem Set.Finite.toFinset_ssubset {α : Type u} {s : Set α} {hs : s.Finite} {t : Finset α} :
        hs.toFinset t s t
        @[simp]
        theorem Set.Finite.subset_toFinset {α : Type u} {t : Set α} {ht : t.Finite} {s : Finset α} :
        s ht.toFinset s t
        @[simp]
        theorem Set.Finite.ssubset_toFinset {α : Type u} {t : Set α} {ht : t.Finite} {s : Finset α} :
        s ht.toFinset s t
        theorem Set.Finite.toFinset_subset_toFinset {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        theorem Set.Finite.toFinset_ssubset_toFinset {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        theorem Set.Finite.toFinset_mono {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        s ths.toFinset ht.toFinset

        Alias of the reverse direction of Set.Finite.toFinset_subset_toFinset.

        theorem Set.Finite.toFinset_strictMono {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        s ths.toFinset ht.toFinset

        Alias of the reverse direction of Set.Finite.toFinset_ssubset_toFinset.

        @[simp]
        theorem Set.Finite.toFinset_setOf {α : Type u} [Fintype α] (p : αProp) [DecidablePred p] (h : {x : α | p x}.Finite) :
        h.toFinset = {x : α | p x}
        @[simp]
        theorem Set.Finite.disjoint_toFinset {α : Type u} {s t : Set α} {hs : s.Finite} {ht : t.Finite} :
        theorem Set.Finite.toFinset_inter {α : Type u} {s t : Set α} [DecidableEq α] (hs : s.Finite) (ht : t.Finite) (h : (s t).Finite) :
        theorem Set.Finite.toFinset_union {α : Type u} {s t : Set α} [DecidableEq α] (hs : s.Finite) (ht : t.Finite) (h : (s t).Finite) :
        theorem Set.Finite.toFinset_diff {α : Type u} {s t : Set α} [DecidableEq α] (hs : s.Finite) (ht : t.Finite) (h : (s \ t).Finite) :
        theorem Set.Finite.toFinset_symmDiff {α : Type u} {s t : Set α} [DecidableEq α] (hs : s.Finite) (ht : t.Finite) (h : (_root_.symmDiff s t).Finite) :
        theorem Set.Finite.toFinset_compl {α : Type u} {s : Set α} [DecidableEq α] [Fintype α] (hs : s.Finite) (h : s.Finite) :
        @[simp]
        theorem Set.Finite.toFinset_eq_empty {α : Type u} {s : Set α} {h : s.Finite} :
        @[simp]
        theorem Set.Finite.toFinset_eq_univ {α : Type u} {s : Set α} [Fintype α] {h : s.Finite} :
        theorem Set.Finite.toFinset_image {α : Type u} {β : Type v} {s : Set α} [DecidableEq β] (f : αβ) (hs : s.Finite) (h : (f '' s).Finite) :
        theorem Set.Finite.toFinset_range {α : Type u} {β : Type v} [DecidableEq α] [Fintype β] (f : βα) (h : (range f).Finite) :
        @[simp]

        Fintype instances #

        Every instance here should have a corresponding Set.Finite constructor in the next section.

        noncomputable def Set.fintypeOfFiniteUniv {α : Type u} (H : univ.Finite) :

        If (Set.univ : Set α) is finite then α is a finite type.

        Equations
        Instances For
          instance Set.fintypeUnion {α : Type u} [DecidableEq α] (s t : Set α) [Fintype s] [Fintype t] :
          Fintype ↑(s t)
          Equations
          instance Set.fintypeSep {α : Type u} (s : Set α) (p : αProp) [Fintype s] [DecidablePred p] :
          Fintype {a : α | a s p a}
          Equations
          instance Set.fintypeInter {α : Type u} (s t : Set α) [DecidableEq α] [Fintype s] [Fintype t] :
          Fintype ↑(s t)
          Equations
          instance Set.fintypeInterOfLeft {α : Type u} (s t : Set α) [Fintype s] [DecidablePred fun (x : α) => x t] :
          Fintype ↑(s t)

          A Fintype instance for set intersection where the left set has a Fintype instance.

          Equations
          instance Set.fintypeInterOfRight {α : Type u} (s t : Set α) [Fintype t] [DecidablePred fun (x : α) => x s] :
          Fintype ↑(s t)

          A Fintype instance for set intersection where the right set has a Fintype instance.

          Equations
          def Set.fintypeSubset {α : Type u} (s : Set α) {t : Set α} [Fintype s] [DecidablePred fun (x : α) => x t] (h : t s) :
          Fintype t

          A Fintype structure on a set defines a Fintype structure on its subset.

          Equations
          Instances For
            instance Set.fintypeDiff {α : Type u} [DecidableEq α] (s t : Set α) [Fintype s] [Fintype t] :
            Fintype ↑(s \ t)
            Equations
            instance Set.fintypeDiffLeft {α : Type u} (s t : Set α) [Fintype s] [DecidablePred fun (x : α) => x t] :
            Fintype ↑(s \ t)
            Equations
            instance Set.fintypeSingleton {α : Type u} (a : α) :
            Equations
            instance Set.fintypeInsert {α : Type u} (a : α) (s : Set α) [DecidableEq α] [Fintype s] :
            Fintype (insert a s)

            A Fintype instance for inserting an element into a Set using the corresponding insert function on Finset. This requires DecidableEq α. There is also Set.fintypeInsert' when a ∈ s is decidable.

            Equations
            def Set.fintypeInsertOfNotMem {α : Type u} {a : α} (s : Set α) [Fintype s] (h : as) :
            Fintype (insert a s)

            A Fintype structure on insert a s when inserting a new element.

            Equations
            Instances For
              def Set.fintypeInsertOfMem {α : Type u} {a : α} (s : Set α) [Fintype s] (h : a s) :
              Fintype (insert a s)

              A Fintype structure on insert a s when inserting a pre-existing element.

              Equations
              Instances For
                @[instance 100]
                instance Set.fintypeInsert' {α : Type u} (a : α) (s : Set α) [Decidable (a s)] [Fintype s] :
                Fintype (insert a s)

                The Set.fintypeInsert instance requires decidable equality, but when a ∈ s is decidable for this particular a we can still get a Fintype instance by using Set.fintypeInsertOfNotMem or Set.fintypeInsertOfMem.

                This instance pre-dates Set.fintypeInsert, and it is less efficient. When Set.decidableMemOfFintype is made a local instance, then this instance would override Set.fintypeInsert if not for the fact that its priority has been adjusted. See Note [lower instance priority].

                Equations
                instance Set.fintypeImage {α : Type u} {β : Type v} [DecidableEq β] (s : Set α) (f : αβ) [Fintype s] :
                Fintype ↑(f '' s)
                Equations
                def Set.fintypeOfFintypeImage {α : Type u} {β : Type v} (s : Set α) {f : αβ} {g : βOption α} (I : Function.IsPartialInv f g) [Fintype ↑(f '' s)] :
                Fintype s

                If a function f has a partial inverse g and the image of s under f is a set with a Fintype instance, then s has a Fintype structure as well.

                Equations
                Instances For
                  instance Set.fintypeMap {α β : Type u_1} [DecidableEq β] (s : Set α) (f : αβ) [Fintype s] :
                  Fintype ↑(f <$> s)
                  Equations
                  instance Set.fintypeLENat (n : ) :
                  Fintype {i : | i n}
                  Equations
                  def Set.Nat.fintypeIio (n : ) :
                  Fintype (Iio n)

                  This is not an instance so that it does not conflict with the one in Mathlib/Order/Interval/Finset/Defs.lean.

                  Equations
                  Instances For
                    instance Set.fintypeMemFinset {α : Type u} (s : Finset α) :
                    Fintype {a : α | a s}
                    Equations

                    Finset #

                    @[simp]
                    theorem Finset.finite_toSet {α : Type u} (s : Finset α) :
                    (↑s).Finite

                    Gives a Set.Finite for the Finset coerced to a Set. This is a wrapper around Set.toFinite.

                    theorem Finset.finite_toSet_toFinset {α : Type u} (s : Finset α) :
                    .toFinset = s
                    theorem Finset.forall {α : Type u} {p : Finset αProp} :
                    (∀ (s : Finset α), p s) ∀ (s : Set α) (hs : s.Finite), p hs.toFinset

                    This is a kind of induction principle. See Finset.induction for the usual induction principle for finsets.

                    theorem Finset.exists {α : Type u} {p : Finset αProp} :
                    (∃ (s : Finset α), p s) ∃ (s : Set α) (hs : s.Finite), p hs.toFinset
                    @[simp]
                    theorem Multiset.finite_toSet {α : Type u} (s : Multiset α) :
                    {x : α | x s}.Finite
                    @[simp]
                    @[simp]
                    theorem List.finite_toSet {α : Type u} (l : List α) :
                    {x : α | x l}.Finite
                    noncomputable def OrderIso.finsetSetFinite {α : Type u} :
                    Finset α ≃o { s : Set α // s.Finite }

                    Finset α is order isomorphic to the type of finite sets in α.

                    Equations
                    Instances For
                      @[simp]
                      theorem OrderIso.finsetSetFinite_apply_coe {α : Type u} (s : Finset α) :
                      (finsetSetFinite s) = s

                      Finite instances #

                      There is seemingly some overlap between the following instances and the Fintype instances in Data.Set.Finite. While every Fintype instance gives a Finite instance, those instances that depend on Fintype or Decidable instances need an additional Finite instance to be able to generally apply.

                      Some set instances do not appear here since they are consequences of others, for example Subtype.Finite for subsets of a finite type.

                      instance Finite.Set.finite_union {α : Type u} (s t : Set α) [Finite s] [Finite t] :
                      Finite ↑(s t)
                      instance Finite.Set.finite_sep {α : Type u} (s : Set α) (p : αProp) [Finite s] :
                      Finite {a : α | a s p a}
                      theorem Finite.Set.subset {α : Type u} (s : Set α) {t : Set α} [Finite s] (h : t s) :
                      Finite t
                      instance Finite.Set.finite_inter_of_right {α : Type u} (s t : Set α) [Finite t] :
                      Finite ↑(s t)
                      instance Finite.Set.finite_inter_of_left {α : Type u} (s t : Set α) [Finite s] :
                      Finite ↑(s t)
                      instance Finite.Set.finite_diff {α : Type u} (s t : Set α) [Finite s] :
                      Finite ↑(s \ t)
                      instance Finite.Set.finite_insert {α : Type u} (a : α) (s : Set α) [Finite s] :
                      Finite (insert a s)
                      instance Finite.Set.finite_image {α : Type u} {β : Type v} (s : Set α) (f : αβ) [Finite s] :
                      Finite ↑(f '' s)

                      Constructors for Set.Finite #

                      Every constructor here should have a corresponding Fintype instance in the previous section (or in the Fintype module).

                      The implementation of these constructors ideally should be no more than Set.toFinite, after possibly setting up some Fintype and classical Decidable instances.

                      theorem Set.Finite.of_subsingleton {α : Type u} [Subsingleton α] (s : Set α) :

                      Alias of the forward direction of Set.finite_univ_iff.

                      theorem Set.Finite.subset {α : Type u} {s : Set α} (hs : s.Finite) {t : Set α} (ht : t s) :
                      theorem Set.Finite.union {α : Type u} {s t : Set α} (hs : s.Finite) (ht : t.Finite) :
                      (s t).Finite
                      theorem Set.Finite.finite_of_compl {α : Type u} {s : Set α} (hs : s.Finite) (hsc : s.Finite) :
                      theorem Set.Finite.sup {α : Type u} {s t : Set α} :
                      s.Finitet.Finite(st).Finite
                      theorem Set.Finite.sep {α : Type u} {s : Set α} (hs : s.Finite) (p : αProp) :
                      {a : α | a s p a}.Finite
                      theorem Set.Finite.inter_of_left {α : Type u} {s : Set α} (hs : s.Finite) (t : Set α) :
                      (s t).Finite
                      theorem Set.Finite.inter_of_right {α : Type u} {s : Set α} (hs : s.Finite) (t : Set α) :
                      (t s).Finite
                      theorem Set.Finite.inf_of_left {α : Type u} {s : Set α} (h : s.Finite) (t : Set α) :
                      (st).Finite
                      theorem Set.Finite.inf_of_right {α : Type u} {s : Set α} (h : s.Finite) (t : Set α) :
                      (ts).Finite
                      theorem Set.Infinite.mono {α : Type u} {s t : Set α} (h : s t) :
                      theorem Set.Finite.diff {α : Type u} {s t : Set α} (hs : s.Finite) :
                      (s \ t).Finite
                      theorem Set.Finite.of_diff {α : Type u} {s t : Set α} (hd : (s \ t).Finite) (ht : t.Finite) :
                      theorem Set.Finite.symmDiff {α : Type u} {s t : Set α} (hs : s.Finite) (ht : t.Finite) :
                      @[simp]
                      theorem Set.finite_empty {α : Type u} :
                      theorem Set.Infinite.nonempty {α : Type u} {s : Set α} (h : s.Infinite) :
                      @[simp]
                      theorem Set.finite_singleton {α : Type u} (a : α) :
                      theorem Set.Finite.insert {α : Type u} (a : α) {s : Set α} (hs : s.Finite) :
                      @[simp]
                      theorem Set.finite_insert {α : Type u} {s : Set α} {a : α} :
                      theorem Set.Finite.image {α : Type u} {β : Type v} {s : Set α} (f : αβ) (hs : s.Finite) :
                      (f '' s).Finite
                      theorem Set.Finite.of_surjOn {α : Type u} {β : Type v} {s : Set α} {t : Set β} (f : αβ) (hf : SurjOn f s t) (hs : s.Finite) :
                      theorem Set.Finite.map {α β : Type u_1} {s : Set α} (f : αβ) :
                      s.Finite(f <$> s).Finite
                      theorem Set.Finite.of_finite_image {α : Type u} {β : Type v} {s : Set α} {f : αβ} (h : (f '' s).Finite) (hi : InjOn f s) :
                      theorem Set.Finite.of_injOn {α : Type u} {β : Type v} {f : αβ} {s : Set α} {t : Set β} (hm : MapsTo f s t) (hi : InjOn f s) (ht : t.Finite) :
                      theorem Set.BijOn.finite_iff_finite {α : Type u} {β : Type v} {f : αβ} {s : Set α} {t : Set β} (h : BijOn f s t) :
                      theorem Set.finite_of_finite_preimage {α : Type u} {β : Type v} {f : αβ} {s : Set β} (h : (f ⁻¹' s).Finite) (hs : s range f) :
                      theorem Set.Finite.of_preimage {α : Type u} {β : Type v} {f : αβ} {s : Set β} (h : (f ⁻¹' s).Finite) (hf : Function.Surjective f) :
                      theorem Set.Finite.preimage {α : Type u} {β : Type v} {f : αβ} {s : Set β} (I : InjOn f (f ⁻¹' s)) (h : s.Finite) :
                      theorem Set.Infinite.preimage {α : Type u} {β : Type v} {f : αβ} {s : Set β} (hs : s.Infinite) (hf : s range f) :
                      theorem Set.Infinite.preimage' {α : Type u} {β : Type v} {f : αβ} {s : Set β} (hs : (s range f).Infinite) :
                      theorem Set.Finite.preimage_embedding {α : Type u} {β : Type v} {s : Set β} (f : α β) (h : s.Finite) :
                      (f ⁻¹' s).Finite
                      theorem Set.finite_lt_nat (n : ) :
                      {i : | i < n}.Finite
                      theorem Set.Finite.surjOn_iff_bijOn_of_mapsTo {α : Type u} {s : Set α} {f : αα} (hs : s.Finite) (hm : MapsTo f s s) :
                      SurjOn f s s BijOn f s s
                      theorem Set.Finite.injOn_iff_bijOn_of_mapsTo {α : Type u} {s : Set α} {f : αα} (hs : s.Finite) (hm : MapsTo f s s) :
                      InjOn f s BijOn f s s
                      theorem Set.finite_mem_finset {α : Type u} (s : Finset α) :
                      {a : α | a s}.Finite
                      theorem Set.Subsingleton.finite {α : Type u} {s : Set α} (h : s.Subsingleton) :
                      theorem Set.Infinite.nontrivial {α : Type u} {s : Set α} (hs : s.Infinite) :
                      theorem Set.exists_finite_iff_finset {α : Type u} {p : Set αProp} :
                      (∃ (s : Set α), s.Finite p s) ∃ (s : Finset α), p s
                      theorem Set.exists_subset_image_finite_and {α : Type u} {β : Type v} {f : αβ} {s : Set α} {p : Set βProp} :
                      (∃ tf '' s, t.Finite p t) ts, t.Finite p (f '' t)
                      theorem Set.finite_range_ite {α : Type u} {β : Type v} {p : αProp} [DecidablePred p] {f g : αβ} (hf : (range f).Finite) (hg : (range g).Finite) :
                      (range fun (x : α) => if p x then f x else g x).Finite
                      theorem Set.finite_range_const {α : Type u} {β : Type v} {c : β} :
                      (range fun (x : α) => c).Finite

                      Properties #

                      instance Set.Finite.inhabited {α : Type u} :
                      Equations
                      @[simp]
                      theorem Set.finite_union {α : Type u} {s t : Set α} :
                      theorem Set.finite_image_iff {α : Type u} {β : Type v} {s : Set α} {f : αβ} (hi : InjOn f s) :
                      theorem Set.Finite.toFinset_singleton {α : Type u} {a : α} (ha : {a}.Finite := ) :
                      @[simp]
                      theorem Set.Finite.toFinset_insert {α : Type u} [DecidableEq α] {s : Set α} {a : α} (hs : (insert a s).Finite) :
                      theorem Set.Finite.toFinset_insert' {α : Type u} [DecidableEq α] {a : α} {s : Set α} (hs : s.Finite) :
                      theorem Set.finite_option {α : Type u} {s : Set (Option α)} :
                      theorem Set.Finite.induction_on {α : Type u} {motive : (s : Set α) → s.FiniteProp} (s : Set α) (hs : s.Finite) (empty : motive ) (insert : ∀ {a : α} {s : Set α}, as∀ (hs : s.Finite), motive s hsmotive (insert a s) ) :
                      motive s hs

                      Induction principle for finite sets: To prove a property motive of a finite set s, it's enough to prove for the empty set and to prove that motive t → motive ({a} ∪ t) for all t.

                      See also Set.Finite.induction_on for the version requiring to check motive t → motive ({a} ∪ t) only for t ⊆ s.

                      theorem Set.Finite.induction_on_subset {α : Type u} {motive : (s : Set α) → s.FiniteProp} (s : Set α) (hs : s.Finite) (empty : motive ) (insert : ∀ {a : α} {t : Set α}, a s∀ (hts : t s), atmotive t motive (insert a t) ) :
                      motive s hs

                      Induction principle for finite sets: To prove a property C of a finite set s, it's enough to prove for the empty set and to prove that C t → C ({a} ∪ t) for all t ⊆ s.

                      This is analogous to Finset.induction_on'. See also Set.Finite.induction_on for the version requiring C t → C ({a} ∪ t) for all t.

                      theorem Set.seq_of_forall_finite_exists {γ : Type u_1} {P : γSet γProp} (h : ∀ (t : Set γ), t.Finite∃ (c : γ), P c t) :
                      ∃ (u : γ), ∀ (n : ), P (u n) (u '' Iio n)

                      If P is some relation between terms of γ and sets in γ, such that every finite set t : Set γ has some c : γ related to it, then there is a recursively defined sequence u in γ so u n is related to the image of {0, 1, ..., n-1} under u.

                      (We use this later to show sequentially compact sets are totally bounded.)

                      Cardinality #

                      theorem Set.card_empty {α : Type u} :
                      theorem Set.card_fintypeInsertOfNotMem {α : Type u} {a : α} (s : Set α) [Fintype s] (h : as) :
                      @[simp]
                      theorem Set.card_insert {α : Type u} {a : α} (s : Set α) [Fintype s] (h : as) {d : Fintype (insert a s)} :
                      theorem Set.card_image_of_inj_on {α : Type u} {β : Type v} {s : Set α} [Fintype s] {f : αβ} [Fintype ↑(f '' s)] (H : xs, ys, f x = f yx = y) :
                      theorem Set.card_image_of_injective {α : Type u} {β : Type v} (s : Set α) [Fintype s] {f : αβ} [Fintype ↑(f '' s)] (H : Function.Injective f) :
                      @[simp]
                      theorem Set.card_singleton {α : Type u} (a : α) :
                      theorem Set.card_lt_card {α : Type u} {s t : Set α} [Fintype s] [Fintype t] (h : s t) :
                      theorem Set.card_le_card {α : Type u} {s t : Set α} [Fintype s] [Fintype t] (hsub : s t) :
                      theorem Set.eq_of_subset_of_card_le {α : Type u} {s t : Set α} [Fintype s] [Fintype t] (hsub : s t) (hcard : Fintype.card t Fintype.card s) :
                      s = t
                      theorem Set.card_range_of_injective {α : Type u} {β : Type v} [Fintype α] {f : αβ} (hf : Function.Injective f) [Fintype (range f)] :
                      theorem Set.Finite.card_toFinset {α : Type u} {s : Set α} [Fintype s] (h : s.Finite) :
                      theorem Set.card_ne_eq {α : Type u} [Fintype α] (a : α) [Fintype {x : α | x a}] :
                      Fintype.card {x : α | x a} = Fintype.card α - 1

                      Infinite sets #

                      theorem Set.Infinite.exists_notMem_finite {α : Type u} {s t : Set α} (hs : s.Infinite) (ht : t.Finite) :
                      as, at
                      @[deprecated Set.Infinite.exists_notMem_finite (since := "2025-05-23")]
                      theorem Set.Infinite.exists_not_mem_finite {α : Type u} {s t : Set α} (hs : s.Infinite) (ht : t.Finite) :
                      as, at

                      Alias of Set.Infinite.exists_notMem_finite.

                      theorem Set.Infinite.exists_notMem_finset {α : Type u} {s : Set α} (hs : s.Infinite) (t : Finset α) :
                      as, at
                      @[deprecated Set.Infinite.exists_notMem_finset (since := "2025-05-23")]
                      theorem Set.Infinite.exists_not_mem_finset {α : Type u} {s : Set α} (hs : s.Infinite) (t : Finset α) :
                      as, at

                      Alias of Set.Infinite.exists_notMem_finset.

                      theorem Set.Finite.exists_notMem {α : Type u} {s : Set α} [Infinite α] (hs : s.Finite) :
                      ∃ (a : α), as
                      @[deprecated Set.Finite.exists_notMem (since := "2025-05-23")]
                      theorem Set.Finite.exists_not_mem {α : Type u} {s : Set α} [Infinite α] (hs : s.Finite) :
                      ∃ (a : α), as

                      Alias of Set.Finite.exists_notMem.

                      theorem Finset.exists_notMem {α : Type u} [Infinite α] (s : Finset α) :
                      ∃ (a : α), as
                      @[deprecated Finset.exists_notMem (since := "2025-05-23")]
                      theorem Finset.exists_not_mem {α : Type u} [Infinite α] (s : Finset α) :
                      ∃ (a : α), as

                      Alias of Finset.exists_notMem.

                      noncomputable def Set.Infinite.natEmbedding {α : Type u} (s : Set α) (h : s.Infinite) :
                      s

                      Embedding of into an infinite set.

                      Equations
                      Instances For
                        theorem Set.Infinite.exists_subset_card_eq {α : Type u} {s : Set α} (hs : s.Infinite) (n : ) :
                        ∃ (t : Finset α), t s t.card = n
                        theorem Set.infinite_of_finite_compl {α : Type u} [Infinite α] {s : Set α} (hs : s.Finite) :
                        theorem Set.Finite.infinite_compl {α : Type u} [Infinite α] {s : Set α} (hs : s.Finite) :
                        theorem Set.Infinite.diff {α : Type u} {s t : Set α} (hs : s.Infinite) (ht : t.Finite) :
                        (s \ t).Infinite
                        @[simp]
                        theorem Set.infinite_union {α : Type u} {s t : Set α} :
                        theorem Set.Infinite.of_image {α : Type u} {β : Type v} (f : αβ) {s : Set α} (hs : (f '' s).Infinite) :
                        theorem Set.infinite_image_iff {α : Type u} {β : Type v} {s : Set α} {f : αβ} (hi : InjOn f s) :
                        theorem Set.infinite_range_iff {α : Type u} {β : Type v} {f : αβ} (hi : Function.Injective f) :
                        theorem Set.Infinite.image {α : Type u} {β : Type v} {s : Set α} {f : αβ} (hi : InjOn f s) :
                        s.Infinite(f '' s).Infinite

                        Alias of the reverse direction of Set.infinite_image_iff.

                        theorem Set.infinite_of_injOn_mapsTo {α : Type u} {β : Type v} {s : Set α} {t : Set β} {f : αβ} (hi : InjOn f s) (hm : MapsTo f s t) (hs : s.Infinite) :
                        theorem Set.Infinite.exists_ne_map_eq_of_mapsTo {α : Type u} {β : Type v} {s : Set α} {t : Set β} {f : αβ} (hs : s.Infinite) (hf : MapsTo f s t) (ht : t.Finite) :
                        xs, ys, x y f x = f y
                        theorem Set.infinite_range_of_injective {α : Type u} {β : Type v} [Infinite α] {f : αβ} (hi : Function.Injective f) :
                        theorem Set.infinite_of_injective_forall_mem {α : Type u} {β : Type v} [Infinite α] {s : Set β} {f : αβ} (hi : Function.Injective f) (hf : ∀ (x : α), f x s) :
                        theorem Set.not_injOn_infinite_finite_image {α : Type u} {β : Type v} {f : αβ} {s : Set α} (h_inf : s.Infinite) (h_fin : (f '' s).Finite) :
                        theorem Set.finite_range_findGreatest {α : Type u} {P : αProp} [(x : α) → DecidablePred (P x)] {b : } :
                        (range fun (x : α) => Nat.findGreatest (P x) b).Finite
                        theorem Finset.exists_card_eq {α : Type u} [Infinite α] (n : ) :
                        ∃ (s : Finset α), s.card = n
                        theorem Finset.exists_subset_injOn_image_eq_of_surjOn {α : Type u} {β : Type v} [DecidableEq β] {f : αβ} (s : Set α) (t : Finset β) (hfs : Set.SurjOn f s t) :
                        ∃ (u : Finset α), u s Set.InjOn f u image f u = t

                        Finset version of Set.SurjOn.exists_subset_injOn_image_eq.

                        theorem Finite.of_forall_not_lt_lt {α : Type u} [LinearOrder α] (h : ∀ ⦃x y z : α⦄, x < yy < zFalse) :

                        If a linear order does not contain any triple of elements x < y < z, then this type is finite.

                        theorem Set.finite_of_forall_not_lt_lt {α : Type u} [LinearOrder α] {s : Set α} (h : xs, ys, zs, x < yy < zFalse) :

                        If a set s does not contain any triple of elements x < y < z, then s is finite.