#include "mpoly.h"
#include "nmod_mpoly.h"
void nmod_mpoly_set_term_exp_fmpz(nmod_mpoly_t A, slong i,
fmpz * const * exp, const nmod_mpoly_ctx_t ctx)
{
slong N;
flint_bitcnt_t exp_bits;
if (i >= A->length)
{
flint_throw(FLINT_ERROR, "nmod_mpoly_set_term_exp_fmpz: index out of range");
}
exp_bits = mpoly_exp_bits_required_pfmpz(exp, ctx->minfo);
exp_bits = mpoly_fix_bits(exp_bits, ctx->minfo);
nmod_mpoly_fit_length_fit_bits(A, A->length, exp_bits, ctx);
N = mpoly_words_per_exp(A->bits, ctx->minfo);
mpoly_set_monomial_pfmpz(A->exps + N*i, exp, A->bits, ctx->minfo);
}
void nmod_mpoly_set_term_exp_ui(nmod_mpoly_t A, slong i,
const ulong * exp, const nmod_mpoly_ctx_t ctx)
{
slong N;
flint_bitcnt_t exp_bits;
if (i >= A->length)
{
flint_throw(FLINT_ERROR, "nmod_mpoly_set_term_exp_ui: index is out of range");
}
exp_bits = mpoly_exp_bits_required_ui(exp, ctx->minfo);
exp_bits = mpoly_fix_bits(exp_bits, ctx->minfo);
nmod_mpoly_fit_length_fit_bits(A, A->length, exp_bits, ctx);
N = mpoly_words_per_exp(A->bits, ctx->minfo);
mpoly_set_monomial_ui(A->exps + N*i, exp, A->bits, ctx->minfo);
}