#ifndef PADIC_MAT_H
#define PADIC_MAT_H
#ifdef PADIC_MAT_INLINES_C
#define PADIC_MAT_INLINE
#else
#define PADIC_MAT_INLINE static inline
#endif
#include "fmpq_types.h"
#include "padic_types.h"
#ifdef __cplusplus
extern "C" {
#endif
PADIC_MAT_INLINE
fmpz_mat_struct * padic_mat(const padic_mat_t A)
{
return (fmpz_mat_struct *)(&(A->mat));
}
PADIC_MAT_INLINE
fmpz * padic_mat_entry(const padic_mat_t A, slong i, slong j)
{
return A->mat.entries + i * A->mat.stride + j;
}
#define padic_mat_val(A) ((A)->val)
#define padic_mat_prec(A) ((A)->N)
PADIC_MAT_INLINE
slong padic_mat_get_val(const padic_mat_t A)
{
return A->val;
}
PADIC_MAT_INLINE
slong padic_mat_get_prec(const padic_mat_t A)
{
return A->N;
}
PADIC_MAT_INLINE
slong padic_mat_nrows(const padic_mat_t A)
{
return (A->mat).r;
}
PADIC_MAT_INLINE
slong padic_mat_ncols(const padic_mat_t A)
{
return (A->mat).c;
}
void padic_mat_init(padic_mat_t A, slong r, slong c);
void padic_mat_init2(padic_mat_t A, slong r, slong c, slong prec);
void padic_mat_clear(padic_mat_t A);
void _padic_mat_canonicalise(padic_mat_t A, const padic_ctx_t ctx);
void _padic_mat_reduce(padic_mat_t A, const padic_ctx_t ctx);
void padic_mat_reduce(padic_mat_t A, const padic_ctx_t ctx);
PADIC_MAT_INLINE int
padic_mat_is_empty(const padic_mat_t A)
{
return padic_mat_nrows(A) == 0 || padic_mat_ncols(A) == 0;
}
PADIC_MAT_INLINE int
padic_mat_is_square(const padic_mat_t A)
{
return padic_mat_nrows(A) == padic_mat_ncols(A);
}
int padic_mat_is_canonical(const padic_mat_t A, const padic_ctx_t ctx);
int padic_mat_is_reduced(const padic_mat_t A, const padic_ctx_t ctx);
void padic_mat_set(padic_mat_t B, const padic_mat_t A, const padic_ctx_t ctx);
void padic_mat_swap(padic_mat_t A, padic_mat_t B);
PADIC_MAT_INLINE void
padic_mat_swap_entrywise(padic_mat_t mat1, padic_mat_t mat2)
{
slong i, j;
for (i = 0; i < padic_mat_nrows(mat1); i++)
for (j = 0; j < padic_mat_ncols(mat1); j++)
FLINT_SWAP(fmpz, *padic_mat_entry(mat2, i, j), *padic_mat_entry(mat1, i, j));
}
void padic_mat_zero(padic_mat_t A);
void padic_mat_one(padic_mat_t A);
void padic_mat_set_fmpq_mat(padic_mat_t B,
const fmpq_mat_t A, const padic_ctx_t ctx);
void padic_mat_get_fmpq_mat(fmpq_mat_t B,
const padic_mat_t A, const padic_ctx_t ctx);
void padic_mat_get_entry_padic(padic_t rop,
const padic_mat_t op, slong i, slong j,
const padic_ctx_t ctx);
void padic_mat_set_entry_padic(padic_mat_t rop, slong i, slong j,
const padic_t op, const padic_ctx_t ctx);
int padic_mat_equal(const padic_mat_t A, const padic_mat_t B);
int padic_mat_is_zero(const padic_mat_t A);
#ifdef FLINT_HAVE_FILE
int padic_mat_fprint(FILE * file, const padic_mat_t A, const padic_ctx_t ctx);
int padic_mat_fprint_pretty(FILE * file, const padic_mat_t A, const padic_ctx_t ctx);
#endif
int padic_mat_print(const padic_mat_t A, const padic_ctx_t ctx);
int padic_mat_print_pretty(const padic_mat_t A, const padic_ctx_t ctx);
void padic_mat_randtest(padic_mat_t mat, flint_rand_t state,
const padic_ctx_t ctx);
void padic_mat_transpose(padic_mat_t B, const padic_mat_t A);
void _padic_mat_add(padic_mat_t C, const padic_mat_t A, const padic_mat_t B,
const padic_ctx_t ctx);
void padic_mat_add(padic_mat_t C, const padic_mat_t A, const padic_mat_t B,
const padic_ctx_t ctx);
void _padic_mat_sub(padic_mat_t C, const padic_mat_t A, const padic_mat_t B,
const padic_ctx_t ctx);
void padic_mat_sub(padic_mat_t C, const padic_mat_t A, const padic_mat_t B,
const padic_ctx_t ctx);
void _padic_mat_neg(padic_mat_t B, const padic_mat_t A);
void padic_mat_neg(padic_mat_t B, const padic_mat_t A, const padic_ctx_t ctx);
void _padic_mat_scalar_mul_padic(padic_mat_t B,
const padic_mat_t A, const padic_t c,
const padic_ctx_t FLINT_UNUSED(ctx));
void padic_mat_scalar_mul_padic(padic_mat_t B,
const padic_mat_t A, const padic_t c,
const padic_ctx_t ctx);
void _padic_mat_scalar_mul_fmpz(padic_mat_t B,
const padic_mat_t A, const fmpz_t c,
const padic_ctx_t ctx);
void padic_mat_scalar_mul_fmpz(padic_mat_t B,
const padic_mat_t A, const fmpz_t c,
const padic_ctx_t ctx);
void padic_mat_scalar_div_fmpz(padic_mat_t B,
const padic_mat_t A, const fmpz_t c,
const padic_ctx_t ctx);
void padic_mat_mul(padic_mat_t C, const padic_mat_t A, const padic_mat_t B,
const padic_ctx_t ctx);
#ifdef __cplusplus
}
#endif
#endif