Skip to content

Commit ba1a7fe

Browse files
Merge pull request #182 from GiacomoPope/add_fq_poly
Add `fq_default_poly`
2 parents 23e1ed3 + 6db1a87 commit ba1a7fe

28 files changed

+3204
-89
lines changed

doc/source/fq_default_poly.rst

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
**fq_default_poly** -- polynomials over finite fields
2+
===============================================================================
3+
4+
.. autoclass :: flint.fq_default_poly_ctx
5+
:members:
6+
:inherited-members:
7+
:undoc-members:
8+
9+
.. autoclass :: flint.fq_default_poly
10+
:members:
11+
:inherited-members:
12+
:undoc-members:
13+

doc/source/index.rst

+1
Original file line numberDiff line numberDiff line change
@@ -74,6 +74,7 @@ Polynomial types
7474
fmpq_poly.rst
7575
nmod_poly.rst
7676
fmpz_mod_poly.rst
77+
fq_default_poly.rst
7778
arb_poly.rst
7879
acb_poly.rst
7980

setup.py

+1
Original file line numberDiff line numberDiff line change
@@ -105,6 +105,7 @@
105105
("flint.types.fmpq_mpoly", ["src/flint/types/fmpq_mpoly.pyx"]),
106106

107107
("flint.types.fq_default", ["src/flint/types/fq_default.pyx"]),
108+
("flint.types.fq_default_poly", ["src/flint/types/fq_default_poly.pyx"]),
108109

109110
("flint.types.arf", ["src/flint/types/arf.pyx"]),
110111
("flint.types.arb", ["src/flint/types/arb.pyx"]),

src/flint/__init__.py

+1
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,7 @@
2525
from .types.fmpq_mpoly import fmpq_mpoly_ctx, fmpq_mpoly, fmpq_mpoly_vec
2626

2727
from .types.fq_default import *
28+
from .types.fq_default_poly import *
2829

2930
from .types.arf import *
3031
from .types.arb import *

src/flint/flintlib/fq.pxd

+15-2
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ from flint.flintlib.fmpz_poly cimport fmpz_poly_t, fmpz_poly_struct
66
from flint.flintlib.fmpz_mod_poly cimport fmpz_mod_poly_t, fmpz_mod_poly_struct
77

88
cdef extern from "flint/fq.h":
9-
9+
# Type definitions **********************************************/
1010
ctypedef fmpz_poly_t fq_t
1111
ctypedef fmpz_poly_struct fq_struct
1212

@@ -24,9 +24,22 @@ cdef extern from "flint/fq.h":
2424
fmpz_mod_poly_t inv
2525

2626
char * var
27-
2827
ctypedef fq_ctx_struct fq_ctx_t[1]
2928

29+
ctypedef struct fq_poly_struct:
30+
fq_struct * coeffs
31+
slong alloc
32+
slong length
33+
ctypedef fq_poly_struct fq_poly_t[1]
34+
35+
ctypedef struct fq_mat_struct:
36+
fq_struct * entries
37+
slong r
38+
slong s
39+
fq_struct ** rows
40+
ctypedef fq_mat_struct fq_mat_t[1]
41+
42+
# Parsed from here **********************************************/
3043
void fq_ctx_init(fq_ctx_t ctx, const fmpz_t p, slong d, const char *var)
3144
int _fq_ctx_init_conway(fq_ctx_t ctx, const fmpz_t p, slong d, const char *var)
3245
void fq_ctx_init_conway(fq_ctx_t ctx, const fmpz_t p, slong d, const char *var)

src/flint/flintlib/fq_default_mat.pxd

+78
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,78 @@
1+
from flint.flintlib.flint cimport flint_rand_t, slong
2+
from flint.flintlib.fq cimport fq_ctx_t, fq_struct
3+
from flint.flintlib.nmod_mat cimport nmod_mat_t
4+
from flint.flintlib.fmpz_mat cimport fmpz_mat_t
5+
from flint.flintlib.fmpz_mod_mat cimport fmpz_mod_mat_t
6+
from flint.flintlib.fmpz cimport fmpz_t
7+
from flint.flintlib.fq_default cimport fq_default_t, fq_default_ctx_t
8+
from flint.flintlib.fq_default_poly cimport fq_default_poly_t
9+
from flint.flintlib.fq_mat cimport fq_mat_t
10+
from flint.flintlib.fq_nmod_mat cimport fq_nmod_mat_t
11+
from flint.flintlib.fq_zech_mat cimport fq_zech_mat_t
12+
from flintlib.nmod_mat cimport nmod_mat_t
13+
from flintlib.fmpz_mod_mat cimport fmpz_mod_mat_t
14+
15+
cdef extern from "flint/fq_default_mat.h":
16+
# Type definitions **********************************************/
17+
ctypedef union fq_default_mat_struct:
18+
fq_mat_t fq
19+
fq_nmod_mat_t fq_nmod
20+
fq_zech_mat_t fq_zech
21+
nmod_mat_t nmod
22+
fmpz_mod_mat_t fmpz_mod
23+
ctypedef fq_default_mat_struct fq_default_mat_t[1]
24+
25+
# Parsed from here **********************************************/
26+
void fq_default_mat_init(fq_default_mat_t mat, slong rows, slong cols, const fq_default_ctx_t ctx)
27+
void fq_default_mat_init_set(fq_default_mat_t mat, const fq_default_mat_t src, const fq_default_ctx_t ctx)
28+
void fq_default_mat_clear(fq_default_mat_t mat, const fq_default_ctx_t ctx)
29+
void fq_default_mat_set(fq_default_mat_t mat, const fq_default_mat_t src, const fq_default_ctx_t ctx)
30+
void fq_default_mat_entry(fq_default_t val, const fq_default_mat_t mat, slong i, slong j, const fq_default_ctx_t ctx)
31+
void fq_default_mat_entry_set(fq_default_mat_t mat, slong i, slong j, const fq_default_t x, const fq_default_ctx_t ctx)
32+
void fq_default_mat_entry_set_fmpz(fq_default_mat_t mat, slong i, slong j, const fmpz_t x, const fq_default_ctx_t ctx)
33+
slong fq_default_mat_nrows(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
34+
slong fq_default_mat_ncols(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
35+
void fq_default_mat_swap(fq_default_mat_t mat1, fq_default_mat_t mat2, const fq_default_ctx_t ctx)
36+
void fq_default_mat_zero(fq_default_mat_t mat, const fq_default_ctx_t ctx)
37+
void fq_default_mat_one(fq_default_mat_t mat, const fq_default_ctx_t ctx)
38+
void fq_default_mat_swap_rows(fq_default_mat_t mat, slong * perm, slong r, slong s, const fq_default_ctx_t ctx)
39+
void fq_default_mat_swap_cols(fq_default_mat_t mat, slong * perm, slong r, slong s, const fq_default_ctx_t ctx)
40+
void fq_default_mat_invert_rows(fq_default_mat_t mat, slong * perm, const fq_default_ctx_t ctx)
41+
void fq_default_mat_invert_cols(fq_default_mat_t mat, slong * perm, const fq_default_ctx_t ctx)
42+
void fq_default_mat_set_nmod_mat(fq_default_mat_t mat1, const nmod_mat_t mat2, const fq_default_ctx_t ctx)
43+
void fq_default_mat_set_fmpz_mod_mat(fq_default_mat_t mat1, const fmpz_mod_mat_t mat2, const fq_default_ctx_t ctx)
44+
void fq_default_mat_set_fmpz_mat(fq_default_mat_t mat1, const fmpz_mat_t mat2, const fq_default_ctx_t ctx)
45+
void fq_default_mat_concat_vertical(fq_default_mat_t res, const fq_default_mat_t mat1, const fq_default_mat_t mat2, const fq_default_ctx_t ctx)
46+
void fq_default_mat_concat_horizontal(fq_default_mat_t res, const fq_default_mat_t mat1, const fq_default_mat_t mat2, const fq_default_ctx_t ctx)
47+
int fq_default_mat_print_pretty(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
48+
# int fq_default_mat_fprint_pretty(FILE * file, const fq_default_mat_t mat, const fq_default_ctx_t ctx)
49+
int fq_default_mat_print(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
50+
# int fq_default_mat_fprint(FILE * file, const fq_default_mat_t mat, const fq_default_ctx_t ctx)
51+
void fq_default_mat_window_init(fq_default_mat_t window, const fq_default_mat_t mat, slong r1, slong c1, slong r2, slong c2, const fq_default_ctx_t ctx)
52+
void fq_default_mat_window_clear(fq_default_mat_t window, const fq_default_ctx_t ctx)
53+
void fq_default_mat_randtest(fq_default_mat_t mat, flint_rand_t state, const fq_default_ctx_t ctx)
54+
int fq_default_mat_randpermdiag(fq_mat_t mat, flint_rand_t state, fq_struct * diag, slong n, const fq_ctx_t ctx)
55+
void fq_default_mat_randrank(fq_default_mat_t mat, flint_rand_t state, slong rank, const fq_default_ctx_t ctx)
56+
void fq_default_mat_randops(fq_default_mat_t mat, flint_rand_t state, slong count, const fq_default_ctx_t ctx)
57+
void fq_default_mat_randtril(fq_default_mat_t mat, flint_rand_t state, int unit, const fq_default_ctx_t ctx)
58+
void fq_default_mat_randtriu(fq_default_mat_t mat, flint_rand_t state, int unit, const fq_default_ctx_t ctx)
59+
int fq_default_mat_equal(const fq_default_mat_t mat1, const fq_default_mat_t mat2, const fq_default_ctx_t ctx)
60+
int fq_default_mat_is_zero(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
61+
int fq_default_mat_is_one(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
62+
int fq_default_mat_is_empty(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
63+
int fq_default_mat_is_square(const fq_default_mat_t mat, const fq_default_ctx_t ctx)
64+
void fq_default_mat_add(fq_default_mat_t C, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
65+
void fq_default_mat_sub(fq_default_mat_t C, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
66+
void fq_default_mat_neg(fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
67+
void fq_default_mat_mul(fq_default_mat_t C, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
68+
void fq_default_mat_submul(fq_default_mat_t D, const fq_default_mat_t C, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
69+
int fq_default_mat_inv(fq_default_mat_t B, fq_default_mat_t A, const fq_default_ctx_t ctx)
70+
slong fq_default_mat_lu(slong * P, fq_default_mat_t A, int rank_check, const fq_default_ctx_t ctx)
71+
slong fq_default_mat_rref(fq_default_mat_t B, const fq_default_mat_t A, const fq_default_ctx_t ctx)
72+
void fq_default_mat_solve_tril(fq_default_mat_t X, const fq_default_mat_t L, const fq_default_mat_t B, int unit, const fq_default_ctx_t ctx)
73+
void fq_default_mat_solve_triu(fq_default_mat_t X, const fq_default_mat_t U, const fq_default_mat_t B, int unit, const fq_default_ctx_t ctx)
74+
int fq_default_mat_solve(fq_default_mat_t X, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
75+
int fq_default_mat_can_solve(fq_default_mat_t X, const fq_default_mat_t A, const fq_default_mat_t B, const fq_default_ctx_t ctx)
76+
void fq_default_mat_similarity(fq_default_mat_t M, slong r, fq_default_t d, const fq_default_ctx_t ctx)
77+
void fq_default_mat_charpoly(fq_default_poly_t p, const fq_default_mat_t M, const fq_default_ctx_t ctx)
78+
void fq_default_mat_minpoly(fq_default_poly_t p, const fq_default_mat_t M, const fq_default_ctx_t ctx)
+102
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,102 @@
1+
from flint.flintlib.fq_default cimport fq_default_ctx_t, fq_default_t
2+
from flint.flintlib.nmod_poly cimport nmod_poly_t
3+
from flint.flintlib.flint cimport slong, ulong, flint_rand_t
4+
from flint.flintlib.fmpz_poly cimport fmpz_poly_t
5+
from flint.flintlib.fmpz cimport fmpz_t
6+
from flint.flintlib.fmpz_mod_poly cimport fmpz_mod_poly_t
7+
from flint.flintlib.fq_poly cimport fq_poly_t
8+
from flint.flintlib.fq_nmod_poly cimport fq_nmod_poly_t
9+
from flint.flintlib.fq_zech_poly cimport fq_zech_poly_t
10+
11+
12+
cdef extern from "flint/fq_default_poly.h":
13+
# Type definitions **********************************************/
14+
ctypedef union fq_default_poly_struct:
15+
fq_poly_t fq
16+
fq_nmod_poly_t fq_nmod
17+
fq_zech_poly_t fq_zech
18+
nmod_poly_t nmod
19+
fmpz_mod_poly_t fmpz_mod
20+
ctypedef fq_default_poly_struct fq_default_poly_t[1]
21+
22+
# Parsed from here **********************************************/
23+
void fq_default_poly_init(fq_default_poly_t poly, const fq_default_ctx_t ctx)
24+
void fq_default_poly_init2(fq_default_poly_t poly, slong alloc, const fq_default_ctx_t ctx)
25+
void fq_default_poly_realloc(fq_default_poly_t poly, slong alloc, const fq_default_ctx_t ctx)
26+
void fq_default_poly_fit_length(fq_default_poly_t poly, slong len, const fq_default_ctx_t ctx)
27+
void fq_default_poly_clear(fq_default_poly_t poly, const fq_default_ctx_t ctx)
28+
void _fq_default_poly_set_length(fq_default_poly_t poly, slong len, const fq_default_ctx_t ctx)
29+
void fq_default_poly_truncate(fq_default_poly_t poly, slong newlen, const fq_default_ctx_t ctx)
30+
void fq_default_poly_set_trunc(fq_default_poly_t poly1, fq_default_poly_t poly2, slong newlen, const fq_default_ctx_t ctx)
31+
void fq_default_poly_reverse(fq_default_poly_t output, const fq_default_poly_t input, slong m, const fq_default_ctx_t ctx)
32+
slong fq_default_poly_degree(const fq_default_poly_t poly, const fq_default_ctx_t ctx)
33+
slong fq_default_poly_length(const fq_default_poly_t poly, const fq_default_ctx_t ctx)
34+
void fq_default_poly_randtest(fq_default_poly_t f, flint_rand_t state, slong len, const fq_default_ctx_t ctx)
35+
void fq_default_poly_randtest_not_zero(fq_default_poly_t f, flint_rand_t state, slong len, const fq_default_ctx_t ctx)
36+
void fq_default_poly_randtest_monic(fq_default_poly_t f, flint_rand_t state, slong len, const fq_default_ctx_t ctx)
37+
void fq_default_poly_randtest_irreducible(fq_default_poly_t f, flint_rand_t state, slong len, const fq_default_ctx_t ctx)
38+
void fq_default_poly_set(fq_default_poly_t poly1, const fq_default_poly_t poly2, const fq_default_ctx_t ctx)
39+
void fq_default_poly_set_fq_default(fq_default_poly_t poly, const fq_default_t c, const fq_default_ctx_t ctx)
40+
void fq_default_poly_swap(fq_default_poly_t op1, fq_default_poly_t op2, const fq_default_ctx_t ctx)
41+
void fq_default_poly_zero(fq_default_poly_t poly, const fq_default_ctx_t ctx)
42+
void fq_default_poly_one(fq_default_poly_t poly, const fq_default_ctx_t ctx)
43+
void fq_default_poly_gen(fq_default_poly_t poly, const fq_default_ctx_t ctx)
44+
void fq_default_poly_make_monic(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_ctx_t ctx)
45+
void fq_default_poly_set_nmod_poly(fq_default_poly_t rop, const nmod_poly_t op, const fq_default_ctx_t ctx)
46+
void fq_default_poly_set_fmpz_mod_poly(fq_default_poly_t rop, const fmpz_mod_poly_t op, const fq_default_ctx_t ctx)
47+
void fq_default_poly_set_fmpz_poly(fq_default_poly_t rop, const fmpz_poly_t op, const fq_default_ctx_t ctx)
48+
void fq_default_poly_get_coeff(fq_default_t x, const fq_default_poly_t poly, slong n, const fq_default_ctx_t ctx)
49+
void fq_default_poly_set_coeff(fq_default_poly_t poly, slong n, const fq_default_t x, const fq_default_ctx_t ctx)
50+
void fq_default_poly_set_coeff_fmpz(fq_default_poly_t poly, slong n, const fmpz_t x, const fq_default_ctx_t ctx)
51+
int fq_default_poly_equal(const fq_default_poly_t poly1, const fq_default_poly_t poly2, const fq_default_ctx_t ctx)
52+
int fq_default_poly_equal_trunc(const fq_default_poly_t poly1, const fq_default_poly_t poly2, slong n, const fq_default_ctx_t ctx)
53+
int fq_default_poly_is_zero(const fq_default_poly_t poly, const fq_default_ctx_t ctx)
54+
int fq_default_poly_is_one(const fq_default_poly_t op, const fq_default_ctx_t ctx)
55+
int fq_default_poly_is_gen(const fq_default_poly_t op, const fq_default_ctx_t ctx)
56+
int fq_default_poly_is_unit(const fq_default_poly_t op, const fq_default_ctx_t ctx)
57+
int fq_default_poly_equal_fq_default(const fq_default_poly_t poly, const fq_default_t c, const fq_default_ctx_t ctx)
58+
void fq_default_poly_add(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, const fq_default_ctx_t ctx)
59+
void fq_default_poly_add_si(fq_default_poly_t res, const fq_default_poly_t poly1, slong c, const fq_default_ctx_t ctx)
60+
void fq_default_poly_add_series(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, slong n, const fq_default_ctx_t ctx)
61+
void fq_default_poly_sub(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, const fq_default_ctx_t ctx)
62+
void fq_default_poly_sub_series(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, slong n, const fq_default_ctx_t ctx)
63+
void fq_default_poly_neg(fq_default_poly_t res, const fq_default_poly_t poly, const fq_default_ctx_t ctx)
64+
void fq_default_poly_scalar_mul_fq_default(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_t x, const fq_default_ctx_t ctx)
65+
void fq_default_poly_scalar_addmul_fq_default(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_t x, const fq_default_ctx_t ctx)
66+
void fq_default_poly_scalar_submul_fq_default(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_t x, const fq_default_ctx_t ctx)
67+
void fq_default_poly_scalar_div_fq_default(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_t x, const fq_default_ctx_t ctx)
68+
void fq_default_poly_mul(fq_default_poly_t rop, const fq_default_poly_t op1, const fq_default_poly_t op2, const fq_default_ctx_t ctx)
69+
void fq_default_poly_mullow(fq_default_poly_t rop, const fq_default_poly_t op1, const fq_default_poly_t op2, slong n, const fq_default_ctx_t ctx)
70+
void fq_default_poly_mulhigh(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, slong start, const fq_default_ctx_t ctx)
71+
void fq_default_poly_mulmod(fq_default_poly_t res, const fq_default_poly_t poly1, const fq_default_poly_t poly2, const fq_default_poly_t f, const fq_default_ctx_t ctx)
72+
void fq_default_poly_sqr(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_ctx_t ctx)
73+
void fq_default_poly_pow(fq_default_poly_t rop, const fq_default_poly_t op, ulong e, const fq_default_ctx_t ctx)
74+
void fq_default_poly_powmod_ui_binexp(fq_default_poly_t res, const fq_default_poly_t poly, ulong e, const fq_default_poly_t f, const fq_default_ctx_t ctx)
75+
void fq_default_poly_powmod_fmpz_binexp(fq_default_poly_t res, const fq_default_poly_t poly, const fmpz_t e, const fq_default_poly_t f, const fq_default_ctx_t ctx)
76+
void fq_default_poly_pow_trunc(fq_default_poly_t res, const fq_default_poly_t poly, ulong e, slong trunc, const fq_default_ctx_t ctx)
77+
void fq_default_poly_shift_left(fq_default_poly_t rop, const fq_default_poly_t op, slong n, const fq_default_ctx_t ctx)
78+
void fq_default_poly_shift_right(fq_default_poly_t rop, const fq_default_poly_t op, slong n, const fq_default_ctx_t ctx)
79+
slong fq_default_poly_hamming_weight(const fq_default_poly_t op, const fq_default_ctx_t ctx)
80+
void fq_default_poly_divrem(fq_default_poly_t Q, fq_default_poly_t R, const fq_default_poly_t A, const fq_default_poly_t B, const fq_default_ctx_t ctx)
81+
void fq_default_poly_rem(fq_default_poly_t R, const fq_default_poly_t A, const fq_default_poly_t B, const fq_default_ctx_t ctx)
82+
void fq_default_poly_inv_series(fq_default_poly_t Qinv, const fq_default_poly_t Q, slong n, const fq_default_ctx_t ctx)
83+
void fq_default_poly_div_series(fq_default_poly_t Q, const fq_default_poly_t A, const fq_default_poly_t B, slong n, const fq_default_ctx_t ctx)
84+
void fq_default_poly_gcd(fq_default_poly_t rop, const fq_default_poly_t op1, const fq_default_poly_t op2, const fq_default_ctx_t ctx)
85+
void fq_default_poly_xgcd(fq_default_poly_t G, fq_default_poly_t S, fq_default_poly_t T, const fq_default_poly_t A, const fq_default_poly_t B, const fq_default_ctx_t ctx)
86+
int fq_default_poly_divides(fq_default_poly_t Q, const fq_default_poly_t A, const fq_default_poly_t B, const fq_default_ctx_t ctx)
87+
void fq_default_poly_derivative(fq_default_poly_t rop, const fq_default_poly_t op, const fq_default_ctx_t ctx)
88+
void fq_default_poly_invsqrt_series(fq_default_poly_t g, const fq_default_poly_t h, slong n, fq_default_ctx_t ctx)
89+
void fq_default_poly_sqrt_series(fq_default_poly_t g, const fq_default_poly_t h, slong n, fq_default_ctx_t ctx)
90+
int fq_default_poly_sqrt(fq_default_poly_t s, const fq_default_poly_t p, fq_default_ctx_t mod)
91+
void fq_default_poly_evaluate_fq_default(fq_default_t rop, const fq_default_poly_t f, const fq_default_t a, const fq_default_ctx_t ctx)
92+
void fq_default_poly_compose(fq_default_poly_t rop, const fq_default_poly_t op1, const fq_default_poly_t op2, const fq_default_ctx_t ctx)
93+
void fq_default_poly_compose_mod(fq_default_poly_t res, const fq_default_poly_t f, const fq_default_poly_t g, const fq_default_poly_t h, const fq_default_ctx_t ctx)
94+
# int fq_default_poly_fprint_pretty(FILE * file, const fq_default_poly_t poly, const char * x, const fq_default_ctx_t ctx)
95+
int fq_default_poly_print_pretty(const fq_default_poly_t poly, const char * x, const fq_default_ctx_t ctx)
96+
# int fq_default_poly_fprint(FILE * file, const fq_default_poly_t poly, const fq_default_ctx_t ctx)
97+
int fq_default_poly_print(const fq_default_poly_t poly, const fq_default_ctx_t ctx)
98+
char * fq_default_poly_get_str(const fq_default_poly_t poly, const fq_default_ctx_t ctx)
99+
char * fq_default_poly_get_str_pretty(const fq_default_poly_t poly, const char * x, const fq_default_ctx_t ctx)
100+
void fq_default_poly_inflate(fq_default_poly_t result, const fq_default_poly_t input, ulong inflation, const fq_default_ctx_t ctx)
101+
void fq_default_poly_deflate(fq_default_poly_t result, const fq_default_poly_t input, ulong deflation, const fq_default_ctx_t ctx)
102+
ulong fq_default_poly_deflation(const fq_default_poly_t input, const fq_default_ctx_t ctx)

0 commit comments

Comments
 (0)