Blame isl-0.16.1/isl_multi_floor.c
|
Packit |
fb9d21 |
/*
|
|
Packit |
fb9d21 |
* Copyright 2014 Ecole Normale Superieure
|
|
Packit |
fb9d21 |
*
|
|
Packit |
fb9d21 |
* Use of this software is governed by the MIT license
|
|
Packit |
fb9d21 |
*
|
|
Packit |
fb9d21 |
* Written by Sven Verdoolaege,
|
|
Packit |
fb9d21 |
* Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
|
|
Packit |
fb9d21 |
*/
|
|
Packit |
fb9d21 |
|
|
Packit |
fb9d21 |
#include <isl_multi_macro.h>
|
|
Packit |
fb9d21 |
|
|
Packit |
fb9d21 |
/* Given f, return floor(f).
|
|
Packit |
fb9d21 |
*/
|
|
Packit |
fb9d21 |
__isl_give MULTI(BASE) *FN(MULTI(BASE),floor)(__isl_take MULTI(BASE) *multi)
|
|
Packit |
fb9d21 |
{
|
|
Packit |
fb9d21 |
int i;
|
|
Packit |
fb9d21 |
|
|
Packit |
fb9d21 |
multi = FN(MULTI(BASE),cow)(multi);
|
|
Packit |
fb9d21 |
if (!multi)
|
|
Packit |
fb9d21 |
return NULL;
|
|
Packit |
fb9d21 |
|
|
Packit |
fb9d21 |
for (i = 0; i < multi->n; ++i) {
|
|
Packit |
fb9d21 |
multi->p[i] = FN(EL,floor)(multi->p[i]);
|
|
Packit |
fb9d21 |
if (!multi->p[i])
|
|
Packit |
fb9d21 |
return FN(MULTI(BASE),free)(multi);
|
|
Packit |
fb9d21 |
}
|
|
Packit |
fb9d21 |
|
|
Packit |
fb9d21 |
return multi;
|
|
Packit |
fb9d21 |
}
|