Helper definitions and theorems for converting Semiring expressions into Ring ones.
We use them to implement grind
@[reducible, inline]
Equations
Instances For
Equations
@[reducible, inline]
Equations
Instances For
Equations
- Lean.Grind.Ring.OfSemiring.Var.denote ctx v = Lean.RArray.get ctx v
Instances For
Equations
- Lean.Grind.Ring.OfSemiring.Expr.denote ctx (Lean.Grind.Ring.OfSemiring.Expr.num k) = OfNat.ofNat k
- Lean.Grind.Ring.OfSemiring.Expr.denote ctx (Lean.Grind.Ring.OfSemiring.Expr.var v) = Lean.Grind.Ring.OfSemiring.Var.denote ctx v
- Lean.Grind.Ring.OfSemiring.Expr.denote ctx (a.add b) = Lean.Grind.Ring.OfSemiring.Expr.denote ctx a + Lean.Grind.Ring.OfSemiring.Expr.denote ctx b
- Lean.Grind.Ring.OfSemiring.Expr.denote ctx (a.mul b) = Lean.Grind.Ring.OfSemiring.Expr.denote ctx a * Lean.Grind.Ring.OfSemiring.Expr.denote ctx b
- Lean.Grind.Ring.OfSemiring.Expr.denote ctx (a.pow k) = Lean.Grind.Ring.OfSemiring.Expr.denote ctx a ^ k
Instances For
Equations
- Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx (Lean.Grind.Ring.OfSemiring.Expr.num k) = OfNat.ofNat k
- Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx (Lean.Grind.Ring.OfSemiring.Expr.var v) = ↑(Lean.Grind.Ring.OfSemiring.Var.denote ctx v)
- Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx (a.add b) = Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx a + Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx b
- Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx (a.mul b) = Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx a * Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx b
- Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx (a.pow k) = Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing ctx a ^ k
Instances For
theorem
Lean.Grind.Ring.OfSemiring.Expr.denoteAsRing_eq
{α : Type u_1}
[Semiring α]
(ctx : Context α)
(e : Expr)
 :
theorem
Lean.Grind.Ring.OfSemiring.of_eq
{α : Type u_1}
[Semiring α]
(ctx : Context α)
(lhs rhs : Expr)
 :
Expr.denote ctx lhs = Expr.denote ctx rhs → Expr.denoteAsRing ctx lhs = Expr.denoteAsRing ctx rhs
theorem
Lean.Grind.Ring.OfSemiring.of_diseq
{α : Type u_1}
[Semiring α]
[AddRightCancel α]
(ctx : Context α)
(lhs rhs : Expr)
 :
Expr.denote ctx lhs ≠ Expr.denote ctx rhs → Expr.denoteAsRing ctx lhs ≠ Expr.denoteAsRing ctx rhs
Equations
- (Lean.Grind.Ring.OfSemiring.Expr.num k).toPoly = Lean.Grind.CommRing.Poly.num ↑k
- (Lean.Grind.Ring.OfSemiring.Expr.var v).toPoly = Lean.Grind.CommRing.Poly.ofVar v
- (a.add b).toPoly = a.toPoly.combine b.toPoly
- (a.mul b).toPoly = a.toPoly.mul b.toPoly
- ((Lean.Grind.Ring.OfSemiring.Expr.num n).pow k).toPoly = Lean.Grind.CommRing.Poly.num (↑n ^ k)
- ((Lean.Grind.Ring.OfSemiring.Expr.var x_1).pow k).toPoly = Lean.Grind.CommRing.Poly.ofMon (Lean.Grind.CommRing.Mon.mult { x := x_1, k := k } Lean.Grind.CommRing.Mon.unit)
- (a.pow k).toPoly = a.toPoly.pow k
Instances For
- num (c : Int) : c ≥ 0 → (Poly.num c).NonnegCoeffs
- add (a : Int) (m : Mon) (p : Poly) : a ≥ 0 → p.NonnegCoeffs → (Poly.add a m p).NonnegCoeffs
Instances For
Equations
- Lean.Grind.CommRing.denoteSInt k = bif decide (k < 0) then 0 else OfNat.ofNat k.natAbs
Instances For
Equations
Instances For
theorem
Lean.Grind.CommRing.Poly.denoteS_ofMon
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(m : Mon)
 :
theorem
Lean.Grind.CommRing.Poly.denoteS_ofVar
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(x : Var)
 :
theorem
Lean.Grind.CommRing.Poly.denoteS_addConst
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p : Poly)
(k : Int)
 :
theorem
Lean.Grind.CommRing.Poly.denoteS_insert
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(k : Int)
(m : Mon)
(p : Poly)
 :
k ≥ 0 → p.NonnegCoeffs → denoteS ctx (insert k m p) = ↑k.toNat * Mon.denote ctx m + denoteS ctx p
theorem
Lean.Grind.CommRing.Poly.denoteS_concat
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p₁ p₂ : Poly)
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → denoteS ctx (p₁.concat p₂) = denoteS ctx p₁ + denoteS ctx p₂
theorem
Lean.Grind.CommRing.Poly.denoteS_mulConst
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(k : Int)
(p : Poly)
 :
theorem
Lean.Grind.CommRing.Poly.denoteS_mulMon
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(k : Int)
(m : Mon)
(p : Poly)
 :
k ≥ 0 → p.NonnegCoeffs → denoteS ctx (mulMon k m p) = ↑k.toNat * Mon.denote ctx m * denoteS ctx p
theorem
Lean.Grind.CommRing.Poly.denoteS_combine
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p₁ p₂ : Poly)
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → denoteS ctx (p₁.combine p₂) = denoteS ctx p₁ + denoteS ctx p₂
theorem
Lean.Grind.CommRing.Poly.mulConst_NonnegCoeffs
{p : Poly}
{k : Int}
 :
k ≥ 0 → p.NonnegCoeffs → (mulConst k p).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.mulMon_NonnegCoeffs
{p : Poly}
{k : Int}
(m : Mon)
 :
k ≥ 0 → p.NonnegCoeffs → (mulMon k m p).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.addConst_NonnegCoeffs
{p : Poly}
{k : Int}
 :
k ≥ 0 → p.NonnegCoeffs → (p.addConst k).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.concat_NonnegCoeffs
{p₁ p₂ : Poly}
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → (p₁.concat p₂).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.combine_NonnegCoeffs
{p₁ p₂ : Poly}
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → (p₁.combine p₂).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.mul_go_NonnegCoeffs
(p₁ p₂ acc : Poly)
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → acc.NonnegCoeffs → (mul.go p₂ p₁ acc).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.mul_NonnegCoeffs
{p₁ p₂ : Poly}
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → (p₁.mul p₂).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.pow_NonnegCoeffs
{p : Poly}
(k : Nat)
 :
p.NonnegCoeffs → (p.pow k).NonnegCoeffs
theorem
Lean.Grind.CommRing.Poly.denoteS_mul_go
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p₁ p₂ acc : Poly)
 :
p₁.NonnegCoeffs →
  p₂.NonnegCoeffs →
    acc.NonnegCoeffs → denoteS ctx (mul.go p₂ p₁ acc) = denoteS ctx acc + denoteS ctx p₁ * denoteS ctx p₂
theorem
Lean.Grind.CommRing.Poly.denoteS_mul
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p₁ p₂ : Poly)
 :
p₁.NonnegCoeffs → p₂.NonnegCoeffs → denoteS ctx (p₁.mul p₂) = denoteS ctx p₁ * denoteS ctx p₂
theorem
Lean.Grind.CommRing.Poly.denoteS_pow
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(p : Poly)
(k : Nat)
 :
theorem
Lean.Grind.Ring.OfSemiring.Expr.denoteS_toPoly
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(e : Expr)
 :
Equations
- Lean.Grind.Ring.OfSemiring.eq_normS_cert lhs rhs = (lhs.toPoly == rhs.toPoly)
Instances For
theorem
Lean.Grind.Ring.OfSemiring.eq_normS
{α : Type u_1}
[CommSemiring α]
(ctx : Context α)
(lhs rhs : Expr)
 :
eq_normS_cert lhs rhs = true → Expr.denote ctx lhs = Expr.denote ctx rhs