Documentation

Lean.Level

def Nat.imax (n m : Nat) :
Equations
  • n.imax m = if m = 0 then 0 else n.max m
Instances For

    Cached hash code, cached results, and other data for Level. hash : 32-bits hasMVar : 1-bit hasParam : 1-bit depth : 24-bits

    Equations
    Instances For
      Equations
      Instances For
        Equations
        Equations
        Instances For
          Equations
          Instances For
            Equations
            Instances For
              def Lean.Level.mkData (h : UInt64) (depth : Nat := 0) (hasMVar hasParam : Bool := 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.

                Universe level metavariable Id

                Instances For
                  @[reducible, inline]

                  Short for LevelMVarId

                  Equations
                  Instances For
                    Equations
                    Equations
                    Instances For
                      Equations
                      Instances For
                        @[implemented_by Lean.Level.data._override]
                        Equations
                        Instances For
                          inductive Lean.Level :
                          Instances For
                            Equations
                            • u.hash = u.data.hash
                            Instances For
                              Equations
                              • u.depth = u.data.depth.toNat
                              Instances For
                                Equations
                                • u.hasMVar = u.data.hasMVar
                                Instances For
                                  Equations
                                  • u.hasParam = u.data.hasParam
                                  Instances For
                                    @[export lean_level_hash]
                                    Equations
                                    • u.hashEx = (hash u).toUInt32
                                    Instances For
                                      @[export lean_level_has_mvar]
                                      Equations
                                      Instances For
                                        @[export lean_level_has_param]
                                        Equations
                                        Instances For
                                          @[export lean_level_depth]
                                          Equations
                                          • u.depthEx = u.data.depth
                                          Instances For
                                            Equations
                                            Instances For
                                              Equations
                                              Instances For
                                                Equations
                                                Instances For
                                                  Equations
                                                  Instances For
                                                    @[export lean_level_mk_zero]
                                                    Equations
                                                    Instances For
                                                      @[export lean_level_mk_succ]
                                                      Equations
                                                      Instances For
                                                        @[export lean_level_mk_mvar]
                                                        Equations
                                                        Instances For
                                                          @[export lean_level_mk_param]
                                                          Equations
                                                          Instances For
                                                            @[export lean_level_mk_max]
                                                            Equations
                                                            Instances For
                                                              @[export lean_level_mk_imax]
                                                              Equations
                                                              Instances For
                                                                Equations
                                                                Instances For
                                                                  Equations
                                                                  Instances For
                                                                    Equations
                                                                    Instances For
                                                                      Equations
                                                                      Instances For
                                                                        Equations
                                                                        Instances For
                                                                          Equations
                                                                          Instances For
                                                                            Equations
                                                                            Instances For
                                                                              Equations
                                                                              Instances For

                                                                                If result is true, then forall assignments A which assigns all parameters and metavariables occurring in l, l[A] != zero

                                                                                Equations
                                                                                Instances For
                                                                                  Equations
                                                                                  Instances For
                                                                                    Equations
                                                                                    Instances For
                                                                                      Equations
                                                                                      • u.succ.getOffsetAux x✝ = u.getOffsetAux (x✝ + 1)
                                                                                      • x✝¹.getOffsetAux x✝ = x✝
                                                                                      Instances For
                                                                                        Equations
                                                                                        • lvl.getOffset = lvl.getOffsetAux 0
                                                                                        Instances For
                                                                                          Equations
                                                                                          • a.succ.getLevelOffset = a.getLevelOffset
                                                                                          • x✝.getLevelOffset = x✝
                                                                                          Instances For
                                                                                            Equations
                                                                                            Instances For
                                                                                              @[extern lean_level_eq]

                                                                                              occurs u l return true iff u occurs in l.

                                                                                              Equations
                                                                                              • x✝.occurs v₁.succ = (x✝ == v₁.succ || x✝.occurs v₁)
                                                                                              • x✝.occurs (v₁.max v₂) = (x✝ == v₁.max v₂ || x✝.occurs v₁ || x✝.occurs v₂)
                                                                                              • x✝.occurs (v₁.imax v₂) = (x✝ == v₁.imax v₂ || x✝.occurs v₁ || x✝.occurs v₂)
                                                                                              • x✝¹.occurs x✝ = (x✝¹ == x✝)
                                                                                              Instances For
                                                                                                Equations
                                                                                                Instances For
                                                                                                  @[irreducible]
                                                                                                  Equations
                                                                                                  • l₁.succ.normLtAux x✝² x✝¹ x✝ = l₁.normLtAux (x✝² + 1) x✝¹ x✝
                                                                                                  • x✝².normLtAux x✝¹ l₂.succ x✝ = x✝².normLtAux x✝¹ l₂ (x✝ + 1)
                                                                                                  • (l₁₁.max l₁₂).normLtAux x✝¹ (l₂₁.max l₂₂) x✝ = if (l₁₁.max l₁₂ == l₂₁.max l₂₂) = true then decide (x✝¹ < x✝) else if (l₁₁ != l₂₁) = true then l₁₁.normLtAux 0 l₂₁ 0 else l₁₂.normLtAux 0 l₂₂ 0
                                                                                                  • (l₁₁.imax l₁₂).normLtAux x✝¹ (l₂₁.imax l₂₂) x✝ = if (l₁₁.imax l₁₂ == l₂₁.imax l₂₂) = true then decide (x✝¹ < x✝) else if (l₁₁ != l₂₁) = true then l₁₁.normLtAux 0 l₂₁ 0 else l₁₂.normLtAux 0 l₂₂ 0
                                                                                                  • (Lean.Level.param n₁).normLtAux x✝¹ (Lean.Level.param n₂) x✝ = if (n₁ == n₂) = true then decide (x✝¹ < x✝) else n₁.lt n₂
                                                                                                  • (Lean.Level.mvar n₁).normLtAux x✝¹ (Lean.Level.mvar n₂) x✝ = if (n₁ == n₂) = true then decide (x✝¹ < x✝) else n₁.name.lt n₂.name
                                                                                                  • x✝³.normLtAux x✝² x✝¹ x✝ = if (x✝³ == x✝¹) = true then decide (x✝² < x✝) else decide (x✝³.ctorToNat < x✝¹.ctorToNat)
                                                                                                  Instances For
                                                                                                    def Lean.Level.normLt (l₁ l₂ : Lean.Level) :

                                                                                                    A total order on level expressions that has the following properties

                                                                                                    • succ l is an immediate successor of l.
                                                                                                    • zero is the minimal element. This total order is used in the normalization procedure.
                                                                                                    Equations
                                                                                                    • l₁.normLt l₂ = l₁.normLtAux 0 l₂ 0
                                                                                                    Instances For

                                                                                                      Return true if u and v denote the same level. Check is currently incomplete.

                                                                                                      Equations
                                                                                                      • u.isEquiv v = (u == v || u.normalize == v.normalize)
                                                                                                      Instances For

                                                                                                        Reduce (if possible) universe level by 1

                                                                                                        Equations
                                                                                                        Instances For
                                                                                                          Equations
                                                                                                          Instances For
                                                                                                            Equations
                                                                                                            Instances For
                                                                                                              Equations
                                                                                                              Equations
                                                                                                              def Lean.Level.quote (u : Lean.Level) (prec : Nat := 0) (mvars : Bool := true) :
                                                                                                              Equations
                                                                                                              Instances For
                                                                                                                Equations
                                                                                                                Equations
                                                                                                                Instances For
                                                                                                                  Equations
                                                                                                                  Instances For

                                                                                                                    The update functions try to avoid allocating new values using pointer equality. Note that if the update*! functions are used under a match-expression, the compiler will eliminate the double-match.

                                                                                                                    @[implemented_by _private.Lean.Level.0.Lean.Level.updateSucc!Impl]
                                                                                                                    Equations
                                                                                                                    Instances For
                                                                                                                      @[implemented_by _private.Lean.Level.0.Lean.Level.updateMax!Impl]
                                                                                                                      def Lean.Level.updateMax! (lvl newLhs newRhs : Lean.Level) :
                                                                                                                      Equations
                                                                                                                      Instances For
                                                                                                                        @[implemented_by _private.Lean.Level.0.Lean.Level.updateIMax!Impl]
                                                                                                                        def Lean.Level.updateIMax! (lvl newLhs newRhs : Lean.Level) :
                                                                                                                        Equations
                                                                                                                        Instances For
                                                                                                                          @[specialize #[]]
                                                                                                                          Equations
                                                                                                                          Instances For
                                                                                                                            Equations
                                                                                                                            Instances For
                                                                                                                              Equations
                                                                                                                              Instances For
                                                                                                                                Equations
                                                                                                                                Instances For
                                                                                                                                  Equations
                                                                                                                                  Instances For
                                                                                                                                    @[irreducible]
                                                                                                                                    Instances For
                                                                                                                                      @[reducible, inline]
                                                                                                                                      abbrev Lean.LevelMap (α : Type) :
                                                                                                                                      Equations
                                                                                                                                      Instances For
                                                                                                                                        @[reducible, inline]
                                                                                                                                        Equations
                                                                                                                                        Instances For
                                                                                                                                          @[reducible, inline]
                                                                                                                                          Equations
                                                                                                                                          Instances For
                                                                                                                                            @[reducible, inline]
                                                                                                                                            Equations
                                                                                                                                            Instances For
                                                                                                                                              @[reducible, inline]
                                                                                                                                              Equations
                                                                                                                                              Instances For
                                                                                                                                                Equations
                                                                                                                                                • v.succ.collectMVars s = v.collectMVars s
                                                                                                                                                • (u_2.max v).collectMVars s = u_2.collectMVars (v.collectMVars s)
                                                                                                                                                • (u_2.imax v).collectMVars s = u_2.collectMVars (v.collectMVars s)
                                                                                                                                                • (Lean.Level.mvar n).collectMVars s = Lean.RBTree.insert s n
                                                                                                                                                • u.collectMVars s = s
                                                                                                                                                Instances For
                                                                                                                                                  Equations
                                                                                                                                                  Instances For
                                                                                                                                                    Equations
                                                                                                                                                    Instances For
                                                                                                                                                      Equations
                                                                                                                                                      • u.any p = (u.find? p).isSome
                                                                                                                                                      Instances For
                                                                                                                                                        @[reducible, inline]
                                                                                                                                                        abbrev Nat.toLevel (n : Nat) :
                                                                                                                                                        Equations
                                                                                                                                                        Instances For