Documentation

Lean.Compiler.LCNF.Simp.DiscrM

  • discrCtorMap : FVarIdMap CtorInfo

    A mapping from discriminant to constructor application it is equal to in the current context.

  • ctorDiscrMap : PersistentExprMap FVarId

    A mapping from constructor application to discriminant it is equal to in the current context.

@[reducible, inline]

Helper monad for tracking mappings from discriminant to constructor applications and back. The combinator withDiscrCtor should be used when visiting cases alternatives.

Equations

If fvarId is a constructor application, returns constructor information. Remark: we use the map discrCtorMap. Remark: We use this method when simplifying projections and cases-constructor.

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

If type is an inductive datatype, return its universe levels and parameters.

Equations
  • One or more equations did not get rendered due to their size.
@[inline]
def Lean.Compiler.LCNF.Simp.withDiscrCtorImp {α : Type} (discr : FVarId) (ctorName : Name) (ctorFields : Array Param) (x : DiscrM α) :

Execute x with the information that discr = ctorName ctorFields. We use this information to simplify nested cases on the same discriminant.

Equations
  • One or more equations did not get rendered due to their size.
Equations
  • One or more equations did not get rendered due to their size.
@[inline]
def Lean.Compiler.LCNF.Simp.withDiscrCtor {m : TypeType u_1} {α : Type} [MonadFunctorT DiscrM m] (discr : FVarId) (ctorName : Name) (ctorFields : Array Param) :
m αm α

Execute x with the information that discr = ctorName ctorFields. We use this information to simplify nested cases on the same discriminant.

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