Большие целые и / или рациональные числа в задаче ввода не являются окончательным показателем твердости.
Z3 может генерировать большие числа внутри, даже если вход содержит только маленькие числа.
Я наблюдал много примеров, когда Z3 тратит много времени на обработку больших рациональных чисел.
Много времени тратится на вычисление GCD числителя и знаменателя.
Каждое вычисление GCD занимает относительно небольшое количество времени, но на сложных задачах Z3 выполнит миллионы из них.
Обратите внимание, что Z3 использует рациональные числа для решения чисто целочисленных задач, потому что он использует симплексный алгоритм для решения линейной арифметики.
Если вы разместите свой пример, я могу дать вам более точный ответ.