#include "test_helpers.h"
#include "fmpq.h"
TEST_FUNCTION_START(fmpq_next_minimal, state)
{
slong i;
fmpq_t r, ans;
fmpq_init(r);
fmpq_init(ans);
fmpq_set_si(r, 0, 1);
fmpq_set_si(ans, 85, 128);
for (i = 0; i < 10000; i++)
fmpq_next_minimal(r, r);
if (!fmpq_equal(r, ans))
{
flint_printf("FAIL: enum from 0\n");
fmpq_print(r);
flint_printf("\n");
fmpq_print(ans);
flint_printf("\n");
fflush(stdout);
flint_abort();
}
fmpq_set_si(r, 0, 1);
fmpq_set_si(ans, -25, 91);
for (i = 0; i < 10000; i++)
fmpq_next_signed_minimal(r, r);
if (!fmpq_equal(r, ans))
{
flint_printf("FAIL: signed enum from 0\n");
fmpq_print(r);
flint_printf("\n");
fmpq_print(ans);
flint_printf("\n");
fflush(stdout);
flint_abort();
}
fmpz_set_str(fmpq_numref(r), "36893488147419102231", 10);
fmpz_set_str(fmpq_denref(r), "36893488147419103232", 10);
fmpz_set_str(fmpq_numref(ans), "7484", 10);
fmpz_set_str(fmpq_denref(ans), "36893488147419103233", 10);
for (i = 0; i < 10000; i++)
fmpq_next_minimal(r, r);
if (!fmpq_equal(r, ans))
{
flint_printf("FAIL: enum from 2^65\n");
fmpq_print(r);
flint_printf("\n");
fmpq_print(ans);
flint_printf("\n");
fflush(stdout);
flint_abort();
}
fmpz_set_str(fmpq_numref(r), "36893488147419102231", 10);
fmpz_set_str(fmpq_denref(r), "36893488147419103232", 10);
fmpz_set_str(fmpq_numref(ans), "3326", 10);
fmpz_set_str(fmpq_denref(ans), "36893488147419103233", 10);
for (i = 0; i < 10000; i++)
fmpq_next_signed_minimal(r, r);
if (!fmpq_equal(r, ans))
{
flint_printf("FAIL: signed enum from 2^65\n");
fmpq_print(r);
flint_printf("\n");
fmpq_print(ans);
flint_printf("\n");
fflush(stdout);
flint_abort();
}
fmpq_clear(r);
fmpq_clear(ans);
TEST_FUNCTION_END(state);
}