2 * Copyright 2010 INRIA Saclay
4 * Use of this software is governed by the GNU LGPLv2.1 license
6 * Written by Sven Verdoolaege, INRIA Saclay - Ile-de-France,
7 * Parc Club Orsay Universite, ZAC des vignes, 4 rue Jacques Monod,
19 #if defined(__cplusplus)
23 /* An isl_morph is a "morphism" on (basic) sets.
24 * "map" is an affine mapping from "dom" to "ran"
25 * and "inv" is the inverse mapping.
36 typedef struct isl_morph isl_morph
;
38 __isl_give isl_morph
*isl_morph_alloc(
39 __isl_take isl_basic_set
*dom
, __isl_take isl_basic_set
*ran
,
40 __isl_take isl_mat
*map
, __isl_take isl_mat
*inv
);
41 __isl_give isl_morph
*isl_morph_copy(__isl_keep isl_morph
*morph
);
42 __isl_give isl_morph
*isl_morph_identity(__isl_keep isl_basic_set
*bset
);
43 void isl_morph_free(__isl_take isl_morph
*morph
);
45 __isl_give isl_dim
*isl_morph_get_ran_dim(__isl_keep isl_morph
*morph
);
46 unsigned isl_morph_dom_dim(__isl_keep isl_morph
*morph
, enum isl_dim_type type
);
47 unsigned isl_morph_ran_dim(__isl_keep isl_morph
*morph
, enum isl_dim_type type
);
49 __isl_give isl_morph
*isl_morph_remove_dom_dims(__isl_take isl_morph
*morph
,
50 enum isl_dim_type type
, unsigned first
, unsigned n
);
51 __isl_give isl_morph
*isl_morph_remove_ran_dims(__isl_take isl_morph
*morph
,
52 enum isl_dim_type type
, unsigned first
, unsigned n
);
54 __isl_give isl_morph
*isl_morph_compose(__isl_take isl_morph
*morph1
,
55 __isl_take isl_morph
*morph2
);
56 __isl_give isl_morph
*isl_morph_inverse(__isl_take isl_morph
*morph
);
58 void isl_morph_dump(__isl_take isl_morph
*morph
, FILE *out
);
60 __isl_give isl_morph
*isl_basic_set_variable_compression(
61 __isl_keep isl_basic_set
*bset
, enum isl_dim_type type
);
62 __isl_give isl_morph
*isl_basic_set_parameter_compression(
63 __isl_keep isl_basic_set
*bset
);
64 __isl_give isl_morph
*isl_basic_set_full_compression(
65 __isl_keep isl_basic_set
*bset
);
67 __isl_give isl_basic_set
*isl_morph_basic_set(__isl_take isl_morph
*morph
,
68 __isl_take isl_basic_set
*bset
);
69 __isl_give isl_set
*isl_morph_set(__isl_take isl_morph
*morph
,
70 __isl_take isl_set
*set
);
71 __isl_give isl_vec
*isl_morph_vec(__isl_take isl_morph
*morph
,
72 __isl_take isl_vec
*vec
);
74 #if defined(__cplusplus)