use libc::*;
use crate::deps::*;
use crate::flint::*;
use crate::fmpz_mod_types::*;
use crate::fmpz_types::*;
use crate::fq_types::*;
extern "C" {
pub fn fq_ctx_init(ctx: *mut fq_ctx_struct, p: *const fmpz, d: slong, var: *const libc::c_char);
pub fn _fq_ctx_init_conway_ui(
ctx: *mut fq_ctx_struct,
p: ulong,
d: slong,
var: *const libc::c_char,
) -> libc::c_int;
pub fn fq_ctx_init_conway_ui(
ctx: *mut fq_ctx_struct,
p: ulong,
d: slong,
var: *const libc::c_char,
);
pub fn _fq_ctx_init_conway(
ctx: *mut fq_ctx_struct,
p: *const fmpz,
d: slong,
var: *const libc::c_char,
) -> libc::c_int;
pub fn fq_ctx_init_conway(
ctx: *mut fq_ctx_struct,
p: *const fmpz,
d: slong,
var: *const libc::c_char,
);
pub fn fq_ctx_init_modulus(
ctx: *mut fq_ctx_struct,
modulus: *const fmpz_mod_poly_struct,
ctxp: *const fmpz_mod_ctx_struct,
var: *const libc::c_char,
);
pub fn fq_ctx_init_randtest(
ctx: *mut fq_ctx_struct,
state: *mut flint_rand_struct,
type_: libc::c_int,
);
pub fn fq_ctx_init_randtest_reducible(
ctx: *mut fq_ctx_struct,
state: *mut flint_rand_struct,
type_: libc::c_int,
);
pub fn fq_ctx_clear(ctx: *mut fq_ctx_struct);
#[link_name = "fq_ctx_modulus__extern"]
pub fn fq_ctx_modulus(ctx: *const fq_ctx_struct) -> *const fmpz_mod_poly_struct;
#[link_name = "fq_ctx_degree__extern"]
pub fn fq_ctx_degree(ctx: *const fq_ctx_struct) -> slong;
#[link_name = "fq_ctx_prime__extern"]
pub fn fq_ctx_prime(ctx: *const fq_ctx_struct) -> *const fmpz;
pub fn fq_ctx_order(f: *mut fmpz, ctx: *const fq_ctx_struct);
pub fn fq_ctx_fprint(file: *mut FILE, ctx: *const fq_ctx_struct) -> libc::c_int;
pub fn fq_ctx_print(ctx: *const fq_ctx_struct);
pub fn fq_init(rop: *mut fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct);
pub fn fq_init2(rop: *mut fmpz_poly_struct, ctx: *const fq_ctx_struct);
pub fn fq_clear(rop: *mut fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct);
pub fn _fq_sparse_reduce(R: *mut fmpz, lenR: slong, ctx: *const fq_ctx_struct);
pub fn _fq_dense_reduce(R: *mut fmpz, lenR: slong, ctx: *const fq_ctx_struct);
pub fn _fq_reduce(R: *mut fmpz, lenR: slong, ctx: *const fq_ctx_struct);
pub fn fq_reduce(rop: *mut fmpz_poly_struct, ctx: *const fq_ctx_struct);
pub fn fq_add(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
op2: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_sub(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
op2: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_sub_one(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_neg(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_mul(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
op2: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_mul_fmpz(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
x: *const fmpz,
ctx: *const fq_ctx_struct,
);
pub fn fq_mul_si(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
x: slong,
ctx: *const fq_ctx_struct,
);
pub fn fq_mul_ui(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
x: ulong,
ctx: *const fq_ctx_struct,
);
pub fn fq_sqr(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_inv(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn _fq_pow(
rop: *mut fmpz,
op: *const fmpz,
len: slong,
e: *const fmpz,
ctx: *const fq_ctx_struct,
);
pub fn fq_pow(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
e: *const fmpz,
ctx: *const fq_ctx_struct,
);
pub fn fq_pow_ui(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
e: ulong,
ctx: *const fq_ctx_struct,
);
pub fn fq_sqrt(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
) -> libc::c_int;
pub fn fq_pth_root(
rop: *mut fmpz_poly_struct,
op1: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_is_square(op: *const fmpz_poly_struct, ctx: *const fq_ctx_struct) -> libc::c_int;
pub fn fq_randtest(
rop: *mut fmpz_poly_struct,
state: *mut flint_rand_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_randtest_dense(
rop: *mut fmpz_poly_struct,
state: *mut flint_rand_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_randtest_not_zero(
rop: *mut fmpz_poly_struct,
state: *mut flint_rand_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_rand(
rop: *mut fmpz_poly_struct,
state: *mut flint_rand_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_rand_not_zero(
rop: *mut fmpz_poly_struct,
state: *mut flint_rand_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_equal(
op1: *const fmpz_poly_struct,
op2: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
) -> libc::c_int;
pub fn fq_is_zero(op: *const fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct)
-> libc::c_int;
pub fn fq_is_one(op: *const fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct) -> libc::c_int;
pub fn fq_set(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
);
pub fn fq_set_ui(rop: *mut fmpz_poly_struct, x: ulong, ctx: *const fq_ctx_struct);
pub fn fq_set_si(rop: *mut fmpz_poly_struct, x: slong, ctx: *const fq_ctx_struct);
pub fn fq_set_fmpz(rop: *mut fmpz_poly_struct, x: *const fmpz, ctx: *const fq_ctx_struct);
pub fn fq_set_fmpz_poly(
a: *mut fmpz_poly_struct,
b: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_set_fmpz_mod_poly(
a: *mut fmpz_poly_struct,
b: *const fmpz_mod_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_get_fmpz(
a: *mut fmpz,
b: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
) -> libc::c_int;
pub fn fq_get_fmpz_poly(
a: *mut fmpz_poly_struct,
b: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
);
pub fn fq_get_fmpz_mod_poly(
a: *mut fmpz_mod_poly_struct,
b: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
);
pub fn fq_zero(rop: *mut fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct);
pub fn fq_one(rop: *mut fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct);
pub fn fq_swap(
op1: *mut fmpz_poly_struct,
op2: *mut fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
);
pub fn fq_gen(rop: *mut fmpz_poly_struct, ctx: *const fq_ctx_struct);
pub fn fq_fprint(
file: *mut FILE,
op: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
) -> libc::c_int;
pub fn fq_print(op: *const fmpz_poly_struct, UNUSED_ctx: *const fq_ctx_struct);
pub fn fq_fprint_pretty(
file: *mut FILE,
op: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
) -> libc::c_int;
pub fn fq_print_pretty(op: *const fmpz_poly_struct, ctx: *const fq_ctx_struct) -> libc::c_int;
pub fn fq_get_str(
op: *const fmpz_poly_struct,
UNUSED_ctx: *const fq_ctx_struct,
) -> *mut libc::c_char;
pub fn fq_get_str_pretty(
op: *const fmpz_poly_struct,
ctx: *const fq_ctx_struct,
) -> *mut libc::c_char;
pub fn _fq_trace(rop: *mut fmpz, op: *const fmpz, len: slong, ctx: *const fq_ctx_struct);
pub fn fq_trace(rop: *mut fmpz, op: *const fmpz_poly_struct, ctx: *const fq_ctx_struct);
pub fn _fq_frobenius(
rop: *mut fmpz,
op: *const fmpz,
len: slong,
e: slong,
ctx: *const fq_ctx_struct,
);
pub fn fq_frobenius(
rop: *mut fmpz_poly_struct,
op: *const fmpz_poly_struct,
e: slong,
ctx: *const fq_ctx_struct,
);
pub fn _fq_norm(rop: *mut fmpz, op: *const fmpz, len: slong, ctx: *const fq_ctx_struct);
pub fn fq_norm(rop: *mut fmpz, op: *const fmpz_poly_struct, ctx: *const fq_ctx_struct);
pub fn fq_bit_pack(
f: *mut fmpz,
op: *const fmpz_poly_struct,
bit_size: flint_bitcnt_t,
UNUSED_ctx: *const fq_ctx_struct,
);
pub fn fq_bit_unpack(
rop: *mut fmpz_poly_struct,
f: *const fmpz,
bit_size: flint_bitcnt_t,
ctx: *const fq_ctx_struct,
);
pub fn __fq_ctx_prime(p: *mut fmpz, ctx: *mut fq_ctx_struct);
}