Skip to content

Commit

Permalink
Polish
Browse files Browse the repository at this point in the history
  • Loading branch information
nomeata committed Jan 2, 2025
1 parent ed2e741 commit e2f2a9b
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 18 deletions.
1 change: 1 addition & 0 deletions src/Lean/Elab/Tactic.lean
Original file line number Diff line number Diff line change
Expand Up @@ -45,3 +45,4 @@ import Lean.Elab.Tactic.BVDecide
import Lean.Elab.Tactic.BoolToPropSimps
import Lean.Elab.Tactic.Classical
import Lean.Elab.Tactic.Grind
import Lean.Elab.Tactic.Monotonicity
28 changes: 13 additions & 15 deletions src/Lean/Elab/Tactic/Monotonicity.lean
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,7 @@ builtin_initialize registerBuiltinAttribute {
}

/--
Given expression `e` of the form `f xs`, possibly open, try to find monotonicity theorems.
for f.
Finds tagged monotonicity theorems of the form `monotone (fun x => e)`.
-/
def findMonoThms (e : Expr) : MetaM (Array Name) := do
(monotoneExt.getState (← getEnv)).getMatch e
Expand Down Expand Up @@ -98,7 +97,7 @@ partial def solveMonoCall (α inst_α : Expr) (e : Expr) : MetaM (Option Expr) :

def solveMonoStep (failK : ∀ {α}, Expr → Array Name → MetaM α := @defaultFailK) (goal : MVarId) : MetaM (List MVarId) :=
goal.withContext do
trace[Elab.Tactic.partial_monotonicity] "partial_monotonicity at\n{goal}"
trace[Elab.Tactic.monotonicity] "monotonicity at\n{goal}"
let type ← goal.getType
if type.isForall then
let (_, goal) ← goal.intro1P
Expand Down Expand Up @@ -171,23 +170,23 @@ def solveMonoStep (failK : ∀ {α}, Expr → Array Name → MetaM α := @defaul

-- A recursive call
if let some hmono ← solveMonoCall α inst_α e then
trace[Elab.Tactic.partial_monotonicity] "Found recursive call {e}:{indentExpr hmono}"
trace[Elab.Tactic.monotonicity] "Found recursive call {e}:{indentExpr hmono}"
unless ← goal.checkedAssign hmono do
trace[Elab.Tactic.partial_monotonicity] "Failed to assign {hmono} : {← inferType hmono} to goal"
trace[Elab.Tactic.monotonicity] "Failed to assign {hmono} : {← inferType hmono} to goal"
failK f #[]
return []

let monoThms ← withLocalDeclD `f f.bindingDomain! fun f =>
-- The discrimination tree does not like open terms
findMonoThms (e.instantiate1 f)
trace[Elab.Tactic.partial_monotonicity] "Found monoThms: {monoThms.map MessageData.ofConstName}"
trace[Elab.Tactic.monotonicity] "Found monoThms: {monoThms.map MessageData.ofConstName}"
for monoThm in monoThms do
let new_goals? ← try
let new_goals ← applyConst goal monoThm
trace[Elab.Tactic.partial_monotonicity] "Succeeded with {.ofConstName monoThm}"
trace[Elab.Tactic.monotonicity] "Succeeded with {.ofConstName monoThm}"
pure (some new_goals)
catch e =>
trace[Elab.Tactic.partial_monotonicity] "{e.toMessageData}"
trace[Elab.Tactic.monotonicity] "{e.toMessageData}"
pure none
if let some new_goals := new_goals? then
return new_goals
Expand All @@ -214,12 +213,11 @@ partial def solveMono (failK : ∀ {α}, Expr → Array Name → MetaM α := def
let new_goals ← solveMonoStep failK goal
new_goals.forM (solveMono failK)

end Lean.Meta.Monotonicity


open Lean Elab Tactic in
open Elab Tactic in
@[builtin_tactic Lean.Order.monotonicity]
def evalApplyRules : Tactic := fun _stx =>
liftMetaTactic Lean.Meta.Monotonicity.solveMonoStep
def evalMonotonicity : Tactic := fun _stx =>
liftMetaTactic Lean.Meta.Monotonicity.solveMonoStep

end Lean.Meta.Monotonicity

builtin_initialize Lean.registerTraceClass `Elab.Tactic.partial_monotonicity
builtin_initialize Lean.registerTraceClass `Elab.Tactic.monotonicity
3 changes: 0 additions & 3 deletions tests/lean/run/partial_fixpoint_monotonicity.lean
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,6 @@ attribute [partial_fixpoint_monotone]
monotone_ite
monotone_dite
monotone_bind
monotone_mapM
monotone_mapFinIdxM


/-
Should test that the tactic syntax is scoped, but cannot use #guard_msgs to catch “tactic not known”
Expand Down

0 comments on commit e2f2a9b

Please sign in to comment.