The pipeline phase a certain Pass
is supposed to happen in.
- base : Phase
Here we still carry most of the original type information, most of the dependent portion is already (partially) erased though.
- mono : Phase
In this phase polymorphism has been eliminated.
- impure : Phase
In this phase impure stuff such as RC or efficient BaseIO transformations happen.
Instances For
Equations
- Lean.Compiler.LCNF.instInhabitedPhase = { default := Lean.Compiler.LCNF.Phase.base }
Equations
- Lean.Compiler.LCNF.CompilerM.instInhabitedState = { default := { lctx := default, nextIdx := default } }
- phase : Phase
- config : ConfigOptions
Instances For
Equations
- Lean.Compiler.LCNF.CompilerM.instInhabitedContext = { default := { phase := default, config := default } }
Equations
Instances For
Equations
Instances For
Equations
- Lean.Compiler.LCNF.getPhase = do let __do_lift ← read pure __do_lift.phase
Instances For
Equations
- Lean.Compiler.LCNF.inBasePhase = do let __do_lift ← Lean.Compiler.LCNF.getPhase pure (match __do_lift with | Lean.Compiler.LCNF.Phase.base => true | x => false)
Instances For
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.
Instances For
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.
Instances For
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.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
Equations
Instances For
Equations
- Lean.Compiler.LCNF.eraseCodeDecl (Lean.Compiler.LCNF.CodeDecl.let decl_2) = Lean.Compiler.LCNF.eraseLetDecl decl_2
- Lean.Compiler.LCNF.eraseCodeDecl (Lean.Compiler.LCNF.CodeDecl.jp decl_2) = Lean.Compiler.LCNF.eraseFunDecl decl_2
- Lean.Compiler.LCNF.eraseCodeDecl (Lean.Compiler.LCNF.CodeDecl.fun decl_2) = Lean.Compiler.LCNF.eraseFunDecl decl_2
Instances For
Erase all free variables occurring in decls
from the local context.
Equations
Instances For
Equations
Instances For
A free variable substitution.
We use these substitutions when inlining definitions and "internalizing" LCNF code into CompilerM
.
During the internalization process, we ensure all free variables in the LCNF code do not collide with existing ones
at the CompilerM
local context.
Remark: in LCNF, (computationally relevant) data is in A-normal form, but this is not the case for types and type formers.
So, when inlining we often want to replace a free variable with a type or type former.
The substitution contains entries fvarId ↦ e
s.t., e
is a valid LCNF argument. That is,
it is a free variable, a type (or type former), or lcErased
.
Check.lean
contains a substitution validator.
Instances For
Result type for normFVar
and normFVarImp
.
- fvar
(fvarId : FVarId)
: NormFVarResult
New free variable.
- erased : NormFVarResult
Free variable has been erased. This can happen when instantiating polymorphic code with computationally irrelant stuff.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Add the entry fvarId ↦ fvarId'
to the free variable substitution.
Equations
Instances For
Add the substitution fvarId ↦ e
, e
must be a valid LCNF argument.
That is, it must be a free variable, type (or type former), or lcErased
.
See Check.lean
for the free variable substitution checker.
Equations
Instances For
Normalize the given free variable.
See normExprImp
for documentation on the translator
parameter.
This function is meant to be used in contexts where the input free-variable is computationally relevant.
This function panics if the substitution is mapping fvarId
to an expression that is not another free variable.
That is, it is not a type (or type former), nor lcErased
. Recall that a valid FVarSubst
contains only
expressions that are free variables, lcErased
, or type formers.
Equations
Instances For
Replace the free variables in e
using the given substitution.
If translator = true
, then we assume the free variables occurring in the range of the substitution are in another
local context. For example, translator = true
during internalization where we are making sure all free variables
in a given expression are replaced with new ones that do not collide with the ones in the current local context.
If translator = false
, we assume the substitution contains free variable replacements in the same local context,
and given entries such as x₁ ↦ x₂
, x₂ ↦ x₃
, ..., xₙ₋₁ ↦ xₙ
, and the expression f x₁ x₂
, we want the resulting
expression to be f xₙ xₙ
. We use this setting, for example, in the simplifier.
Equations
Instances For
Replace the free variables in arg
using the given substitution.
See normExprImp
Equations
Instances For
Replace the free variables in e
using the given substitution.
See normExprImp
Equations
Instances For
Replace the free variables in e
using the given substitution.
If translator = true
, then we assume the free variables occurring in the range of the substitution are in another
local context. For example, translator = true
during internalization where we are making sure all free variables
in a given expression are replaced with new ones that do not collide with the ones in the current local context.
If translator = false
, we assume the substitution contains free variable replacements in the same local context,
and given entries such as x₁ ↦ x₂
, x₂ ↦ x₃
, ..., xₙ₋₁ ↦ xₙ
, and the expression f x₁ x₂
, we want the resulting
expression to be f xₙ xₙ
. We use this setting, for example, in the simplifier.
Equations
Instances For
Normalize the given arguments using the current substitution.
Equations
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Helper functions for creating LCNF local declarations.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Compiler.LCNF.mkReturnErased = do let auxDecl ← Lean.Compiler.LCNF.mkLetDeclErased pure (Lean.Compiler.LCNF.Code.let auxDecl (Lean.Compiler.LCNF.Code.return auxDecl.fvarId))
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
Equations
- Lean.Compiler.LCNF.instMonadFVarSubstNormalizerM = { getSubst := read }
If result
is .fvar fvarId
, then return x fvarId
. Otherwise, it is .erased
,
and method returns let _x.i := .erased; return _x.i
.
Equations
Instances For
Equations
Instances For
Similar to internalize
, but does not refresh FVarId
s.
Equations
Instances For
Instances For
Equations
Instances For
Equations
- Lean.Compiler.LCNF.getConfig = do let __do_lift ← read pure __do_lift.config
Instances For
Equations
- x.run s phase = do let __do_lift ← Lean.getOptions (x { phase := phase, config := Lean.Compiler.LCNF.toConfigOptions __do_lift }).run' s