Which constants should be unfolded?
- all : TransparencyModeUnfolds all constants, even those tagged as @[irreducible].
- default : TransparencyModeUnfolds all constants except those tagged as @[irreducible].
- reducible : TransparencyModeUnfolds only constants tagged with the @[reducible]attribute.
- instances : TransparencyModeUnfolds reducible constants and constants tagged with the @[instance]attribute.
Instances For
Equations
Equations
Which structure types should eta be used with?
- all : EtaStructModeEnable eta for structure and classes. 
- notClasses : EtaStructModeEnable eta only for structures that are not classes. 
- none : EtaStructModeDisable eta for structures and classes. 
Instances For
Equations
Equations
The configuration for dsimp.
Passed to dsimp using, for example, the dsimp (config := {zeta := false}) syntax.
Implementation note: this structure is only used for processing the (config := ...) syntax, and it is not used internally.
It is immediately converted to Lean.Meta.Simp.Config by Lean.Elab.Tactic.elabSimpConfig.
- zeta : BoolWhen true(default:true), performs zeta reduction of let expressions. That is,let x := v; e[x]reduces toe[v]. See alsozetaDelta.
- beta : BoolWhen true(default:true), performs beta reduction of applications offunexpressions. That is,(fun x => e[x]) vreduces toe[v].
- eta : BoolTODO (currently unimplemented). When true(default:true), performs eta reduction forfunexpressions. That is,(fun x => f x)reduces tof.
- etaStruct : EtaStructModeConfigures how to determine definitional equality between two structure instances. See documentation for Lean.Meta.EtaStructMode.
- iota : BoolWhen true(default:true), reducesmatchexpressions applied to constructors.
- proj : BoolWhen true(default:true), reduces projections of structure constructors.
- decide : Bool
- autoUnfold : BoolWhen true(default:false), unfolds definitions. This can be enabled using thesimp!syntax.
- failIfUnchanged : BoolIf failIfUnchangedistrue(default:true), then calls tosimp,dsimp, orsimp_allwill fail if they do not make progress.
- unfoldPartialApp : BoolIf unfoldPartialAppistrue(default:false), then calls tosimp,dsimp, orsimp_allwill unfold even partial applications offwhen we requestfto be unfolded.
- zetaDelta : BoolWhen true(default:false), local definitions are unfolded. That is, given a local context containing entryx : t := e, the free variablexreduces toe.
- index : BoolWhen index(default :true) isfalse,simpwill only use the root symbol to find candidatesimptheorems. It approximates Lean 3simpbehavior.
- zetaUnused : BoolWhen true(default :true), then simps will remove unused let-declarations:let x := v; esimplifies toewhenxdoes not occur ine.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
Equations
- Lean.Meta.Simp.defaultMaxSteps = 100000
Instances For
The configuration for simp.
Passed to simp using, for example, the simp (config := {contextual := true}) syntax.
See also Lean.Meta.Simp.neutralConfig and Lean.Meta.DSimp.Config.
- maxSteps : NatThe maximum number of subexpressions to visit when performing simplification. The default is 100000. 
- maxDischargeDepth : NatWhen simp discharges side conditions for conditional lemmas, it can recursively apply simplification. The maxDischargeDepth(default: 2) is the maximum recursion depth when recursively applying simplification to side conditions.
- contextual : BoolWhen contextualis true (default:false) and simplification encounters an implicationp → qit includespas an additional simp lemma when simplifyingq.
- memoize : BoolWhen true (default: true) then the simplifier caches the result of simplifying each subexpression, if possible.
- singlePass : BoolWhen singlePassistrue(default:false), the simplifier runs through a single round of simplification, which consists of running pre-methods, recursing using congruence lemmas, and then running post-methods. Otherwise, when it isfalse, it iteratively applies this simplification procedure.
- zeta : BoolWhen true(default:true), performs zeta reduction of let expressions. That is,let x := v; e[x]reduces toe[v]. See alsozetaDelta.
- beta : BoolWhen true(default:true), performs beta reduction of applications offunexpressions. That is,(fun x => e[x]) vreduces toe[v].
- eta : BoolTODO (currently unimplemented). When true(default:true), performs eta reduction forfunexpressions. That is,(fun x => f x)reduces tof.
- etaStruct : EtaStructModeConfigures how to determine definitional equality between two structure instances. See documentation for Lean.Meta.EtaStructMode.
- iota : BoolWhen true(default:true), reducesmatchexpressions applied to constructors.
- proj : BoolWhen true(default:true), reduces projections of structure constructors.
- decide : Bool
- arith : BoolWhen true(default:false), simplifies simple arithmetic expressions.
- autoUnfold : BoolWhen true(default:false), unfolds definitions. This can be enabled using thesimp!syntax.
- dsimp : Bool
- failIfUnchanged : BoolIf failIfUnchangedistrue(default:true), then calls tosimp,dsimp, orsimp_allwill fail if they do not make progress.
- ground : BoolIf groundistrue(default:false), then ground terms are reduced. A term is ground when it does not contain free or meta variables. Reduction is interrupted at a function applicationf ...iffis marked to not be unfolded. Ground term reduction applies@[seval]lemmas.
- unfoldPartialApp : BoolIf unfoldPartialAppistrue(default:false), then calls tosimp,dsimp, orsimp_allwill unfold even partial applications offwhen we requestfto be unfolded.
- zetaDelta : BoolWhen true(default:false), local definitions are unfolded. That is, given a local context containing entryx : t := e, the free variablexreduces toe.
- index : BoolWhen index(default :true) isfalse,simpwill only use the root symbol to find candidatesimptheorems. It approximates Lean 3simpbehavior.
- implicitDefEqProofs : BoolIf implicitDefEqProofs := true,simpdoes not create proof terms when the input and output terms are definitionally equal.
- zetaUnused : BoolWhen true(default :true), then simps will remove unused let-declarations:let x := v; esimplifies toewhenxdoes not occur ine.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
Instances For
Instances For
Configuration for which occurrences that match an expression should be rewritten.
- all : OccurrencesAll occurrences should be rewritten. 
- pos
(idxs : List Nat)
 : OccurrencesA list of indices for which occurrences should be rewritten. 
- neg
(idxs : List Nat)
 : OccurrencesA list of indices for which occurrences should not be rewritten. 
Instances For
Equations
Equations
Equations
Configuration for the extract_lets tactic.
- proofs : BoolIf true (default: false), extract lets from subterms that are proofs. Top-level lets are always extracted. 
- types : BoolIf true (default: true), extract lets from subterms that are types. Top-level lets are always extracted. 
- implicits : BoolIf true (default: false), extract lets from subterms that are implicit arguments. 
- descend : Bool
- underBinder : BoolIf true (default: true), descend into forall/lambda/let bodies when extracting. Only relevant when descendis true.
- usedOnly : BoolIf true (default: false), eliminate unused lets rather than extract them. 
- merge : BoolIf true (default: true), reuse local declarations that have syntactically equal values. Note that even when false, the caching strategy for extract_lets may result in fewer extracted let bindings than expected.
- useContext : BoolWhen merging is enabled, if true (default: true), make use of pre-existing local definitions in the local context. 
- onlyGivenNames : BoolIf true (default: false), then once givenNamesis exhausted, stop extracting lets. Otherwise continue extracting lets.
- preserveBinderNames : BoolIf true (default: false), then when no name is provided for a 'let' expression, the name is used as-is without making it be inaccessible. The name still might be inaccessible if the binder name was. 
- lift : BoolIf true (default: false), lift non-extractable lets as far out as possible.
Instances For
Configuration for the lift_lets tactic.