Basic Definitions for RefinedDiscrTree #
We define
Discrimination tree key.
- star : KeyA metavariable. This key matches with anything. 
- labelledStar
(id : Nat)
 : KeyA metavariable. This key matches with anything. It stores an identifier. 
- opaque : KeyAn opaque variable. This key only matches with Key.star.
- const
(declName : Name)
(nargs : Nat)
 : KeyA constant. It stores the name and the arity. 
- fvar
(fvarId : FVarId)
(nargs : Nat)
 : KeyA free variable. It stores the FVarIdand the arity.
- bvar
(deBruijnIndex nargs : Nat)
 : KeyA bound variable, from a lambda or forall binder. It stores the De Bruijn index and the arity. 
- lit
(v : Literal)
 : KeyA literal. 
- sort : KeyA sort. Universe levels are ignored. 
- lam : KeyA lambda function. 
- forall : KeyA dependent arrow. 
- proj
(typeName : Name)
(idx nargs : Nat)
 : KeyA projection. It stores the structure name, the projection index and the arity. 
Instances For
Equations
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq Lean.Meta.RefinedDiscrTree.Key.star Lean.Meta.RefinedDiscrTree.Key.star = true
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.labelledStar a) (Lean.Meta.RefinedDiscrTree.Key.labelledStar b) = (a == b)
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq Lean.Meta.RefinedDiscrTree.Key.opaque Lean.Meta.RefinedDiscrTree.Key.opaque = true
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.const a a_1) (Lean.Meta.RefinedDiscrTree.Key.const b b_1) = (a == b && a_1 == b_1)
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.fvar a a_1) (Lean.Meta.RefinedDiscrTree.Key.fvar b b_1) = (a == b && a_1 == b_1)
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.bvar a a_1) (Lean.Meta.RefinedDiscrTree.Key.bvar b b_1) = (a == b && a_1 == b_1)
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.lit a) (Lean.Meta.RefinedDiscrTree.Key.lit b) = (a == b)
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq Lean.Meta.RefinedDiscrTree.Key.sort Lean.Meta.RefinedDiscrTree.Key.sort = true
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq Lean.Meta.RefinedDiscrTree.Key.lam Lean.Meta.RefinedDiscrTree.Key.lam = true
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq Lean.Meta.RefinedDiscrTree.Key.forall Lean.Meta.RefinedDiscrTree.Key.forall = true
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq (Lean.Meta.RefinedDiscrTree.Key.proj a a_1 a_2) (Lean.Meta.RefinedDiscrTree.Key.proj b b_1 b_2) = (a == b && (a_1 == b_1 && a_2 == b_2))
- Lean.Meta.RefinedDiscrTree.instBEqKey.beq x✝¹ x✝ = false
Instances For
Converts an entry (i.e., List Key) to the discrimination tree into
MessageData that is more user-friendly.
This is a copy of Lean.Meta.DiscrTree.keysAsPattern
Equations
- One or more equations did not get rendered due to their size.
Instances For
Get the next key.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Format the application f args.
Format the next expression.
Add parentheses if paren == true.
Equations
Instances For
Return the number of arguments that the Key takes.
Equations
- (Lean.Meta.RefinedDiscrTree.Key.const declName nargs).arity = nargs
- (Lean.Meta.RefinedDiscrTree.Key.fvar fvarId nargs).arity = nargs
- (Lean.Meta.RefinedDiscrTree.Key.bvar deBruijnIndex nargs).arity = nargs
- Lean.Meta.RefinedDiscrTree.Key.lam.arity = 1
- Lean.Meta.RefinedDiscrTree.Key.forall.arity = 2
- (Lean.Meta.RefinedDiscrTree.Key.proj typeName idx nargs).arity = nargs + 1
- x✝.arity = 0
Instances For
The information for computing the keys of a subexpression.
- expr : ExprThe expression 
- Variables that come from a lambda or forall binder. The list index gives the De Bruijn index. 
- lctx : LocalContextThe local context, which contains the introduced bound variables. 
- localInsts : LocalInstancesThe local instances, which may contain the introduced bound variables. 
- cfg : ConfigThe Meta.Configused by this entry.
Instances For
The possible values that can appear in the stack
- star : StackEntry.staris an expression that will not be explicitly indexed.
- expr
(info : ExprInfo)
 : StackEntry.expris an expression that will be indexed.
Instances For
A LazyEntry represents a snapshot of the computation of encoding an Expr as Array Key.
This is used for computing the keys one by one.
- If an expression creates more entries in the stack, for example because it is an application, then instead of pushing to the stack greedily, we only extend the stack once we need to. So, the field - previousis used to extend the- stackbefore looking in the- stack.- For example in - 10.add (20.add 30), after computing the key- ⟨Nat.add, 2⟩, the stack is still empty, and- previouswill be- 10.add (20.add 30).
- stack : List StackEntryThe stack, used to emulate recursion. It contains the list of all expressions for which the keys still need to be computed, in that order. For example in 10.add (20.add 30), after computing the keys⟨Nat.add, 2⟩and10, the stack will be a list of length 1 containing the expression20.add 30.
- mctx : MetavarContextThe metavariable context, which may contain variables appearing in this entry. 
- MVarIds corresponding to the- .labelledStarlabels. The index in the array is the label. It is- noneif we use- .starinstead of- labelledStar, for example when encoding the lookup expression.
Instances For
Array index of a Trie α in the tries of a RefinedDiscrTree.
Equations
Instances For
Discrimination tree trie. See RefinedDiscrTree.
A Trie will normally have exactly one of the following
- nonempty values
- nonempty stars,labelledStarsand/orchildren
- nonempty pendingBut defining it as a structure that can have all at the same time turns out to be easier.
- node :: (
- values : Array αReturn values, at a leaf 
- labelledStars : Std.HashMap Nat TrieIndexFollowing Tries based on aKey.labelledStar.
- children : Std.HashMap Key TrieIndex
- Lazy entries that still have to be evaluated. 
- )
Instances For
Lazy refined discrimination tree. It is an index from expressions to values of type α.
We store all of the nodes in one Array, tries, instead of using a 'normal' inductive type.
This is so that we can modify the tree globally, which is very useful when evaluating lazy
entries and saving the result globally.
- root : Std.HashMap Key TrieIndex
- Array of trie entries. Should be owned by this trie.