| 1 | /* |
| 2 | * Copyright 2010 INRIA Saclay |
| 3 | * |
| 4 | * Use of this software is governed by the MIT license |
| 5 | * |
| 6 | * Written by Sven Verdoolaege, INRIA Saclay - Ile-de-France, |
| 7 | * Parc Club Orsay Universite, ZAC des vignes, 4 rue Jacques Monod, |
| 8 | * 91893 Orsay, France |
| 9 | */ |
| 10 | |
| 11 | __isl_give PW *FN(PW,morph_domain)(__isl_take PW *pw, |
| 12 | __isl_take isl_morph *morph) |
| 13 | { |
| 14 | int i; |
| 15 | isl_size n; |
| 16 | isl_ctx *ctx; |
| 17 | isl_space *space; |
| 18 | |
| 19 | n = FN(PW,n_piece)(pw); |
| 20 | if (n < 0 || !morph) |
| 21 | goto error; |
| 22 | |
| 23 | ctx = isl_space_get_ctx(space: pw->dim); |
| 24 | isl_assert(ctx, isl_space_is_domain_internal(morph->dom->dim, pw->dim), |
| 25 | goto error); |
| 26 | |
| 27 | space = FN(PW,take_space)(pw); |
| 28 | space = isl_space_extend_domain_with_range( |
| 29 | domain: isl_space_copy(space: morph->ran->dim), model: space); |
| 30 | pw = FN(PW,restore_space)(pw, space); |
| 31 | |
| 32 | for (i = 0; i < n; ++i) { |
| 33 | isl_set *domain; |
| 34 | EL *el; |
| 35 | |
| 36 | domain = FN(PW,take_domain_at)(pw, pos: i); |
| 37 | domain = isl_morph_set(morph: isl_morph_copy(morph), set: domain); |
| 38 | pw = FN(PW,restore_domain_at)(pw, pos: i, domain); |
| 39 | el = FN(PW,take_base_at)(pw, pos: i); |
| 40 | el = FN(EL,morph_domain)(qp: el, morph: isl_morph_copy(morph)); |
| 41 | pw = FN(PW,restore_base_at)(pw, pos: i, el); |
| 42 | } |
| 43 | |
| 44 | isl_morph_free(morph); |
| 45 | |
| 46 | return pw; |
| 47 | error: |
| 48 | FN(PW,free)(pw); |
| 49 | isl_morph_free(morph); |
| 50 | return NULL; |
| 51 | } |
| 52 | |