summate.c: join_compatible: use isl_space_has_equal_params
[barvinok.git] / Makefile.am
blob2371511fd75cec7866180a0f93bebfa08ba3a4e7
1 if BUNDLED_POLYLIB
2     MAYBE_POLYLIB = polylib
3     POLYLIB_LA = $(top_builddir)/polylib/libpolylibgmp.la
4     LOCAL_POLYLIB_LA = polylib/libpolylibgmp.la
5 endif
6 if BUNDLED_ISL
7     MAYBE_ISL = isl
8     ISL_LA = $(top_builddir)/isl/libisl.la
9     LOCAL_ISL_LA = isl/libisl.la
10 endif
11 if BUILD_ISL
12     ISL_LA = $(ISL_BUILDDIR)/libisl.la
13 endif
14 if BUNDLED_PET
15     MAYBE_PET = pet
16     PET_LA = $(top_builddir)/pet/libpet.la
17 endif
18 if BUILD_PET
19     PET_LA = $(PET_BUILDDIR)/libpet.la
20 endif
21 if USE_ZSOLVE
22     MAYBE_ZSOLVE = zsolve
23 endif
24 if USE_PARKER
25     MAYBE_PARKER = parker
26 endif
27 SUBDIRS = $(MAYBE_POLYLIB) $(MAYBE_ISL) $(MAYBE_PET) \
28                 $(MAYBE_ZSOLVE) $(MAYBE_PARKER) . doc
29 DIST_SUBDIRS = $(MAYBE_POLYLIB) $(MAYBE_ISL) $(MAYBE_PET) \
30                 zsolve parker doc
32 FORCE:
33 polylib/libpolylibgmp.la: FORCE
34         cd polylib; $(MAKE) $(AM_MAKEFLAGS) libpolylibgmp.la
35 isl/libisl.la: FORCE
36         cd isl; $(MAKE) $(AM_MAKEFLAGS) libisl.la
37 pet/libpet.la: FORCE
38         cd pet; $(MAKE) $(AM_MAKEFLAGS) libpet.la
39 zsolve/libzsolve.la: FORCE
40         cd zsolve; $(MAKE) $(AM_MAKEFLAGS) libzsolve.la
41 parker/libparker.la: FORCE
42         cd parker; $(MAKE) $(AM_MAKEFLAGS) libparker.la
44 AM_CPPFLAGS = @POLYLIB_CPPFLAGS@ \
45               @ISL_CFLAGS@ @NTL_CPPFLAGS@
46 AM_LDFLAGS = @POLYLIB_LDFLAGS@ @NTL_LDFLAGS@
48 LIB_ISL = $(ISL_LA) @ISL_LIBS@
49 LIB_PET = $(PET_LA) @PET_LIBS@
50 LIB_POLYLIB = $(POLYLIB_LA) @POLYLIB_LIBS@
52 lib_LTLIBRARIES = libbarvinok.la
53 bin_PROGRAMS = barvinok_count barvinok_enumerate barvinok_enumerate_e \
54                   barvinok_ehrhart polytope_scan iscc
55 noinst_PROGRAMS = test testlib randomtest \
56                   remove_redundant_equalities \
57                   barvinok_union polytope_volume test_approx \
58                   barvinok_summate verify_lexsmaller \
59                   polyhedron_sample 4coins lexmin \
60                   @bv_cone_hilbert_basis@ cone_integer_hull \
61                   polytope_lattice_width \
62                   polyhedron_integer_hull vector_partition_chambers \
63                   semigroup_holes \
64                   barvinok_bound test_bound
65 EXTRA_PROGRAMS = cone_hilbert_basis
66 pkginclude_HEADERS = \
67     barvinok/NTL_QQ.h \
68     barvinok/isl.h \
69     barvinok/barvinok.h \
70     barvinok/util.h \
71     barvinok/evalue.h \
72     barvinok/genfun.h \
73     barvinok/options.h \
74     barvinok/polylib.h \
75     barvinok/sample.h \
76     barvinok/basis_reduction.h
77 nodist_pkginclude_HEADERS = \
78     barvinok/NTL.h \
79     barvinok/set.h
80 LINK = $(CXXLINK)
82 if HAVE_CDDLIB
83     BR_CDD = basis_reduction_cdd.cc initcdd.cc
84     POLYSIGN_CDD = polysign_cddf.cc polysign_cdd.cc
85 endif
86 if HAVE_GLPK
87     BR_GLPK = basis_reduction_glpk.c
88     POLYSIGN_GLPK = polysign_glpk.c
89 endif
90 if HAVE_TOPCOM
91     TOPCOM = topcom.c topcom.h
92 endif
93 if USE_ZSOLVE
94     HILBERT_C = hilbert.c
95 endif
96 libbarvinok_la_SOURCES = \
97     barvinok/evalue.h \
98     barvinok/genfun.h \
99     barvinok/util.h \
100     barvinok/barvinok.h \
101     NTL_QQ.cc \
102     basis_reduction.c \
103     evalue.c \
104     genfun.cc \
105     util.c \
106     version.c \
107     bernoulli.c \
108     bernoulli.h \
109     bfcounter.cc \
110     bfcounter.h \
111     binomial.c \
112     binomial.h \
113     conversion.cc \
114     conversion.h \
115     counter.cc \
116     counter.h \
117     decomposer.cc \
118     decomposer.h \
119     dpoly.cc \
120     dpoly.h \
121     euler.cc \
122     euler.h \
123     evalue_isl.c \
124     genfun_constructor.cc \
125     genfun_constructor.h \
126     $(HILBERT_C) \
127     hilbert.h \
128     hull.c \
129     hull.h \
130     ilp.c \
131     ilp.h \
132     isl_aff_polylib.c \
133     isl_aff_polylib.h \
134     isl_map_polylib.c \
135     isl_map_polylib.h \
136     isl_set_polylib.h \
137     isl_param_util.c \
138     isl_param_util.h \
139     lattice_point.cc \
140     lattice_point.h \
141     lattice_width.c \
142     lattice_width.h \
143     laurent.cc \
144     laurent.h \
145     laurent_old.cc \
146     laurent_old.h \
147     normalization.c \
148     normalization.h \
149     options.c \
150     param_polynomial.cc \
151     param_polynomial.h \
152     param_util.c \
153     param_util.h \
154     $(POLYSIGN_CDD) \
155     $(POLYSIGN_GLPK) \
156     polysign.c \
157     polysign_isl.c \
158     polysign_polylib.c \
159     polysign.h \
160     power.h \
161     reduce_domain.c \
162     reduce_domain.h \
163     reducer.cc \
164     reducer.h \
165     remove_equalities.h \
166     remove_equalities.c \
167     sample.c \
168     scale.c \
169     scale.h \
170     scarf.cc \
171     section_array.h \
172     series.cc \
173     $(TOPCOM) \
174     summate.c \
175     summate.h \
176     vertex_cone.cc \
177     vertex_cone.h \
178     volume.c \
179     volume.h \
180     mat_util.cc \
181     mat_util.h \
182     matrix_read.cc \
183     matrix_read.h \
184     barvinok.cc \
185     barvinok_e.cc \
186     $(BR_CDD) \
187     $(BR_GLPK)
188 EXTRA_libbarvinok_la_SOURCES = \
189     basis_reduction_cdd.cc \
190     basis_reduction_glpk.c \
191     hilbert.c \
192     polysign_cddf.cc \
193     polysign_cdd.cc \
194     polysign.c \
195     initcdd.cc \
196     initcdd.h \
197     topcom.c \
198     topcom.h
199 if USE_ZSOLVE
200     ZSOLVE_LA = zsolve/libzsolve.la
201 endif
202 libbarvinok_la_LIBADD = @LTLIBOBJS@ $(LIB_ISL) \
203                              $(LIB_POLYLIB) $(ZSOLVE_LA)
204 libbarvinok_la_LDFLAGS = @BV_LDFLAGS@ -version-info @versioninfo@ \
205                                 $(AM_LDFLAGS)
206 LDADD = libbarvinok.la $(LIB_ISL) $(LIB_POLYLIB)
208 test_SOURCES = \
209         test.c
210 testlib_SOURCES = \
211         evalue_read.c \
212         evalue_read.h \
213         testlib.cc
214 barvinok_count_SOURCES = barvinok_count.c
215 barvinok_ehrhart_SOURCES = \
216         barvinok_ehrhart_options.c \
217         barvinok_ehrhart_options.h \
218         barvinok_ehrhart.cc \
219         evalue_convert_options.c \
220         evalue_convert.cc \
221         evalue_convert.h \
222         $(FDSTREAM)
223 barvinok_union_SOURCES = \
224         barvinok_union_options.c \
225         barvinok_union_options.h \
226         barvinok_union.cc
227 if HAVE_OMEGA
228 BEEO_SOURCES = \
229         omega_interface/Exit.cc \
230         omega_interface/convert.h \
231         omega_interface/convert.cc \
232         omega_interface/count.h \
233         omega_interface/count.cc
234 else
235 BEEO_SOURCES = 
236 endif
237 if USE_FDSTREAM
238 FDSTREAM = fdstream.cc fdstream.h
239 endif
240 barvinok_enumerate_SOURCES = \
241         barvinok_enumerate_options.c \
242         barvinok_enumerate_options.h \
243         barvinok_enumerate.cc \
244         evalue_convert_options.c \
245         evalue_convert.cc \
246         evalue_convert.h \
247         $(FDSTREAM) \
248         skewed_genfun.cc \
249         skewed_genfun.h \
250         verify.h \
251         verify.c \
252         verify_series.h \
253         verify_series.cc
254 EXTRA_barvinok_enumerate_SOURCES = fdstream.cc fdstream.h
255 barvinok_enumerate_e_SOURCES = \
256         barvinok_enumerate_e_options.c \
257         barvinok_enumerate_e_options.h \
258         barvinok_enumerate_e.cc \
259         evalue_convert_options.c \
260         evalue_convert.cc \
261         evalue_convert.h \
262         $(FDSTREAM) \
263         skewed_genfun.cc \
264         skewed_genfun.h \
265         verify.h \
266         verify.c \
267         verif_ehrhart.h \
268         verif_ehrhart.c \
269         verify_series.h \
270         verify_series.cc \
271         $(BEEO_SOURCES)
272 EXTRA_barvinok_enumerate_e_SOURCES = fdstream.cc fdstream.h
273 if USE_PARKER
274     MONA_LIBS = -ldfa -lbdd -lmem
275     PARKER_LA = parker/libparker.la
276     PARKERLDFLAGS = -L$(MONAPATH)/DFA -L$(MONAPATH)/BDD -L$(MONAPATH)/Mem
277     PARKERCPPFLAGS = -I$(MONAPATH)/Mem -I$(MONAPATH)/DFA -I$(MONAPATH)/BDD
278 endif
279 barvinok_enumerate_e_CPPFLAGS = \
280         $(PARKERCPPFLAGS) @OMEGA_CPPFLAGS@ $(AM_CPPFLAGS)
281 barvinok_enumerate_e_LDFLAGS = $(PARKERLDFLAGS) @OMEGA_LDFLAGS@ @LDFLAGS@
282 barvinok_enumerate_e_LDADD = \
283         $(PARKER_LA) $(MONA_LIBS) @OMEGA_LIBS@ libbarvinok.la \
284         $(LIB_ISL) $(LIB_POLYLIB)
285 barvinok_bound_SOURCES = \
286         bound.c \
287         verify.h \
288         verify.c
289 EXTRA_barvinok_bound_SOURCES = fdstream.cc fdstream.h
290 barvinok_summate_SOURCES = \
291         barvinok_summate.c \
292         verify.h \
293         verify.c
294 EXTRA_barvinok_summate_SOURCES = fdstream.cc fdstream.h
295 4coins_SOURCES = 4coins.cc
296 semigroup_holes_SOURCES = semigroup_holes.cc
297 lexmin_SOURCES = \
298         lexmin_options.c \
299         lexmin.h \
300         lexmin.cc \
301         edomain.cc \
302         edomain.h \
303         evalue_util.cc \
304         evalue_util.h \
305         verify.h \
306         verify.c
307 test_approx_SOURCES = \
308         test_approx.c \
309         verify.h \
310         verify.c
311 test_bound_SOURCES = \
312         test_bound.c \
313         verify.h \
314         verify.c
315 EXTRA_test_bound_SOURCES = fdstream.cc fdstream.h
316 iscc_SOURCES =  \
317         isl_obj_list.h \
318         isl_obj_list.c \
319         isl_obj_str.h \
320         isl_obj_str.c \
321         iscc.c
322 iscc_CPPFLAGS = @PET_CFLAGS@ $(AM_CPPFLAGS)
323 iscc_LDADD = \
324         libbarvinok.la $(LIB_PET) $(LIB_ISL) \
325         $(LIB_POLYLIB)
327 isl.py: interface/isl.py.top
328         (cat interface/isl.py.top; \
329                 @ISL_BUILDDIR@/interface/extract_interface$(EXEEXT) \
330                         $(DEFAULT_INCLUDES) @ISL_CFLAGS@ -I"@ISL_SRCDIR@" \
331                         $(srcdir)/interface/all_barvinok.h) \
332                         > isl.py
334 TESTFILES = $(shell find $(top_srcdir)/tests -type f ! -path '*CVS*')
336 EXTRA_DIST = \
337     ChangeLog \
338     $(TESTFILES) \
339     latte2polylib.pl \
340     NTL_5_3_2.patch \
341     basis_reduction_templ.c \
342     cdd94e-test \
343     polysign_cdd_template.cc \
344     barvinok/NTL.h.broken \
345     barvinok/NTL.h.normal \
346     barvinok/set.h.broken \
347     barvinok/set.h.normal \
348     config_post.h \
349     doc/isl.tex \
350     doc/Internal.tex \
351     doc/applications.tex \
352     doc/barvinok.tex \
353     doc/polymake.tex \
354     doc/reports.tex \
355     doc/barvinok.bib \
356     doc/barvinok.gdf \
357     doc/chicago.bst \
358     doc/chicago.sty \
359     doc/mydefs.sty \
360     interface/all_barvinok.h \
361     interface/isl.py.top \
362     polymake/Makefile.in \
363     polymake/README \
364     polymake/autogen.sh \
365     polymake/configure.in \
366     polymake/convert.cc \
367     polymake/convert.h \
368     polymake/h_star_vector.cc \
369     polymake/lattice_points.cc
371 ACLOCAL_AMFLAGS = -I m4
373 install-data-local:
374         @test -z "$(pkgconfig_libdir)" || $(mkdir_p) "$(DESTDIR)$(pkgconfig_libdir)"
375         $(INSTALL_DATA) $(pkgconfig_libfile) "$(DESTDIR)$(pkgconfig_libdir)/$(pkgconfig_libfile)"
377 uninstall-local:
378         rm -f "$(DESTDIR)$(pkgconfig_libdir)/$(pkgconfig_libfile)"
380 dist-hook: isl.py
381         cp isl.py $(distdir)/
382         (cd $(distdir)/polymake; \
383             ./autogen.sh; rm -rf autogen.sh autom4te.cache)
384         (cd doc; make barvinok.pdf)
385         cp doc/barvinok.pdf $(distdir)/doc/
386         if test -f $(top_srcdir)/.git/HEAD; then \
387             echo @GIT_HEAD_VERSION@ > $(distdir)/GIT_HEAD_ID; \
388         else \
389             echo $(GIT_HEAD_ID) > $(distdir)/GIT_HEAD_ID; \
390         fi
392 dist-git: dist
393         mv $(distdir).tar.gz @GIT_HEAD_VERSION@.tar.gz
395 BEE_TESTDIRS = ehrhart_e ehrhart_e/scarf ehrhart_e/piplib
397 check: check-testlib check-enumerate check-enumerate_e check-test \
398         check-lexmin check-approx check-pwqp check-euler check-iscc \
399         check-union
400 check-testlib: testlib$(EXEEXT)
401         ./testlib$(EXEEXT)
402 check-approx: test_approx$(EXEEXT)
403         @for i in $(top_srcdir)/tests/ehrhart/*; do \
404             if test -f $$i; then \
405                 echo $$i | ./test_approx$(EXEEXT) -q -r 10 || exit; \
406             fi \
407         done
408 check-pwqp: barvinok_bound$(EXEEXT) test_bound$(EXEEXT) barvinok_summate$(EXEEXT)
409         @for i in $(top_srcdir)/tests/pwqp/*; do \
410             if test -f $$i; then \
411                 echo $$i; \
412                 ./barvinok_bound$(EXEEXT) -T -r30 < $$i || exit; \
413                 echo $$i | ./test_bound$(EXEEXT) -q -r30 || exit; \
414                 ./barvinok_summate$(EXEEXT) -T -r30 < $$i || exit; \
415             fi \
416         done
417 check-euler: barvinok_summate$(EXEEXT)
418         @for i in $(top_srcdir)/tests/euler/*; do \
419             if test -f $$i; then \
420                 for method in 'euler' 'laurent_old' 'laurent'; do \
421                     opt="--summation=$$method"; \
422                     echo $$i $$opt; \
423                     ./barvinok_summate$(EXEEXT) -T $$opt < $$i || exit; \
424                 done \
425             fi \
426         done
427         @for t in dull EML_p EML-product EML line square square_p square \
428                 square_p3 triangle triangle2 triangle_p quasi; do \
429             i=$(top_srcdir)/tests/euler/$$t.pwqp; \
430             if test -f $$i; then \
431                 opt="--summation=box"; \
432                 echo $$i $$opt; \
433                 ./barvinok_summate$(EXEEXT) -T $$opt < $$i || exit; \
434             fi \
435         done
436         @for t in dull dull_p EML line square square_p square \
437                 square_p3 triangle triangle2 triangle_p; do \
438             i=$(top_srcdir)/tests/euler/$$t.pwqp; \
439             if test -f $$i; then \
440                 opt="--summation=bernoulli"; \
441                 echo $$i $$opt; \
442                 ./barvinok_summate$(EXEEXT) -T $$opt < $$i || exit; \
443             fi \
444         done
445 if HAVE_TOPCOM
446     TOPCOM_CD = '--chamber-decomposition=topcom'
447 endif
448 ISL_CD = '--chamber-decomposition=isl'
449 check-enumerate: barvinok_enumerate$(EXEEXT)
450         @for i in $(top_srcdir)/tests/ehrhart/*; do \
451             if test -f $$i; then \
452                 echo $$i; \
453                 for options in '' '--series' '--series --primal' $(TOPCOM_CD) $(ISL_CD); do \
454                     for spec in 'random' 'bf' 'df'; do \
455                         opt="--specialization=$$spec $$options"; \
456                         echo "        $$opt"; \
457                         ./barvinok_enumerate$(EXEEXT) --verify $$opt < $$i || exit; \
458                     done \
459                 done; \
460                 opt="--index=4"; \
461                 echo "        $$opt"; \
462                 ./barvinok_enumerate$(EXEEXT) --verify $$opt < $$i || exit; \
463                 opt="--summation=bernoulli"; \
464                 echo "        $$opt"; \
465                 ./barvinok_enumerate$(EXEEXT) --verify $$opt < $$i || exit; \
466             fi \
467         done
468 if HAVE_OMEGA
469     SPEC_OMEGA = '--isl --omega'
470 endif
471 check-enumerate_e: barvinok_enumerate_e$(EXEEXT)
472         @for dir in $(BEE_TESTDIRS); do \
473             for i in $(top_srcdir)/tests/$$dir/*; do \
474                 if test -f $$i; then \
475                     for options in '' $(SPEC_OMEGA) '--isl'; do \
476                         for spec in 'random' 'bf' 'df'; do \
477                             opt="--specialization=$$spec $$options"; \
478                             echo $$i $$opt; \
479                             ./barvinok_enumerate_e$(EXEEXT) --verify $$opt < $$i || exit; \
480                         done \
481                     done \
482                 fi \
483             done \
484         done
485         @for i in $(top_srcdir)/tests/ehrhart_e/scarf/*; do \
486             if test -f $$i; then \
487                 for spec in 'random' 'bf' 'df'; do \
488                     opt="--specialization=$$spec --scarf"; \
489                     echo $$i $$opt; \
490                     ./barvinok_enumerate_e$(EXEEXT) --verify $$opt < $$i || exit; \
491                 done; \
492                 echo $$i --series; \
493                 ./barvinok_enumerate_e$(EXEEXT) --verify --series < $$i || exit; \
494             fi \
495         done
496 check-test: test$(EXEEXT)
497         @failed=0; \
498         for i in $(top_srcdir)/tests/*; do \
499             if test -f $$i; then \
500                 for options in '--index=10' '--primal --index=10'; do \
501                     for spec in 'random' 'bf' 'df' 'todd'; do \
502                         opt="--specialization=$$spec $$options"; \
503                         echo -n $$i $$opt; \
504                         ./test$(EXEEXT) $$opt < $$i; \
505                         if test "$$?" -ne "0"; then \
506                             failed=`expr $$failed + 1`; \
507                             echo " NOT ok"; \
508                         else \
509                             echo " ok"; \
510                         fi; \
511                     done \
512                 done \
513             fi \
514         done; \
515         for i in $(top_srcdir)/tests/sample/*; do \
516             echo -n $$i; \
517             ./test$(EXEEXT) < $$i; \
518             if test "$$?" -ne "0"; then \
519                 failed=`expr $$failed + 1`; \
520                 echo " NOT ok"; \
521             else \
522                 echo " ok"; \
523             fi; \
524         done; \
525         if test $$failed != 0; then \
526                 echo "$$failed tests failed"; \
527                 exit -1; \
528         fi
529 check-lexmin: lexmin$(EXEEXT)
530         @for i in $(top_srcdir)/tests/lexmin/*; do \
531             if test -f $$i; then \
532                 for spec in 'random' 'bf' 'df'; do \
533                     opt="--specialization=$$spec"; \
534                     echo $$i $$opt; \
535                     ./lexmin$(EXEEXT) --verify $$opt < $$i || exit; \
536                 done \
537             fi \
538         done
539 check-iscc: iscc$(EXEEXT)
540         @for i in $(top_srcdir)/tests/iscc/*; do \
541                 if test -f $$i; then \
542                         echo $$i; \
543                         ./iscc$(EXEEXT) < $$i || exit; \
544                 fi \
545         done
546 check-union: barvinok_union$(EXEEXT)
547         @for i in $(top_srcdir)/tests/ehrhart_union/*; do \
548             if test -f $$i; then \
549                 for spec in 'random' 'bf' 'df'; do \
550                     opt="--specialization=$$spec $$options"; \
551                     echo $$i $$opt; \
552                     ./barvinok_union$(EXEEXT) -c $$opt < $$i || exit; \
553                 done \
554             fi \
555         done
557 version.h: @GIT_HEAD@
558         echo '#define GIT_HEAD_ID "'@GIT_HEAD_VERSION@'"' > $@