(struct isl_basic_map **)bset, c, opt_n, opt_d);
}
-/* Compute the convex hull of a basic map, by removing the redundant
+/* Remove redundant
* constraints. If the minimal value along the normal of a constraint
* is the same if the constraint is removed, then the constraint is redundant.
*
* corresponding equality and the checked if the dimension was that
* of a facet.
*/
-struct isl_basic_map *isl_basic_map_convex_hull(struct isl_basic_map *bmap)
+__isl_give isl_basic_map *isl_basic_map_remove_redundancies(
+ __isl_take isl_basic_map *bmap)
{
struct isl_tab *tab;
return NULL;
}
-struct isl_basic_set *isl_basic_set_convex_hull(struct isl_basic_set *bset)
+__isl_give isl_basic_set *isl_basic_set_remove_redundancies(
+ __isl_take isl_basic_set *bset)
{
return (struct isl_basic_set *)
- isl_basic_map_convex_hull((struct isl_basic_map *)bset);
+ isl_basic_map_remove_redundancies((struct isl_basic_map *)bset);
}
/* Check if the set set is bound in the direction of the affine
hull_facet = isl_basic_set_add_equality(hull_facet, hull->ineq[i]);
hull_facet = isl_basic_set_gauss(hull_facet, NULL);
hull_facet = isl_basic_set_normalize_constraints(hull_facet);
- if (!facet)
+ if (!facet || !hull_facet)
goto error;
hull = isl_basic_set_cow(hull);
hull = isl_basic_set_extend_dim(hull,
isl_dim_copy(hull->dim), 0, 0, facet->n_ineq);
+ if (!hull)
+ goto error;
for (j = 0; j < facet->n_ineq; ++j) {
for (f = 0; f < hull_facet->n_ineq; ++f)
if (isl_seq_eq(facet->ineq[j],
}
hull = isl_basic_set_set_rational(hull);
hull = isl_basic_set_remove_dims(hull, dim, 2*(1+dim));
- hull = isl_basic_set_convex_hull(hull);
+ hull = isl_basic_set_remove_redundancies(hull);
isl_basic_set_free(bset1);
isl_basic_set_free(bset2);
return hull;
map = isl_map_detect_equalities(map);
map = isl_map_align_divs(map);
+ if (!map)
+ goto error;
model = isl_basic_map_copy(map->p[0]);
set = isl_map_underlying_set(map);
if (!set)
hull = isl_basic_map_overlying_set(bset, model);
hull = isl_basic_map_intersect(hull, affine_hull);
- hull = isl_basic_map_convex_hull(hull);
+ hull = isl_basic_map_remove_redundancies(hull);
ISL_F_SET(hull, ISL_BASIC_MAP_NO_IMPLICIT);
ISL_F_SET(hull, ISL_BASIC_MAP_ALL_EQUALITIES);