#include "mpoly.h"
#include "nmod_mpoly.h"
slong nmod_mpoly_get_term_var_exp_si(const nmod_mpoly_t A, slong i,
slong var, const nmod_mpoly_ctx_t ctx)
{
slong N;
if ((ulong) i >= (ulong) A->length)
{
flint_throw(FLINT_ERROR, "Index out of range in nmod_mpoly_get_term_var_exp_si");
}
N = mpoly_words_per_exp(A->bits, ctx->minfo);
return mpoly_get_monomial_var_exp_si(A->exps + N*i, var, A->bits, ctx->minfo);
}
ulong nmod_mpoly_get_term_var_exp_ui(const nmod_mpoly_t A, slong i,
slong var, const nmod_mpoly_ctx_t ctx)
{
slong N;
if ((ulong) i >= (ulong) A->length)
{
flint_throw(FLINT_ERROR, "Index out of range in nmod_mpoly_get_term_var_exp_ui");
}
N = mpoly_words_per_exp(A->bits, ctx->minfo);
return mpoly_get_monomial_var_exp_ui(A->exps + N*i, var, A->bits, ctx->minfo);
}