A map from rule names to rule pattern substitutions. When run on a goal, the rule pattern index returns such a map.
Instances For
Insert an array of rule pattern substitutions into a rule pattern substitution map.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Build a rule pattern substitution map from an array of substitutions.
Equations
Instances For
Convert a rule pattern substitution map to a flat array of substitutions.
Equations
- One or more equations did not get rendered due to their size.
Instances For
An entry of the rule pattern index.
- name : RuleNameThe name of the rule to which the pattern belongs. 
- pattern : RulePatternThe rule's pattern. We assume that there is at most one pattern per rule. 
Instances For
Equations
- Aesop.instBEqEntry = { beq := fun (e₁ e₂ : Aesop.RulePatternIndex.Entry) => e₁.name == e₂.name }
A rule pattern index. Maps expressions e to rule patterns that likely
unify with e.
- tree : Lean.Meta.DiscrTree EntryThe index. 
- isEmpty : Booltrueiff the index contains no patterns.
Instances For
Add a rule pattern to the index.
Equations
- Aesop.RulePatternIndex.add name pattern idx = { tree := idx.tree.insertCore pattern.discrTreeKeys { name := name, pattern := pattern }, isEmpty := false }
Instances For
Merge two rule pattern indices. Patterns that appear in both indices appear twice in the result.
Equations
Instances For
Get rule pattern substitutions for the patterns that match e.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Get all substitutions of the rule patterns that match a subexpression of
e. Subexpressions containing bound variables are not considered. The returned
array may contain duplicates.
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
Get all substitutions of the rule patterns that match a subexpression of
e. Subexpressions containing bound variables are not considered. The returned
array may contain duplicates.
Equations
Instances For
Get all substitutions of the rule patterns that match a subexpression of the given local declaration. Subexpressions containing bound variables are not considered.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Get all substitutions of the rule patterns that match a subexpression of the given local declaration. Subexpressions containing bound variables are not considered.
Equations
- Aesop.RulePatternIndex.getInLocalDecl ldecl idx = Aesop.RulePatternIndex.getInLocalDeclCore ∅ ldecl idx
Instances For
Get all substitutions of the rule patterns that match a subexpression of a hypothesis or the target. Subexpressions containing bound variables are not considered.
Equations
- One or more equations did not get rendered due to their size.