/* Copyright (C) 2007 David Howden Copyright (C) 2007, 2008, 2009, 2010 William Hart Copyright (C) 2008 Richard Howell-Peak Copyright (C) 2011 Fredrik Johansson Copyright (C) 2012 Lina Kulakova This file is part of FLINT. FLINT is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License (LGPL) as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. See . */ #include #include "fmpz_mod_poly.h" #include "ulong_extras.h" int main(void) { int iter; fmpz_mod_ctx_t ctx; FLINT_TEST_INIT(state); flint_printf("factor...."); fflush(stdout); fmpz_mod_ctx_init_ui(ctx, 2); for (iter = 0; iter < 20 * flint_test_multiplier(); iter++) { fmpz_mod_poly_t poly1, poly, q, r, product; fmpz_mod_poly_factor_t res; fmpz_t modulus; slong i, j, length, num; slong exp[6]; fmpz_init_set_ui(modulus, n_randtest_prime(state, 0)); fmpz_mod_ctx_set_modulus(ctx, modulus); fmpz_mod_poly_init(poly1, ctx); fmpz_mod_poly_init(poly, ctx); fmpz_mod_poly_init(q, ctx); fmpz_mod_poly_init(r, ctx); fmpz_mod_poly_zero(poly1, ctx); fmpz_mod_poly_set_coeff_ui(poly1, 0, 1, ctx); length = n_randint(state, 7) + 2; do { fmpz_mod_poly_randtest(poly, state, length, ctx); if (poly->length) fmpz_mod_poly_make_monic(poly, poly, ctx); } while ((poly->length < 2) || (!fmpz_mod_poly_is_irreducible(poly, ctx))); exp[0] = n_randint(state, 30) + 1; for (i = 0; i < exp[0]; i++) fmpz_mod_poly_mul(poly1, poly1, poly, ctx); num = n_randint(state, 6) + 1; for (i = 1; i < num; i++) { do { length = n_randint(state, 7) + 2; fmpz_mod_poly_randtest(poly, state, length, ctx); if (poly->length) { fmpz_mod_poly_make_monic(poly, poly, ctx); fmpz_mod_poly_divrem(q, r, poly1, poly, ctx); } } while ((poly->length < 2) || (!fmpz_mod_poly_is_irreducible(poly, ctx)) || (r->length == 0)); exp[i] = n_randint(state, 30) + 1; for (j = 0; j < exp[i]; j++) fmpz_mod_poly_mul(poly1, poly1, poly, ctx); } fmpz_mod_poly_factor_init(res, ctx); fmpz_mod_poly_factor(res, poly1, ctx); if (res->num != num) { flint_printf("Error: number of factors incorrect: %wd != %wd\n", res->num, num); abort(); } fmpz_mod_poly_init(product, ctx); fmpz_mod_poly_set_coeff_ui(product, 0, 1, ctx); for (i = 0; i < res->num; i++) for (j = 0; j < res->exp[i]; j++) fmpz_mod_poly_mul(product, product, res->poly + i, ctx); fmpz_mod_poly_scalar_mul_fmpz(product, product, &(poly1->coeffs[poly1->length - 1]), ctx); if (!fmpz_mod_poly_equal(poly1, product, ctx)) { flint_printf ("Error: product of factors does not equal to the original polynomial\n"); flint_printf("poly:\n"); fmpz_mod_poly_print(poly1, ctx); flint_printf("\n"); flint_printf("product:\n"); fmpz_mod_poly_print(product, ctx); flint_printf("\n"); abort(); } fmpz_clear(modulus); fmpz_mod_poly_clear(product, ctx); fmpz_mod_poly_clear(q, ctx); fmpz_mod_poly_clear(r, ctx); fmpz_mod_poly_clear(poly1, ctx); fmpz_mod_poly_clear(poly, ctx); fmpz_mod_poly_factor_clear(res, ctx); } fmpz_mod_ctx_clear(ctx); FLINT_TEST_CLEANUP(state); flint_printf("PASS\n"); return 0; }