Given a metavariable mvarId representing the goal
Ctx |- T
and an expression e : I A j, where I A j is an inductive datatype where A are parameters,
and j the indices. Generate the goal
Ctx, j' : J, h' : I A j' |- j == j' -> e == h' -> T
Remark: (j == j' -> e == h') is a "telescopic" equality.
Remark: j is sequence of terms, and j' a sequence of free variables.
The result contains the fields
- mvarId: the new goal
- indicesFVarIds:- j'ids
- fvarId:- h'id
- numEqs: number of equations in the target
If varName? is not none, it is used to name h'.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Similar to generalizeTargets but customized for the casesOn motive.
Given a metavariable mvarId representing the
Ctx, h : I A j, D |- T
where fvarId is hs id, and the type I A j is an inductive datatype where A are parameters,
and j the indices. Generate the goal
Ctx, h : I A j, D, j' : J, h' : I A j' |- j == j' -> h == h' -> T
Remark: (j == j' -> h == h') is a "telescopic" equality.
Remark: j is sequence of terms, and j' a sequence of free variables.
The result contains the fields
- mvarId: the new goal
- indicesFVarIds:- j'ids
- fvarId:- h'id
- numEqs: number of equations in the target
Equations
- Lean.Meta.generalizeIndices mvarId fvarId = mvarId.withContext do let fvarDecl ← fvarId.getDecl Lean.Meta.generalizeIndices' mvarId fvarDecl.toExpr (some fvarDecl.userName)
Instances For
- inductiveVal : InductiveVal
- casesOnVal : DefinitionVal
- nminors : Nat
- majorDecl : LocalDecl
- majorTypeFn : Expr
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Apply casesOn using the free variable majorFVarId as the major premise (aka discriminant).
givenNames contains user-facing names for each alternative.
- useNatCasesAuxOnis a temporary hack for the- rcasesfamily of tactics. Do not use it, as it is subject to removal. It enables using- Nat.casesAuxOninstead of- Nat.casesOn, which causes case splits on- n : Natto be represented as- 0and- n' + 1rather than as- Nat.zeroand- Nat.succ n'.
Equations
- mvarId.cases majorFVarId givenNames useNatCasesAuxOn = Lean.Meta.Cases.cases mvarId majorFVarId givenNames useNatCasesAuxOn
Instances For
Split the goal in two subgoals: one containing the hypothesis h : p and another containing h : ¬ p.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Given dec : Decidable p, split the goal in two subgoals: one containing the hypothesis h : p and another containing h : ¬ p.
Equations
- One or more equations did not get rendered due to their size.