From: Norbert Voelker <norbert@essex.ac.uk>
Trying to prove
lemma div_less_square: "[| x < n * n; 0 < n |] ==> x div n < (n::nat)";
arith fails with the following counter example:
x div n = 1, x = 0, n * n = 1, n = 1
This seems odd given that ((x div n) = (0 div 1) = 0) according to
Divides.div_0.
Any thoughts? Is my interpretation of the counter example perhaps incorrect?
Norbert.
From: nipkow@in.tum.de
lemma div_less_square: "[| x < n * n; 0 < n |] ==> x div n < (n::nat)";
arith fails with the following counter example:
Multiplication and div are outside linear arithmetic and lead into
undecidable territory. Hence arith ignores them (except in special cases
involving numerals) which means that "n * n" and "x div n" are simply
regarded as new variables. In such cases one may get bogus counter examples.
Tobias
Last updated: Jan 04 2025 at 20:18 UTC