trans tactic #
This implements the trans tactic, which can apply transitivity theorems with an optional middle
variable argument.
Compose using transitivity, homogeneous case.
Equations
Instances For
Environment extension storing transitivity lemmas
solving e ← mkAppM' f #[x]
Equations
- One or more equations did not get rendered due to their size.
- Batteries.Tactic.getExplicitFuncArg? e = pure none
Instances For
solving tgt ← mkAppM' rel #[x, z] given tgt = f z
Equations
- One or more equations did not get rendered due to their size.
- Batteries.Tactic.getExplicitRelArg? tgt f z = pure none
Instances For
refining tgt ← mkAppM' rel #[x, z] dropping more arguments if possible
Equations
Instances For
Internal definition for trans tactic. Either a binary relation or a non-dependent
arrow.
- app
(rel : Lean.Expr)
 : TransRelationExpression for transitive relation. 
- implies
(name : Lean.Name)
(bi : Lean.BinderInfo)
 : TransRelationConstant name for transitive relation. 
Instances For
Finds an explicit binary relation in the argument, if possible.
Equations
- One or more equations did not get rendered due to their size.
- Batteries.Tactic.getRel (Lean.Expr.forallE name binderType body info) = pure (some (Batteries.Tactic.TransRelation.implies name info, binderType, body))
- Batteries.Tactic.getRel tgt = pure none
Instances For
trans applies to a goal whose target has the form t ~ u where ~ is a transitive relation,
that is, a relation which has a transitivity lemma tagged with the attribute [trans].
- trans sreplaces the goal with the two subgoals- t ~ sand- s ~ u.
- If sis omitted, then a metavariable is used instead.
Additionally, trans also applies to a goal whose target has the form t → u,
in which case it replaces the goal with t → s and s → u.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Synonym for trans tactic.
Equations
- One or more equations did not get rendered due to their size.