add isl_aff_drop_dims
authorSven Verdoolaege <skimo@kotnet.org>
Tue, 28 Jun 2011 18:36:13 +0000 (20:36 +0200)
committerSven Verdoolaege <skimo@kotnet.org>
Fri, 1 Jul 2011 16:52:20 +0000 (18:52 +0200)
Signed-off-by: Sven Verdoolaege <skimo@kotnet.org>
doc/user.pod
include/isl/aff.h
isl_aff.c

index f44f3f5..38cef38 100644 (file)
@@ -2286,6 +2286,13 @@ It can be modified using
                __isl_take isl_aff *aff,
                enum isl_dim_type type, int pos, int v);
 
+       __isl_give isl_aff *isl_aff_drop_dims(
+               __isl_take isl_aff *aff,
+               enum isl_dim_type type, unsigned first, unsigned n);
+       __isl_give isl_pw_aff *isl_pw_aff_drop_dims(
+               __isl_take isl_pw_aff *pwaff,
+               enum isl_dim_type type, unsigned first, unsigned n);
+
 Note that the C<set_constant> and C<set_coefficient> functions
 set the I<numerator> of the constant or coefficient, while
 C<add_constant> and C<add_coefficient> add an integer value to
index 2df4420..3a7e69c 100644 (file)
@@ -68,6 +68,9 @@ __isl_give isl_aff *isl_aff_scale(__isl_take isl_aff *aff, isl_int f);
 __isl_give isl_aff *isl_aff_scale_down(__isl_take isl_aff *aff, isl_int f);
 __isl_give isl_aff *isl_aff_scale_down_ui(__isl_take isl_aff *aff, unsigned f);
 
+__isl_give isl_aff *isl_aff_drop_dims(__isl_take isl_aff *aff,
+       enum isl_dim_type type, unsigned first, unsigned n);
+
 __isl_give isl_aff *isl_aff_gist(__isl_take isl_aff *aff,
        __isl_take isl_set *context);
 
@@ -105,6 +108,9 @@ __isl_give isl_set *isl_pw_aff_domain(__isl_take isl_pw_aff *pwaff);
 __isl_give isl_pw_aff *isl_pw_aff_add(__isl_take isl_pw_aff *pwaff1,
        __isl_take isl_pw_aff *pwaff2);
 
+__isl_give isl_pw_aff *isl_pw_aff_drop_dims(__isl_take isl_pw_aff *pwaff,
+       enum isl_dim_type type, unsigned first, unsigned n);
+
 __isl_give isl_pw_aff *isl_pw_aff_coalesce(__isl_take isl_pw_aff *pwqp);
 __isl_give isl_pw_aff *isl_pw_aff_gist(__isl_take isl_pw_aff *pwaff,
        __isl_take isl_set *context);
index e61b73c..72869f7 100644 (file)
--- a/isl_aff.c
+++ b/isl_aff.c
@@ -824,6 +824,37 @@ error:
        return -1;
 }
 
+__isl_give isl_aff *isl_aff_drop_dims(__isl_take isl_aff *aff,
+       enum isl_dim_type type, unsigned first, unsigned n)
+{
+       isl_ctx *ctx;
+
+       if (!aff)
+               return NULL;
+       if (n == 0 && !isl_local_space_is_named_or_nested(aff->ls, type))
+               return aff;
+
+       ctx = isl_aff_get_ctx(aff);
+       if (first + n > isl_aff_dim(aff, type))
+               isl_die(ctx, isl_error_invalid, "range out of bounds",
+                       return isl_aff_free(aff));
+
+       aff = isl_aff_cow(aff);
+       if (!aff)
+               return NULL;
+
+       aff->ls = isl_local_space_drop_dims(aff->ls, type, first, n);
+       if (!aff->ls)
+               return isl_aff_free(aff);
+
+       first += 1 + isl_local_space_offset(aff->ls, type);
+       aff->v = isl_vec_drop_els(aff->v, first, n);
+       if (!aff->v)
+               return isl_aff_free(aff);
+
+       return aff;
+}
+
 #undef PW
 #define PW isl_pw_aff
 #undef EL
@@ -840,7 +871,6 @@ error:
 #define NO_EVAL
 #define NO_OPT
 #define NO_MOVE_DIMS
-#define NO_DROP_DIMS
 #define NO_INSERT_DIMS
 #define NO_REALIGN
 #define NO_LIFT