#include "test_helpers.h"
#include "fmpz_mpoly_factor.h"
void check_content(const fmpz_mpoly_t p, const fmpz_mpoly_ctx_t ctx)
{
slong i, v;
fmpz_mpoly_t q;
fmpz_mpoly_factor_t g;
fmpz_t deg;
fmpz_mpoly_factor_init(g, ctx);
fmpz_mpoly_init(q, ctx);
fmpz_init(deg);
if (!fmpz_mpoly_factor_content(g, p, ctx))
{
flint_printf("FAIL:\ncheck factorization could be computed\n");
fflush(stdout);
flint_abort();
}
for (i = 0; i < g->num; i++)
{
if (g->poly[i].length < 1 || fmpz_sgn(g->poly[i].coeffs + 0) < 0)
{
flint_printf("FAIL:\nfactorization is not unit normal\n");
fflush(stdout);
flint_abort();
}
}
fmpz_mpoly_factor_expand(q, g, ctx);
if (!fmpz_mpoly_equal(q, p, ctx))
{
flint_printf("FAIL:\nfactorization does not match original polynomial\n");
fflush(stdout);
flint_abort();
}
for (i = 0; i < g->num; i++)
{
for (v = 0; v < ctx->minfo->nvars; v++)
{
if (fmpz_mpoly_length(g->poly + i, ctx) < 2)
{
if (!fmpz_mpoly_is_gen(g->poly + i, -1, ctx))
{
flint_printf("FAIL:\nmonomial is bad\n");
fflush(stdout);
flint_abort();
}
}
else
{
if (!fmpz_mpoly_content_vars(q, g->poly + i, &v, 1, ctx))
{
flint_printf("FAIL:\ncheck content could be computed\n");
fflush(stdout);
flint_abort();
}
fmpz_mpoly_degree_fmpz(deg, g->poly + i, v, ctx);
if (!fmpz_mpoly_is_one(q, ctx) && !fmpz_is_zero(deg))
{
flint_printf("FAIL:\ncontent is bad\n");
fflush(stdout);
flint_abort();
}
}
}
}
fmpz_mpoly_clear(q, ctx);
fmpz_mpoly_factor_clear(g, ctx);
fmpz_clear(deg);
}
TEST_FUNCTION_START(fmpz_mpoly_factor_content, state)
{
slong i, j, k, tmul = 30;
for (i = 0; i < tmul * flint_test_multiplier(); i++)
{
fmpz_mpoly_ctx_t ctx;
fmpz_mpoly_t a, t;
slong n, nfacs, len;
ulong * expbounds;
flint_bitcnt_t coeffbits;
fmpz_mpoly_ctx_init_rand(ctx, state, 10);
fmpz_mpoly_init(a, ctx);
fmpz_mpoly_init(t, ctx);
n = FLINT_MAX(WORD(1), ctx->minfo->nvars);
nfacs = 5 + (8 + n_randint(state, 8))/n;
expbounds = FLINT_ARRAY_ALLOC(ctx->minfo->nvars, ulong);
for (k = 0; k < ctx->minfo->nvars; k++)
expbounds[k] = 3;
fmpz_mpoly_one(a, ctx);
for (j = 0; j < nfacs; j++)
{
len = 1 + n_randint(state, 9);
coeffbits = 2 + n_randint(state, 100);
if (ctx->minfo->nvars > 0)
{
k = n_randint(state, ctx->minfo->nvars);
expbounds[k] = 1;
}
fmpz_mpoly_randtest_bounds(t, state, len, coeffbits, expbounds, ctx);
if (!fmpz_mpoly_is_zero(t, ctx))
{
fmpz_mpoly_mul(t, a, t, ctx);
if (t->length < 1500)
fmpz_mpoly_swap(a, t, ctx);
}
}
check_content(a, ctx);
flint_free(expbounds);
fmpz_mpoly_clear(t, ctx);
fmpz_mpoly_clear(a, ctx);
fmpz_mpoly_ctx_clear(ctx);
}
TEST_FUNCTION_END(state);
}