Lazy Discrimination Tree #
This file defines a new type of discrimination tree optimized for rapid population of imported modules for use in tactics. It uses a lazy initialization strategy.
The discrimination tree can be created through
createImportedDiscrTree. This creates a discrimination tree from all
imported modules in an environment using a callback that provides the
entries as InitEntry values.
The function getMatch can be used to get the values that match the
expression as well as an updated lazy discrimination tree that has
elaborated additional parts of the tree.
Equations
Equations
Equations
Hash function
Equations
- (Lean.Meta.LazyDiscrTree.Key.const a a_1).hash = mixHash 5237 (mixHash a.hash (hash a_1))
- (Lean.Meta.LazyDiscrTree.Key.fvar a a_1).hash = mixHash 3541 (mixHash (hash a) (hash a_1))
- (Lean.Meta.LazyDiscrTree.Key.lit a).hash = mixHash 1879 (hash a)
- Lean.Meta.LazyDiscrTree.Key.star.hash = 7883
- Lean.Meta.LazyDiscrTree.Key.other.hash = 2411
- Lean.Meta.LazyDiscrTree.Key.arrow.hash = 17
- (Lean.Meta.LazyDiscrTree.Key.proj a a_1 a_2).hash = mixHash (hash a_2) (mixHash (hash a) (hash a_1))
Instances For
Equations
LazyDiscrTree is a variant of the discriminator tree datatype
DiscrTree in Lean core that is designed to be efficiently
initializable with a large number of patterns.  This is useful
in contexts such as searching an entire Lean environment for
expressions that match a pattern.
Lazy discriminator trees achieve good performance by minimizing the amount of work that is done up front to build the discriminator tree. When first adding patterns to the tree, only the root discriminator key is computed and processing the remaining terms is deferred until demanded by a match.
- tries : Array (Lean.Meta.LazyDiscrTree.Trie✝ α)Backing array of trie entries. Should be owned by this trie. 
- Map from discriminator trie roots to the index. 
Instances For
Create a key path from an expression using the function used for patterns.
This differs from Lean.Meta.DiscrTree.mkPath and targetPath in that the expression should uses free variables rather than meta-variables for holes.
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
This drops a specific key from the lazy discrimination tree so that all the entries matching that key exactly are removed.
Equations
Instances For
A match result contains the terms formed from matching a term against patterns in the discrimination tree.
- The elements in the match result. - The top-level array represents an array from - scorevalues to the results with that score. A- scoreis the number of non-star matches in a pattern against the term, and thus bounded by the size of the term being matched against. The elements of this array are themselves arrays of non-empty arrays so that we can defer concatenating results until needed.
Instances For
Number of elements in result
Equations
Instances For
Append results to array
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- mr.appendResults a = mr.appendResultsAux a fun (x : Nat) (a : α) => a
Instances For
- score : Nat
Instances For
Find values that match e in d.
The results are ordered so that the longest matches in terms of number of non-star keys are first with ties going to earlier operators first.
Equations
Instances For
Merge two discrimination trees.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Initial entry in lazy discrimination tree
- key : KeyReturn root key for an entry. 
- entry : Lean.Meta.LazyDiscrTree.LazyEntry✝ αReturns rest of entry for later insertion. 
Instances For
Creates an entry for a subterm of an initial entry.
This is slightly more efficient than using fromExpr on subterms since it avoids a redundant call
to whnf.
Equations
- One or more equations did not get rendered due to their size.
Instances For
- ngen : NameGenerator
- core : Core.Cache
- meta : Meta.Cache
Instances For
Instances For
Equations
- One or more equations did not get rendered due to their size.
- Lean.Meta.LazyDiscrTree.blacklistInsertion env declName = (!Lean.Meta.allowCompletion env declName || declName == `sorryAx || declName.isInternalDetail || false || false)
Instances For
Combine two initial results.
Equations
Instances For
Equations
- Lean.Meta.LazyDiscrTree.getChildNgen = do let ngen ← Lean.getNGen match ngen.mkChild with | (cngen, ngen) => do Lean.setNGen ngen pure cngen
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- t.dropKeys keys = List.foldlM (fun (x1 : Lean.Meta.LazyDiscrTree α) (x2 : List Lean.Meta.LazyDiscrTree.Key) => x1.dropKey x2) t keys
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Create a discriminator tree for imported environment.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Allocate constants to tasks according to constantsPerTask.
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
A discriminator tree for the current module's declarations only.
Note. We use different discriminator trees for imported and current module declarations since imported declarations are typically much more numerous but not changed after the environment is created.
- ref : IO.Ref (LazyDiscrTree α)
Instances For
Create a discriminator tree for current module declarations.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Creates reference for lazy discriminator tree that only contains this module's definitions.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Returns candidates from this module in this module that match the expression.
- moduleRefis a references to a lazy discriminator tree only containing this module's definitions.
Equations
- One or more equations did not get rendered due to their size.
Instances For
findMatchesExt searches for entries in a lazily initialized discriminator tree.
It provides some additional capabilities beyond findMatches to adjust results
based on priority and cache module declarations
- modulesTreeRefpoints to the discriminator tree for local environment. Used for caching and created by- createLocalTree.
- extshould be an environment extension with an IO.Ref for caching the import lazy discriminator tree.
- addEntryis the function for creating discriminator tree entries from constants.
- droppedKeyscontains keys we do not want to consider when searching for matches. It is used for dropping very general keys.
- constantsPerTaskstores number of constants in imported modules used to decide when to create new task.
- adjustResulttakes the priority and value to produce a final result.
- tyis the expression type.
Equations
- One or more equations did not get rendered due to their size.
Instances For
findMatches searches for entries in a lazily initialized discriminator tree.
- extshould be an environment extension with an IO.Ref for caching the import lazy discriminator tree.
- addEntryis the function for creating discriminator tree entries from constants.
- droppedKeyscontains keys we do not want to consider when searching for matches. It is used for dropping very general keys.
Equations
- One or more equations did not get rendered due to their size.