Documentation

Mathlib.Data.Fintype.Order

Order structures on finite types #

This file provides order instances on fintypes.

Computable instances #

On a Fintype, we can construct

Those are marked as def to avoid defeqness issues.

Completion instances #

Those instances are noncomputable because the definitions of sSup and sInf use Set.toFinset and set membership is undecidable in general.

On a Fintype, we can promote:

Those are marked as def to avoid typeclass loops.

Concrete instances #

We provide a few instances for concrete types:

@[reducible]

Constructs the of a finite nonempty SemilatticeInf.

Equations
Instances For
    @[reducible]

    Constructs the of a finite nonempty SemilatticeSup

    Equations
    Instances For
      @[reducible]

      Constructs the and of a finite nonempty Lattice.

      Equations
      Instances For
        @[reducible]
        noncomputable def Fintype.toCompleteLattice (α : Type u_2) [Fintype α] [Lattice α] [BoundedOrder α] :

        A finite bounded lattice is complete.

        Equations
        • One or more equations did not get rendered due to their size.
        Instances For
          @[reducible]

          A finite bounded distributive lattice is completely distributive.

          Equations
          Instances For
            @[reducible]

            A finite bounded linear order is complete.

            Equations
            • One or more equations did not get rendered due to their size.
            Instances For
              @[reducible]

              A finite boolean algebra is complete.

              Equations
              • One or more equations did not get rendered due to their size.
              Instances For
                @[reducible]

                A finite boolean algebra is complete and atomic.

                Equations
                Instances For
                  @[reducible]
                  noncomputable def Fintype.toCompleteLatticeOfNonempty (α : Type u_2) [Fintype α] [Nonempty α] [Lattice α] :

                  A nonempty finite lattice is complete. If the lattice is already a BoundedOrder, then use Fintype.toCompleteLattice instead, as this gives definitional equality for and .

                  Equations
                  Instances For
                    @[reducible]

                    A nonempty finite linear order is complete. If the linear order is already a BoundedOrder, then use Fintype.toCompleteLinearOrder instead, as this gives definitional equality for and .

                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For

                      Concrete instances #

                      noncomputable instance Fin.completeLinearOrder {n : } :
                      Equations

                      Directed Orders #

                      theorem Directed.fintype_le {α : Type u_1} {r : ααProp} [IsTrans α r] {β : Type u_2} {γ : Type u_3} [Nonempty γ] {f : γα} [Fintype β] (D : Directed r f) (g : βγ) :
                      z, (i : β) → r (f (g i)) (f z)
                      theorem Fintype.exists_le {α : Type u_1} [Nonempty α] [Preorder α] [IsDirected α fun x x_1 => x x_1] {β : Type u_2} [Fintype β] (f : βα) :
                      M, ∀ (i : β), f i M
                      theorem Fintype.exists_ge {α : Type u_1} [Nonempty α] [Preorder α] [IsDirected α fun x x_1 => x x_1] {β : Type u_2} [Fintype β] (f : βα) :
                      M, ∀ (i : β), M f i
                      theorem Fintype.bddAbove_range {α : Type u_1} [Nonempty α] [Preorder α] [IsDirected α fun x x_1 => x x_1] {β : Type u_2} [Fintype β] (f : βα) :
                      theorem Fintype.bddBelow_range {α : Type u_1} [Nonempty α] [Preorder α] [IsDirected α fun x x_1 => x x_1] {β : Type u_2} [Fintype β] (f : βα) :