decomposer.cc: barvinok_decompose: implement in terms of primal_decompose
[barvinok.git] / configure.in
blob61b0398610c701bdd715160e8d45cd166f7809f9
1 AC_INIT
2 AM_INIT_AUTOMAKE(barvinok, 0.22)
3 AC_PROG_CC
4 gl_EARLY
6 AC_PROG_CXX
7 AM_PROG_LEX
8 AC_PROG_YACC
9 AC_SUBST(versioninfo)
10 versioninfo=12:0:0
12 AC_CANONICAL_HOST
13 AC_LIBTOOL_WIN32_DLL
14 AC_SUBST(BV_LDFLAGS)
15 case $host in
16         *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
17         if test "$enable_shared" = yes; then
18                 BV_LDFLAGS="-no-undefined" 
19         fi
20         ;;
21 esac
23 AC_DISABLE_SHARED
24 AC_PROG_LIBTOOL
26 gl_MODULES(argp progname)
27 gl_INIT
29 AC_CHECK_HEADERS(getopt.h)
30 AC_CHECK_HEADERS(sys/times.h)
32 dnl Check for GMP library
33 AC_MSG_CHECKING(whether to use GMP)
34 AC_ARG_WITH(libgmp, 
35         [  --with-libgmp           DIR Location of the GMP Distribution], 
36         gmp_package=$withval, gmp_package=yes)
37 if test "x$gmp_package" = "xno"; then
38         AC_MSG_RESULT(no)
39         AC_MSG_ERROR(Need gmp)
40 else
41         AC_MSG_RESULT(yes)
42         if test "x$gmp_package" != "xyes"; then
43             GMP_DIR=$gmp_package
44             if test ! -d "$GMP_DIR"; then
45                 AC_ERROR(Directory given for GMP Distribution is not a directory)
46             fi
47             CPPFLAGS="-I$GMP_DIR/include $CPPFLAGS"
48             LDFLAGS="-L$GMP_DIR/lib $LDFLAGS"
49         fi
50         poly_cv_gmpfatal="no"
51         AC_CHECK_HEADER(gmp.h,
52                 [AC_CHECK_LIB(gmp,main,
53                     [],
54                     [poly_cv_gmpfatal="yes"])],
55                 [poly_cv_gmpfatal="yes"])
56         if test "$poly_cv_gmpfatal" = "yes"; then
57                 AC_MSG_ERROR([GMP not found])
58         fi
60 AC_CHECK_DECL(mpz_divisible_p,[],[AC_LIBOBJ(mpz_divisible_p)],[#include <gmp.h>])
62 AC_ARG_WITH(polylib,
63             [  --with-polylib=DIR      DIR Location of PolyLib],
64             [ echo "Package polylib : $withval" && polylib_package=$withval],  
65             [ polylib_package=yes ])
67 if test "$polylib_package" = "no"; then
68     AC_MSG_ERROR(Need polylib)
71 if test "$polylib_package" != "yes"; then
72     CPPFLAGS="-I$polylib_package/include $CPPFLAGS"
73     LDFLAGS="-L$polylib_package/lib $LDFLAGS"
74     LD_LIBRARY_PATH="$polylib_package/lib:$LD_LIBRARY_PATH"
75     export LD_LIBRARY_PATH
78 AC_CHECK_LIB(polylibgmp, PolyhedronTSort,[],[
79     AC_MSG_ERROR(Need polylib)
81 AC_CHECK_FUNCS(Enumeration_Free)
82 AC_CHECK_FUNCS(compress_parms, [AC_LIBOBJ(remove_equalities)])
83 AC_SUBST(bv_extra_programs)
84 AC_CHECK_FUNCS(LexSmaller,[
85         bv_extra_programs="verify_lexsmaller $bv_extra_programs"
86     ])
87 AC_REPLACE_FUNCS(DomainConstraintSimplify)
88 AC_TRY_RUN([
89 #include <polylib/polylibgmp.h>
91 int main()
93     int i, j;
94     Polyhedron *P;
95     Matrix *M = Matrix_Alloc(6,5);
96     for (i = 0; i < 6; ++i) {
97         value_set_si(M->p[i][0], 1);
98         for (j = 1; j < 4; ++j)
99             value_set_si(M->p[i][j], (j-1 == i/2) * (1-2*(i%2)));
100         value_set_si(M->p[i][4], i%2);
101     }
102     P = Constraints2Polyhedron(M, 6);
103     return !(P->NbRays == 8);
106 [AC_DEFINE(HAVE_GROWING_CHERNIKOVA,[],
107           [PolyLib automatically grows the Chernikova table space])],
108 AC_MSG_WARN([This version of PolyLib does not automatically])
109 AC_MSG_WARN([enlarge the Chernikova table space]),
110 AC_MSG_WARN([Unable to determine whether PolyLib automatically])
111 AC_MSG_WARN([grows the Chernikova table space]))
113 AC_TRY_RUN([
114 #include <polylib/polylibgmp.h>
116 int main()
118     enode *en = new_enode(polynomial, 1, 1);
119     return !(en->arr[0].x.p == NULL);
122 AC_MSG_WARN([This version of polylib leaks]),[true])
124 AC_TRY_RUN([
125 #include <stdio.h>
126 #include <polylib/polylibgmp.h>
128 int main()
130     Matrix *M;
131     Polyhedron *P, *C;
132     Param_Polyhedron *PP;
133     int i;
134     Param_Vertices *V;
136     freopen("$srcdir/tests/ehrhart/t12.in", "r", stdin);
137     M = Matrix_Read();
138     P = Constraints2Polyhedron(M, 1024);
139     M = Matrix_Read();
140     C = Constraints2Polyhedron(M, 1024);
141     PP = Polyhedron2Param_Domain(P, C, 1024);
142     for (i = 0, V = PP->V; V; ++i, V = V->next)
143         ;
144     return !(i == 10);
147 [AC_DEFINE(HAVE_CORRECT_VERTICES,[],
148           [PolyLib computes correct vertices])],
149 AC_MSG_WARN([This version of polylib produces incorrect vertices.]),
150 AC_MSG_WARN([Unable to determine whether PolyLib computes correct vertices]))
152 AC_MSG_CHECKING([number of arguments of Polyhedron_Enumerate])
153 AC_TRY_COMPILE([#include <polylib/polylibgmp.h>], 
154                [Polyhedron_Enumerate(NULL,NULL,0,NULL)],
155                [AC_MSG_RESULT(4)
156                 AC_DEFINE(HAVE_ENUMERATE4,[],
157                           [Polyhedron_Enumerate takes four arguments])],
158                [AC_MSG_RESULT(3)])
160 AC_MSG_CHECKING([number of arguments of count_points])
161 AC_TRY_COMPILE([#include <polylib/polylibgmp.h>], 
162                [count_points(0,NULL,NULL,NULL)],
163                [AC_MSG_RESULT(4)
164                 AC_DEFINE(HAVE_COUNT_POINTS4,[],
165                           [count_points takes four arguments])],
166                [AC_MSG_RESULT(3)])
168 AC_MSG_CHECKING([for value_subtract macro])
169 AC_EGREP_CPP(yes, [
170     #include <polylib/polylibgmp.h>
171     #ifdef value_subtract
172     yes
173     #endif
174     ],[AC_MSG_RESULT(yes)],
175     [AC_MSG_RESULT(no)
176      AC_DEFINE(value_subtract,value_substract,
177                 [define to value_substract if missing from PolyLib])])
179 AC_MSG_CHECKING([for value_addmul macro])
180 AC_EGREP_CPP(yes, [
181     #include <polylib/polylibgmp.h>
182     #ifdef value_addmul
183     yes
184     #endif
185     ],[AC_MSG_RESULT(yes)],
186     [AC_MSG_RESULT(no)
187      AC_DEFINE([value_addmul(ref,val1,val2)],[do {Value _tmp; value_init(_tmp); dnl
188                 value_multiply(_tmp,val1,val2); dnl
189                 value_addto(ref,ref,_tmp); dnl
190                 value_clear(_tmp); } while(0)],
191                 [define if missing from PolyLib])])
193 AC_ARG_WITH(piplib,
194             [  --with-piplib=DIR       DIR Location of PIP],
195             [ echo "Package piplib : $withval" && piplib_package=$withval],  
196             [ piplib_package=yes ])
198 have_piplib=false
199 if test "$piplib_package" != "no"; then
200     SAVE_CPPFLAGS="$CPPFLAGS"
201     SAVE_LDFLAGS="$LDFLAGS"
202     if test "$piplib_package" != "yes"; then
203         CPPFLAGS="-I$piplib_package/include $CPPFLAGS"
204         LDFLAGS="-L$piplib_package/lib $LDFLAGS"
205     fi
207     bv_cv_piplibfatal="no"
208     AC_CHECK_LIB(piplibMP, pip_solve,[
209         AC_CHECK_MEMBER(PipOptions.Urs_parms, [], [
210             AC_MSG_WARN([Piplib too old; please install version 1.3.6 or newer])
211             bv_cv_piplibfatal="yes"
212         ],[#include <stdio.h>
213            #include <piplib/piplibMP.h>])
214     ],[
215         AC_MSG_WARN([Piplib not found])
216         bv_cv_piplibfatal="yes"
217     ])
218     if test "$bv_cv_piplibfatal" = "no"; then
219         AC_DEFINE(HAVE_PIPLIB,[],[use piplib])
220         LIBS="-lpiplibMP $LIBS"
221         AC_LIBOBJ(piputil)
222         bv_extra_programs="piptest $bv_extra_programs"
223         have_piplib=true
224     else
225         CPPFLAGS="$SAVE_CPPFLAGS"
226         LDFLAGS="$SAVE_LDFLAGS"
227     fi
229 AM_CONDITIONAL(HAVE_PIPLIB, test x$have_piplib = xtrue)
231 AC_MSG_CHECKING(if the fractional representation should be used)
232 AC_ARG_ENABLE(fractional, [AS_HELP_STRING([--disable-fractional],
233                                           [Don't use fractional representation])],
234             [bv_cv_fractional=$enableval], [bv_cv_fractional="yes"])
235 AC_ARG_ENABLE(modulo, [AS_HELP_STRING([--disable-modulo],
236                                       [Don't use fractional representation])],
237             [bv_cv_modulo=$enableval], [bv_cv_modulo="$bv_cv_fractional"])
238 AC_MSG_RESULT($bv_cv_modulo)
239 if test "x$bv_cv_modulo" != "xno" ; then
240         AC_DEFINE(USE_MODULO,[], [Use fractional representation])
243 AC_MSG_CHECKING(whether to use incremental algorithm)
244 AC_ARG_ENABLE(incremental,
245         [AS_HELP_STRING([--enable-incremental@<:@=bf|df@:>@],
246                         [Enable incremental algorithm [bf]])],
247         [bv_cv_incremental=$enableval], [bv_cv_incremental="no"])
248 AC_MSG_RESULT($bv_cv_incremental)
249 case $bv_cv_incremental in
250         yes | bf)
251                 AC_DEFINE(USE_INCREMENTAL_BF,[], 
252                           [Use breadth-first incremental algorithm])
253         ;;
254         df)
255                 AC_DEFINE(USE_INCREMENTAL_DF,[], 
256                           [Use depth-first incremental algorithm])
257         ;;
258 esac
260 AC_ARG_WITH(ntl,
261             [  --with-ntl=DIR          DIR Location of NTL],
262             [ echo "Package ntl : $withval" && ntl_package=$withval],  
263             [ ntl_package=yes ])
265 if test "$ntl_package" = "no"; then
266     AC_MSG_ERROR(Need ntl)
269 if test "$ntl_package" != "yes"; then
270     CPPFLAGS="-I$ntl_package/include $CPPFLAGS"
271     LDFLAGS="-L$ntl_package/lib $LDFLAGS"
274 AC_EGREP_CPP(yes, [
275     #include <NTL/ZZ.h>
276     #ifdef NTL_GMP_LIP
277     yes
278     #endif
279     ],:,AC_MSG_ERROR(ntl not compiled with gmp support))
281 AC_CHECK_LIB(ntl, main,[],[
282     AC_MSG_ERROR(Need ntl)
285 AC_MSG_CHECKING(whether to compile bernstein)
286 AC_ARG_WITH(bernstein,
287             [AS_HELP_STRING([--without-bernstein],[do not compile bernstein])],
288             [ with_bernstein=$withval],  [ with_bernstein=yes ])
289 AC_MSG_RESULT($with_bernstein)
291 have_ginac=false
292 if test "$with_bernstein" != "no"; then
293         AC_LANG_PUSH(C++)
294         AM_PATH_GINAC(1.3.3, [
295                 have_ginac=true
296                 AC_DEFINE(HAVE_GINAC,[],[use GiNaC])]
297                 PACKAGE_LIBS="-lbarvinok -lbernstein")
298         AC_LANG_POP
300 AM_CONDITIONAL(HAVE_GINAC, test x$have_ginac = xtrue)
302 AC_MSG_CHECKING(whether to use Omega)
303 AC_ARG_WITH(omega, [AS_HELP_STRING([--with-omega=DIR],[DIR Location of Omega])],
304             [ omega_package=$withval],  [ omega_package=yes ])
305 AC_MSG_RESULT($omega_package)
307 AC_SUBST(OMEGA_CPPFLAGS)
308 AC_SUBST(OMEGA_LDFLAGS)
309 AC_SUBST(OMEGA_LIBS)
310 AC_SUBST(bv_omega_programs)
311 have_omega=false
312 if test "$omega_package" != "no"; then
313     if test "x$omega_package" != "xyes"; then
314         OMEGA_CPPFLAGS="-I$omega_package/include/omega"
315         OMEGA_LDFLAGS="-L$omega_package/lib"
316     else
317         for i in /usr/include /usr/local/include; do
318             if test -f $i/omega/omega.h; then
319                 OMEGA_CPPFLAGS="-I$i/omega"
320             fi
321         done
322     fi
324     AC_LANG_PUSH(C++)
325     SAVE_CPPFLAGS="$CPPFLAGS"
326     CPPFLAGS="$OMEGA_CPPFLAGS $CPPFLAGS"
327     AC_CHECK_HEADERS([omega.h],[
328         if test x$have_ginac = xtrue; then
329             bv_omega_programs="occ $bv_omega_programs"
330         fi
331         AC_DEFINE(HAVE_OMEGA,[],[use omega])
332         OMEGA_LIBS="-lcode_gen -lomega"
333         have_omega=true
334     ],[AC_MSG_WARN(Omega not found)])
335     CPPFLAGS="$SAVE_CPPFLAGS"
336     AC_LANG_POP
338 AM_CONDITIONAL(HAVE_OMEGA, test x$have_omega = xtrue)
341 AC_MSG_CHECKING(whether to use cddlib)
342 AC_ARG_WITH(cddlib, [AS_HELP_STRING([--with-cddlib=DIR],[DIR Location of cddlib])],
343             [ cddlib_package=$withval],  [ cddlib_package=yes ])
344 AC_MSG_RESULT($cddlib_package)
346 have_cddlib=false
347 if test "$cddlib_package" != "no"; then
348     if test "x$cddlib_package" != "xyes"; then
349         CPPFLAGS="-I$cddlib_package/include $CPPFLAGS"
350         LDFLAGS="-L$cddlib_package/lib $LDFLAGS"
351     fi
352     AC_TRY_LINK([
353 #define GMPRATIONAL
354 #include <setoper.h>
355 #include <cddmp.h>
356 ], [
357     mytype a;
358     dd_init(a); ], [
359         have_cddlib=true
360         AC_CHECK_LIB(cddgmp, main,[],[have_cddlib=false])
361     ])
363 AM_CONDITIONAL(HAVE_CDDLIB, test x$have_cddlib = xtrue)
367 AC_MSG_CHECKING(whether to use GLPK)
368 AC_ARG_WITH(glpk, [AS_HELP_STRING([--with-glpk=DIR],[DIR Location of GLPK])],
369             [ glpk_package=$withval],  [ glpk_package=yes ])
370 AC_MSG_RESULT($glpk_package)
372 have_glpk=false
373 if test "$glpk_package" != "no"; then
374     if test "x$glpk_package" != "xyes"; then
375         CPPFLAGS="-I$glpk_package/include $CPPFLAGS"
376         LDFLAGS="-L$glpk_package/lib $LDFLAGS"
377     fi
378     AC_CHECK_HEADERS([glpk.h],[
379         have_glpk=true
380         AC_CHECK_LIB(glpk, main,[],[have_glpk=false])
381     ])
383 AM_CONDITIONAL(HAVE_GLPK, test x$have_glpk = xtrue)
385 if test "$have_glpk" = "true" -o "$have_cddlib" = "true"; then
386     AC_LIBOBJ(sample)
387     bv_extra_programs="polyhedron_sample 4coins lexmin $bv_extra_programs"
388     bv_extra_programs="polytope_scan $bv_extra_programs"
391 AC_SUBST(GIT_HEAD_ID)
392 AC_SUBST(GIT_HEAD)
393 AC_SUBST(GIT_HEAD_VERSION)
394 if test -f $srcdir/.git/HEAD; then
395     GIT_HEAD="$srcdir/.git/index"
396     GIT_REPO="$srcdir/.git"
397     GIT_HEAD_ID=`GIT_DIR=$GIT_REPO git describe`
398 elif test -f $srcdir/GIT_HEAD_ID; then
399     GIT_HEAD_ID=`cat $srcdir/GIT_HEAD_ID`
400 else
401     mysrcdir=`(cd $srcdir; pwd)`
402     head=`basename $mysrcdir | sed -e 's/.*-//'`
403     head2=`echo $head | sed -e 's/[^0-9a-f]//'`
404     head3=`echo $head2 | sed -e 's/........................................//'`
405     base=`basename $mysrcdir | sed -e 's/-.*//'`
406     if test "x$head3" = "x" -a "x$head" = "x$head2"; then
407         GIT_HEAD_ID="barvinok-$VERSION-$head
408     elif test "x$base" = "xbarvinok-$VERSION" -a "x$head" != "x"; then
409         GIT_HEAD_ID="barvinok-$VERSION-$head
410     else
411         GIT_HEAD_ID="UNKNOWN"
412     fi
414 if test -z "$GIT_REPO" ; then
415     GIT_HEAD_VERSION="$GIT_HEAD_ID"
416 else
417     GIT_HEAD_VERSION="\`GIT_DIR=$GIT_REPO git describe\`"
419 echo '#define GIT_HEAD_ID "'$GIT_HEAD_ID'"' > version.h
421 AX_CREATE_PKGCONFIG_INFO
423 AC_CONFIG_HEADERS(config.h)
424 AC_CONFIG_FILES(Makefile lib/Makefile doc/Makefile omega/Makefile)
425 if test x$have_ginac = xtrue; then
426     AC_CONFIG_SUBDIRS(bernstein)
428 AC_OUTPUT