Equations
- Nat.SOM.instInhabitedExpr = { default := Nat.SOM.Expr.num default }
Equations
- Nat.SOM.Expr.denote ctx (Nat.SOM.Expr.num n) = n
- Nat.SOM.Expr.denote ctx (Nat.SOM.Expr.var v) = Nat.Linear.Var.denote ctx v
- Nat.SOM.Expr.denote ctx (a.add b) = (Nat.SOM.Expr.denote ctx a).add (Nat.SOM.Expr.denote ctx b)
- Nat.SOM.Expr.denote ctx (a.mul b) = (Nat.SOM.Expr.denote ctx a).mul (Nat.SOM.Expr.denote ctx b)
Instances For
@[reducible, inline]
Equations
Instances For
Equations
- Nat.SOM.Mon.denote ctx [] = 1
- Nat.SOM.Mon.denote ctx (v :: vs) = (Nat.Linear.Var.denote ctx v).mul (Nat.SOM.Mon.denote ctx vs)
Instances For
Equations
- m₁.mul m₂ = Nat.SOM.Mon.mul.go Nat.Linear.hugeFuel m₁ m₂
Instances For
Equations
- One or more equations did not get rendered due to their size.
- Nat.SOM.Mon.mul.go 0 m₁ m₂ = m₁ ++ m₂
- Nat.SOM.Mon.mul.go fuel_2.succ m₁ [] = m₁
- Nat.SOM.Mon.mul.go fuel_2.succ [] m₂ = m₂
Instances For
@[reducible, inline]
Equations
Instances For
Equations
- Nat.SOM.Poly.denote ctx [] = 0
- Nat.SOM.Poly.denote ctx ((k, m) :: p) = (k.mul (Nat.SOM.Mon.denote ctx m)).add (Nat.SOM.Poly.denote ctx p)
Instances For
Equations
- p₁.add p₂ = Nat.SOM.Poly.add.go Nat.Linear.hugeFuel p₁ p₂
Instances For
Equations
- One or more equations did not get rendered due to their size.
- Nat.SOM.Poly.add.go 0 p₁ p₂ = p₁ ++ p₂
- Nat.SOM.Poly.add.go fuel_2.succ p₁ [] = p₁
- Nat.SOM.Poly.add.go fuel_2.succ [] p₂ = p₂
Instances For
Equations
- Nat.SOM.Poly.insertSorted k m [] = [(k, m)]
- Nat.SOM.Poly.insertSorted k m ((k_1, m_1) :: p_1) = bif decide (m < m_1) then (k, m) :: (k_1, m_1) :: p_1 else (k_1, m_1) :: Nat.SOM.Poly.insertSorted k m p_1
Instances For
Equations
- p.mulMon k m = Nat.SOM.Poly.mulMon.go k m p []
Instances For
Equations
- Nat.SOM.Poly.mulMon.go k m [] acc = acc
- Nat.SOM.Poly.mulMon.go k m ((k_1, m_1) :: p_1) acc = Nat.SOM.Poly.mulMon.go k m p_1 (Nat.SOM.Poly.insertSorted (k * k_1) (m.mul m_1) acc)
Instances For
Equations
- p₁.mul p₂ = Nat.SOM.Poly.mul.go p₂ p₁ []
Instances For
Equations
- Nat.SOM.Poly.mul.go p₂ [] acc = acc
- Nat.SOM.Poly.mul.go p₂ ((k, m) :: p) acc = Nat.SOM.Poly.mul.go p₂ p (acc.add (p₂.mulMon k m))
Instances For
Equations
- (Nat.SOM.Expr.num n).toPoly = bif n == 0 then [] else [(n, [])]
- (Nat.SOM.Expr.var v).toPoly = [(1, [v])]
- (a.add b).toPoly = a.toPoly.add b.toPoly
- (a.mul b).toPoly = a.toPoly.mul b.toPoly
Instances For
theorem
Nat.SOM.Poly.denote_insertSorted
(ctx : Linear.Context)
(k : Nat)
(m : Mon)
(p : Poly)
:
denote ctx (insertSorted k m p) = denote ctx p + k * Mon.denote ctx m
theorem
Nat.SOM.Expr.toPoly_denote
(ctx : Linear.Context)
(e : Expr)
:
Poly.denote ctx e.toPoly = denote ctx e
theorem
Nat.SOM.Expr.eq_of_toPoly_eq
(ctx : Linear.Context)
(a b : Expr)
(h : (a.toPoly == b.toPoly) = true)
: