Skip to content

Commit

Permalink
Expr.nat
Browse files Browse the repository at this point in the history
  • Loading branch information
kim-em committed Dec 15, 2023
1 parent 6b4cf96 commit 5fb302d
Showing 1 changed file with 38 additions and 0 deletions.
38 changes: 38 additions & 0 deletions Std/Lean/Expr.lean
Original file line number Diff line number Diff line change
Expand Up @@ -135,3 +135,41 @@ def constName (e : Expr) : Name :=
/-- Return the function (name) and arguments of an application. -/
def getAppFnArgs (e : Expr) : Name × Array Expr :=
withApp e λ e a => (e.constName, a)


/-- Turns an expression that is a natural number literal into a natural number. -/
def natLit! : Expr → Nat
| lit (Literal.natVal v) => v
| _ => panic! "nat literal expected"

/-- Turns an expression that is a constructor of `Int` applied to a natural number literal
into an integer. -/
def intLit! (e : Expr) : Int :=
if e.isAppOfArity ``Int.ofNat 1 then
e.appArg!.natLit!
else if e.isAppOfArity ``Int.negOfNat 1 then
.negOfNat e.appArg!.natLit!
else
panic! "not a raw integer literal"

/--
Checks if an expression is a "natural number in normal form",
i.e. of the form `OfNat n`, where `n` matches `.lit (.natVal lit)` for some `lit`.
and if so returns `lit`.
-/
-- Note that an `Expr.lit (.natVal n)` is not considered in normal form!
def nat? (e : Expr) : Option Nat := do
guard <| e.isAppOfArity ``OfNat.ofNat 3
let lit (.natVal n) := e.appFn!.appArg! | none
n

/--
Checks if an expression is an "integer in normal form",
i.e. either a natural number in normal form, or the negation of one,
and if so returns the integer.
-/
def int? (e : Expr) : Option Int :=
if e.isAppOfArity ``Neg.neg 3 then
(- ·) <$> e.appArg!.nat?
else
e.nat?

0 comments on commit 5fb302d

Please sign in to comment.