PhysLean Documentation

Init.Data.List.Sort.Impl

Replacing merge and mergeSort at runtime with tail-recursive and faster versions. #

We replace merge with mergeTR using a @[csimp] lemma.

We replace mergeSort in two steps:

There is no public API in this file; it solely exists to implement the @[csimp] lemmas affecting runtime behaviour.

Future work #

The current runtime implementation could be further improved in a number of ways, e.g.:

Because the theory developed for mergeSort is independent of the runtime implementation, as long as such improvements are carefully validated by benchmarking, they can be done without changing the theory, as long as a @[csimp] lemma is provided.

def List.MergeSort.Internal.mergeTR {α : Type u_1} (l₁ l₂ : List α) (le : ααBool) :
List α

O(|l₁| + |l₂|). Merge two lists using le as a switch.

Equations
Instances For
    def List.MergeSort.Internal.splitRevAt {α : Type u_1} (n : Nat) (l : List α) :
    List α × List α

    Variant of splitAt, that does not reverse the first list, i.e splitRevAt n l = ((l.take n).reverse, l.drop n).

    This exists solely as an optimization for mergeSortTR and mergeSortTR₂, and should not be used elsewhere.

    Equations
    Instances For
      theorem List.MergeSort.Internal.splitRevAt_eq {α : Type u_1} (i : Nat) (l : List α) :
      def List.MergeSort.Internal.mergeSortTR {α : Type u_1} (l : List α) (le : ααBool := by exact fun a b => a ≤ b) :
      List α

      An intermediate speed-up for mergeSort. This version uses the tail-recursive mergeTR function as a subroutine.

      This is not the final version we use at runtime, as mergeSortTR₂ is faster. This definition is useful as an intermediate step in proving the @[csimp] lemma for mergeSortTR₂.

      Equations
      Instances For
        def List.MergeSort.Internal.splitRevInTwo {α : Type u_1} {n : Nat} (l : { l : List α // l.length = n }) :
        { l : List α // l.length = (n + 1) / 2 } × { l : List α // l.length = n / 2 }

        Split a list in two equal parts, reversing the first part. If the length is odd, the first part will be one element longer.

        Equations
        Instances For
          def List.MergeSort.Internal.splitRevInTwo' {α : Type u_1} {n : Nat} (l : { l : List α // l.length = n }) :
          { l : List α // l.length = n / 2 } × { l : List α // l.length = (n + 1) / 2 }

          Split a list in two equal parts, reversing the first part. If the length is odd, the second part will be one element longer.

          Equations
          Instances For
            def List.MergeSort.Internal.mergeSortTR₂ {α : Type u_1} (l : List α) (le : ααBool := by exact fun a b => a ≤ b) :
            List α

            Faster version of mergeSortTR, which avoids unnecessary list reversals.

            Equations
            Instances For