#include "mpoly.h"
#include "nmod_mpoly.h"
void nmod_mpoly_get_term_exp_fmpz(fmpz ** exp, const nmod_mpoly_t A,
slong i, 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_exp_fmpz");
}
N = mpoly_words_per_exp(A->bits, ctx->minfo);
mpoly_get_monomial_pfmpz(exp, A->exps + N*i, A->bits, ctx->minfo);
}
void nmod_mpoly_get_term_exp_si(slong * exp, const nmod_mpoly_t A,
slong i, 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_exp_si");
}
N = mpoly_words_per_exp(A->bits, ctx->minfo);
mpoly_get_monomial_si(exp, A->exps + N*i, A->bits, ctx->minfo);
}
void nmod_mpoly_get_term_exp_ui(ulong * exp, const nmod_mpoly_t A,
slong i, 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_exp_ui");
}
N = mpoly_words_per_exp(A->bits, ctx->minfo);
mpoly_get_monomial_ui(exp, A->exps + N*i, A->bits, ctx->minfo);
}