lean4-htt/tests/lean/run/grind_ring_1.lean
Leonardo de Moura e36d1925f1
refactor: grind cutsat as solver extension (#10312)
This PR uses the new solver extension framework to implement `grind
cutsat`. All satellite solvers have been migrated to the new framework.
2025-09-09 00:23:12 +00:00

97 lines
2.6 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

module
set_option grind.debug true
open Std Lean.Grind
example [CommRing α] (x : α) : (x + 1)*(x - 1) = x^2 - 1 := by
grind
example [CommRing α] [IsCharP α 256] (x : α) : (x + 16)*(x - 16) = x^2 := by
grind
example (x : Int) : (x + 1)*(x - 1) = x^2 - 1 := by
grind
example (x : UInt8) : (x + 16)*(x - 16) = x^2 := by
grind
/--
trace: [grind.ring] new ring: Int
[grind.ring] NoNatZeroDivisors available: true
-/
#guard_msgs (trace) in
set_option trace.grind.ring true in
example (x : Int) : (x + 1)^2 - 1 = x^2 + 2*x := by
grind
example (x : BitVec 8) : (x + 16)*(x - 16) = x^2 := by
grind
/--
trace: [grind.ring] new ring: Ring.OfSemiring.Q Nat
[grind.ring] NoNatZeroDivisors available: true
[grind.ring] new ring: Int
[grind.ring] NoNatZeroDivisors available: true
[grind.ring] new ring: BitVec 8
[grind.ring] NoNatZeroDivisors available: false
-/
#guard_msgs (trace) in
set_option trace.grind.ring true in
example (x : BitVec 8) : (x + 1)^2 - 1 = x^2 + 2*x := by
grind
example (x : Int) : (x + 1)*(x - 1) = x^2 → False := by
grind
example (x y : Int) : (x + 1)*(x - 1)*y + y = y*x^2 + 1 → False := by
grind
example (x : UInt8) : (x + 1)*(x - 1) = x^2 → False := by
grind
example (x y : BitVec 8) : (x + 1)*(x - 1)*y + y = y*x^2 + 1 → False := by
grind
example [CommRing α] (x : α) : (x + 1)*(x - 1) = x^2 → False := by
fail_if_success grind
sorry
example [CommRing α] [IsCharP α 0] (x : α) : (x + 1)*(x - 1) = x^2 → False := by
grind
example [CommRing α] [IsCharP α 8] (x : α) : (x + 1)*(x - 1) = x^2 → False := by
grind
/-- trace: [grind.ring.assert.queue] -7 * x ^ 2 + 16 * y ^ 2 + x = 0 -/
#guard_msgs (trace) in
set_option trace.grind.ring.assert.queue true in
example (x y : Int) : x + 16*y^2 - 7*x^2 = 0 → False := by
fail_if_success grind -cutsat
sorry
/--
trace: [grind.debug.ring.basis] a ^ 2 * b + -1 = 0
[grind.debug.ring.basis] a * b ^ 2 + -1 * b = 0
[grind.debug.ring.basis] a * b + -1 * b = 0
[grind.debug.ring.basis] b + -1 = 0
[grind.debug.ring.basis] a + -1 = 0
-/
#guard_msgs (drop error, trace) in
set_option trace.grind.debug.ring.basis true in
example [CommRing α] (a b c : α)
: a^2*b = 1 → a*b^2 = b → False := by
grind
/--
trace: [grind.ring.assert.basis] a ^ 2 * b + -1 = 0
[grind.ring.assert.basis] a * b ^ 2 + -1 * b = 0
[grind.ring.assert.basis] a * b + -1 * b = 0
[grind.ring.assert.basis] b + -1 = 0
[grind.ring.assert.basis] a + -1 = 0
-/
#guard_msgs (drop error, trace) in
set_option trace.grind.ring.assert.basis true in
example [CommRing α] [LE α] [LT α] [IsPreorder α] [OrderedRing α] (a b c : α)
: a^2*b = 1 → a*b^2 = b → False := by
grind