• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef ISL_MAT_PRIVATE_H
2 #define ISL_MAT_PRIVATE_H
3 
4 #include <isl/mat.h>
5 #include <isl_blk.h>
6 
7 struct isl_mat {
8 	int ref;
9 
10 	struct isl_ctx *ctx;
11 
12 #define ISL_MAT_BORROWED		(1 << 0)
13 	unsigned flags;
14 
15 	unsigned n_row;
16 	unsigned n_col;
17 
18 	isl_int **row;
19 
20 	/* actual size of the rows in memory; n_col <= max_col */
21 	unsigned max_col;
22 
23 	struct isl_blk block;
24 };
25 
26 uint32_t isl_mat_get_hash(__isl_keep isl_mat *mat);
27 
28 __isl_give isl_mat *isl_mat_zero(isl_ctx *ctx, unsigned n_row, unsigned n_col);
29 __isl_give isl_mat *isl_mat_dup(__isl_keep isl_mat *mat);
30 __isl_give isl_mat *isl_mat_cow(__isl_take isl_mat *mat);
31 __isl_give isl_mat *isl_mat_sub_alloc(__isl_keep isl_mat *mat,
32 	unsigned first_row, unsigned n_row, unsigned first_col, unsigned n_col);
33 __isl_give isl_mat *isl_mat_sub_alloc6(isl_ctx *ctx, isl_int **row,
34 	unsigned first_row, unsigned n_row, unsigned first_col, unsigned n_col);
35 void isl_mat_sub_copy(struct isl_ctx *ctx, isl_int **dst, isl_int **src,
36 	unsigned n_row, unsigned dst_col, unsigned src_col, unsigned n_col);
37 void isl_mat_sub_neg(struct isl_ctx *ctx, isl_int **dst, isl_int **src,
38 	unsigned n_row, unsigned dst_col, unsigned src_col, unsigned n_col);
39 isl_stat isl_mat_sub_transform(isl_int **row, unsigned n_row,
40 	unsigned first_col, __isl_take isl_mat *mat);
41 __isl_give isl_mat *isl_mat_diag(isl_ctx *ctx, unsigned n_row, isl_int d);
42 
43 __isl_give isl_mat *isl_mat_reverse_gauss(__isl_take isl_mat *mat);
44 
45 __isl_give isl_mat *isl_mat_scale(__isl_take isl_mat *mat, isl_int m);
46 __isl_give isl_mat *isl_mat_scale_down_row(__isl_take isl_mat *mat, int row,
47 	isl_int m);
48 
49 __isl_give isl_vec *isl_mat_get_row(__isl_keep isl_mat *mat, unsigned row);
50 
51 __isl_give isl_mat *isl_mat_lexnonneg_rows(__isl_take isl_mat *mat);
52 
53 isl_bool isl_mat_is_scaled_identity(__isl_keep isl_mat *mat);
54 
55 isl_stat isl_mat_row_gcd(__isl_keep isl_mat *mat, int row, isl_int *gcd);
56 
57 void isl_mat_col_mul(__isl_keep isl_mat *mat, int dst_col, isl_int f,
58 	int src_col);
59 void isl_mat_col_submul(__isl_keep isl_mat *mat,
60 			int dst_col, isl_int f, int src_col);
61 __isl_give isl_mat *isl_mat_col_addmul(__isl_take isl_mat *mat, int dst_col,
62 	isl_int f, int src_col);
63 __isl_give isl_mat *isl_mat_col_neg(__isl_take isl_mat *mat, int col);
64 __isl_give isl_mat *isl_mat_row_neg(__isl_take isl_mat *mat, int row);
65 
66 int isl_mat_get_element(__isl_keep isl_mat *mat, int row, int col, isl_int *v);
67 __isl_give isl_mat *isl_mat_set_element(__isl_take isl_mat *mat,
68 	int row, int col, isl_int v);
69 
70 #endif
71