summaryrefslogtreecommitdiff
path: root/isl_mat.c
diff options
context:
space:
mode:
Diffstat (limited to 'isl_mat.c')
-rw-r--r--isl_mat.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/isl_mat.c b/isl_mat.c
index df0ac2fd..38bee990 100644
--- a/isl_mat.c
+++ b/isl_mat.c
@@ -1132,6 +1132,31 @@ error:
return NULL;
}
+__isl_give isl_mat *isl_mat_insert_rows(__isl_take isl_mat *mat,
+ unsigned row, unsigned n)
+{
+ isl_mat *ext;
+
+ if (!mat)
+ return NULL;
+ if (n == 0)
+ return mat;
+
+ ext = isl_mat_alloc(mat->ctx, mat->n_row + n, mat->n_col);
+ if (!ext)
+ goto error;
+
+ isl_mat_sub_copy(mat->ctx, ext->row, mat->row, row, 0, 0, mat->n_col);
+ isl_mat_sub_copy(mat->ctx, ext->row + row + n, mat->row + row,
+ mat->n_row - row, 0, 0, mat->n_col);
+
+ isl_mat_free(mat);
+ return ext;
+error:
+ isl_mat_free(mat);
+ return NULL;
+}
+
void isl_mat_col_submul(struct isl_mat *mat,
int dst_col, isl_int f, int src_col)
{