/* Copyright (C) 2010 William Hart Copyright (C) 2010 Fredrik Johansson Copyright (C) 2014 Abhinav Baid This file is part of FLINT. FLINT is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License (LGPL) as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. See . */ #ifndef D_MAT_H #define D_MAT_H #ifdef D_MAT_INLINES_C #define D_MAT_INLINE FLINT_DLL #else #define D_MAT_INLINE static __inline__ #endif #undef ulong #define ulong ulongxx /* interferes with system includes */ #include #undef ulong #include #define ulong mp_limb_t #include "flint.h" #include "d_vec.h" #ifdef __cplusplus extern "C" { #endif typedef struct { double * entries; slong r; slong c; double ** rows; } d_mat_struct; typedef d_mat_struct d_mat_t[1]; #define d_mat_entry(mat,i,j) (*((mat)->rows[i] + (j))) D_MAT_INLINE double * d_mat_entry_ptr(const d_mat_t mat, slong i, slong j) { return mat->rows[i] + j; } D_MAT_INLINE double d_mat_get_entry(const d_mat_t mat, slong i, slong j) { return mat->rows[i][j]; } D_MAT_INLINE slong d_mat_nrows(const d_mat_t mat) { return mat->r; } D_MAT_INLINE slong d_mat_ncols(const d_mat_t mat) { return mat->c; } /* Memory management ********************************************************/ FLINT_DLL void d_mat_init(d_mat_t mat, slong rows, slong cols); FLINT_DLL void d_mat_swap(d_mat_t mat1, d_mat_t mat2); D_MAT_INLINE void d_mat_swap_entrywise(d_mat_t mat1, d_mat_t mat2) { slong i, j; for (i = 0; i < d_mat_nrows(mat1); i++) { double * row1 = mat1->rows[i]; double * row2 = mat2->rows[i]; for (j = 0; j < d_mat_ncols(mat1); j++) DOUBLE_SWAP(row1[j], row2[j]); } } FLINT_DLL void d_mat_set(d_mat_t mat1, const d_mat_t mat2); FLINT_DLL void d_mat_clear(d_mat_t mat); FLINT_DLL int d_mat_equal(const d_mat_t mat1, const d_mat_t mat2); FLINT_DLL int d_mat_approx_equal(const d_mat_t mat1, const d_mat_t mat2, double eps); FLINT_DLL int d_mat_is_zero(const d_mat_t mat); FLINT_DLL int d_mat_is_approx_zero(const d_mat_t mat, double eps); D_MAT_INLINE int d_mat_is_empty(const d_mat_t mat) { return (mat->r == 0) || (mat->c == 0); } D_MAT_INLINE int d_mat_is_square(const d_mat_t mat) { return (mat->r == mat->c); } FLINT_DLL void d_mat_zero(d_mat_t mat); FLINT_DLL void d_mat_one(d_mat_t mat); /* Input and output *********************************************************/ FLINT_DLL void d_mat_print(const d_mat_t mat); /* Random matrix generation *************************************************/ FLINT_DLL void d_mat_randtest(d_mat_t mat, flint_rand_t state, slong minexp, slong maxexp); /* Transpose */ FLINT_DLL void d_mat_transpose(d_mat_t B, const d_mat_t A); /* Multiplication */ FLINT_DLL void d_mat_mul_classical(d_mat_t C, const d_mat_t A, const d_mat_t B); /* Permutations */ D_MAT_INLINE void d_mat_swap_rows(d_mat_t mat, slong r, slong s) { if (r != s) { double * u; u = mat->rows[s]; mat->rows[s] = mat->rows[r]; mat->rows[r] = u; } } /* Gram-Schmidt Orthogonalisation and QR Decomposition ********************************************************/ FLINT_DLL void d_mat_gso(d_mat_t B, const d_mat_t A); FLINT_DLL void d_mat_qr(d_mat_t Q, d_mat_t R, const d_mat_t A); #ifdef __cplusplus } #endif #endif