lean4-htt/tests/lean/grind/algebra/nat_mod.lean
Kim Morrison c06af84d9f
fix: refactor grind's module/ring design to avoid a diamond (#9168)
This PR resolves a defeq diamond, which caused a problem in Mathlib:
```
import Mathlib

example (R : Type) [I : Ring R] :
  @AddCommGroup.toGrindIntModule R (@Ring.toAddCommGroup R I) =
    @Lean.Grind.Ring.instIntModule R (@Ring.toGrindRing R I) := rfl -- fails
```
2025-07-03 06:50:46 +00:00

20 lines
765 B
Text

-- I'll start collecting particularly horrific examples
-- involving `Nat` modulo and div with variable denominators.
example (a b n : Nat) (ha : a < n) : (n - a) * b % n = (n - a * b % n) % n := by
rw [Nat.sub_mul]
rw [Nat.mod_eq_mod_iff]
match b with
| 0 => refine ⟨1, 0, by simp⟩
| b+1 =>
refine ⟨a*(b+1)/n, b, ?_⟩
rw [Nat.mod_def, Nat.mul_add_one, Nat.mul_comm _ n, Nat.mul_comm b n]
have : n * (a * (b + 1) / n) ≤ a * (b + 1) := Nat.mul_div_le (a * (b + 1)) n
have := Nat.lt_mul_div_succ (a * (b + 1)) (show 0 < n by omega)
rw [Nat.mul_add_one n] at this
have : a * (b + 1) ≤ n * b + n := by
rw [Nat.mul_add_one]
have := Nat.mul_le_mul_right b ha
rw [Nat.succ_mul] at this
omega
omega