[Polly] Update isl to isl-0.23-61-g24e8cd12.

This fixes llvm.org/PR48554

Some test cases had to be updated because the hash function for
union_maps have been changed which affects the output order.
This commit is contained in:
Michael Kruse 2021-01-19 10:28:43 -06:00
parent 2f80995090
commit 842314b5f0
137 changed files with 6991 additions and 4465 deletions

View File

@ -23,8 +23,8 @@ isl was written by
Domaine de Voluceau - Rocquencourt, B.P. 105
78153 Le Chesnay
France
2015-2019 Polly Labs
2018-2019 Cerebras Systems
2015-2020 Polly Labs
2018-2020 Cerebras Systems
175 S San Antonio Rd
Los Altos, CA
USA
@ -54,6 +54,7 @@ Uday Bondhugula
Andreas Simbuerger
Malhar Thakkar
Sergei Trofimovich
Miheer Vaidya
Sven van Haastregt
Oleksandr Zinenko

View File

@ -1,3 +1,11 @@
version: 0.23
date: Sun 01 Nov 2020 02:41:20 PM CET
changes:
- minor improvements to coalescing
- use build compiler to build extract_interface
- add some convenience functions
- ignore parameters in isl_union_* hash tables
---
version: 0.22.1
date: Sun Jan 12 10:48:18 CET 2020
changes:
@ -6,6 +14,7 @@ changes:
version: 0.22
date: Fri Nov 1 18:39:30 CET 2019
changes:
- require C++11 to generate bindings
- improved bindings
- scheduler fix involving fixed dimensions
- accept ranges in tuples during parsing

View File

@ -1 +1 @@
isl-0.22.1-416-g61d6dc75
isl-0.23-61-g24e8cd12

View File

@ -141,6 +141,7 @@ libisl_la_SOURCES = \
isl_ilp_private.h \
isl_input.c \
isl_int.h \
isl_list_private.h \
isl_local_private.h \
isl_local.h \
isl_local.c \
@ -465,7 +466,9 @@ EXTRA_DIST = \
isl_check_named_params_templ.c \
check_reparse_templ.c \
check_reparse_test_templ.c \
check_single_reference_templ.c \
check_type_range_templ.c \
isl_copy_tuple_id_templ.c \
isl_domain_factor_templ.c \
extract_key.c \
isl_ilp_opt_multi_val_templ.c \
@ -558,6 +561,7 @@ EXTRA_DIST = \
isl_type_check_equal_space_templ.c \
isl_type_has_equal_space_bin_templ.c \
isl_type_has_equal_space_templ.c \
isl_type_has_space_templ.c \
isl_unbind_params_templ.c \
uset_to_umap.c \
uset_from_umap.c \
@ -567,6 +571,7 @@ EXTRA_DIST = \
isl_union_multi.c \
isl_union_eval.c \
isl_union_locals_templ.c \
isl_union_map_lex_templ.c \
isl_union_neg.c \
isl_union_pw_templ.c \
libisl-gdb.py \

View File

@ -1,7 +1,7 @@
# Makefile.in generated by automake 1.15.1 from Makefile.am.
# Makefile.in generated by automake 1.16.1 from Makefile.am.
# @configure_input@
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
# This Makefile.in is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -151,16 +151,13 @@ CONFIG_HEADER = isl_config.h
CONFIG_CLEAN_FILES = isl_srcdir.c bound_test.sh codegen_test.sh \
pip_test.sh flow_test.sh schedule_test.sh
CONFIG_CLEAN_VPATH_FILES =
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_1 = \
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp$(EXEEXT)
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_2 = isl_test_cpp-checked$(EXEEXT) \
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp-checked-conversion$(EXEEXT)
@IMATH_FOR_MP_TRUE@am__EXEEXT_3 = isl_test_imath$(EXEEXT)
PROGRAMS = $(noinst_PROGRAMS)
LIBRARIES = $(noinst_LIBRARIES)
ARFLAGS = cru
AM_V_AR = $(am__v_AR_@AM_V@)
am__v_AR_ = $(am__v_AR_@AM_DEFAULT_V@)
am__v_AR_0 = @echo " AR " $@;
am__v_AR_1 =
libdep_a_AR = $(AR) $(ARFLAGS)
libdep_a_LIBADD =
am_libdep_a_OBJECTS = dep.$(OBJEXT)
libdep_a_OBJECTS = $(am_libdep_a_OBJECTS)
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
am__vpath_adj = case $$p in \
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
@ -191,6 +188,15 @@ am__uninstall_files_from_dir = { \
am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(pkgconfigdir)" \
"$(DESTDIR)$(pkgincludedir)" "$(DESTDIR)$(pkgincludedir)"
LTLIBRARIES = $(lib_LTLIBRARIES)
ARFLAGS = cru
AM_V_AR = $(am__v_AR_@AM_V@)
am__v_AR_ = $(am__v_AR_@AM_DEFAULT_V@)
am__v_AR_0 = @echo " AR " $@;
am__v_AR_1 =
libdep_a_AR = $(AR) $(ARFLAGS)
libdep_a_LIBADD =
am_libdep_a_OBJECTS = dep.$(OBJEXT)
libdep_a_OBJECTS = $(am_libdep_a_OBJECTS)
libisl_la_DEPENDENCIES =
am__libisl_la_SOURCES_DIST = mp_get_memory_functions.c isl_int_gmp.h \
isl_gmp.c isl_val_gmp.c isl_imath.c isl_imath.h \
@ -211,17 +217,18 @@ am__libisl_la_SOURCES_DIST = mp_get_memory_functions.c isl_int_gmp.h \
isl_factorization.c isl_factorization.h isl_farkas.c isl_ffs.c \
isl_flow.c isl_fold.c isl_hash.c isl_id_to_ast_expr.c \
isl_id_to_id.c isl_id_to_pw_aff.c isl_ilp.c isl_ilp_private.h \
isl_input.c isl_int.h isl_local_private.h isl_local.h \
isl_local.c isl_local_space_private.h isl_local_space.c \
isl_lp.c isl_lp_private.h isl_map.c isl_map_list.c \
isl_map_simplify.c isl_map_subtract.c isl_map_private.h \
isl_map_to_basic_set.c isl_mat.c isl_mat_private.h isl_morph.c \
isl_morph.h isl_id.c isl_id_private.h isl_obj.c isl_options.c \
isl_options_private.h isl_output.c isl_output_private.h \
isl_point_private.h isl_point.c isl_polynomial_private.h \
isl_polynomial.c isl_printer_private.h isl_printer.c print.c \
isl_range.c isl_range.h isl_reordering.c isl_reordering.h \
isl_sample.h isl_sample.c isl_scan.c isl_scan.h isl_schedule.c \
isl_input.c isl_int.h isl_list_private.h isl_local_private.h \
isl_local.h isl_local.c isl_local_space_private.h \
isl_local_space.c isl_lp.c isl_lp_private.h isl_map.c \
isl_map_list.c isl_map_simplify.c isl_map_subtract.c \
isl_map_private.h isl_map_to_basic_set.c isl_mat.c \
isl_mat_private.h isl_morph.c isl_morph.h isl_id.c \
isl_id_private.h isl_obj.c isl_options.c isl_options_private.h \
isl_output.c isl_output_private.h isl_point_private.h \
isl_point.c isl_polynomial_private.h isl_polynomial.c \
isl_printer_private.h isl_printer.c print.c isl_range.c \
isl_range.h isl_reordering.c isl_reordering.h isl_sample.h \
isl_sample.c isl_scan.c isl_scan.h isl_schedule.c \
isl_schedule_band.c isl_schedule_band.h isl_schedule_node.c \
isl_schedule_node_private.h isl_schedule_read.c \
isl_schedule_tree.c isl_schedule_tree.h isl_schedule_private.h \
@ -281,12 +288,6 @@ am__v_lt_1 =
libisl_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
$(libisl_la_LDFLAGS) $(LDFLAGS) -o $@
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_1 = \
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp$(EXEEXT)
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_2 = isl_test_cpp-checked$(EXEEXT) \
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp-checked-conversion$(EXEEXT)
@IMATH_FOR_MP_TRUE@am__EXEEXT_3 = isl_test_imath$(EXEEXT)
PROGRAMS = $(noinst_PROGRAMS)
am_isl_bound_OBJECTS = bound.$(OBJEXT)
isl_bound_OBJECTS = $(am_isl_bound_OBJECTS)
isl_bound_DEPENDENCIES = libisl.la
@ -410,7 +411,70 @@ am__v_at_0 = @
am__v_at_1 =
DEFAULT_INCLUDES =
depcomp = $(SHELL) $(top_srcdir)/depcomp
am__depfiles_maybe = depfiles
am__maybe_remake_depfiles = depfiles
am__depfiles_remade = ./$(DEPDIR)/basis_reduction_tab.Plo \
./$(DEPDIR)/bound.Po ./$(DEPDIR)/cat.Po ./$(DEPDIR)/closure.Po \
./$(DEPDIR)/codegen.Po ./$(DEPDIR)/dep.Po ./$(DEPDIR)/flow.Po \
./$(DEPDIR)/flow_cmp.Po ./$(DEPDIR)/isl_aff.Plo \
./$(DEPDIR)/isl_aff_map.Plo ./$(DEPDIR)/isl_affine_hull.Plo \
./$(DEPDIR)/isl_arg.Plo ./$(DEPDIR)/isl_ast.Plo \
./$(DEPDIR)/isl_ast_build.Plo \
./$(DEPDIR)/isl_ast_build_expr.Plo \
./$(DEPDIR)/isl_ast_codegen.Plo ./$(DEPDIR)/isl_ast_graft.Plo \
./$(DEPDIR)/isl_bernstein.Plo ./$(DEPDIR)/isl_blk.Plo \
./$(DEPDIR)/isl_bound.Plo ./$(DEPDIR)/isl_box.Plo \
./$(DEPDIR)/isl_coalesce.Plo ./$(DEPDIR)/isl_constraint.Plo \
./$(DEPDIR)/isl_convex_hull.Plo ./$(DEPDIR)/isl_ctx.Plo \
./$(DEPDIR)/isl_deprecated.Plo ./$(DEPDIR)/isl_dim_map.Plo \
./$(DEPDIR)/isl_equalities.Plo \
./$(DEPDIR)/isl_factorization.Plo ./$(DEPDIR)/isl_farkas.Plo \
./$(DEPDIR)/isl_ffs.Plo ./$(DEPDIR)/isl_flow.Plo \
./$(DEPDIR)/isl_fold.Plo ./$(DEPDIR)/isl_gmp.Plo \
./$(DEPDIR)/isl_hash.Plo ./$(DEPDIR)/isl_id.Plo \
./$(DEPDIR)/isl_id_to_ast_expr.Plo \
./$(DEPDIR)/isl_id_to_id.Plo ./$(DEPDIR)/isl_id_to_pw_aff.Plo \
./$(DEPDIR)/isl_ilp.Plo ./$(DEPDIR)/isl_imath.Plo \
./$(DEPDIR)/isl_input.Plo ./$(DEPDIR)/isl_int_sioimath.Plo \
./$(DEPDIR)/isl_local.Plo ./$(DEPDIR)/isl_local_space.Plo \
./$(DEPDIR)/isl_lp.Plo ./$(DEPDIR)/isl_map.Plo \
./$(DEPDIR)/isl_map_list.Plo ./$(DEPDIR)/isl_map_simplify.Plo \
./$(DEPDIR)/isl_map_subtract.Plo \
./$(DEPDIR)/isl_map_to_basic_set.Plo ./$(DEPDIR)/isl_mat.Plo \
./$(DEPDIR)/isl_morph.Plo ./$(DEPDIR)/isl_obj.Plo \
./$(DEPDIR)/isl_options.Plo ./$(DEPDIR)/isl_output.Plo \
./$(DEPDIR)/isl_point.Plo ./$(DEPDIR)/isl_polynomial.Plo \
./$(DEPDIR)/isl_printer.Plo ./$(DEPDIR)/isl_range.Plo \
./$(DEPDIR)/isl_reordering.Plo ./$(DEPDIR)/isl_sample.Plo \
./$(DEPDIR)/isl_scan.Plo ./$(DEPDIR)/isl_schedule.Plo \
./$(DEPDIR)/isl_schedule_band.Plo \
./$(DEPDIR)/isl_schedule_constraints.Plo \
./$(DEPDIR)/isl_schedule_node.Plo \
./$(DEPDIR)/isl_schedule_read.Plo \
./$(DEPDIR)/isl_schedule_tree.Plo \
./$(DEPDIR)/isl_scheduler.Plo ./$(DEPDIR)/isl_seq.Plo \
./$(DEPDIR)/isl_set_list.Plo \
./$(DEPDIR)/isl_set_to_ast_graft_list.Plo \
./$(DEPDIR)/isl_sort.Plo ./$(DEPDIR)/isl_space.Plo \
./$(DEPDIR)/isl_stream.Plo ./$(DEPDIR)/isl_stride.Plo \
./$(DEPDIR)/isl_tab.Plo ./$(DEPDIR)/isl_tab_pip.Plo \
./$(DEPDIR)/isl_tarjan.Plo ./$(DEPDIR)/isl_test.Po \
./$(DEPDIR)/isl_test_cpp-checked-conversion.Po \
./$(DEPDIR)/isl_test_cpp-checked.Po \
./$(DEPDIR)/isl_test_cpp.Po ./$(DEPDIR)/isl_test_imath.Po \
./$(DEPDIR)/isl_test_int.Po \
./$(DEPDIR)/isl_transitive_closure.Plo \
./$(DEPDIR)/isl_union_map.Plo ./$(DEPDIR)/isl_val.Plo \
./$(DEPDIR)/isl_val_gmp.Plo ./$(DEPDIR)/isl_val_imath.Plo \
./$(DEPDIR)/isl_val_sioimath.Plo ./$(DEPDIR)/isl_vec.Plo \
./$(DEPDIR)/isl_version.Plo ./$(DEPDIR)/isl_vertices.Plo \
./$(DEPDIR)/mp_get_memory_functions.Plo ./$(DEPDIR)/pip.Po \
./$(DEPDIR)/polyhedron_detect_equalities.Po \
./$(DEPDIR)/polyhedron_minimize.Po \
./$(DEPDIR)/polyhedron_sample.Po ./$(DEPDIR)/polytope_scan.Po \
./$(DEPDIR)/print.Plo ./$(DEPDIR)/schedule.Po \
./$(DEPDIR)/schedule_cmp.Po \
imath_wrap/$(DEPDIR)/gmp_compat.Plo \
imath_wrap/$(DEPDIR)/imath.Plo imath_wrap/$(DEPDIR)/imrat.Plo
am__mv = mv -f
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
@ -522,7 +586,8 @@ am__recursive_targets = \
$(RECURSIVE_CLEAN_TARGETS) \
$(am__extra_recursive_targets)
AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
cscope check recheck distdir dist dist-all distcheck
cscope check recheck distdir distdir-am dist dist-all \
distcheck
am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \
$(LISP)isl_config.h.in
# Read a list of newline-separated strings from the standard input,
@ -1006,6 +1071,7 @@ libisl_la_SOURCES = \
isl_ilp_private.h \
isl_input.c \
isl_int.h \
isl_list_private.h \
isl_local_private.h \
isl_local.h \
isl_local.c \
@ -1278,7 +1344,9 @@ EXTRA_DIST = \
isl_check_named_params_templ.c \
check_reparse_templ.c \
check_reparse_test_templ.c \
check_single_reference_templ.c \
check_type_range_templ.c \
isl_copy_tuple_id_templ.c \
isl_domain_factor_templ.c \
extract_key.c \
isl_ilp_opt_multi_val_templ.c \
@ -1371,6 +1439,7 @@ EXTRA_DIST = \
isl_type_check_equal_space_templ.c \
isl_type_has_equal_space_bin_templ.c \
isl_type_has_equal_space_templ.c \
isl_type_has_space_templ.c \
isl_unbind_params_templ.c \
uset_to_umap.c \
uset_from_umap.c \
@ -1380,6 +1449,7 @@ EXTRA_DIST = \
isl_union_multi.c \
isl_union_eval.c \
isl_union_locals_templ.c \
isl_union_map_lex_templ.c \
isl_union_neg.c \
isl_union_pw_templ.c \
libisl-gdb.py \
@ -1432,8 +1502,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
echo ' $(SHELL) ./config.status'; \
$(SHELL) ./config.status;; \
*) \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
esac;
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
@ -1472,14 +1542,18 @@ flow_test.sh: $(top_builddir)/config.status $(srcdir)/flow_test.sh.in
schedule_test.sh: $(top_builddir)/config.status $(srcdir)/schedule_test.sh.in
cd $(top_builddir) && $(SHELL) ./config.status $@
clean-noinstPROGRAMS:
@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
echo " rm -f" $$list; \
rm -f $$list || exit $$?; \
test -n "$(EXEEXT)" || exit 0; \
list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
echo " rm -f" $$list; \
rm -f $$list
clean-noinstLIBRARIES:
-test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES)
libdep.a: $(libdep_a_OBJECTS) $(libdep_a_DEPENDENCIES) $(EXTRA_libdep_a_DEPENDENCIES)
$(AM_V_at)-rm -f libdep.a
$(AM_V_AR)$(libdep_a_AR) libdep.a $(libdep_a_OBJECTS) $(libdep_a_LIBADD)
$(AM_V_at)$(RANLIB) libdep.a
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
@$(NORMAL_INSTALL)
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
@ -1514,6 +1588,11 @@ clean-libLTLIBRARIES:
echo rm -f $${locs}; \
rm -f $${locs}; \
}
libdep.a: $(libdep_a_OBJECTS) $(libdep_a_DEPENDENCIES) $(EXTRA_libdep_a_DEPENDENCIES)
$(AM_V_at)-rm -f libdep.a
$(AM_V_AR)$(libdep_a_AR) libdep.a $(libdep_a_OBJECTS) $(libdep_a_LIBADD)
$(AM_V_at)$(RANLIB) libdep.a
imath_wrap/$(am__dirstamp):
@$(MKDIR_P) imath_wrap
@: > imath_wrap/$(am__dirstamp)
@ -1530,15 +1609,6 @@ imath_wrap/imrat.lo: imath_wrap/$(am__dirstamp) \
libisl.la: $(libisl_la_OBJECTS) $(libisl_la_DEPENDENCIES) $(EXTRA_libisl_la_DEPENDENCIES)
$(AM_V_CCLD)$(libisl_la_LINK) -rpath $(libdir) $(libisl_la_OBJECTS) $(libisl_la_LIBADD) $(LIBS)
clean-noinstPROGRAMS:
@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
echo " rm -f" $$list; \
rm -f $$list || exit $$?; \
test -n "$(EXEEXT)" || exit 0; \
list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
echo " rm -f" $$list; \
rm -f $$list
isl_bound$(EXEEXT): $(isl_bound_OBJECTS) $(isl_bound_DEPENDENCIES) $(EXTRA_isl_bound_DEPENDENCIES)
@rm -f isl_bound$(EXEEXT)
$(AM_V_CCLD)$(isl_bound_LINK) $(isl_bound_OBJECTS) $(isl_bound_LDADD) $(LIBS)
@ -1623,113 +1693,119 @@ mostlyclean-compile:
distclean-compile:
-rm -f *.tab.c
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/basis_reduction_tab.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bound.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cat.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/closure.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/codegen.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dep.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow_cmp.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff_map.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_affine_hull.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_arg.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build_expr.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_codegen.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_graft.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bernstein.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_blk.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bound.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_box.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_coalesce.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_constraint.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_convex_hull.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ctx.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_deprecated.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_dim_map.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_equalities.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_factorization.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_farkas.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ffs.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_flow.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_fold.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_gmp.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_hash.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_ast_expr.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_id.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_pw_aff.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ilp.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_imath.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_input.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_int_sioimath.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local_space.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_lp.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_list.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_simplify.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_subtract.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_to_basic_set.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_mat.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_morph.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_obj.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_options.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_output.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_point.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_polynomial.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_printer.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_range.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_reordering.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sample.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scan.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_band.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_constraints.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_node.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_read.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_tree.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scheduler.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_seq.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_list.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_to_ast_graft_list.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sort.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_space.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stream.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stride.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab_pip.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tarjan.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked-conversion.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_imath.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_int.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_transitive_closure.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_union_map.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_gmp.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_imath.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_sioimath.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vec.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_version.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vertices.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mp_get_memory_functions.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pip.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_detect_equalities.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_minimize.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_sample.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polytope_scan.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/print.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule_cmp.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/gmp_compat.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imath.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imrat.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/basis_reduction_tab.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bound.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cat.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/closure.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/codegen.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dep.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow_cmp.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff_map.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_affine_hull.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_arg.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build_expr.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_codegen.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_graft.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bernstein.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_blk.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bound.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_box.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_coalesce.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_constraint.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_convex_hull.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ctx.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_deprecated.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_dim_map.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_equalities.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_factorization.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_farkas.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ffs.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_flow.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_fold.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_gmp.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_hash.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_ast_expr.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_id.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_pw_aff.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ilp.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_imath.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_input.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_int_sioimath.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local_space.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_lp.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_list.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_simplify.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_subtract.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_to_basic_set.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_mat.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_morph.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_obj.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_options.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_output.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_point.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_polynomial.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_printer.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_range.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_reordering.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sample.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scan.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_band.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_constraints.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_node.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_read.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_tree.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scheduler.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_seq.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_list.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_to_ast_graft_list.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sort.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_space.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stream.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stride.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab_pip.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tarjan.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked-conversion.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_imath.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_int.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_transitive_closure.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_union_map.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_gmp.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_imath.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_sioimath.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vec.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_version.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vertices.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mp_get_memory_functions.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pip.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_detect_equalities.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_minimize.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_sample.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polytope_scan.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/print.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule_cmp.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/gmp_compat.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imath.Plo@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imrat.Plo@am__quote@ # am--include-marker
$(am__depfiles_remade):
@$(MKDIR_P) $(@D)
@echo '# dummy' >$@-t && $(am__mv) $@-t $@
am--depfiles: $(am__depfiles_remade)
.c.o:
@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\
@ -2078,7 +2154,7 @@ $(TEST_SUITE_LOG): $(TEST_LOGS)
fi; \
$$success || exit 1
check-TESTS:
check-TESTS:
@list='$(RECHECK_LOGS)'; test -z "$$list" || rm -f $$list
@list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list
@test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
@ -2191,7 +2267,10 @@ isl_test_imath.log: isl_test_imath$(EXEEXT)
@am__EXEEXT_TRUE@ $(am__common_driver_flags) $(AM_PY_LOG_DRIVER_FLAGS) $(PY_LOG_DRIVER_FLAGS) -- $(PY_LOG_COMPILE) \
@am__EXEEXT_TRUE@ "$$tst" $(AM_TESTS_FD_REDIRECT)
distdir: $(DISTFILES)
distdir: $(BUILT_SOURCES)
$(MAKE) $(AM_MAKEFLAGS) distdir-am
distdir-am: $(DISTFILES)
$(am__remove_distdir)
test -d "$(distdir)" || mkdir "$(distdir)"
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
@ -2386,7 +2465,7 @@ check-am: all-am
$(MAKE) $(AM_MAKEFLAGS) check-TESTS
check: $(BUILT_SOURCES)
$(MAKE) $(AM_MAKEFLAGS) check-recursive
all-am: Makefile $(LIBRARIES) $(LTLIBRARIES) $(PROGRAMS) $(DATA) \
all-am: Makefile $(PROGRAMS) $(LIBRARIES) $(LTLIBRARIES) $(DATA) \
$(HEADERS) isl_config.h
installdirs: installdirs-recursive
installdirs-am:
@ -2439,7 +2518,113 @@ clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
distclean: distclean-recursive
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
-rm -rf ./$(DEPDIR) imath_wrap/$(DEPDIR)
-rm -f ./$(DEPDIR)/basis_reduction_tab.Plo
-rm -f ./$(DEPDIR)/bound.Po
-rm -f ./$(DEPDIR)/cat.Po
-rm -f ./$(DEPDIR)/closure.Po
-rm -f ./$(DEPDIR)/codegen.Po
-rm -f ./$(DEPDIR)/dep.Po
-rm -f ./$(DEPDIR)/flow.Po
-rm -f ./$(DEPDIR)/flow_cmp.Po
-rm -f ./$(DEPDIR)/isl_aff.Plo
-rm -f ./$(DEPDIR)/isl_aff_map.Plo
-rm -f ./$(DEPDIR)/isl_affine_hull.Plo
-rm -f ./$(DEPDIR)/isl_arg.Plo
-rm -f ./$(DEPDIR)/isl_ast.Plo
-rm -f ./$(DEPDIR)/isl_ast_build.Plo
-rm -f ./$(DEPDIR)/isl_ast_build_expr.Plo
-rm -f ./$(DEPDIR)/isl_ast_codegen.Plo
-rm -f ./$(DEPDIR)/isl_ast_graft.Plo
-rm -f ./$(DEPDIR)/isl_bernstein.Plo
-rm -f ./$(DEPDIR)/isl_blk.Plo
-rm -f ./$(DEPDIR)/isl_bound.Plo
-rm -f ./$(DEPDIR)/isl_box.Plo
-rm -f ./$(DEPDIR)/isl_coalesce.Plo
-rm -f ./$(DEPDIR)/isl_constraint.Plo
-rm -f ./$(DEPDIR)/isl_convex_hull.Plo
-rm -f ./$(DEPDIR)/isl_ctx.Plo
-rm -f ./$(DEPDIR)/isl_deprecated.Plo
-rm -f ./$(DEPDIR)/isl_dim_map.Plo
-rm -f ./$(DEPDIR)/isl_equalities.Plo
-rm -f ./$(DEPDIR)/isl_factorization.Plo
-rm -f ./$(DEPDIR)/isl_farkas.Plo
-rm -f ./$(DEPDIR)/isl_ffs.Plo
-rm -f ./$(DEPDIR)/isl_flow.Plo
-rm -f ./$(DEPDIR)/isl_fold.Plo
-rm -f ./$(DEPDIR)/isl_gmp.Plo
-rm -f ./$(DEPDIR)/isl_hash.Plo
-rm -f ./$(DEPDIR)/isl_id.Plo
-rm -f ./$(DEPDIR)/isl_id_to_ast_expr.Plo
-rm -f ./$(DEPDIR)/isl_id_to_id.Plo
-rm -f ./$(DEPDIR)/isl_id_to_pw_aff.Plo
-rm -f ./$(DEPDIR)/isl_ilp.Plo
-rm -f ./$(DEPDIR)/isl_imath.Plo
-rm -f ./$(DEPDIR)/isl_input.Plo
-rm -f ./$(DEPDIR)/isl_int_sioimath.Plo
-rm -f ./$(DEPDIR)/isl_local.Plo
-rm -f ./$(DEPDIR)/isl_local_space.Plo
-rm -f ./$(DEPDIR)/isl_lp.Plo
-rm -f ./$(DEPDIR)/isl_map.Plo
-rm -f ./$(DEPDIR)/isl_map_list.Plo
-rm -f ./$(DEPDIR)/isl_map_simplify.Plo
-rm -f ./$(DEPDIR)/isl_map_subtract.Plo
-rm -f ./$(DEPDIR)/isl_map_to_basic_set.Plo
-rm -f ./$(DEPDIR)/isl_mat.Plo
-rm -f ./$(DEPDIR)/isl_morph.Plo
-rm -f ./$(DEPDIR)/isl_obj.Plo
-rm -f ./$(DEPDIR)/isl_options.Plo
-rm -f ./$(DEPDIR)/isl_output.Plo
-rm -f ./$(DEPDIR)/isl_point.Plo
-rm -f ./$(DEPDIR)/isl_polynomial.Plo
-rm -f ./$(DEPDIR)/isl_printer.Plo
-rm -f ./$(DEPDIR)/isl_range.Plo
-rm -f ./$(DEPDIR)/isl_reordering.Plo
-rm -f ./$(DEPDIR)/isl_sample.Plo
-rm -f ./$(DEPDIR)/isl_scan.Plo
-rm -f ./$(DEPDIR)/isl_schedule.Plo
-rm -f ./$(DEPDIR)/isl_schedule_band.Plo
-rm -f ./$(DEPDIR)/isl_schedule_constraints.Plo
-rm -f ./$(DEPDIR)/isl_schedule_node.Plo
-rm -f ./$(DEPDIR)/isl_schedule_read.Plo
-rm -f ./$(DEPDIR)/isl_schedule_tree.Plo
-rm -f ./$(DEPDIR)/isl_scheduler.Plo
-rm -f ./$(DEPDIR)/isl_seq.Plo
-rm -f ./$(DEPDIR)/isl_set_list.Plo
-rm -f ./$(DEPDIR)/isl_set_to_ast_graft_list.Plo
-rm -f ./$(DEPDIR)/isl_sort.Plo
-rm -f ./$(DEPDIR)/isl_space.Plo
-rm -f ./$(DEPDIR)/isl_stream.Plo
-rm -f ./$(DEPDIR)/isl_stride.Plo
-rm -f ./$(DEPDIR)/isl_tab.Plo
-rm -f ./$(DEPDIR)/isl_tab_pip.Plo
-rm -f ./$(DEPDIR)/isl_tarjan.Plo
-rm -f ./$(DEPDIR)/isl_test.Po
-rm -f ./$(DEPDIR)/isl_test_cpp-checked-conversion.Po
-rm -f ./$(DEPDIR)/isl_test_cpp-checked.Po
-rm -f ./$(DEPDIR)/isl_test_cpp.Po
-rm -f ./$(DEPDIR)/isl_test_imath.Po
-rm -f ./$(DEPDIR)/isl_test_int.Po
-rm -f ./$(DEPDIR)/isl_transitive_closure.Plo
-rm -f ./$(DEPDIR)/isl_union_map.Plo
-rm -f ./$(DEPDIR)/isl_val.Plo
-rm -f ./$(DEPDIR)/isl_val_gmp.Plo
-rm -f ./$(DEPDIR)/isl_val_imath.Plo
-rm -f ./$(DEPDIR)/isl_val_sioimath.Plo
-rm -f ./$(DEPDIR)/isl_vec.Plo
-rm -f ./$(DEPDIR)/isl_version.Plo
-rm -f ./$(DEPDIR)/isl_vertices.Plo
-rm -f ./$(DEPDIR)/mp_get_memory_functions.Plo
-rm -f ./$(DEPDIR)/pip.Po
-rm -f ./$(DEPDIR)/polyhedron_detect_equalities.Po
-rm -f ./$(DEPDIR)/polyhedron_minimize.Po
-rm -f ./$(DEPDIR)/polyhedron_sample.Po
-rm -f ./$(DEPDIR)/polytope_scan.Po
-rm -f ./$(DEPDIR)/print.Plo
-rm -f ./$(DEPDIR)/schedule.Po
-rm -f ./$(DEPDIR)/schedule_cmp.Po
-rm -f imath_wrap/$(DEPDIR)/gmp_compat.Plo
-rm -f imath_wrap/$(DEPDIR)/imath.Plo
-rm -f imath_wrap/$(DEPDIR)/imrat.Plo
-rm -f Makefile
distclean-am: clean-am distclean-compile distclean-generic \
distclean-hdr distclean-libtool distclean-tags
@ -2488,7 +2673,113 @@ installcheck-am:
maintainer-clean: maintainer-clean-recursive
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
-rm -rf $(top_srcdir)/autom4te.cache
-rm -rf ./$(DEPDIR) imath_wrap/$(DEPDIR)
-rm -f ./$(DEPDIR)/basis_reduction_tab.Plo
-rm -f ./$(DEPDIR)/bound.Po
-rm -f ./$(DEPDIR)/cat.Po
-rm -f ./$(DEPDIR)/closure.Po
-rm -f ./$(DEPDIR)/codegen.Po
-rm -f ./$(DEPDIR)/dep.Po
-rm -f ./$(DEPDIR)/flow.Po
-rm -f ./$(DEPDIR)/flow_cmp.Po
-rm -f ./$(DEPDIR)/isl_aff.Plo
-rm -f ./$(DEPDIR)/isl_aff_map.Plo
-rm -f ./$(DEPDIR)/isl_affine_hull.Plo
-rm -f ./$(DEPDIR)/isl_arg.Plo
-rm -f ./$(DEPDIR)/isl_ast.Plo
-rm -f ./$(DEPDIR)/isl_ast_build.Plo
-rm -f ./$(DEPDIR)/isl_ast_build_expr.Plo
-rm -f ./$(DEPDIR)/isl_ast_codegen.Plo
-rm -f ./$(DEPDIR)/isl_ast_graft.Plo
-rm -f ./$(DEPDIR)/isl_bernstein.Plo
-rm -f ./$(DEPDIR)/isl_blk.Plo
-rm -f ./$(DEPDIR)/isl_bound.Plo
-rm -f ./$(DEPDIR)/isl_box.Plo
-rm -f ./$(DEPDIR)/isl_coalesce.Plo
-rm -f ./$(DEPDIR)/isl_constraint.Plo
-rm -f ./$(DEPDIR)/isl_convex_hull.Plo
-rm -f ./$(DEPDIR)/isl_ctx.Plo
-rm -f ./$(DEPDIR)/isl_deprecated.Plo
-rm -f ./$(DEPDIR)/isl_dim_map.Plo
-rm -f ./$(DEPDIR)/isl_equalities.Plo
-rm -f ./$(DEPDIR)/isl_factorization.Plo
-rm -f ./$(DEPDIR)/isl_farkas.Plo
-rm -f ./$(DEPDIR)/isl_ffs.Plo
-rm -f ./$(DEPDIR)/isl_flow.Plo
-rm -f ./$(DEPDIR)/isl_fold.Plo
-rm -f ./$(DEPDIR)/isl_gmp.Plo
-rm -f ./$(DEPDIR)/isl_hash.Plo
-rm -f ./$(DEPDIR)/isl_id.Plo
-rm -f ./$(DEPDIR)/isl_id_to_ast_expr.Plo
-rm -f ./$(DEPDIR)/isl_id_to_id.Plo
-rm -f ./$(DEPDIR)/isl_id_to_pw_aff.Plo
-rm -f ./$(DEPDIR)/isl_ilp.Plo
-rm -f ./$(DEPDIR)/isl_imath.Plo
-rm -f ./$(DEPDIR)/isl_input.Plo
-rm -f ./$(DEPDIR)/isl_int_sioimath.Plo
-rm -f ./$(DEPDIR)/isl_local.Plo
-rm -f ./$(DEPDIR)/isl_local_space.Plo
-rm -f ./$(DEPDIR)/isl_lp.Plo
-rm -f ./$(DEPDIR)/isl_map.Plo
-rm -f ./$(DEPDIR)/isl_map_list.Plo
-rm -f ./$(DEPDIR)/isl_map_simplify.Plo
-rm -f ./$(DEPDIR)/isl_map_subtract.Plo
-rm -f ./$(DEPDIR)/isl_map_to_basic_set.Plo
-rm -f ./$(DEPDIR)/isl_mat.Plo
-rm -f ./$(DEPDIR)/isl_morph.Plo
-rm -f ./$(DEPDIR)/isl_obj.Plo
-rm -f ./$(DEPDIR)/isl_options.Plo
-rm -f ./$(DEPDIR)/isl_output.Plo
-rm -f ./$(DEPDIR)/isl_point.Plo
-rm -f ./$(DEPDIR)/isl_polynomial.Plo
-rm -f ./$(DEPDIR)/isl_printer.Plo
-rm -f ./$(DEPDIR)/isl_range.Plo
-rm -f ./$(DEPDIR)/isl_reordering.Plo
-rm -f ./$(DEPDIR)/isl_sample.Plo
-rm -f ./$(DEPDIR)/isl_scan.Plo
-rm -f ./$(DEPDIR)/isl_schedule.Plo
-rm -f ./$(DEPDIR)/isl_schedule_band.Plo
-rm -f ./$(DEPDIR)/isl_schedule_constraints.Plo
-rm -f ./$(DEPDIR)/isl_schedule_node.Plo
-rm -f ./$(DEPDIR)/isl_schedule_read.Plo
-rm -f ./$(DEPDIR)/isl_schedule_tree.Plo
-rm -f ./$(DEPDIR)/isl_scheduler.Plo
-rm -f ./$(DEPDIR)/isl_seq.Plo
-rm -f ./$(DEPDIR)/isl_set_list.Plo
-rm -f ./$(DEPDIR)/isl_set_to_ast_graft_list.Plo
-rm -f ./$(DEPDIR)/isl_sort.Plo
-rm -f ./$(DEPDIR)/isl_space.Plo
-rm -f ./$(DEPDIR)/isl_stream.Plo
-rm -f ./$(DEPDIR)/isl_stride.Plo
-rm -f ./$(DEPDIR)/isl_tab.Plo
-rm -f ./$(DEPDIR)/isl_tab_pip.Plo
-rm -f ./$(DEPDIR)/isl_tarjan.Plo
-rm -f ./$(DEPDIR)/isl_test.Po
-rm -f ./$(DEPDIR)/isl_test_cpp-checked-conversion.Po
-rm -f ./$(DEPDIR)/isl_test_cpp-checked.Po
-rm -f ./$(DEPDIR)/isl_test_cpp.Po
-rm -f ./$(DEPDIR)/isl_test_imath.Po
-rm -f ./$(DEPDIR)/isl_test_int.Po
-rm -f ./$(DEPDIR)/isl_transitive_closure.Plo
-rm -f ./$(DEPDIR)/isl_union_map.Plo
-rm -f ./$(DEPDIR)/isl_val.Plo
-rm -f ./$(DEPDIR)/isl_val_gmp.Plo
-rm -f ./$(DEPDIR)/isl_val_imath.Plo
-rm -f ./$(DEPDIR)/isl_val_sioimath.Plo
-rm -f ./$(DEPDIR)/isl_vec.Plo
-rm -f ./$(DEPDIR)/isl_version.Plo
-rm -f ./$(DEPDIR)/isl_vertices.Plo
-rm -f ./$(DEPDIR)/mp_get_memory_functions.Plo
-rm -f ./$(DEPDIR)/pip.Po
-rm -f ./$(DEPDIR)/polyhedron_detect_equalities.Po
-rm -f ./$(DEPDIR)/polyhedron_minimize.Po
-rm -f ./$(DEPDIR)/polyhedron_sample.Po
-rm -f ./$(DEPDIR)/polytope_scan.Po
-rm -f ./$(DEPDIR)/print.Plo
-rm -f ./$(DEPDIR)/schedule.Po
-rm -f ./$(DEPDIR)/schedule_cmp.Po
-rm -f imath_wrap/$(DEPDIR)/gmp_compat.Plo
-rm -f imath_wrap/$(DEPDIR)/imath.Plo
-rm -f imath_wrap/$(DEPDIR)/imrat.Plo
-rm -f Makefile
maintainer-clean-am: distclean-am maintainer-clean-generic
@ -2513,8 +2804,8 @@ uninstall-am: uninstall-libLTLIBRARIES uninstall-local \
install-strip
.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \
am--refresh check check-TESTS check-am clean clean-cscope \
clean-generic clean-libLTLIBRARIES clean-libtool \
am--depfiles am--refresh check check-TESTS check-am clean \
clean-cscope clean-generic clean-libLTLIBRARIES clean-libtool \
clean-noinstLIBRARIES clean-noinstPROGRAMS cscope \
cscopelist-am ctags ctags-am dist dist-all dist-bzip2 \
dist-gzip dist-hook dist-lzip dist-shar dist-tarZ dist-xz \

View File

@ -1,6 +1,6 @@
# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -20,7 +20,7 @@ You have another version of autoconf. It may work, but is not guaranteed to.
If you have problems, you may need to regenerate the build system entirely.
To do so, use the procedure documented by the package, typically 'autoreconf'.])])
# Copyright (C) 2002-2017 Free Software Foundation, Inc.
# Copyright (C) 2002-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
# generated from the m4 files accompanying Automake X.Y.
# (This private macro should not be called outside this file.)
AC_DEFUN([AM_AUTOMAKE_VERSION],
[am__api_version='1.15'
[am__api_version='1.16'
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
dnl require some minimum version. Point them to the right macro.
m4_if([$1], [1.15.1], [],
m4_if([$1], [1.16.1], [],
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
])
@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
[AM_AUTOMAKE_VERSION([1.15.1])dnl
[AM_AUTOMAKE_VERSION([1.16.1])dnl
m4_ifndef([AC_AUTOCONF_VERSION],
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -110,7 +110,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
# AM_CONDITIONAL -*- Autoconf -*-
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -141,7 +141,7 @@ AC_CONFIG_COMMANDS_PRE(
Usually this means the macro was only invoked conditionally.]])
fi])])
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -332,13 +332,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
# Generate code to set up dependency tracking. -*- Autoconf -*-
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.
# _AM_OUTPUT_DEPENDENCY_COMMANDS
# ------------------------------
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
@ -346,49 +345,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
case $CONFIG_FILES in
*\'*) eval set x "$CONFIG_FILES" ;;
*) set x $CONFIG_FILES ;;
esac
# TODO: see whether this extra hack can be removed once we start
# requiring Autoconf 2.70 or later.
AS_CASE([$CONFIG_FILES],
[*\'*], [eval set x "$CONFIG_FILES"],
[*], [set x $CONFIG_FILES])
shift
for mf
# Used to flag and report bootstrapping failures.
am_rc=0
for am_mf
do
# Strip MF so we end up with the name of the file.
mf=`echo "$mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile or not.
# We used to match only the files named 'Makefile.in', but
# some people rename them; so instead we look at the file content.
# Grep'ing the first line is not enough: some people post-process
# each Makefile.in and add a new line on top of each file to say so.
# Grep'ing the whole file is not good either: AIX grep has a line
am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile which includes
# dependency-tracking related rules and includes.
# Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
dirpart=`AS_DIRNAME("$mf")`
else
continue
fi
# Extract the definition of DEPDIR, am__include, and am__quote
# from the Makefile without running 'make'.
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
test -z "$DEPDIR" && continue
am__include=`sed -n 's/^am__include = //p' < "$mf"`
test -z "$am__include" && continue
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
# Find all dependency output files, they are included files with
# $(DEPDIR) in their names. We invoke sed twice because it is the
# simplest approach to changing $(DEPDIR) to its actual value in the
# expansion.
for file in `sed -n "
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
# Make sure the directory exists.
test -f "$dirpart/$file" && continue
fdir=`AS_DIRNAME(["$file"])`
AS_MKDIR_P([$dirpart/$fdir])
# echo "creating $dirpart/$file"
echo '# dummy' > "$dirpart/$file"
done
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|| continue
am_dirpart=`AS_DIRNAME(["$am_mf"])`
am_filepart=`AS_BASENAME(["$am_mf"])`
AM_RUN_LOG([cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles]) || am_rc=$?
done
if test $am_rc -ne 0; then
AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
for automatic dependency tracking. Try re-running configure with the
'--disable-dependency-tracking' option to at least be able to build
the package (albeit without support for automatic dependency tracking).])
fi
AS_UNSET([am_dirpart])
AS_UNSET([am_filepart])
AS_UNSET([am_mf])
AS_UNSET([am_rc])
rm -f conftest-deps.mk
}
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
@ -397,18 +388,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# -----------------------------
# This macro should only be invoked once -- use via AC_REQUIRE.
#
# This code is only required when automatic dependency tracking
# is enabled. FIXME. This creates each '.P' file that we will
# need in order to bootstrap the dependency handling code.
# This code is only required when automatic dependency tracking is enabled.
# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
# order to bootstrap the dependency handling code.
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
[AC_CONFIG_COMMANDS([depfiles],
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
])
[AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
# Do all the work for Automake. -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -495,8 +485,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
# We need awk for the "check" target (and possibly the TAP driver). The
# system "awk" is bad on some platforms.
@ -563,7 +553,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
that behaves properly: <http://www.gnu.org/software/coreutils/>.
that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@ -605,7 +595,7 @@ for _am_header in $config_headers :; do
done
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -626,7 +616,7 @@ if test x"${install_sh+set}" != xset; then
fi
AC_SUBST([install_sh])])
# Copyright (C) 2003-2017 Free Software Foundation, Inc.
# Copyright (C) 2003-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -647,7 +637,7 @@ AC_SUBST([am__leading_dot])])
# Check to see how 'make' treats includes. -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -655,49 +645,42 @@ AC_SUBST([am__leading_dot])])
# AM_MAKE_INCLUDE()
# -----------------
# Check to see how make treats includes.
# Check whether make has an 'include' directive that can support all
# the idioms we need for our automatic dependency tracking code.
AC_DEFUN([AM_MAKE_INCLUDE],
[am_make=${MAKE-make}
cat > confinc << 'END'
[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
cat > confinc.mk << 'END'
am__doit:
@echo this is the am__doit target
@echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
# If we don't find an include directive, just comment out the code.
AC_MSG_CHECKING([for style of include used by $am_make])
am__include="#"
am__quote=
_am_result=none
# First try GNU make style include.
echo "include confinc" > confmf
# Ignore all kinds of additional output from 'make'.
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=include
am__quote=
_am_result=GNU
;;
esac
# Now try BSD make style include.
if test "$am__include" = "#"; then
echo '.include "confinc"' > confmf
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=.include
am__quote="\""
_am_result=BSD
;;
esac
fi
AC_SUBST([am__include])
AC_SUBST([am__quote])
AC_MSG_RESULT([$_am_result])
rm -f confinc confmf
])
# BSD make does it like this.
echo '.include "confinc.mk" # ignored' > confmf.BSD
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
echo 'include confinc.mk # ignored' > confmf.GNU
_am_result=no
for s in GNU BSD; do
AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
AS_CASE([$?:`cat confinc.out 2>/dev/null`],
['0:this is the am__doit target'],
[AS_CASE([$s],
[BSD], [am__include='.include' am__quote='"'],
[am__include='include' am__quote=''])])
if test "$am__include" != "#"; then
_am_result="yes ($s style)"
break
fi
done
rm -f confinc.* confmf.*
AC_MSG_RESULT([${_am_result}])
AC_SUBST([am__include])])
AC_SUBST([am__quote])])
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -736,7 +719,7 @@ fi
# Helper functions for option handling. -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -765,7 +748,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
AC_DEFUN([_AM_IF_OPTION],
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -812,7 +795,7 @@ AC_LANG_POP([C])])
# For backward compatibility.
AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -845,10 +828,12 @@ AC_DEFUN([AM_PATH_PYTHON],
[
dnl Find a Python interpreter. Python versions prior to 2.0 are not
dnl supported. (2.0 was released on October 16, 2000).
dnl FIXME: Remove the need to hard-code Python versions here.
m4_define_default([_AM_PYTHON_INTERPRETER_LIST],
[python python2 python3 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 dnl
python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0])
[python python2 python3 dnl
python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 dnl
python3.2 python3.1 python3.0 dnl
python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 dnl
python2.0])
AC_ARG_VAR([PYTHON], [the Python interpreter])
@ -1048,7 +1033,7 @@ for i in list(range(0, 4)): minverhex = (minverhex << 8) + minver[[i]]
sys.exit(sys.hexversion < minverhex)"
AS_IF([AM_RUN_LOG([$1 -c "$prog"])], [$3], [$4])])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1067,7 +1052,7 @@ AC_DEFUN([AM_RUN_LOG],
# Check to make sure that the build environment is sane. -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1148,7 +1133,7 @@ AC_CONFIG_COMMANDS_PRE(
rm -f conftest.file
])
# Copyright (C) 2009-2017 Free Software Foundation, Inc.
# Copyright (C) 2009-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1208,7 +1193,7 @@ AC_SUBST([AM_BACKSLASH])dnl
_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1236,7 +1221,7 @@ fi
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
AC_SUBST([INSTALL_STRIP_PROGRAM])])
# Copyright (C) 2006-2017 Free Software Foundation, Inc.
# Copyright (C) 2006-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1255,7 +1240,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
# Check how to create a tarball. -*- Autoconf -*-
# Copyright (C) 2004-2017 Free Software Foundation, Inc.
# Copyright (C) 2004-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,

View File

@ -0,0 +1,19 @@
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
#define FN(TYPE,NAME) xFN(TYPE,NAME)
/* Check that "obj" has a single reference.
* That is, check that "obj" can be changed inplace.
*/
isl_stat FN(TYPE,check_single_reference)(__isl_keep TYPE *obj)
{
isl_bool single;
single = FN(TYPE,has_single_reference)(obj);
if (single < 0)
return isl_stat_error;
if (!single)
isl_die(FN(TYPE,get_ctx)(obj), isl_error_invalid,
"object should have a single reference",
return isl_stat_error);
return isl_stat_ok;
}

View File

@ -1,9 +1,9 @@
#! /bin/sh
# Wrapper for compilers which do not understand '-c -o'.
scriptversion=2012-10-14.11; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1999-2014 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# Written by Tom Tromey <tromey@cygnus.com>.
#
# This program is free software; you can redistribute it and/or modify
@ -17,7 +17,7 @@ scriptversion=2012-10-14.11; # UTC
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -255,7 +255,8 @@ EOF
echo "compile $scriptversion"
exit $?
;;
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
func_cl_wrapper "$@" # Doesn't return...
;;
esac
@ -339,9 +340,9 @@ exit $ret
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -1,6 +1,6 @@
#! /bin/sh
# Guess values for system-dependent variables and create Makefiles.
# Generated by GNU Autoconf 2.69 for isl 0.22.1.
# Generated by GNU Autoconf 2.69 for isl 0.23.
#
# Report bugs to <isl-development@googlegroups.com>.
#
@ -590,8 +590,8 @@ MAKEFLAGS=
# Identity of this package.
PACKAGE_NAME='isl'
PACKAGE_TARNAME='isl'
PACKAGE_VERSION='0.22.1'
PACKAGE_STRING='isl 0.22.1'
PACKAGE_VERSION='0.23'
PACKAGE_STRING='isl 0.23'
PACKAGE_BUGREPORT='isl-development@googlegroups.com'
PACKAGE_URL=''
@ -734,7 +734,6 @@ am__nodep
AMDEPBACKSLASH
AMDEP_FALSE
AMDEP_TRUE
am__quote
am__include
DEPDIR
OBJEXT
@ -810,7 +809,8 @@ PACKAGE_VERSION
PACKAGE_TARNAME
PACKAGE_NAME
PATH_SEPARATOR
SHELL'
SHELL
am__quote'
ac_subst_files=''
ac_user_opts='
enable_option_checking
@ -1400,7 +1400,7 @@ if test "$ac_init_help" = "long"; then
# Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF
\`configure' configures isl 0.22.1 to adapt to many kinds of systems.
\`configure' configures isl 0.23 to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]...
@ -1471,7 +1471,7 @@ fi
if test -n "$ac_init_help"; then
case $ac_init_help in
short | recursive ) echo "Configuration of isl 0.22.1:";;
short | recursive ) echo "Configuration of isl 0.23:";;
esac
cat <<\_ACEOF
@ -1602,7 +1602,7 @@ fi
test -n "$ac_init_help" && exit $ac_status
if $ac_init_version; then
cat <<\_ACEOF
isl configure 0.22.1
isl configure 0.23
generated by GNU Autoconf 2.69
Copyright (C) 2012 Free Software Foundation, Inc.
@ -2375,7 +2375,7 @@ cat >config.log <<_ACEOF
This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake.
It was created by isl $as_me 0.22.1, which was
It was created by isl $as_me 0.23, which was
generated by GNU Autoconf 2.69. Invocation command line was
$ $0 $@
@ -2753,7 +2753,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
am__api_version='1.15'
am__api_version='1.16'
# Find a good install program. We prefer a C program (faster),
# so one script is as good as another. But avoid the broken or
@ -3239,7 +3239,7 @@ fi
# Define the identity of the package.
PACKAGE='isl'
VERSION='0.22.1'
VERSION='0.23'
cat >>confdefs.h <<_ACEOF
@ -3269,8 +3269,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
mkdir_p='$(MKDIR_P)'
# We need awk for the "check" target (and possibly the TAP driver). The
@ -3321,7 +3321,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
that behaves properly: <http://www.gnu.org/software/coreutils/>.
that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@ -3372,7 +3372,7 @@ fi
AM_BACKSLASH='\'
versioninfo=22:1:0
versioninfo=23:0:0
if test "x$prefix" != "xNONE"; then
prefix_wd=`cd $prefix && pwd`
@ -4237,45 +4237,45 @@ DEPDIR="${am__leading_dot}deps"
ac_config_commands="$ac_config_commands depfiles"
am_make=${MAKE-make}
cat > confinc << 'END'
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
cat > confinc.mk << 'END'
am__doit:
@echo this is the am__doit target
@echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
# If we don't find an include directive, just comment out the code.
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
$as_echo_n "checking for style of include used by $am_make... " >&6; }
am__include="#"
am__quote=
_am_result=none
# First try GNU make style include.
echo "include confinc" > confmf
# Ignore all kinds of additional output from 'make'.
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=include
am__quote=
_am_result=GNU
;;
esac
# Now try BSD make style include.
if test "$am__include" = "#"; then
echo '.include "confinc"' > confmf
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=.include
am__quote="\""
_am_result=BSD
# BSD make does it like this.
echo '.include "confinc.mk" # ignored' > confmf.BSD
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
echo 'include confinc.mk # ignored' > confmf.GNU
_am_result=no
for s in GNU BSD; do
{ echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
(${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }
case $?:`cat confinc.out 2>/dev/null` in #(
'0:this is the am__doit target') :
case $s in #(
BSD) :
am__include='.include' am__quote='"' ;; #(
*) :
am__include='include' am__quote='' ;;
esac ;; #(
*) :
;;
esac
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
$as_echo "$_am_result" >&6; }
rm -f confinc confmf
esac
if test "$am__include" != "#"; then
_am_result="yes ($s style)"
break
fi
done
rm -f confinc.* confmf.*
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
$as_echo "${_am_result}" >&6; }
# Check whether --enable-dependency-tracking was given.
if test "${enable_dependency_tracking+set}" = set; then :
@ -9767,7 +9767,7 @@ esac
fi
: ${AR=ar}
: ${AR_FLAGS=cru}
: ${AR_FLAGS=cr}
@ -10268,11 +10268,8 @@ _LT_EOF
test $ac_status = 0; }; then
# Now try to grab the symbols.
nlist=conftest.nm
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5
(eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; } && test -s "$nlist"; then
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&5
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&5 && test -s "$nlist"; then
# Try sorting and uniquifying the output.
if sort "$nlist" | uniq > "$nlist"T; then
mv -f "$nlist"T "$nlist"
@ -11491,8 +11488,8 @@ int forced_loaded() { return 2;}
_LT_EOF
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5
echo "$AR cru libconftest.a conftest.o" >&5
$AR cru libconftest.a conftest.o 2>&5
echo "$AR cr libconftest.a conftest.o" >&5
$AR cr libconftest.a conftest.o 2>&5
echo "$RANLIB libconftest.a" >&5
$RANLIB libconftest.a 2>&5
cat > conftest.c << _LT_EOF
@ -12494,6 +12491,12 @@ lt_prog_compiler_static=
lt_prog_compiler_pic='-KPIC'
lt_prog_compiler_static='-static'
;;
# flang / f18. f95 an alias for gfortran or flang on Debian
flang* | f18* | f95*)
lt_prog_compiler_wl='-Wl,'
lt_prog_compiler_pic='-fPIC'
lt_prog_compiler_static='-static'
;;
# icc used to be incompatible with GCC.
# ICC 10 doesn't accept -KPIC any more.
icc* | ifort*)
@ -16436,7 +16439,7 @@ with_gnu_ld=$lt_cv_prog_gnu_ld
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
GXX=no
@ -16928,7 +16931,7 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -16993,7 +16996,7 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -17332,7 +17335,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# FIXME: insert proper C++ library support
@ -17416,7 +17419,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# g++ 2.7 appears to require '-G' NOT '-shared' on this
# platform.
@ -17427,7 +17430,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
fi
hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir'
@ -19482,7 +19485,7 @@ if ${am_cv_pathless_PYTHON+:} false; then :
$as_echo_n "(cached) " >&6
else
for am_cv_pathless_PYTHON in python python2 python3 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0 none; do
for am_cv_pathless_PYTHON in python python2 python3 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0 none; do
test "$am_cv_pathless_PYTHON" = none && break
prog="import sys
# split strings by '.' and convert to numeric. Append some zeros
@ -21762,7 +21765,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
# report actual input values of CONFIG_FILES etc. instead of their
# values after options handling.
ac_log="
This file was extended by isl $as_me 0.22.1, which was
This file was extended by isl $as_me 0.23, which was
generated by GNU Autoconf 2.69. Invocation command line was
CONFIG_FILES = $CONFIG_FILES
@ -21828,7 +21831,7 @@ _ACEOF
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"
ac_cs_version="\\
isl config.status 0.22.1
isl config.status 0.23
configured by $0, generated by GNU Autoconf 2.69,
with options \\"\$ac_cs_config\\"
@ -21947,7 +21950,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
#
# INIT-COMMANDS
#
AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
# The HP-UX ksh and POSIX shell print the target directory to stdout
@ -22990,29 +22993,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
case $CONFIG_FILES in
*\'*) eval set x "$CONFIG_FILES" ;;
*) set x $CONFIG_FILES ;;
esac
# TODO: see whether this extra hack can be removed once we start
# requiring Autoconf 2.70 or later.
case $CONFIG_FILES in #(
*\'*) :
eval set x "$CONFIG_FILES" ;; #(
*) :
set x $CONFIG_FILES ;; #(
*) :
;;
esac
shift
for mf
# Used to flag and report bootstrapping failures.
am_rc=0
for am_mf
do
# Strip MF so we end up with the name of the file.
mf=`echo "$mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile or not.
# We used to match only the files named 'Makefile.in', but
# some people rename them; so instead we look at the file content.
# Grep'ing the first line is not enough: some people post-process
# each Makefile.in and add a new line on top of each file to say so.
# Grep'ing the whole file is not good either: AIX grep has a line
am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile which includes
# dependency-tracking related rules and includes.
# Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
dirpart=`$as_dirname -- "$mf" ||
$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$mf" : 'X\(//\)[^/]' \| \
X"$mf" : 'X\(//\)$' \| \
X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$mf" |
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|| continue
am_dirpart=`$as_dirname -- "$am_mf" ||
$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$am_mf" : 'X\(//\)[^/]' \| \
X"$am_mf" : 'X\(//\)$' \| \
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$am_mf" |
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
s//\1/
q
@ -23030,53 +23039,48 @@ $as_echo X"$mf" |
q
}
s/.*/./; q'`
else
continue
fi
# Extract the definition of DEPDIR, am__include, and am__quote
# from the Makefile without running 'make'.
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
test -z "$DEPDIR" && continue
am__include=`sed -n 's/^am__include = //p' < "$mf"`
test -z "$am__include" && continue
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
# Find all dependency output files, they are included files with
# $(DEPDIR) in their names. We invoke sed twice because it is the
# simplest approach to changing $(DEPDIR) to its actual value in the
# expansion.
for file in `sed -n "
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
# Make sure the directory exists.
test -f "$dirpart/$file" && continue
fdir=`$as_dirname -- "$file" ||
$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$file" : 'X\(//\)[^/]' \| \
X"$file" : 'X\(//\)$' \| \
X"$file" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$file" |
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
am_filepart=`$as_basename -- "$am_mf" ||
$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
X"$am_mf" : 'X\(//\)$' \| \
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X/"$am_mf" |
sed '/^.*\/\([^/][^/]*\)\/*$/{
s//\1/
q
}
/^X\(\/\/\)[^/].*/{
/^X\/\(\/\/\)$/{
s//\1/
q
}
/^X\(\/\/\)$/{
s//\1/
q
}
/^X\(\/\).*/{
/^X\/\(\/\).*/{
s//\1/
q
}
s/.*/./; q'`
as_dir=$dirpart/$fdir; as_fn_mkdir_p
# echo "creating $dirpart/$file"
echo '# dummy' > "$dirpart/$file"
done
{ echo "$as_me:$LINENO: cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles" >&5
(cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles) >&5 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } || am_rc=$?
done
if test $am_rc -ne 0; then
{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
as_fn_error $? "Something went wrong bootstrapping makefile fragments
for automatic dependency tracking. Try re-running configure with the
'--disable-dependency-tracking' option to at least be able to build
the package (albeit without support for automatic dependency tracking).
See \`config.log' for more details" "$LINENO" 5; }
fi
{ am_dirpart=; unset am_dirpart;}
{ am_filepart=; unset am_filepart;}
{ am_mf=; unset am_mf;}
{ am_rc=; unset am_rc;}
rm -f conftest-deps.mk
}
;;
"libtool":C)

View File

@ -1,10 +1,10 @@
AC_INIT([isl], [0.22.1], [isl-development@googlegroups.com])
AC_INIT([isl], [0.23], [isl-development@googlegroups.com])
AC_CONFIG_AUX_DIR([.])
AC_CONFIG_MACRO_DIR([m4])
AM_INIT_AUTOMAKE([foreign])
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
AC_SUBST(versioninfo)
versioninfo=22:1:0
versioninfo=23:0:0
if test "x$prefix" != "xNONE"; then
prefix_wd=`cd $prefix && pwd`

View File

@ -1,9 +1,9 @@
#! /bin/sh
# depcomp - compile a program generating dependencies as side-effects
scriptversion=2016-01-11.22; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -783,7 +783,7 @@ exit 0
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"

View File

@ -1,7 +1,7 @@
# Makefile.in generated by automake 1.15.1 from Makefile.am.
# Makefile.in generated by automake 1.16.1 from Makefile.am.
# @configure_input@
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
# This Makefile.in is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -330,8 +330,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
*config.status*) \
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
*) \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \
esac;
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
@ -355,7 +355,10 @@ ctags CTAGS:
cscope cscopelist:
distdir: $(DISTFILES)
distdir: $(BUILT_SOURCES)
$(MAKE) $(AM_MAKEFLAGS) distdir-am
distdir-am: $(DISTFILES)
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
list='$(DISTFILES)'; \

View File

@ -2725,6 +2725,8 @@ a specified dimension on a given domain can be created using
__isl_give isl_aff *isl_aff_var_on_domain(
__isl_take isl_local_space *ls,
enum isl_dim_type type, unsigned pos);
__isl_give isl_aff *isl_aff_nan_on_domain_space(
__isl_take isl_space *space);
__isl_give isl_aff *isl_aff_nan_on_domain(
__isl_take isl_local_space *ls);
@ -3417,10 +3419,15 @@ then create a piecewise expression over a universe domain.
__isl_give isl_pw_aff *isl_pw_aff_var_on_domain(
__isl_take isl_local_space *ls,
enum isl_dim_type type, unsigned pos);
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
__isl_take isl_space *space);
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain(
__isl_take isl_local_space *ls);
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_zero(
__isl_take isl_space *space);
__isl_give isl_pw_multi_aff *
isl_pw_multi_aff_identity_on_domain_space(
__isl_take isl_space *space)
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
__isl_take isl_space *space);
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_domain_map(
@ -4019,6 +4026,10 @@ Objects can be read from input using the following functions.
isl_union_pw_qpolynomial_read_from_str(
isl_ctx *ctx, const char *str);
__isl_give isl_pw_qpolynomial_fold *
isl_pw_qpolynomial_fold_read_from_str(
isl_ctx *ctx, const char *str);
For sets and relations,
the input format is autodetected and may be either the C<PolyLib> format
or the C<isl> format.
@ -5595,12 +5606,6 @@ dimension has the fixed given value.
__isl_take isl_map *map,
enum isl_dim_type type, unsigned pos,
__isl_take isl_val *value);
__isl_give isl_map *isl_map_lower_bound_multi_val(
__isl_take isl_map *map,
__isl_take isl_multi_val *lower);
__isl_give isl_map *isl_map_upper_bound_multi_val(
__isl_take isl_map *map,
__isl_take isl_multi_val *upper);
__isl_give isl_map *isl_map_lower_bound_multi_pw_aff(
__isl_take isl_map *map,
__isl_take isl_multi_pw_aff *lower);
@ -5614,6 +5619,9 @@ symbolic constant expression.
For functions taking a multi expression,
this applies to all set dimensions.
Those that bound a map, bound the range of that map.
If the multi expression is zero-dimensional but has an explicit domain,
then the (parameter) domain of the set or map is intersected
with this explicit domain.
__isl_give isl_set *isl_set_equate(__isl_take isl_set *set,
enum isl_dim_type type1, int pos1,
@ -5775,6 +5783,16 @@ between image elements and corresponding domain elements in the input.
The functions above construct a (basic, regular or union) relation
that maps (a wrapped version of) the input relation to its delta set.
=item * Translation
#include <isl/map.h>
__isl_give isl_map *isl_set_translation(
__isl_take isl_set *deltas);
This function performs essentially the opposite operation
of C<isl_map_deltas>. In particular, it returns pairs
of elements in the same space that have a difference in C<deltas>.
=item * Coalescing
Simplify the representation of a set, relation or functions by trying
@ -6959,6 +6977,10 @@ the same (number of) parameters.
__isl_take isl_map *map1,
__isl_take isl_map *map2);
__isl_give isl_map *
isl_map_intersect_domain_factor_domain(
__isl_take isl_map *map,
__isl_take isl_map *factor);
__isl_give isl_map *
isl_map_intersect_domain_factor_range(
__isl_take isl_map *map,
__isl_take isl_map *factor);
@ -7009,6 +7031,10 @@ the same (number of) parameters.
__isl_take isl_union_map *umap1,
__isl_take isl_union_map *umap2);
__isl_give isl_union_map *
isl_union_map_intersect_domain_factor_domain(
__isl_take isl_union_map *umap,
__isl_take isl_union_map *factor);
__isl_give isl_union_map *
isl_union_map_intersect_domain_factor_range(
__isl_take isl_union_map *umap,
__isl_take isl_union_map *factor);
@ -7539,9 +7565,19 @@ piecewise quasipolynomial reduction.
__isl_take isl_union_map *umap,
__isl_take isl_union_pw_multi_aff *upma);
#include <isl/aff.h>
__isl_give isl_pw_multi_aff *
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
__isl_take isl_pw_multi_aff *pma1,
__isl_take isl_pw_multi_aff *pma2);
__isl_give isl_union_pw_multi_aff *
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
__isl_take isl_union_pw_multi_aff *upma1,
__isl_take isl_union_pw_multi_aff *upma2);
These functions compute the preimage of the given set or map domain/range under
the given function. In other words, the expression is plugged
into the set description or into the domain/range of the map.
into the set description or into the domain/range of the map or function.
=item * Pullback
@ -7765,12 +7801,20 @@ where the function values satisfy the given relation.
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *
isl_union_map_lex_le_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *
isl_union_map_lex_gt_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *
isl_union_map_lex_ge_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
These functions select the subset of elements in the union map
that have an equal or lexicographically smaller function value.
that have an equal or lexicographically smaller or greater function value.
=item * Cartesian Product
@ -8886,7 +8930,7 @@ Lists are defined over several element types, including
C<isl_val>, C<isl_id>, C<isl_aff>, C<isl_pw_aff>, C<isl_pw_multi_aff>,
C<isl_union_pw_aff>,
C<isl_union_pw_multi_aff>,
C<isl_pw_qpolynomial>, C<isl_pw_qpolynomial_fold>,
C<isl_qpolynomial>, C<isl_pw_qpolynomial>, C<isl_pw_qpolynomial_fold>,
C<isl_constraint>,
C<isl_basic_set>, C<isl_set>, C<isl_basic_map>, C<isl_map>, C<isl_union_set>,
C<isl_union_map>, C<isl_ast_expr> and C<isl_ast_node>.

View File

@ -24,18 +24,20 @@
SOFTWARE.
*/
#include "gmp_compat.h"
#include <stdlib.h>
#include <assert.h>
#include <ctype.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#if defined(_MSC_VER)
#include <BaseTsd.h>
typedef SSIZE_T ssize_t;
#else
#include <sys/types.h>
#endif
#ifdef NDEBUG
#ifdef NDEBUG
#define CHECK(res) (res)
#else
#define CHECK(res) assert(((res) == MP_OK) && "expected MP_OK")
@ -53,34 +55,24 @@ static const uint16_t endian_test = 0x1FF;
*
*************************************************************************/
/* gmp: mpq_clear */
void GMPQAPI(clear)(mp_rat x) {
mp_rat_clear(x);
}
void GMPQAPI(clear)(mp_rat x) { mp_rat_clear(x); }
/* gmp: mpq_cmp */
int GMPQAPI(cmp)(mp_rat op1, mp_rat op2) {
return mp_rat_compare(op1, op2);
}
int GMPQAPI(cmp)(mp_rat op1, mp_rat op2) { return mp_rat_compare(op1, op2); }
/* gmp: mpq_init */
void GMPQAPI(init)(mp_rat x) {
CHECK(mp_rat_init(x));
}
void GMPQAPI(init)(mp_rat x) { CHECK(mp_rat_init(x)); }
/* gmp: mpq_mul */
void GMPQAPI(mul)(mp_rat product, mp_rat multiplier, mp_rat multiplicand) {
CHECK(mp_rat_mul(multiplier, multiplicand, product));
}
/* gmp: mpq_set*/
void GMPQAPI(set)(mp_rat rop, mp_rat op) {
CHECK(mp_rat_copy(op, rop));
}
/* gmp: mpq_set */
void GMPQAPI(set)(mp_rat rop, mp_rat op) { CHECK(mp_rat_copy(op, rop)); }
/* gmp: mpz_abs */
void GMPZAPI(abs)(mp_int rop, mp_int op) {
CHECK(mp_int_abs(op, rop));
}
void GMPZAPI(abs)(mp_int rop, mp_int op) { CHECK(mp_int_abs(op, rop)); }
/* gmp: mpz_add */
void GMPZAPI(add)(mp_int rop, mp_int op1, mp_int op2) {
@ -88,9 +80,7 @@ void GMPZAPI(add)(mp_int rop, mp_int op1, mp_int op2) {
}
/* gmp: mpz_clear */
void GMPZAPI(clear)(mp_int x) {
mp_int_clear(x);
}
void GMPZAPI(clear)(mp_int x) { mp_int_clear(x); }
/* gmp: mpz_cmp_si */
int GMPZAPI(cmp_si)(mp_int op1, long op2) {
@ -103,14 +93,10 @@ int GMPZAPI(cmpabs)(mp_int op1, mp_int op2) {
}
/* gmp: mpz_cmp */
int GMPZAPI(cmp)(mp_int op1, mp_int op2) {
return mp_int_compare(op1, op2);
}
int GMPZAPI(cmp)(mp_int op1, mp_int op2) { return mp_int_compare(op1, op2); }
/* gmp: mpz_init */
void GMPZAPI(init)(mp_int x) {
CHECK(mp_int_init(x));
}
void GMPZAPI(init)(mp_int x) { CHECK(mp_int_init(x)); }
/* gmp: mpz_mul */
void GMPZAPI(mul)(mp_int rop, mp_int op1, mp_int op2) {
@ -118,19 +104,13 @@ void GMPZAPI(mul)(mp_int rop, mp_int op1, mp_int op2) {
}
/* gmp: mpz_neg */
void GMPZAPI(neg)(mp_int rop, mp_int op) {
CHECK(mp_int_neg(op, rop));
}
void GMPZAPI(neg)(mp_int rop, mp_int op) { CHECK(mp_int_neg(op, rop)); }
/* gmp: mpz_set_si */
void GMPZAPI(set_si)(mp_int rop, long op) {
CHECK(mp_int_set_value(rop, op));
}
void GMPZAPI(set_si)(mp_int rop, long op) { CHECK(mp_int_set_value(rop, op)); }
/* gmp: mpz_set */
void GMPZAPI(set)(mp_int rop, mp_int op) {
CHECK(mp_int_copy(op, rop));
}
void GMPZAPI(set)(mp_int rop, mp_int op) { CHECK(mp_int_copy(op, rop)); }
/* gmp: mpz_sub */
void GMPZAPI(sub)(mp_int rop, mp_int op1, mp_int op2) {
@ -138,19 +118,13 @@ void GMPZAPI(sub)(mp_int rop, mp_int op1, mp_int op2) {
}
/* gmp: mpz_swap */
void GMPZAPI(swap)(mp_int rop1, mp_int rop2) {
mp_int_swap(rop1, rop2);
}
void GMPZAPI(swap)(mp_int rop1, mp_int rop2) { mp_int_swap(rop1, rop2); }
/* gmp: mpq_sgn */
int GMPQAPI(sgn)(mp_rat op) {
return mp_rat_compare_zero(op);
}
int GMPQAPI(sgn)(mp_rat op) { return mp_rat_compare_zero(op); }
/* gmp: mpz_sgn */
int GMPZAPI(sgn)(mp_int op) {
return mp_int_compare_zero(op);
}
int GMPZAPI(sgn)(mp_int op) { return mp_int_compare_zero(op); }
/* gmp: mpq_set_ui */
void GMPQAPI(set_ui)(mp_rat rop, unsigned long op1, unsigned long op2) {
@ -163,25 +137,18 @@ void GMPZAPI(set_ui)(mp_int rop, unsigned long op) {
}
/* gmp: mpq_den_ref */
mp_int GMPQAPI(denref)(mp_rat op) {
return mp_rat_denom_ref(op);
}
mp_int GMPQAPI(denref)(mp_rat op) { return mp_rat_denom_ref(op); }
/* gmp: mpq_num_ref */
mp_int GMPQAPI(numref)(mp_rat op) {
return mp_rat_numer_ref(op);
}
mp_int GMPQAPI(numref)(mp_rat op) { return mp_rat_numer_ref(op); }
/* gmp: mpq_canonicalize */
void GMPQAPI(canonicalize)(mp_rat op) {
CHECK(mp_rat_reduce(op));
}
void GMPQAPI(canonicalize)(mp_rat op) { CHECK(mp_rat_reduce(op)); }
/*************************************************************************
*
/*
* Functions that can be implemented as a combination of imath functions
*
*************************************************************************/
*/
/* gmp: mpz_addmul */
/* gmp: rop = rop + (op1 * op2) */
void GMPZAPI(addmul)(mp_int rop, mp_int op1, mp_int op2) {
@ -212,8 +179,7 @@ int GMPZAPI(divisible_p)(mp_int n, mp_int d) {
/* check for d = 0 */
int n_is_zero = mp_int_compare_zero(n) == 0;
int d_is_zero = mp_int_compare_zero(d) == 0;
if (d_is_zero)
return n_is_zero;
if (d_is_zero) return n_is_zero;
/* return true if remainder is 0 */
CHECK(mp_int_init(r));
@ -320,13 +286,12 @@ void GMPZAPI(gcd)(mp_int rop, mp_int op1, mp_int op2) {
}
/* gmp: mpz_get_str */
char* GMPZAPI(get_str)(char *str, int radix, mp_int op) {
char *GMPZAPI(get_str)(char *str, int radix, mp_int op) {
int i, r, len;
/* Support negative radix like gmp */
r = radix;
if (r < 0)
r = -r;
if (r < 0) r = -r;
/* Compute the length of the string needed to hold the int */
len = mp_int_string_len(op, r);
@ -338,16 +303,18 @@ char* GMPZAPI(get_str)(char *str, int radix, mp_int op) {
CHECK(mp_int_to_string(op, r, str, len));
/* Change case to match gmp */
for (i = 0; i < len - 1; i++)
if (radix < 0)
for (i = 0; i < len - 1; i++) {
if (radix < 0) {
str[i] = toupper(str[i]);
else
} else {
str[i] = tolower(str[i]);
}
}
return str;
}
/* gmp: mpq_get_str */
char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
char *GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
int i, r, len;
/* Only print numerator if it is a whole number */
@ -356,8 +323,7 @@ char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
/* Support negative radix like gmp */
r = radix;
if (r < 0)
r = -r;
if (r < 0) r = -r;
/* Compute the length of the string needed to hold the int */
len = mp_rat_string_len(op, r);
@ -369,11 +335,13 @@ char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
CHECK(mp_rat_to_string(op, r, str, len));
/* Change case to match gmp */
for (i = 0; i < len; i++)
if (radix < 0)
for (i = 0; i < len; i++) {
if (radix < 0) {
str[i] = toupper(str[i]);
else
} else {
str[i] = tolower(str[i]);
}
}
return str;
}
@ -393,26 +361,27 @@ int GMPQAPI(set_str)(mp_rat rop, char *s, int base) {
int res = 0;
/* Copy string to temporary storage so we can modify it below */
str = malloc(strlen(s)+1);
str = malloc(strlen(s) + 1);
strcpy(str, s);
/* Properly format the string as an int by terminating at the / */
slash = strchr(str, '/');
if (slash)
*slash = '\0';
if (slash) *slash = '\0';
/* Parse numerator */
resN = mp_int_read_string(mp_rat_numer_ref(rop), base, str);
/* Parse denomenator if given or set to 1 if not */
if (slash)
resD = mp_int_read_string(mp_rat_denom_ref(rop), base, slash+1);
else
/* Parse denominator if given or set to 1 if not */
if (slash) {
resD = mp_int_read_string(mp_rat_denom_ref(rop), base, slash + 1);
} else {
resD = mp_int_set_uvalue(mp_rat_denom_ref(rop), 1);
}
/* Return failure if either parse failed */
if (resN != MP_OK || resD != MP_OK)
if (resN != MP_OK || resD != MP_OK) {
res = -1;
}
free(str);
return res;
@ -423,18 +392,24 @@ static unsigned long get_long_bits(mp_int op) {
* the least significant digits that will fit into the long. Read the digits
* into the long starting at the most significant digit that fits into a
* long. The long is shifted over by MP_DIGIT_BIT before each digit is added.
* The shift is decomposed into two steps to follow the patten used in the
* rest of the imath library. The two step shift is used to accomedate
* architectures that don't deal well with 32-bit shifts. */
mp_size num_digits_in_long = sizeof(unsigned long) / sizeof(mp_digit);
*
* The shift is decomposed into two steps (following the pattern used in the
* rest of the imath library) to accommodate architectures that don't deal
* well with 32-bit shifts.
*/
mp_size digits_to_copy =
(sizeof(unsigned long) + sizeof(mp_digit) - 1) / sizeof(mp_digit);
if (digits_to_copy > MP_USED(op)) {
digits_to_copy = MP_USED(op);
}
mp_digit *digits = MP_DIGITS(op);
unsigned long out = 0;
int i;
for (i = num_digits_in_long - 1; i >= 0; i--) {
out <<= (MP_DIGIT_BIT/2);
out <<= (MP_DIGIT_BIT/2);
out |= digits[i];
for (int i = digits_to_copy - 1; i >= 0; i--) {
out <<= (MP_DIGIT_BIT / 2);
out <<= (MP_DIGIT_BIT / 2);
out |= digits[i];
}
return out;
@ -446,14 +421,12 @@ unsigned long GMPZAPI(get_ui)(mp_int op) {
/* Try a standard conversion that fits into an unsigned long */
mp_result res = mp_int_to_uint(op, &out);
if (res == MP_OK)
return out;
if (res == MP_OK) return out;
/* Abort the try if we don't have a range error in the conversion.
* The range error indicates that the value cannot fit into a long. */
CHECK(res == MP_RANGE ? MP_OK : MP_RANGE);
if (res != MP_RANGE)
return 0;
if (res != MP_RANGE) return 0;
return get_long_bits(op);
}
@ -466,14 +439,12 @@ long GMPZAPI(get_si)(mp_int op) {
/* Try a standard conversion that fits into a long */
mp_result res = mp_int_to_int(op, &out);
if (res == MP_OK)
return out;
if (res == MP_OK) return out;
/* Abort the try if we don't have a range error in the conversion.
* The range error indicates that the value cannot fit into a long. */
CHECK(res == MP_RANGE ? MP_OK : MP_RANGE);
if (res != MP_RANGE)
return 0;
if (res != MP_RANGE) return 0;
/* get least significant bits into an unsigned long */
uout = get_long_bits(op);
@ -483,10 +454,11 @@ long GMPZAPI(get_si)(mp_int op) {
uout &= (~(1UL << long_msb));
/* convert to negative if needed based on sign of op */
if (MP_SIGN(op) == MP_NEG)
if (MP_SIGN(op) == MP_NEG) {
uout = 0 - uout;
}
out = (long) uout;
out = (long)uout;
return out;
}
@ -513,11 +485,9 @@ void GMPZAPI(mul_2exp)(mp_int rop, mp_int op1, unsigned long op2) {
CHECK(mp_int_mul_pow2(op1, op2, rop));
}
/*************************************************************************
*
/*
* Functions needing expanded functionality
*
*************************************************************************/
*/
/* [Note]Overview of division implementation
All division operations (N / D) compute q and r such that
@ -578,9 +548,8 @@ void GMPZAPI(cdiv_q)(mp_int q, mp_int n, mp_int d) {
if (rsign != 0) { /* r != 0 */
CHECK(mp_int_add_value(q, 1, q));
}
}
else if (qsign == 0) { /* q == 0 */
if (rsign != 0) { /* r != 0 */
} else if (qsign == 0) { /* q == 0 */
if (rsign != 0) { /* r != 0 */
if ((nsign > 0 && dsign > 0) || (nsign < 0 && dsign < 0)) {
CHECK(mp_int_set_value(q, 1));
}
@ -610,9 +579,8 @@ void GMPZAPI(fdiv_q)(mp_int q, mp_int n, mp_int d) {
if (rsign != 0) { /* r != 0 */
CHECK(mp_int_sub_value(q, 1, q));
}
}
else if (qsign == 0) { /* q == 0 */
if (rsign != 0) { /* r != 0 */
} else if (qsign == 0) { /* q == 0 */
if (rsign != 0) { /* r != 0 */
if ((nsign < 0 && dsign > 0) || (nsign > 0 && dsign < 0)) {
CHECK(mp_int_set_value(q, -1));
}
@ -684,31 +652,32 @@ unsigned long GMPZAPI(fdiv_q_ui)(mp_int q, mp_int n, unsigned long d) {
}
/* gmp: mpz_export */
void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int endian, size_t nails, mp_int op) {
int i, j;
int num_used_bytes;
void *GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size,
int endian, size_t nails, mp_int op) {
size_t i, j;
size_t num_used_bytes;
size_t num_words, num_missing_bytes;
ssize_t word_offset;
unsigned char* dst;
mp_digit* src;
unsigned char *dst;
mp_digit *src;
int src_bits;
/* We do not have a complete implementation. Assert to ensure our
* restrictions are in place. */
assert(nails == 0 && "Do not support non-full words");
* restrictions are in place.
*/
assert(nails == 0 && "Do not support non-full words");
assert(endian == 1 || endian == 0 || endian == -1);
assert(order == 1 || order == -1);
/* Test for zero */
if (mp_int_compare_zero(op) == 0) {
if (countp)
*countp = 0;
if (countp) *countp = 0;
return rop;
}
/* Calculate how many words we need */
num_used_bytes = mp_int_unsigned_len(op);
num_words = (num_used_bytes + (size-1)) / size; /* ceil division */
num_used_bytes = mp_int_unsigned_len(op);
num_words = (num_used_bytes + (size - 1)) / size; /* ceil division */
assert(num_used_bytes > 0);
/* Check to see if we will have missing bytes in the last word.
@ -720,7 +689,7 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
pad the word with extra zeros. Otherwise, the missing bytes can be filled
directly from the zeros in the last digit in the number.
*/
num_missing_bytes = (size * num_words) - num_used_bytes;
num_missing_bytes = (size * num_words) - num_used_bytes;
assert(num_missing_bytes < size);
/* Allocate space for the result if needed */
@ -733,7 +702,8 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
}
/* Initialize dst and src pointers */
dst = (unsigned char *) rop + (order >= 0 ? (num_words-1) * size : 0) + (endian >= 0 ? size-1 : 0);
dst = (unsigned char *)rop + (order >= 0 ? (num_words - 1) * size : 0) +
(endian >= 0 ? size - 1 : 0);
src = MP_DIGITS(op);
src_bits = MP_DIGIT_BIT;
@ -756,13 +726,13 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
dst += word_offset;
}
if (countp)
*countp = num_words;
if (countp) *countp = num_words;
return rop;
}
/* gmp: mpz_import */
void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endian, size_t nails, const void* op) {
void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size,
int endian, size_t nails, const void *op) {
mpz_t tmpz;
mp_int tmp = &tmpz;
size_t total_size;
@ -771,13 +741,12 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
const unsigned char *src;
mp_digit *dst;
int dst_bits;
int i, j;
if (count == 0 || op == NULL)
return;
size_t i, j;
if (count == 0 || op == NULL) return;
/* We do not have a complete implementation. Assert to ensure our
* restrictions are in place. */
assert(nails == 0 && "Do not support non-full words");
assert(nails == 0 && "Do not support non-full words");
assert(endian == 1 || endian == 0 || endian == -1);
assert(order == 1 || order == -1);
@ -791,11 +760,11 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
/* Init temporary */
mp_int_init_size(tmp, num_digits);
for (i = 0; i < num_digits; i++)
tmp->digits[i] = 0;
for (i = 0; i < num_digits; i++) tmp->digits[i] = 0;
/* Copy bytes */
src = (const unsigned char *) op + (order >= 0 ? (count-1) * size : 0) + (endian >= 0 ? size-1 : 0);
src = (const unsigned char *)op + (order >= 0 ? (count - 1) * size : 0) +
(endian >= 0 ? size - 1 : 0);
dst = MP_DIGITS(tmp);
dst_bits = 0;
@ -814,15 +783,14 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
src += word_offset;
}
MP_USED(tmp) = num_digits;
tmp->used = num_digits;
/* Remove leading zeros from number */
{
mp_size uz_ = MP_USED(tmp);
mp_digit *dz_ = MP_DIGITS(tmp) + uz_ -1;
while (uz_ > 1 && (*dz_-- == 0))
--uz_;
MP_USED(tmp) = uz_;
mp_size uz_ = tmp->used;
mp_digit *dz_ = MP_DIGITS(tmp) + uz_ - 1;
while (uz_ > 1 && (*dz_-- == 0)) --uz_;
tmp->used = uz_;
}
/* Copy to destination */
@ -836,8 +804,7 @@ size_t GMPZAPI(sizeinbase)(mp_int op, int base) {
size_t size;
/* If op == 0, return 1 */
if (mp_int_compare_zero(op) == 0)
return 1;
if (mp_int_compare_zero(op) == 0) return 1;
/* Compute string length in base */
res = mp_int_string_len(op, base);
@ -850,8 +817,7 @@ size_t GMPZAPI(sizeinbase)(mp_int op, int base) {
size -= 1;
/* subtract one for the negative sign */
if (mp_int_compare_zero(op) < 0)
size -= 1;
if (mp_int_compare_zero(op) < 0) size -= 1;
return size;
}

File diff suppressed because it is too large Load Diff

View File

@ -1,7 +1,7 @@
/*
Name: imath.h
Purpose: Arbitrary precision integer arithmetic routines.
Author: M. J. Fromberger <http://spinning-yarns.org/michael/>
Author: M. J. Fromberger
Copyright (C) 2002-2007 Michael J. Fromberger, All Rights Reserved.
@ -27,44 +27,46 @@
#ifndef IMATH_H_
#define IMATH_H_
#include <stdint.h>
#include <limits.h>
#include <stdbool.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef unsigned char mp_sign;
typedef unsigned int mp_size;
typedef int mp_result;
typedef long mp_small; /* must be a signed type */
typedef unsigned long mp_usmall; /* must be an unsigned type */
typedef unsigned char mp_sign;
typedef unsigned int mp_size;
typedef int mp_result;
typedef long mp_small; /* must be a signed type */
typedef unsigned long mp_usmall; /* must be an unsigned type */
/* Force building with uint64_t so that the library builds consistently
* whether we build from the makefile or by embedding imath in another project.
*/
#undef USE_64BIT_WORDS
#define USE_64BIT_WORDS
#ifdef USE_64BIT_WORDS
typedef uint32_t mp_digit;
typedef uint64_t mp_word;
/* Build with words as uint64_t by default. */
#ifdef USE_32BIT_WORDS
typedef uint16_t mp_digit;
typedef uint32_t mp_word;
# define MP_DIGIT_MAX (UINT16_MAX * 1UL)
# define MP_WORD_MAX (UINT32_MAX * 1UL)
#else
typedef uint16_t mp_digit;
typedef uint32_t mp_word;
typedef uint32_t mp_digit;
typedef uint64_t mp_word;
# define MP_DIGIT_MAX (UINT32_MAX * UINT64_C(1))
# define MP_WORD_MAX (UINT64_MAX)
#endif
typedef struct mpz {
mp_digit single;
mp_digit *digits;
mp_size alloc;
mp_size used;
mp_sign sign;
typedef struct {
mp_digit single;
mp_digit* digits;
mp_size alloc;
mp_size used;
mp_sign sign;
} mpz_t, *mp_int;
#define MP_DIGITS(Z) ((Z)->digits)
#define MP_ALLOC(Z) ((Z)->alloc)
#define MP_USED(Z) ((Z)->used)
#define MP_SIGN(Z) ((Z)->sign)
static inline mp_digit* MP_DIGITS(mp_int Z) { return Z->digits; }
static inline mp_size MP_ALLOC(mp_int Z) { return Z->alloc; }
static inline mp_size MP_USED(mp_int Z) { return Z->used; }
static inline mp_sign MP_SIGN(mp_int Z) { return Z->sign; }
extern const mp_result MP_OK;
extern const mp_result MP_FALSE;
@ -76,156 +78,343 @@ extern const mp_result MP_TRUNC;
extern const mp_result MP_BADARG;
extern const mp_result MP_MINERR;
#define MP_DIGIT_BIT (sizeof(mp_digit) * CHAR_BIT)
#define MP_WORD_BIT (sizeof(mp_word) * CHAR_BIT)
#define MP_SMALL_MIN LONG_MIN
#define MP_SMALL_MAX LONG_MAX
#define MP_USMALL_MIN ULONG_MIN
#define MP_USMALL_MAX ULONG_MAX
#define MP_DIGIT_BIT (sizeof(mp_digit) * CHAR_BIT)
#define MP_WORD_BIT (sizeof(mp_word) * CHAR_BIT)
#define MP_SMALL_MIN LONG_MIN
#define MP_SMALL_MAX LONG_MAX
#define MP_USMALL_MAX ULONG_MAX
#ifdef USE_64BIT_WORDS
# define MP_DIGIT_MAX (UINT32_MAX * UINT64_C(1))
# define MP_WORD_MAX (UINT64_MAX)
#else
# define MP_DIGIT_MAX (UINT16_MAX * 1UL)
# define MP_WORD_MAX (UINT32_MAX * 1UL)
#endif
#define MP_MIN_RADIX 2
#define MP_MAX_RADIX 36
#define MP_MIN_RADIX 2
#define MP_MAX_RADIX 36
/** Sets the default number of digits allocated to an `mp_int` constructed by
`mp_int_init_size()` with `prec == 0`. Allocations are rounded up to
multiples of this value. `MP_DEFAULT_PREC` is the default value. Requires
`ndigits > 0`. */
void mp_int_default_precision(mp_size ndigits);
/* Values with fewer than this many significant digits use the standard
multiplication algorithm; otherwise, a recursive algorithm is used.
Choose a value to suit your platform.
*/
#define MP_MULT_THRESH 22
/** Sets the number of digits below which multiplication will use the standard
quadratic "schoolbook" multiplication algorithm rather than Karatsuba-Ofman.
Requires `ndigits >= sizeof(mp_word)`. */
void mp_int_multiply_threshold(mp_size ndigits);
#define MP_DEFAULT_PREC 8 /* default memory allocation, in digits */
/** A sign indicating a (strictly) negative value. */
extern const mp_sign MP_NEG;
extern const mp_sign MP_NEG;
extern const mp_sign MP_ZPOS;
/** A sign indicating a zero or positive value. */
extern const mp_sign MP_ZPOS;
#define mp_int_is_odd(Z) ((Z)->digits[0] & 1)
#define mp_int_is_even(Z) !((Z)->digits[0] & 1)
/** Reports whether `z` is odd, having remainder 1 when divided by 2. */
static inline bool mp_int_is_odd(mp_int z) { return (z->digits[0] & 1) != 0; }
/** Reports whether `z` is even, having remainder 0 when divided by 2. */
static inline bool mp_int_is_even(mp_int z) { return (z->digits[0] & 1) == 0; }
/** Initializes `z` with 1-digit precision and sets it to zero. This function
cannot fail unless `z == NULL`. */
mp_result mp_int_init(mp_int z);
mp_int mp_int_alloc(void);
/** Allocates a fresh zero-valued `mpz_t` on the heap, returning NULL in case
of error. The only possible error is out-of-memory. */
mp_int mp_int_alloc(void);
/** Initializes `z` with at least `prec` digits of storage, and sets it to
zero. If `prec` is zero, the default precision is used. In either case the
size is rounded up to the nearest multiple of the word size. */
mp_result mp_int_init_size(mp_int z, mp_size prec);
/** Initializes `z` to be a copy of an already-initialized value in `old`. The
new copy does not share storage with the original. */
mp_result mp_int_init_copy(mp_int z, mp_int old);
/** Initializes `z` to the specified signed `value` at default precision. */
mp_result mp_int_init_value(mp_int z, mp_small value);
/** Initializes `z` to the specified unsigned `value` at default precision. */
mp_result mp_int_init_uvalue(mp_int z, mp_usmall uvalue);
/** Sets `z` to the value of the specified signed `value`. */
mp_result mp_int_set_value(mp_int z, mp_small value);
/** Sets `z` to the value of the specified unsigned `value`. */
mp_result mp_int_set_uvalue(mp_int z, mp_usmall uvalue);
void mp_int_clear(mp_int z);
void mp_int_free(mp_int z);
mp_result mp_int_copy(mp_int a, mp_int c); /* c = a */
void mp_int_swap(mp_int a, mp_int c); /* swap a, c */
void mp_int_zero(mp_int z); /* z = 0 */
mp_result mp_int_abs(mp_int a, mp_int c); /* c = |a| */
mp_result mp_int_neg(mp_int a, mp_int c); /* c = -a */
mp_result mp_int_add(mp_int a, mp_int b, mp_int c); /* c = a + b */
/** Releases the storage used by `z`. */
void mp_int_clear(mp_int z);
/** Releases the storage used by `z` and also `z` itself.
This should only be used for `z` allocated by `mp_int_alloc()`. */
void mp_int_free(mp_int z);
/** Replaces the value of `c` with a copy of the value of `a`. No new memory is
allocated unless `a` has more significant digits than `c` has allocated. */
mp_result mp_int_copy(mp_int a, mp_int c);
/** Swaps the values and storage between `a` and `c`. */
void mp_int_swap(mp_int a, mp_int c);
/** Sets `z` to zero. The allocated storage of `z` is not changed. */
void mp_int_zero(mp_int z);
/** Sets `c` to the absolute value of `a`. */
mp_result mp_int_abs(mp_int a, mp_int c);
/** Sets `c` to the additive inverse (negation) of `a`. */
mp_result mp_int_neg(mp_int a, mp_int c);
/** Sets `c` to the sum of `a` and `b`. */
mp_result mp_int_add(mp_int a, mp_int b, mp_int c);
/** Sets `c` to the sum of `a` and `value`. */
mp_result mp_int_add_value(mp_int a, mp_small value, mp_int c);
mp_result mp_int_sub(mp_int a, mp_int b, mp_int c); /* c = a - b */
/** Sets `c` to the difference of `a` less `b`. */
mp_result mp_int_sub(mp_int a, mp_int b, mp_int c);
/** Sets `c` to the difference of `a` less `value`. */
mp_result mp_int_sub_value(mp_int a, mp_small value, mp_int c);
mp_result mp_int_mul(mp_int a, mp_int b, mp_int c); /* c = a * b */
/** Sets `c` to the product of `a` and `b`. */
mp_result mp_int_mul(mp_int a, mp_int b, mp_int c);
/** Sets `c` to the product of `a` and `value`. */
mp_result mp_int_mul_value(mp_int a, mp_small value, mp_int c);
/** Sets `c` to the product of `a` and `2^p2`. Requires `p2 >= 0`. */
mp_result mp_int_mul_pow2(mp_int a, mp_small p2, mp_int c);
mp_result mp_int_sqr(mp_int a, mp_int c); /* c = a * a */
mp_result mp_int_div(mp_int a, mp_int b, /* q = a / b */
mp_int q, mp_int r); /* r = a % b */
mp_result mp_int_div_value(mp_int a, mp_small value, /* q = a / value */
mp_int q, mp_small *r); /* r = a % value */
mp_result mp_int_div_pow2(mp_int a, mp_small p2, /* q = a / 2^p2 */
mp_int q, mp_int r); /* r = q % 2^p2 */
mp_result mp_int_mod(mp_int a, mp_int m, mp_int c); /* c = a % m */
#define mp_int_mod_value(A, V, R) mp_int_div_value((A), (V), 0, (R))
mp_result mp_int_expt(mp_int a, mp_small b, mp_int c); /* c = a^b */
mp_result mp_int_expt_value(mp_small a, mp_small b, mp_int c); /* c = a^b */
mp_result mp_int_expt_full(mp_int a, mp_int b, mp_int c); /* c = a^b */
int mp_int_compare(mp_int a, mp_int b); /* a <=> b */
int mp_int_compare_unsigned(mp_int a, mp_int b); /* |a| <=> |b| */
int mp_int_compare_zero(mp_int z); /* a <=> 0 */
int mp_int_compare_value(mp_int z, mp_small v); /* a <=> v */
int mp_int_compare_uvalue(mp_int z, mp_usmall uv); /* a <=> uv */
/** Sets `c` to the square of `a`. */
mp_result mp_int_sqr(mp_int a, mp_int c);
/* Returns true if v|a, false otherwise (including errors) */
int mp_int_divisible_value(mp_int a, mp_small v);
/** Sets `q` and `r` to the quotent and remainder of `a / b`. Division by
powers of 2 is detected and handled efficiently. The remainder is pinned
to `0 <= r < b`.
/* Returns k >= 0 such that z = 2^k, if one exists; otherwise < 0 */
int mp_int_is_pow2(mp_int z);
Either of `q` or `r` may be NULL, but not both, and `q` and `r` may not
point to the same value. */
mp_result mp_int_div(mp_int a, mp_int b, mp_int q, mp_int r);
mp_result mp_int_exptmod(mp_int a, mp_int b, mp_int m,
mp_int c); /* c = a^b (mod m) */
mp_result mp_int_exptmod_evalue(mp_int a, mp_small value,
mp_int m, mp_int c); /* c = a^v (mod m) */
mp_result mp_int_exptmod_bvalue(mp_small value, mp_int b,
mp_int m, mp_int c); /* c = v^b (mod m) */
mp_result mp_int_exptmod_known(mp_int a, mp_int b,
mp_int m, mp_int mu,
mp_int c); /* c = a^b (mod m) */
/** Sets `q` and `*r` to the quotent and remainder of `a / value`. Division by
powers of 2 is detected and handled efficiently. The remainder is pinned to
`0 <= *r < b`. Either of `q` or `r` may be NULL. */
mp_result mp_int_div_value(mp_int a, mp_small value, mp_int q, mp_small *r);
/** Sets `q` and `r` to the quotient and remainder of `a / 2^p2`. This is a
special case for division by powers of two that is more efficient than
using ordinary division. Note that `mp_int_div()` will automatically handle
this case, this function is for cases where you have only the exponent. */
mp_result mp_int_div_pow2(mp_int a, mp_small p2, mp_int q, mp_int r);
/** Sets `c` to the remainder of `a / m`.
The remainder is pinned to `0 <= c < m`. */
mp_result mp_int_mod(mp_int a, mp_int m, mp_int c);
/** Sets `c` to the value of `a` raised to the `b` power.
It returns `MP_RANGE` if `b < 0`. */
mp_result mp_int_expt(mp_int a, mp_small b, mp_int c);
/** Sets `c` to the value of `a` raised to the `b` power.
It returns `MP_RANGE` if `b < 0`. */
mp_result mp_int_expt_value(mp_small a, mp_small b, mp_int c);
/** Sets `c` to the value of `a` raised to the `b` power.
It returns `MP_RANGE`) if `b < 0`. */
mp_result mp_int_expt_full(mp_int a, mp_int b, mp_int c);
/** Sets `*r` to the remainder of `a / value`.
The remainder is pinned to `0 <= r < value`. */
static inline
mp_result mp_int_mod_value(mp_int a, mp_small value, mp_small* r) {
return mp_int_div_value(a, value, 0, r);
}
/** Returns the comparator of `a` and `b`. */
int mp_int_compare(mp_int a, mp_int b);
/** Returns the comparator of the magnitudes of `a` and `b`, disregarding their
signs. Neither `a` nor `b` is modified by the comparison. */
int mp_int_compare_unsigned(mp_int a, mp_int b);
/** Returns the comparator of `z` and zero. */
int mp_int_compare_zero(mp_int z);
/** Returns the comparator of `z` and the signed value `v`. */
int mp_int_compare_value(mp_int z, mp_small v);
/** Returns the comparator of `z` and the unsigned value `uv`. */
int mp_int_compare_uvalue(mp_int z, mp_usmall uv);
/** Reports whether `a` is divisible by `v`. */
bool mp_int_divisible_value(mp_int a, mp_small v);
/** Returns `k >= 0` such that `z` is `2^k`, if such a `k` exists. If no such
`k` exists, the function returns -1. */
int mp_int_is_pow2(mp_int z);
/** Sets `c` to the value of `a` raised to the `b` power, reduced modulo `m`.
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
mp_result mp_int_exptmod(mp_int a, mp_int b, mp_int m, mp_int c);
/** Sets `c` to the value of `a` raised to the `value` power, modulo `m`.
It returns `MP_RANGE` if `value < 0` or `MP_UNDEF` if `m == 0`. */
mp_result mp_int_exptmod_evalue(mp_int a, mp_small value, mp_int m, mp_int c);
/** Sets `c` to the value of `value` raised to the `b` power, modulo `m`.
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
mp_result mp_int_exptmod_bvalue(mp_small value, mp_int b, mp_int m, mp_int c);
/** Sets `c` to the value of `a` raised to the `b` power, reduced modulo `m`,
given a precomputed reduction constant `mu` defined for Barrett's modular
reduction algorithm.
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
mp_result mp_int_exptmod_known(mp_int a, mp_int b, mp_int m, mp_int mu, mp_int c);
/** Sets `c` to the reduction constant for Barrett reduction by modulus `m`.
Requires that `c` and `m` point to distinct locations. */
mp_result mp_int_redux_const(mp_int m, mp_int c);
mp_result mp_int_invmod(mp_int a, mp_int m, mp_int c); /* c = 1/a (mod m) */
/** Sets `c` to the multiplicative inverse of `a` modulo `m`, if it exists.
The least non-negative representative of the congruence class is computed.
mp_result mp_int_gcd(mp_int a, mp_int b, mp_int c); /* c = gcd(a, b) */
It returns `MP_UNDEF` if the inverse does not exist, or `MP_RANGE` if `a ==
0` or `m <= 0`. */
mp_result mp_int_invmod(mp_int a, mp_int m, mp_int c);
mp_result mp_int_egcd(mp_int a, mp_int b, mp_int c, /* c = gcd(a, b) */
mp_int x, mp_int y); /* c = ax + by */
/** Sets `c` to the greatest common divisor of `a` and `b`.
mp_result mp_int_lcm(mp_int a, mp_int b, mp_int c); /* c = lcm(a, b) */
It returns `MP_UNDEF` if the GCD is undefined, such as for example if `a`
and `b` are both zero. */
mp_result mp_int_gcd(mp_int a, mp_int b, mp_int c);
mp_result mp_int_root(mp_int a, mp_small b, mp_int c); /* c = floor(a^{1/b}) */
#define mp_int_sqrt(a, c) mp_int_root(a, 2, c) /* c = floor(sqrt(a)) */
/** Sets `c` to the greatest common divisor of `a` and `b`, and sets `x` and
`y` to values satisfying Bezout's identity `gcd(a, b) = ax + by`.
/* Convert to a small int, if representable; else MP_RANGE */
It returns `MP_UNDEF` if the GCD is undefined, such as for example if `a`
and `b` are both zero. */
mp_result mp_int_egcd(mp_int a, mp_int b, mp_int c, mp_int x, mp_int y);
/** Sets `c` to the least common multiple of `a` and `b`.
It returns `MP_UNDEF` if the LCM is undefined, such as for example if `a`
and `b` are both zero. */
mp_result mp_int_lcm(mp_int a, mp_int b, mp_int c);
/** Sets `c` to the greatest integer not less than the `b`th root of `a`,
using Newton's root-finding algorithm.
It returns `MP_UNDEF` if `a < 0` and `b` is even. */
mp_result mp_int_root(mp_int a, mp_small b, mp_int c);
/** Sets `c` to the greatest integer not less than the square root of `a`.
This is a special case of `mp_int_root()`. */
static inline
mp_result mp_int_sqrt(mp_int a, mp_int c) { return mp_int_root(a, 2, c); }
/** Returns `MP_OK` if `z` is representable as `mp_small`, else `MP_RANGE`.
If `out` is not NULL, `*out` is set to the value of `z` when `MP_OK`. */
mp_result mp_int_to_int(mp_int z, mp_small *out);
/** Returns `MP_OK` if `z` is representable as `mp_usmall`, or `MP_RANGE`.
If `out` is not NULL, `*out` is set to the value of `z` when `MP_OK`. */
mp_result mp_int_to_uint(mp_int z, mp_usmall *out);
/* Convert to nul-terminated string with the specified radix, writing at
most limit characters including the nul terminator */
mp_result mp_int_to_string(mp_int z, mp_size radix,
char *str, int limit);
/** Converts `z` to a zero-terminated string of characters in the specified
`radix`, writing at most `limit` characters to `str` including the
terminating NUL value. A leading `-` is used to indicate a negative value.
/* Return the number of characters required to represent
z in the given radix. May over-estimate. */
Returns `MP_TRUNC` if `limit` was to small to write all of `z`.
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_int_to_string(mp_int z, mp_size radix, char *str, int limit);
/** Reports the minimum number of characters required to represent `z` as a
zero-terminated string in the given `radix`.
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_int_string_len(mp_int z, mp_size radix);
/* Read zero-terminated string into z */
mp_result mp_int_read_string(mp_int z, mp_size radix, const char *str);
mp_result mp_int_read_cstring(mp_int z, mp_size radix, const char *str,
char **end);
/** Reads a string of ASCII digits in the specified `radix` from the zero
terminated `str` provided into `z`. For values of `radix > 10`, the letters
`A`..`Z` or `a`..`z` are accepted. Letters are interpreted without respect
to case.
/* Return the number of significant bits in z */
Leading whitespace is ignored, and a leading `+` or `-` is interpreted as a
sign flag. Processing stops when a NUL or any other character out of range
for a digit in the given radix is encountered.
If the whole string was consumed, `MP_OK` is returned; otherwise
`MP_TRUNC`. is returned.
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_int_read_string(mp_int z, mp_size radix, const char *str);
/** Reads a string of ASCII digits in the specified `radix` from the zero
terminated `str` provided into `z`. For values of `radix > 10`, the letters
`A`..`Z` or `a`..`z` are accepted. Letters are interpreted without respect
to case.
Leading whitespace is ignored, and a leading `+` or `-` is interpreted as a
sign flag. Processing stops when a NUL or any other character out of range
for a digit in the given radix is encountered.
If the whole string was consumed, `MP_OK` is returned; otherwise
`MP_TRUNC`. is returned. If `end` is not NULL, `*end` is set to point to
the first unconsumed byte of the input string (the NUL byte if the whole
string was consumed). This emulates the behavior of the standard C
`strtol()` function.
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_int_read_cstring(mp_int z, mp_size radix, const char *str, char **end);
/** Returns the number of significant bits in `z`. */
mp_result mp_int_count_bits(mp_int z);
/* Convert z to two's complement binary, writing at most limit bytes */
/** Converts `z` to 2's complement binary, writing at most `limit` bytes into
the given `buf`. Returns `MP_TRUNC` if the buffer limit was too small to
contain the whole value. If this occurs, the contents of buf will be
effectively garbage, as the function uses the buffer as scratch space.
The binary representation of `z` is in base-256 with digits ordered from
most significant to least significant (network byte ordering). The
high-order bit of the first byte is set for negative values, clear for
non-negative values.
As a result, non-negative values will be padded with a leading zero byte if
the high-order byte of the base-256 magnitude is set. This extra byte is
accounted for by the `mp_int_binary_len()` function. */
mp_result mp_int_to_binary(mp_int z, unsigned char *buf, int limit);
/* Read a two's complement binary value into z from the given buffer */
/** Reads a 2's complement binary value from `buf` into `z`, where `len` is the
length of the buffer. The contents of `buf` may be overwritten during
processing, although they will be restored when the function returns. */
mp_result mp_int_read_binary(mp_int z, unsigned char *buf, int len);
/* Return the number of bytes required to represent z in binary. */
/** Returns the number of bytes to represent `z` in 2's complement binary. */
mp_result mp_int_binary_len(mp_int z);
/* Convert z to unsigned binary, writing at most limit bytes */
/** Converts the magnitude of `z` to unsigned binary, writing at most `limit`
bytes into the given `buf`. The sign of `z` is ignored, but `z` is not
modified. Returns `MP_TRUNC` if the buffer limit was too small to contain
the whole value. If this occurs, the contents of `buf` will be effectively
garbage, as the function uses the buffer as scratch space during
conversion.
The binary representation of `z` is in base-256 with digits ordered from
most significant to least significant (network byte ordering). */
mp_result mp_int_to_unsigned(mp_int z, unsigned char *buf, int limit);
/* Read an unsigned binary value into z from the given buffer */
/** Reads an unsigned binary value from `buf` into `z`, where `len` is the
length of the buffer. The contents of `buf` are not modified during
processing. */
mp_result mp_int_read_unsigned(mp_int z, unsigned char *buf, int len);
/* Return the number of bytes required to represent z as unsigned output */
/** Returns the number of bytes required to represent `z` as an unsigned binary
value in base 256. */
mp_result mp_int_unsigned_len(mp_int z);
/* Return a statically allocated string describing error code res */
/** Returns a pointer to a brief, human-readable, zero-terminated string
describing `res`. The returned string is statically allocated and must not
be freed by the caller. */
const char *mp_error_string(mp_result res);
#if DEBUG
void s_print(char *tag, mp_int z);
void s_print_buf(char *tag, mp_digit *buf, mp_size num);
#endif
#ifdef __cplusplus
}
#endif

File diff suppressed because it is too large Load Diff

View File

@ -1,7 +1,7 @@
/*
Name: imrat.h
Purpose: Arbitrary precision rational arithmetic routines.
Author: M. J. Fromberger <http://spinning-yarns.org/michael/>
Author: M. J. Fromberger
Copyright (C) 2002-2007 Michael J. Fromberger, All Rights Reserved.
@ -27,19 +27,24 @@
#ifndef IMRAT_H_
#define IMRAT_H_
#include <stdbool.h>
#include "imath.h"
#ifdef __cplusplus
extern "C" {
#endif
typedef struct mpq {
typedef struct {
mpz_t num; /* Numerator */
mpz_t den; /* Denominator, <> 0 */
} mpq_t, *mp_rat;
#define MP_NUMER_P(Q) (&((Q)->num)) /* Pointer to numerator */
#define MP_DENOM_P(Q) (&((Q)->den)) /* Pointer to denominator */
/* Return a pointer to the numerator. */
static inline mp_int MP_NUMER_P(mp_rat Q) { return &(Q->num); }
/* Return a pointer to the denominator. */
static inline mp_int MP_DENOM_P(mp_rat Q) { return &(Q->den); }
/* Rounding constants */
typedef enum {
@ -49,72 +54,213 @@ typedef enum {
MP_ROUND_HALF_DOWN
} mp_round_mode;
/** Initializes `r` with 1-digit precision and sets it to zero. This function
cannot fail unless `r` is NULL. */
mp_result mp_rat_init(mp_rat r);
mp_rat mp_rat_alloc(void);
/** Allocates a fresh zero-valued `mpq_t` on the heap, returning NULL in case
of error. The only possible error is out-of-memory. */
mp_rat mp_rat_alloc(void);
/** Reduces `r` in-place to lowest terms and canonical form.
Zero is represented as 0/1, one as 1/1, and signs are adjusted so that the
sign of the value is carried by the numerator. */
mp_result mp_rat_reduce(mp_rat r);
/** Initializes `r` with at least `n_prec` digits of storage for the numerator
and `d_prec` digits of storage for the denominator, and value zero.
If either precision is zero, the default precision is used, rounded up to
the nearest word size. */
mp_result mp_rat_init_size(mp_rat r, mp_size n_prec, mp_size d_prec);
/** Initializes `r` to be a copy of an already-initialized value in `old`. The
new copy does not share storage with the original. */
mp_result mp_rat_init_copy(mp_rat r, mp_rat old);
/** Sets the value of `r` to the ratio of signed `numer` to signed `denom`. It
returns `MP_UNDEF` if `denom` is zero. */
mp_result mp_rat_set_value(mp_rat r, mp_small numer, mp_small denom);
/** Sets the value of `r` to the ratio of unsigned `numer` to unsigned
`denom`. It returns `MP_UNDEF` if `denom` is zero. */
mp_result mp_rat_set_uvalue(mp_rat r, mp_usmall numer, mp_usmall denom);
void mp_rat_clear(mp_rat r);
void mp_rat_free(mp_rat r);
mp_result mp_rat_numer(mp_rat r, mp_int z); /* z = num(r) */
mp_int mp_rat_numer_ref(mp_rat r); /* &num(r) */
mp_result mp_rat_denom(mp_rat r, mp_int z); /* z = den(r) */
mp_int mp_rat_denom_ref(mp_rat r); /* &den(r) */
mp_sign mp_rat_sign(mp_rat r);
mp_result mp_rat_copy(mp_rat a, mp_rat c); /* c = a */
void mp_rat_zero(mp_rat r); /* r = 0 */
mp_result mp_rat_abs(mp_rat a, mp_rat c); /* c = |a| */
mp_result mp_rat_neg(mp_rat a, mp_rat c); /* c = -a */
mp_result mp_rat_recip(mp_rat a, mp_rat c); /* c = 1 / a */
mp_result mp_rat_add(mp_rat a, mp_rat b, mp_rat c); /* c = a + b */
mp_result mp_rat_sub(mp_rat a, mp_rat b, mp_rat c); /* c = a - b */
mp_result mp_rat_mul(mp_rat a, mp_rat b, mp_rat c); /* c = a * b */
mp_result mp_rat_div(mp_rat a, mp_rat b, mp_rat c); /* c = a / b */
/** Releases the storage used by `r`. */
void mp_rat_clear(mp_rat r);
mp_result mp_rat_add_int(mp_rat a, mp_int b, mp_rat c); /* c = a + b */
mp_result mp_rat_sub_int(mp_rat a, mp_int b, mp_rat c); /* c = a - b */
mp_result mp_rat_mul_int(mp_rat a, mp_int b, mp_rat c); /* c = a * b */
mp_result mp_rat_div_int(mp_rat a, mp_int b, mp_rat c); /* c = a / b */
mp_result mp_rat_expt(mp_rat a, mp_small b, mp_rat c); /* c = a ^ b */
/** Releases the storage used by `r` and also `r` itself.
This should only be used for `r` allocated by `mp_rat_alloc()`. */
void mp_rat_free(mp_rat r);
int mp_rat_compare(mp_rat a, mp_rat b); /* a <=> b */
int mp_rat_compare_unsigned(mp_rat a, mp_rat b); /* |a| <=> |b| */
int mp_rat_compare_zero(mp_rat r); /* r <=> 0 */
int mp_rat_compare_value(mp_rat r, mp_small n, mp_small d); /* r <=> n/d */
int mp_rat_is_integer(mp_rat r);
/** Sets `z` to a copy of the numerator of `r`. */
mp_result mp_rat_numer(mp_rat r, mp_int z);
/* Convert to integers, if representable (returns MP_RANGE if not). */
/** Returns a pointer to the numerator of `r`. */
mp_int mp_rat_numer_ref(mp_rat r);
/** Sets `z` to a copy of the denominator of `r`. */
mp_result mp_rat_denom(mp_rat r, mp_int z);
/** Returns a pointer to the denominator of `r`. */
mp_int mp_rat_denom_ref(mp_rat r);
/** Reports the sign of `r`. */
mp_sign mp_rat_sign(mp_rat r);
/** Sets `c` to a copy of the value of `a`. No new memory is allocated unless a
term of `a` has more significant digits than the corresponding term of `c`
has allocated. */
mp_result mp_rat_copy(mp_rat a, mp_rat c);
/** Sets `r` to zero. The allocated storage of `r` is not changed. */
void mp_rat_zero(mp_rat r);
/** Sets `c` to the absolute value of `a`. */
mp_result mp_rat_abs(mp_rat a, mp_rat c);
/** Sets `c` to the absolute value of `a`. */
mp_result mp_rat_neg(mp_rat a, mp_rat c);
/** Sets `c` to the reciprocal of `a` if the reciprocal is defined.
It returns `MP_UNDEF` if `a` is zero. */
mp_result mp_rat_recip(mp_rat a, mp_rat c);
/** Sets `c` to the sum of `a` and `b`. */
mp_result mp_rat_add(mp_rat a, mp_rat b, mp_rat c);
/** Sets `c` to the difference of `a` less `b`. */
mp_result mp_rat_sub(mp_rat a, mp_rat b, mp_rat c);
/** Sets `c` to the product of `a` and `b`. */
mp_result mp_rat_mul(mp_rat a, mp_rat b, mp_rat c);
/** Sets `c` to the ratio `a / b` if that ratio is defined.
It returns `MP_UNDEF` if `b` is zero. */
mp_result mp_rat_div(mp_rat a, mp_rat b, mp_rat c);
/** Sets `c` to the sum of `a` and integer `b`. */
mp_result mp_rat_add_int(mp_rat a, mp_int b, mp_rat c);
/** Sets `c` to the difference of `a` less integer `b`. */
mp_result mp_rat_sub_int(mp_rat a, mp_int b, mp_rat c);
/** Sets `c` to the product of `a` and integer `b`. */
mp_result mp_rat_mul_int(mp_rat a, mp_int b, mp_rat c);
/** Sets `c` to the ratio `a / b` if that ratio is defined.
It returns `MP_UNDEF` if `b` is zero. */
mp_result mp_rat_div_int(mp_rat a, mp_int b, mp_rat c);
/** Sets `c` to the value of `a` raised to the `b` power.
It returns `MP_RANGE` if `b < 0`. */
mp_result mp_rat_expt(mp_rat a, mp_small b, mp_rat c);
/** Returns the comparator of `a` and `b`. */
int mp_rat_compare(mp_rat a, mp_rat b);
/** Returns the comparator of the magnitudes of `a` and `b`, disregarding their
signs. Neither `a` nor `b` is modified by the comparison. */
int mp_rat_compare_unsigned(mp_rat a, mp_rat b);
/** Returns the comparator of `r` and zero. */
int mp_rat_compare_zero(mp_rat r);
/** Returns the comparator of `r` and the signed ratio `n / d`.
It returns `MP_UNDEF` if `d` is zero. */
int mp_rat_compare_value(mp_rat r, mp_small n, mp_small d);
/** Reports whether `r` is an integer, having canonical denominator 1. */
bool mp_rat_is_integer(mp_rat r);
/** Reports whether the numerator and denominator of `r` can be represented as
small signed integers, and if so stores the corresponding values to `num`
and `den`. It returns `MP_RANGE` if either cannot be so represented. */
mp_result mp_rat_to_ints(mp_rat r, mp_small *num, mp_small *den);
/* Convert to nul-terminated string with the specified radix, writing
at most limit characters including the nul terminator. */
/** Converts `r` to a zero-terminated string of the format `"n/d"` with `n` and
`d` in the specified radix and writing no more than `limit` bytes to the
given output buffer `str`. The output of the numerator includes a sign flag
if `r` is negative. Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_rat_to_string(mp_rat r, mp_size radix, char *str, int limit);
/* Convert to decimal format in the specified radix and precision,
writing at most limit characters including a nul terminator. */
/** Converts the value of `r` to a string in decimal-point notation with the
specified radix, writing no more than `limit` bytes of data to the given
output buffer. It generates `prec` digits of precision, and requires
`MP_MIN_RADIX <= radix <= MP_MAX_RADIX`.
Ratios usually must be rounded when they are being converted for output as
a decimal value. There are four rounding modes currently supported:
MP_ROUND_DOWN
Truncates the value toward zero.
Example: 12.009 to 2dp becomes 12.00
MP_ROUND_UP
Rounds the value away from zero:
Example: 12.001 to 2dp becomes 12.01, but
12.000 to 2dp remains 12.00
MP_ROUND_HALF_DOWN
Rounds the value to nearest digit, half goes toward zero.
Example: 12.005 to 2dp becomes 12.00, but
12.006 to 2dp becomes 12.01
MP_ROUND_HALF_UP
Rounds the value to nearest digit, half rounds upward.
Example: 12.005 to 2dp becomes 12.01, but
12.004 to 2dp becomes 12.00
*/
mp_result mp_rat_to_decimal(mp_rat r, mp_size radix, mp_size prec,
mp_round_mode round, char *str, int limit);
/* Return the number of characters required to represent r in the given
radix. May over-estimate. */
/** Reports the minimum number of characters required to represent `r` as a
zero-terminated string in the given `radix`.
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
mp_result mp_rat_string_len(mp_rat r, mp_size radix);
/* Return the number of characters required to represent r in decimal
format with the given radix and precision. May over-estimate. */
/** Reports the length in bytes of the buffer needed to convert `r` using the
`mp_rat_to_decimal()` function with the specified `radix` and `prec`. The
buffer size estimate may slightly exceed the actual required capacity. */
mp_result mp_rat_decimal_len(mp_rat r, mp_size radix, mp_size prec);
/* Read zero-terminated string into r */
/** Sets `r` to the value represented by a zero-terminated string `str` in the
format `"n/d"` including a sign flag. It returns `MP_UNDEF` if the encoded
denominator has value zero. */
mp_result mp_rat_read_string(mp_rat r, mp_size radix, const char *str);
/** Sets `r` to the value represented by a zero-terminated string `str` in the
format `"n/d"` including a sign flag. It returns `MP_UNDEF` if the encoded
denominator has value zero. If `end` is not NULL then `*end` is set to
point to the first unconsumed character in the string, after parsing.
*/
mp_result mp_rat_read_cstring(mp_rat r, mp_size radix, const char *str,
char **end);
/** Sets `r` to the value represented by a zero-terminated string `str` having
one of the following formats, each with an optional leading sign flag:
n : integer format, e.g. "123"
n/d : ratio format, e.g., "-12/5"
z.ffff : decimal format, e.g., "1.627"
It returns `MP_UNDEF` if the effective denominator is zero. If `end` is not
NULL then `*end` is set to point to the first unconsumed character in the
string, after parsing.
*/
mp_result mp_rat_read_ustring(mp_rat r, mp_size radix, const char *str,
char **end);
/* Read zero-terminated string in decimal format into r */
/** Sets `r` to the value represented by a zero-terminated string `str` in the
format `"z.ffff"` including a sign flag. It returns `MP_UNDEF` if the
effective denominator. */
mp_result mp_rat_read_decimal(mp_rat r, mp_size radix, const char *str);
/** Sets `r` to the value represented by a zero-terminated string `str` in the
format `"z.ffff"` including a sign flag. It returns `MP_UNDEF` if the
effective denominator. If `end` is not NULL then `*end` is set to point to
the first unconsumed character in the string, after parsing. */
mp_result mp_rat_read_cdecimal(mp_rat r, mp_size radix, const char *str,
char **end);

View File

@ -26,6 +26,7 @@ __isl_give isl_aff *isl_aff_val_on_domain(__isl_take isl_local_space *ls,
__isl_take isl_val *val);
__isl_give isl_aff *isl_aff_var_on_domain(__isl_take isl_local_space *ls,
enum isl_dim_type type, unsigned pos);
__isl_give isl_aff *isl_aff_nan_on_domain_space(__isl_take isl_space *space);
__isl_give isl_aff *isl_aff_nan_on_domain(__isl_take isl_local_space *ls);
__isl_give isl_aff *isl_aff_param_on_domain_space_id(
__isl_take isl_space *space, __isl_take isl_id *id);
@ -50,6 +51,7 @@ __isl_give isl_local_space *isl_aff_get_local_space(__isl_keep isl_aff *aff);
const char *isl_aff_get_dim_name(__isl_keep isl_aff *aff,
enum isl_dim_type type, unsigned pos);
__isl_export
__isl_give isl_val *isl_aff_get_constant_val(__isl_keep isl_aff *aff);
__isl_give isl_val *isl_aff_get_coefficient_val(__isl_keep isl_aff *aff,
enum isl_dim_type type, int pos);
@ -73,6 +75,7 @@ __isl_give isl_aff *isl_aff_add_coefficient_si(__isl_take isl_aff *aff,
__isl_give isl_aff *isl_aff_add_coefficient_val(__isl_take isl_aff *aff,
enum isl_dim_type type, int pos, __isl_take isl_val *v);
__isl_export
isl_bool isl_aff_is_cst(__isl_keep isl_aff *aff);
__isl_give isl_aff *isl_aff_set_tuple_id(__isl_take isl_aff *aff,
@ -215,6 +218,8 @@ __isl_give isl_pw_aff *isl_pw_aff_zero_on_domain(
__isl_take isl_local_space *ls);
__isl_give isl_pw_aff *isl_pw_aff_var_on_domain(__isl_take isl_local_space *ls,
enum isl_dim_type type, unsigned pos);
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
__isl_take isl_space *space);
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain(__isl_take isl_local_space *ls);
__isl_give isl_pw_aff *isl_pw_aff_val_on_domain(__isl_take isl_set *domain,
__isl_take isl_val *v);
@ -561,6 +566,9 @@ ISL_DECLARE_MULTI_UNBIND_PARAMS(pw_aff)
__isl_export
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_zero(__isl_take isl_space *space);
__isl_overload
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity_on_domain_space(
__isl_take isl_space *space);
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
__isl_take isl_space *space);
__isl_export
@ -752,6 +760,10 @@ __isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_multi_aff(
__isl_overload
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_pw_multi_aff(
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
__isl_overload
__isl_give isl_pw_multi_aff *
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
__isl_export
isl_size isl_pw_multi_aff_n_piece(__isl_keep isl_pw_multi_aff *pma);
@ -871,6 +883,11 @@ __isl_give isl_union_pw_multi_aff *
isl_union_pw_multi_aff_apply_union_pw_multi_aff(
__isl_take isl_union_pw_multi_aff *upma1,
__isl_take isl_union_pw_multi_aff *upma2);
__isl_overload
__isl_give isl_union_pw_multi_aff *
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
__isl_take isl_union_pw_multi_aff *upma1,
__isl_take isl_union_pw_multi_aff *upma2);
__isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_align_params(
__isl_take isl_union_pw_multi_aff *upma, __isl_take isl_space *model);

View File

@ -328,8 +328,11 @@ public:
inline isl::checked::val eval(isl::checked::point pnt) const;
inline isl::checked::aff floor() const;
inline isl::checked::set ge_set(isl::checked::aff aff2) const;
inline isl::checked::val constant_val() const;
inline isl::checked::val get_constant_val() const;
inline isl::checked::aff gist(isl::checked::set context) const;
inline isl::checked::set gt_set(isl::checked::aff aff2) const;
inline boolean is_cst() const;
inline isl::checked::set le_set(isl::checked::aff aff2) const;
inline isl::checked::set lt_set(isl::checked::aff aff2) const;
inline isl::checked::aff mod(isl::checked::val mod) const;
@ -1491,8 +1494,12 @@ public:
inline isl::checked::map gist_domain(isl::checked::set context) const;
inline isl::checked::map intersect(isl::checked::map map2) const;
inline isl::checked::map intersect_domain(isl::checked::set set) const;
inline isl::checked::map intersect_domain_factor_domain(isl::checked::map factor) const;
inline isl::checked::map intersect_domain_factor_range(isl::checked::map factor) const;
inline isl::checked::map intersect_params(isl::checked::set params) const;
inline isl::checked::map intersect_range(isl::checked::set set) const;
inline isl::checked::map intersect_range_factor_domain(isl::checked::map factor) const;
inline isl::checked::map intersect_range_factor_range(isl::checked::map factor) const;
inline boolean is_bijective() const;
inline boolean is_disjoint(const isl::checked::map &map2) const;
inline boolean is_empty() const;
@ -1510,7 +1517,6 @@ public:
inline isl::checked::map lexmin() const;
inline isl::checked::pw_multi_aff lexmin_pw_multi_aff() const;
inline isl::checked::map lower_bound(isl::checked::multi_pw_aff lower) const;
inline isl::checked::map lower_bound(isl::checked::multi_val lower) const;
inline isl::checked::multi_pw_aff max_multi_pw_aff() const;
inline isl::checked::multi_pw_aff min_multi_pw_aff() const;
inline isl::checked::basic_map polyhedral_hull() const;
@ -1519,6 +1525,7 @@ public:
inline isl::checked::map preimage_domain(isl::checked::pw_multi_aff pma) const;
inline isl::checked::map preimage_range(isl::checked::multi_aff ma) const;
inline isl::checked::map preimage_range(isl::checked::pw_multi_aff pma) const;
inline isl::checked::map product(isl::checked::map map2) const;
inline isl::checked::map project_out_all_params() const;
inline isl::checked::set range() const;
inline isl::checked::map range_factor_domain() const;
@ -1533,8 +1540,8 @@ public:
static inline isl::checked::map universe(isl::checked::space space);
inline isl::checked::basic_map unshifted_simple_hull() const;
inline isl::checked::map upper_bound(isl::checked::multi_pw_aff upper) const;
inline isl::checked::map upper_bound(isl::checked::multi_val upper) const;
inline isl::checked::set wrap() const;
inline isl::checked::map zip() const;
};
// declarations for isl::multi_aff
@ -1588,6 +1595,7 @@ public:
static inline isl::checked::multi_aff identity_on_domain(isl::checked::space space);
inline isl::checked::multi_aff insert_domain(isl::checked::space domain) const;
inline boolean involves_locals() const;
inline boolean involves_nan() const;
inline isl::checked::multi_aff neg() const;
inline boolean plain_is_equal(const isl::checked::multi_aff &multi2) const;
inline isl::checked::multi_aff product(isl::checked::multi_aff multi2) const;
@ -1701,6 +1709,7 @@ public:
inline isl::checked::multi_pw_aff insert_domain(isl::checked::space domain) const;
inline isl::checked::multi_pw_aff intersect_domain(isl::checked::set domain) const;
inline isl::checked::multi_pw_aff intersect_params(isl::checked::set set) const;
inline boolean involves_nan() const;
inline boolean involves_param(const isl::checked::id &id) const;
inline boolean involves_param(const std::string &id) const;
inline boolean involves_param(const isl::checked::id_list &list) const;
@ -1772,6 +1781,7 @@ public:
inline isl::checked::multi_union_pw_aff gist(isl::checked::union_set context) const;
inline isl::checked::multi_union_pw_aff intersect_domain(isl::checked::union_set uset) const;
inline isl::checked::multi_union_pw_aff intersect_params(isl::checked::set params) const;
inline boolean involves_nan() const;
inline isl::checked::multi_union_pw_aff neg() const;
inline boolean plain_is_equal(const isl::checked::multi_union_pw_aff &multi2) const;
inline isl::checked::multi_union_pw_aff pullback(isl::checked::union_pw_multi_aff upma) const;
@ -1826,6 +1836,7 @@ public:
inline isl::checked::val_list get_list() const;
inline isl::checked::space space() const;
inline isl::checked::space get_space() const;
inline boolean involves_nan() const;
inline isl::checked::multi_val max(isl::checked::multi_val multi2) const;
inline isl::checked::multi_val min(isl::checked::multi_val multi2) const;
inline isl::checked::multi_val neg() const;
@ -2029,6 +2040,7 @@ public:
inline isl::checked::space space() const;
inline isl::checked::space get_space() const;
inline isl::checked::pw_multi_aff gist(isl::checked::set set) const;
static inline isl::checked::pw_multi_aff identity_on_domain(isl::checked::space space);
inline isl::checked::pw_multi_aff insert_domain(isl::checked::space domain) const;
inline isl::checked::pw_multi_aff intersect_domain(isl::checked::set set) const;
inline isl::checked::pw_multi_aff intersect_params(isl::checked::set set) const;
@ -2037,6 +2049,7 @@ public:
inline isl::checked::multi_val max_multi_val() const;
inline isl::checked::multi_val min_multi_val() const;
inline class size n_piece() const;
inline isl::checked::pw_multi_aff preimage_domain_wrapped_domain(isl::checked::pw_multi_aff pma2) const;
inline isl::checked::pw_multi_aff product(isl::checked::pw_multi_aff pma2) const;
inline isl::checked::pw_multi_aff pullback(isl::checked::multi_aff ma) const;
inline isl::checked::pw_multi_aff pullback(isl::checked::pw_multi_aff pma2) const;
@ -2119,6 +2132,8 @@ public:
inline isl::checked::ctx ctx() const;
static inline isl::checked::schedule from_domain(isl::checked::union_set domain);
inline isl::checked::union_set domain() const;
inline isl::checked::union_set get_domain() const;
inline isl::checked::union_map map() const;
inline isl::checked::union_map get_map() const;
inline isl::checked::schedule_node root() const;
@ -2590,6 +2605,7 @@ public:
inline isl::checked::basic_set sample() const;
inline isl::checked::point sample_point() const;
inline isl::checked::set subtract(isl::checked::set set2) const;
inline isl::checked::map translation() const;
inline isl::checked::set unbind_params(isl::checked::multi_id tuple) const;
inline isl::checked::map unbind_params_insert_domain(isl::checked::multi_id domain) const;
inline isl::checked::set unite(isl::checked::set set2) const;
@ -2628,6 +2644,7 @@ public:
inline isl::checked::space add_named_tuple(isl::checked::id tuple_id, unsigned int dim) const;
inline isl::checked::space add_named_tuple(const std::string &tuple_id, unsigned int dim) const;
inline isl::checked::space add_unnamed_tuple(unsigned int dim) const;
inline isl::checked::space curry() const;
inline isl::checked::space domain() const;
inline isl::checked::space flatten_domain() const;
inline isl::checked::space flatten_range() const;
@ -2635,7 +2652,11 @@ public:
inline boolean is_wrapping() const;
inline isl::checked::space map_from_set() const;
inline isl::checked::space params() const;
inline isl::checked::space product(isl::checked::space right) const;
inline isl::checked::space range() const;
inline isl::checked::space range_reverse() const;
inline isl::checked::space reverse() const;
inline isl::checked::space uncurry() const;
static inline isl::checked::space unit(isl::checked::ctx ctx);
inline isl::checked::space unwrap() const;
inline isl::checked::space wrap() const;
@ -2780,9 +2801,13 @@ public:
inline isl::checked::union_map intersect(isl::checked::union_map umap2) const;
inline isl::checked::union_map intersect_domain(isl::checked::space space) const;
inline isl::checked::union_map intersect_domain(isl::checked::union_set uset) const;
inline isl::checked::union_map intersect_domain_factor_domain(isl::checked::union_map factor) const;
inline isl::checked::union_map intersect_domain_factor_range(isl::checked::union_map factor) const;
inline isl::checked::union_map intersect_params(isl::checked::set set) const;
inline isl::checked::union_map intersect_range(isl::checked::space space) const;
inline isl::checked::union_map intersect_range(isl::checked::union_set uset) const;
inline isl::checked::union_map intersect_range_factor_domain(isl::checked::union_map factor) const;
inline isl::checked::union_map intersect_range_factor_range(isl::checked::union_map factor) const;
inline boolean is_bijective() const;
inline boolean is_disjoint(const isl::checked::union_map &umap2) const;
inline boolean is_empty() const;
@ -2955,6 +2980,7 @@ public:
inline boolean involves_locals() const;
inline boolean isa_pw_multi_aff() const;
inline boolean plain_is_empty() const;
inline isl::checked::union_pw_multi_aff preimage_domain_wrapped_domain(isl::checked::union_pw_multi_aff upma2) const;
inline isl::checked::union_pw_multi_aff pullback(isl::checked::union_pw_multi_aff upma2) const;
inline isl::checked::union_pw_multi_aff range_factor_domain() const;
inline isl::checked::union_pw_multi_aff range_factor_range() const;
@ -3323,6 +3349,17 @@ isl::checked::set aff::ge_set(isl::checked::aff aff2) const
return manage(res);
}
isl::checked::val aff::constant_val() const
{
auto res = isl_aff_get_constant_val(get());
return manage(res);
}
isl::checked::val aff::get_constant_val() const
{
return constant_val();
}
isl::checked::aff aff::gist(isl::checked::set context) const
{
auto res = isl_aff_gist(copy(), context.release());
@ -3335,6 +3372,12 @@ isl::checked::set aff::gt_set(isl::checked::aff aff2) const
return manage(res);
}
boolean aff::is_cst() const
{
auto res = isl_aff_is_cst(get());
return manage(res);
}
isl::checked::set aff::le_set(isl::checked::aff aff2) const
{
auto res = isl_aff_le_set(copy(), aff2.release());
@ -6343,6 +6386,18 @@ isl::checked::map map::intersect_domain(isl::checked::set set) const
return manage(res);
}
isl::checked::map map::intersect_domain_factor_domain(isl::checked::map factor) const
{
auto res = isl_map_intersect_domain_factor_domain(copy(), factor.release());
return manage(res);
}
isl::checked::map map::intersect_domain_factor_range(isl::checked::map factor) const
{
auto res = isl_map_intersect_domain_factor_range(copy(), factor.release());
return manage(res);
}
isl::checked::map map::intersect_params(isl::checked::set params) const
{
auto res = isl_map_intersect_params(copy(), params.release());
@ -6355,6 +6410,18 @@ isl::checked::map map::intersect_range(isl::checked::set set) const
return manage(res);
}
isl::checked::map map::intersect_range_factor_domain(isl::checked::map factor) const
{
auto res = isl_map_intersect_range_factor_domain(copy(), factor.release());
return manage(res);
}
isl::checked::map map::intersect_range_factor_range(isl::checked::map factor) const
{
auto res = isl_map_intersect_range_factor_range(copy(), factor.release());
return manage(res);
}
boolean map::is_bijective() const
{
auto res = isl_map_is_bijective(get());
@ -6457,12 +6524,6 @@ isl::checked::map map::lower_bound(isl::checked::multi_pw_aff lower) const
return manage(res);
}
isl::checked::map map::lower_bound(isl::checked::multi_val lower) const
{
auto res = isl_map_lower_bound_multi_val(copy(), lower.release());
return manage(res);
}
isl::checked::multi_pw_aff map::max_multi_pw_aff() const
{
auto res = isl_map_max_multi_pw_aff(copy());
@ -6511,6 +6572,12 @@ isl::checked::map map::preimage_range(isl::checked::pw_multi_aff pma) const
return manage(res);
}
isl::checked::map map::product(isl::checked::map map2) const
{
auto res = isl_map_product(copy(), map2.release());
return manage(res);
}
isl::checked::map map::project_out_all_params() const
{
auto res = isl_map_project_out_all_params(copy());
@ -6595,18 +6662,18 @@ isl::checked::map map::upper_bound(isl::checked::multi_pw_aff upper) const
return manage(res);
}
isl::checked::map map::upper_bound(isl::checked::multi_val upper) const
{
auto res = isl_map_upper_bound_multi_val(copy(), upper.release());
return manage(res);
}
isl::checked::set map::wrap() const
{
auto res = isl_map_wrap(copy());
return manage(res);
}
isl::checked::map map::zip() const
{
auto res = isl_map_zip(copy());
return manage(res);
}
inline std::ostream &operator<<(std::ostream &os, const map &obj)
{
char *str = isl_map_to_str(obj.get());
@ -6823,6 +6890,12 @@ boolean multi_aff::involves_locals() const
return manage(res);
}
boolean multi_aff::involves_nan() const
{
auto res = isl_multi_aff_involves_nan(get());
return manage(res);
}
isl::checked::multi_aff multi_aff::neg() const
{
auto res = isl_multi_aff_neg(copy());
@ -7297,6 +7370,12 @@ isl::checked::multi_pw_aff multi_pw_aff::intersect_params(isl::checked::set set)
return manage(res);
}
boolean multi_pw_aff::involves_nan() const
{
auto res = isl_multi_pw_aff_involves_nan(get());
return manage(res);
}
boolean multi_pw_aff::involves_param(const isl::checked::id &id) const
{
auto res = isl_multi_pw_aff_involves_param_id(get(), id.get());
@ -7620,6 +7699,12 @@ isl::checked::multi_union_pw_aff multi_union_pw_aff::intersect_params(isl::check
return manage(res);
}
boolean multi_union_pw_aff::involves_nan() const
{
auto res = isl_multi_union_pw_aff_involves_nan(get());
return manage(res);
}
isl::checked::multi_union_pw_aff multi_union_pw_aff::neg() const
{
auto res = isl_multi_union_pw_aff_neg(copy());
@ -7841,6 +7926,12 @@ isl::checked::space multi_val::get_space() const
return space();
}
boolean multi_val::involves_nan() const
{
auto res = isl_multi_val_involves_nan(get());
return manage(res);
}
isl::checked::multi_val multi_val::max(isl::checked::multi_val multi2) const
{
auto res = isl_multi_val_max(copy(), multi2.release());
@ -8675,6 +8766,12 @@ isl::checked::pw_multi_aff pw_multi_aff::gist(isl::checked::set set) const
return manage(res);
}
isl::checked::pw_multi_aff pw_multi_aff::identity_on_domain(isl::checked::space space)
{
auto res = isl_pw_multi_aff_identity_on_domain_space(space.release());
return manage(res);
}
isl::checked::pw_multi_aff pw_multi_aff::insert_domain(isl::checked::space domain) const
{
auto res = isl_pw_multi_aff_insert_domain(copy(), domain.release());
@ -8723,6 +8820,12 @@ class size pw_multi_aff::n_piece() const
return manage(res);
}
isl::checked::pw_multi_aff pw_multi_aff::preimage_domain_wrapped_domain(isl::checked::pw_multi_aff pma2) const
{
auto res = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(copy(), pma2.release());
return manage(res);
}
isl::checked::pw_multi_aff pw_multi_aff::product(isl::checked::pw_multi_aff pma2) const
{
auto res = isl_pw_multi_aff_product(copy(), pma2.release());
@ -9026,6 +9129,17 @@ isl::checked::schedule schedule::from_domain(isl::checked::union_set domain)
return manage(res);
}
isl::checked::union_set schedule::domain() const
{
auto res = isl_schedule_get_domain(get());
return manage(res);
}
isl::checked::union_set schedule::get_domain() const
{
return domain();
}
isl::checked::union_map schedule::map() const
{
auto res = isl_schedule_get_map(get());
@ -9783,28 +9897,24 @@ schedule_node_band schedule_node_band::tile(isl::checked::multi_val sizes) const
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) const
{
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_default);
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
{
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_atomic);
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
{
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_unroll);
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_separate(int pos) const
{
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_separate);
@ -10654,6 +10764,12 @@ isl::checked::set set::subtract(isl::checked::set set2) const
return manage(res);
}
isl::checked::map set::translation() const
{
auto res = isl_set_translation(copy());
return manage(res);
}
isl::checked::set set::unbind_params(isl::checked::multi_id tuple) const
{
auto res = isl_set_unbind_params(copy(), tuple.release());
@ -10784,6 +10900,12 @@ isl::checked::space space::add_unnamed_tuple(unsigned int dim) const
return manage(res);
}
isl::checked::space space::curry() const
{
auto res = isl_space_curry(copy());
return manage(res);
}
isl::checked::space space::domain() const
{
auto res = isl_space_domain(copy());
@ -10826,12 +10948,36 @@ isl::checked::space space::params() const
return manage(res);
}
isl::checked::space space::product(isl::checked::space right) const
{
auto res = isl_space_product(copy(), right.release());
return manage(res);
}
isl::checked::space space::range() const
{
auto res = isl_space_range(copy());
return manage(res);
}
isl::checked::space space::range_reverse() const
{
auto res = isl_space_range_reverse(copy());
return manage(res);
}
isl::checked::space space::reverse() const
{
auto res = isl_space_reverse(copy());
return manage(res);
}
isl::checked::space space::uncurry() const
{
auto res = isl_space_uncurry(copy());
return manage(res);
}
isl::checked::space space::unit(isl::checked::ctx ctx)
{
auto res = isl_space_unit(ctx.release());
@ -11413,6 +11559,18 @@ isl::checked::union_map union_map::intersect_domain(isl::checked::union_set uset
return manage(res);
}
isl::checked::union_map union_map::intersect_domain_factor_domain(isl::checked::union_map factor) const
{
auto res = isl_union_map_intersect_domain_factor_domain(copy(), factor.release());
return manage(res);
}
isl::checked::union_map union_map::intersect_domain_factor_range(isl::checked::union_map factor) const
{
auto res = isl_union_map_intersect_domain_factor_range(copy(), factor.release());
return manage(res);
}
isl::checked::union_map union_map::intersect_params(isl::checked::set set) const
{
auto res = isl_union_map_intersect_params(copy(), set.release());
@ -11431,6 +11589,18 @@ isl::checked::union_map union_map::intersect_range(isl::checked::union_set uset)
return manage(res);
}
isl::checked::union_map union_map::intersect_range_factor_domain(isl::checked::union_map factor) const
{
auto res = isl_union_map_intersect_range_factor_domain(copy(), factor.release());
return manage(res);
}
isl::checked::union_map union_map::intersect_range_factor_range(isl::checked::union_map factor) const
{
auto res = isl_union_map_intersect_range_factor_range(copy(), factor.release());
return manage(res);
}
boolean union_map::is_bijective() const
{
auto res = isl_union_map_is_bijective(get());
@ -12176,6 +12346,12 @@ boolean union_pw_multi_aff::plain_is_empty() const
return manage(res);
}
isl::checked::union_pw_multi_aff union_pw_multi_aff::preimage_domain_wrapped_domain(isl::checked::union_pw_multi_aff upma2) const
{
auto res = isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(copy(), upma2.release());
return manage(res);
}
isl::checked::union_pw_multi_aff union_pw_multi_aff::pullback(isl::checked::union_pw_multi_aff upma2) const
{
auto res = isl_union_pw_multi_aff_pullback_union_pw_multi_aff(copy(), upma2.release());

View File

@ -392,8 +392,11 @@ public:
inline isl::val eval(isl::point pnt) const;
inline isl::aff floor() const;
inline isl::set ge_set(isl::aff aff2) const;
inline isl::val constant_val() const;
inline isl::val get_constant_val() const;
inline isl::aff gist(isl::set context) const;
inline isl::set gt_set(isl::aff aff2) const;
inline bool is_cst() const;
inline isl::set le_set(isl::aff aff2) const;
inline isl::set lt_set(isl::aff aff2) const;
inline isl::aff mod(isl::val mod) const;
@ -1556,8 +1559,12 @@ public:
inline isl::map gist_domain(isl::set context) const;
inline isl::map intersect(isl::map map2) const;
inline isl::map intersect_domain(isl::set set) const;
inline isl::map intersect_domain_factor_domain(isl::map factor) const;
inline isl::map intersect_domain_factor_range(isl::map factor) const;
inline isl::map intersect_params(isl::set params) const;
inline isl::map intersect_range(isl::set set) const;
inline isl::map intersect_range_factor_domain(isl::map factor) const;
inline isl::map intersect_range_factor_range(isl::map factor) const;
inline bool is_bijective() const;
inline bool is_disjoint(const isl::map &map2) const;
inline bool is_empty() const;
@ -1575,7 +1582,6 @@ public:
inline isl::map lexmin() const;
inline isl::pw_multi_aff lexmin_pw_multi_aff() const;
inline isl::map lower_bound(isl::multi_pw_aff lower) const;
inline isl::map lower_bound(isl::multi_val lower) const;
inline isl::multi_pw_aff max_multi_pw_aff() const;
inline isl::multi_pw_aff min_multi_pw_aff() const;
inline isl::basic_map polyhedral_hull() const;
@ -1584,6 +1590,7 @@ public:
inline isl::map preimage_domain(isl::pw_multi_aff pma) const;
inline isl::map preimage_range(isl::multi_aff ma) const;
inline isl::map preimage_range(isl::pw_multi_aff pma) const;
inline isl::map product(isl::map map2) const;
inline isl::map project_out_all_params() const;
inline isl::set range() const;
inline isl::map range_factor_domain() const;
@ -1598,8 +1605,8 @@ public:
static inline isl::map universe(isl::space space);
inline isl::basic_map unshifted_simple_hull() const;
inline isl::map upper_bound(isl::multi_pw_aff upper) const;
inline isl::map upper_bound(isl::multi_val upper) const;
inline isl::set wrap() const;
inline isl::map zip() const;
};
// declarations for isl::multi_aff
@ -1653,6 +1660,7 @@ public:
static inline isl::multi_aff identity_on_domain(isl::space space);
inline isl::multi_aff insert_domain(isl::space domain) const;
inline bool involves_locals() const;
inline bool involves_nan() const;
inline isl::multi_aff neg() const;
inline bool plain_is_equal(const isl::multi_aff &multi2) const;
inline isl::multi_aff product(isl::multi_aff multi2) const;
@ -1766,6 +1774,7 @@ public:
inline isl::multi_pw_aff insert_domain(isl::space domain) const;
inline isl::multi_pw_aff intersect_domain(isl::set domain) const;
inline isl::multi_pw_aff intersect_params(isl::set set) const;
inline bool involves_nan() const;
inline bool involves_param(const isl::id &id) const;
inline bool involves_param(const std::string &id) const;
inline bool involves_param(const isl::id_list &list) const;
@ -1837,6 +1846,7 @@ public:
inline isl::multi_union_pw_aff gist(isl::union_set context) const;
inline isl::multi_union_pw_aff intersect_domain(isl::union_set uset) const;
inline isl::multi_union_pw_aff intersect_params(isl::set params) const;
inline bool involves_nan() const;
inline isl::multi_union_pw_aff neg() const;
inline bool plain_is_equal(const isl::multi_union_pw_aff &multi2) const;
inline isl::multi_union_pw_aff pullback(isl::union_pw_multi_aff upma) const;
@ -1891,6 +1901,7 @@ public:
inline isl::val_list get_list() const;
inline isl::space space() const;
inline isl::space get_space() const;
inline bool involves_nan() const;
inline isl::multi_val max(isl::multi_val multi2) const;
inline isl::multi_val min(isl::multi_val multi2) const;
inline isl::multi_val neg() const;
@ -2094,6 +2105,7 @@ public:
inline isl::space space() const;
inline isl::space get_space() const;
inline isl::pw_multi_aff gist(isl::set set) const;
static inline isl::pw_multi_aff identity_on_domain(isl::space space);
inline isl::pw_multi_aff insert_domain(isl::space domain) const;
inline isl::pw_multi_aff intersect_domain(isl::set set) const;
inline isl::pw_multi_aff intersect_params(isl::set set) const;
@ -2102,6 +2114,7 @@ public:
inline isl::multi_val max_multi_val() const;
inline isl::multi_val min_multi_val() const;
inline unsigned n_piece() const;
inline isl::pw_multi_aff preimage_domain_wrapped_domain(isl::pw_multi_aff pma2) const;
inline isl::pw_multi_aff product(isl::pw_multi_aff pma2) const;
inline isl::pw_multi_aff pullback(isl::multi_aff ma) const;
inline isl::pw_multi_aff pullback(isl::pw_multi_aff pma2) const;
@ -2184,6 +2197,8 @@ public:
inline isl::ctx ctx() const;
static inline isl::schedule from_domain(isl::union_set domain);
inline isl::union_set domain() const;
inline isl::union_set get_domain() const;
inline isl::union_map map() const;
inline isl::union_map get_map() const;
inline isl::schedule_node root() const;
@ -2655,6 +2670,7 @@ public:
inline isl::basic_set sample() const;
inline isl::point sample_point() const;
inline isl::set subtract(isl::set set2) const;
inline isl::map translation() const;
inline isl::set unbind_params(isl::multi_id tuple) const;
inline isl::map unbind_params_insert_domain(isl::multi_id domain) const;
inline isl::set unite(isl::set set2) const;
@ -2693,6 +2709,7 @@ public:
inline isl::space add_named_tuple(isl::id tuple_id, unsigned int dim) const;
inline isl::space add_named_tuple(const std::string &tuple_id, unsigned int dim) const;
inline isl::space add_unnamed_tuple(unsigned int dim) const;
inline isl::space curry() const;
inline isl::space domain() const;
inline isl::space flatten_domain() const;
inline isl::space flatten_range() const;
@ -2700,7 +2717,11 @@ public:
inline bool is_wrapping() const;
inline isl::space map_from_set() const;
inline isl::space params() const;
inline isl::space product(isl::space right) const;
inline isl::space range() const;
inline isl::space range_reverse() const;
inline isl::space reverse() const;
inline isl::space uncurry() const;
static inline isl::space unit(isl::ctx ctx);
inline isl::space unwrap() const;
inline isl::space wrap() const;
@ -2845,9 +2866,13 @@ public:
inline isl::union_map intersect(isl::union_map umap2) const;
inline isl::union_map intersect_domain(isl::space space) const;
inline isl::union_map intersect_domain(isl::union_set uset) const;
inline isl::union_map intersect_domain_factor_domain(isl::union_map factor) const;
inline isl::union_map intersect_domain_factor_range(isl::union_map factor) const;
inline isl::union_map intersect_params(isl::set set) const;
inline isl::union_map intersect_range(isl::space space) const;
inline isl::union_map intersect_range(isl::union_set uset) const;
inline isl::union_map intersect_range_factor_domain(isl::union_map factor) const;
inline isl::union_map intersect_range_factor_range(isl::union_map factor) const;
inline bool is_bijective() const;
inline bool is_disjoint(const isl::union_map &umap2) const;
inline bool is_empty() const;
@ -3020,6 +3045,7 @@ public:
inline bool involves_locals() const;
inline bool isa_pw_multi_aff() const;
inline bool plain_is_empty() const;
inline isl::union_pw_multi_aff preimage_domain_wrapped_domain(isl::union_pw_multi_aff upma2) const;
inline isl::union_pw_multi_aff pullback(isl::union_pw_multi_aff upma2) const;
inline isl::union_pw_multi_aff range_factor_domain() const;
inline isl::union_pw_multi_aff range_factor_range() const;
@ -3464,6 +3490,23 @@ isl::set aff::ge_set(isl::aff aff2) const
return manage(res);
}
isl::val aff::constant_val() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_aff_get_constant_val(get());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::val aff::get_constant_val() const
{
return constant_val();
}
isl::aff aff::gist(isl::set context) const
{
if (!ptr || context.is_null())
@ -3488,6 +3531,18 @@ isl::set aff::gt_set(isl::aff aff2) const
return manage(res);
}
bool aff::is_cst() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_aff_is_cst(get());
if (res < 0)
exception::throw_last_error(saved_ctx);
return res;
}
isl::set aff::le_set(isl::aff aff2) const
{
if (!ptr || aff2.is_null())
@ -7714,6 +7769,30 @@ isl::map map::intersect_domain(isl::set set) const
return manage(res);
}
isl::map map::intersect_domain_factor_domain(isl::map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_intersect_domain_factor_domain(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::map map::intersect_domain_factor_range(isl::map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_intersect_domain_factor_range(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::map map::intersect_params(isl::set params) const
{
if (!ptr || params.is_null())
@ -7738,6 +7817,30 @@ isl::map map::intersect_range(isl::set set) const
return manage(res);
}
isl::map map::intersect_range_factor_domain(isl::map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_intersect_range_factor_domain(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::map map::intersect_range_factor_range(isl::map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_intersect_range_factor_range(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
bool map::is_bijective() const
{
if (!ptr)
@ -7942,18 +8045,6 @@ isl::map map::lower_bound(isl::multi_pw_aff lower) const
return manage(res);
}
isl::map map::lower_bound(isl::multi_val lower) const
{
if (!ptr || lower.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_lower_bound_multi_val(copy(), lower.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::multi_pw_aff map::max_multi_pw_aff() const
{
if (!ptr)
@ -8050,6 +8141,18 @@ isl::map map::preimage_range(isl::pw_multi_aff pma) const
return manage(res);
}
isl::map map::product(isl::map map2) const
{
if (!ptr || map2.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_product(copy(), map2.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::map map::project_out_all_params() const
{
if (!ptr)
@ -8218,18 +8321,6 @@ isl::map map::upper_bound(isl::multi_pw_aff upper) const
return manage(res);
}
isl::map map::upper_bound(isl::multi_val upper) const
{
if (!ptr || upper.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_upper_bound_multi_val(copy(), upper.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::set map::wrap() const
{
if (!ptr)
@ -8242,6 +8333,18 @@ isl::set map::wrap() const
return manage(res);
}
isl::map map::zip() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_map_zip(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
inline std::ostream &operator<<(std::ostream &os, const map &obj)
{
if (!obj.get())
@ -8600,6 +8703,18 @@ bool multi_aff::involves_locals() const
return res;
}
bool multi_aff::involves_nan() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_multi_aff_involves_nan(get());
if (res < 0)
exception::throw_last_error(saved_ctx);
return res;
}
isl::multi_aff multi_aff::neg() const
{
if (!ptr)
@ -9404,6 +9519,18 @@ isl::multi_pw_aff multi_pw_aff::intersect_params(isl::set set) const
return manage(res);
}
bool multi_pw_aff::involves_nan() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_multi_pw_aff_involves_nan(get());
if (res < 0)
exception::throw_last_error(saved_ctx);
return res;
}
bool multi_pw_aff::involves_param(const isl::id &id) const
{
if (!ptr || id.is_null())
@ -9975,6 +10102,18 @@ isl::multi_union_pw_aff multi_union_pw_aff::intersect_params(isl::set params) co
return manage(res);
}
bool multi_union_pw_aff::involves_nan() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_multi_union_pw_aff_involves_nan(get());
if (res < 0)
exception::throw_last_error(saved_ctx);
return res;
}
isl::multi_union_pw_aff multi_union_pw_aff::neg() const
{
if (!ptr)
@ -10342,6 +10481,18 @@ isl::space multi_val::get_space() const
return space();
}
bool multi_val::involves_nan() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_multi_val_involves_nan(get());
if (res < 0)
exception::throw_last_error(saved_ctx);
return res;
}
isl::multi_val multi_val::max(isl::multi_val multi2) const
{
if (!ptr || multi2.is_null())
@ -11766,6 +11917,18 @@ isl::pw_multi_aff pw_multi_aff::gist(isl::set set) const
return manage(res);
}
isl::pw_multi_aff pw_multi_aff::identity_on_domain(isl::space space)
{
if (space.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = space.ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_pw_multi_aff_identity_on_domain_space(space.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::pw_multi_aff pw_multi_aff::insert_domain(isl::space domain) const
{
if (!ptr || domain.is_null())
@ -11862,6 +12025,18 @@ unsigned pw_multi_aff::n_piece() const
return res;
}
isl::pw_multi_aff pw_multi_aff::preimage_domain_wrapped_domain(isl::pw_multi_aff pma2) const
{
if (!ptr || pma2.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(copy(), pma2.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::pw_multi_aff pw_multi_aff::product(isl::pw_multi_aff pma2) const
{
if (!ptr || pma2.is_null())
@ -12355,6 +12530,23 @@ isl::schedule schedule::from_domain(isl::union_set domain)
return manage(res);
}
isl::union_set schedule::domain() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_schedule_get_domain(get());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::union_set schedule::get_domain() const
{
return domain();
}
isl::union_map schedule::map() const
{
if (!ptr)
@ -13610,7 +13802,6 @@ schedule_node_band schedule_node_band::tile(isl::multi_val sizes) const
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) const
{
if (!ptr)
@ -13623,7 +13814,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) cons
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
{
if (!ptr)
@ -13636,7 +13826,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
{
if (!ptr)
@ -13649,7 +13838,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
return manage(res).as<schedule_node_band>();
}
schedule_node_band schedule_node_band::member_set_ast_loop_separate(int pos) const
{
if (!ptr)
@ -14929,6 +15117,18 @@ isl::set set::subtract(isl::set set2) const
return manage(res);
}
isl::map set::translation() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_set_translation(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::set set::unbind_params(isl::multi_id tuple) const
{
if (!ptr || tuple.is_null())
@ -15137,6 +15337,18 @@ isl::space space::add_unnamed_tuple(unsigned int dim) const
return manage(res);
}
isl::space space::curry() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_space_curry(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::space space::domain() const
{
if (!ptr)
@ -15221,6 +15433,18 @@ isl::space space::params() const
return manage(res);
}
isl::space space::product(isl::space right) const
{
if (!ptr || right.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_space_product(copy(), right.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::space space::range() const
{
if (!ptr)
@ -15233,6 +15457,42 @@ isl::space space::range() const
return manage(res);
}
isl::space space::range_reverse() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_space_range_reverse(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::space space::reverse() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_space_reverse(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::space space::uncurry() const
{
if (!ptr)
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_space_uncurry(copy());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::space space::unit(isl::ctx ctx)
{
auto saved_ctx = ctx;
@ -16204,6 +16464,30 @@ isl::union_map union_map::intersect_domain(isl::union_set uset) const
return manage(res);
}
isl::union_map union_map::intersect_domain_factor_domain(isl::union_map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_union_map_intersect_domain_factor_domain(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::union_map union_map::intersect_domain_factor_range(isl::union_map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_union_map_intersect_domain_factor_range(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::union_map union_map::intersect_params(isl::set set) const
{
if (!ptr || set.is_null())
@ -16240,6 +16524,30 @@ isl::union_map union_map::intersect_range(isl::union_set uset) const
return manage(res);
}
isl::union_map union_map::intersect_range_factor_domain(isl::union_map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_union_map_intersect_range_factor_domain(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::union_map union_map::intersect_range_factor_range(isl::union_map factor) const
{
if (!ptr || factor.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_union_map_intersect_range_factor_range(copy(), factor.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
bool union_map::is_bijective() const
{
if (!ptr)
@ -17557,6 +17865,18 @@ bool union_pw_multi_aff::plain_is_empty() const
return res;
}
isl::union_pw_multi_aff union_pw_multi_aff::preimage_domain_wrapped_domain(isl::union_pw_multi_aff upma2) const
{
if (!ptr || upma2.is_null())
exception::throw_invalid("NULL input", __FILE__, __LINE__);
auto saved_ctx = ctx();
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
auto res = isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(copy(), upma2.release());
if (!res)
exception::throw_last_error(saved_ctx);
return manage(res);
}
isl::union_pw_multi_aff union_pw_multi_aff::pullback(isl::union_pw_multi_aff upma2) const
{
if (!ptr || upma2.is_null())

View File

@ -203,12 +203,6 @@ __isl_give isl_basic_map *isl_basic_map_upper_bound_si(
__isl_take isl_basic_map *bmap,
enum isl_dim_type type, unsigned pos, int value);
__isl_overload
__isl_give isl_map *isl_map_lower_bound_multi_val(__isl_take isl_map *map,
__isl_take isl_multi_val *lower);
__isl_overload
__isl_give isl_map *isl_map_upper_bound_multi_val(__isl_take isl_map *map,
__isl_take isl_multi_val *upper);
__isl_overload
__isl_give isl_map *isl_map_lower_bound_multi_pw_aff(__isl_take isl_map *map,
__isl_take isl_multi_pw_aff *lower);
__isl_overload
@ -327,10 +321,16 @@ __isl_export
__isl_give isl_map *isl_map_intersect_range(
__isl_take isl_map *map,
__isl_take isl_set *set);
__isl_export
__isl_give isl_map *isl_map_intersect_domain_factor_domain(
__isl_take isl_map *map, __isl_take isl_map *factor);
__isl_export
__isl_give isl_map *isl_map_intersect_domain_factor_range(
__isl_take isl_map *map, __isl_take isl_map *factor);
__isl_export
__isl_give isl_map *isl_map_intersect_range_factor_domain(
__isl_take isl_map *map, __isl_take isl_map *factor);
__isl_export
__isl_give isl_map *isl_map_intersect_range_factor_range(
__isl_take isl_map *map, __isl_take isl_map *factor);
__isl_export
@ -358,6 +358,7 @@ __isl_give isl_map *isl_map_preimage_domain_multi_pw_aff(
__isl_take isl_map *map, __isl_take isl_multi_pw_aff *mpa);
__isl_give isl_basic_map *isl_basic_map_product(
__isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2);
__isl_export
__isl_give isl_map *isl_map_product(__isl_take isl_map *map1,
__isl_take isl_map *map2);
__isl_give isl_basic_map *isl_basic_map_domain_product(
@ -497,6 +498,8 @@ __isl_give isl_basic_map *isl_basic_map_order_gt(__isl_take isl_basic_map *bmap,
__isl_give isl_map *isl_map_order_gt(__isl_take isl_map *map,
enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2);
__isl_export
__isl_give isl_map *isl_set_translation(__isl_take isl_set *deltas);
__isl_export
__isl_give isl_map *isl_set_identity(__isl_take isl_set *set);
@ -593,6 +596,7 @@ isl_bool isl_map_has_equal_space(__isl_keep isl_map *map1,
isl_bool isl_basic_map_can_zip(__isl_keep isl_basic_map *bmap);
isl_bool isl_map_can_zip(__isl_keep isl_map *map);
__isl_give isl_basic_map *isl_basic_map_zip(__isl_take isl_basic_map *bmap);
__isl_export
__isl_give isl_map *isl_map_zip(__isl_take isl_map *map);
isl_bool isl_basic_map_can_curry(__isl_keep isl_basic_map *bmap);

View File

@ -144,6 +144,7 @@ __isl_give isl_multi_##BASE *isl_multi_##BASE##_zero( \
__isl_take isl_space *space);
#define ISL_DECLARE_MULTI_NAN(BASE) \
__isl_export \
isl_bool isl_multi_##BASE##_involves_nan( \
__isl_keep isl_multi_##BASE *multi);

View File

@ -315,7 +315,8 @@ __isl_null isl_qpolynomial_fold *isl_qpolynomial_fold_free(
isl_bool isl_qpolynomial_fold_is_empty(__isl_keep isl_qpolynomial_fold *fold);
isl_bool isl_qpolynomial_fold_is_nan(__isl_keep isl_qpolynomial_fold *fold);
int isl_qpolynomial_fold_plain_is_equal(__isl_keep isl_qpolynomial_fold *fold1,
isl_bool isl_qpolynomial_fold_plain_is_equal(
__isl_keep isl_qpolynomial_fold *fold1,
__isl_keep isl_qpolynomial_fold *fold2);
__isl_give isl_space *isl_qpolynomial_fold_get_domain_space(
@ -487,6 +488,8 @@ isl_bool isl_pw_qpolynomial_fold_isa_qpolynomial_fold(
__isl_give isl_qpolynomial_fold *isl_pw_qpolynomial_fold_as_qpolynomial_fold(
__isl_take isl_pw_qpolynomial_fold *pwf);
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_read_from_str(
isl_ctx *ctx, const char *str);
__isl_give isl_printer *isl_printer_print_pw_qpolynomial_fold(
__isl_take isl_printer *p, __isl_keep isl_pw_qpolynomial_fold *pwf);
void isl_pw_qpolynomial_fold_print(__isl_keep isl_pw_qpolynomial_fold *pwf,
@ -814,6 +817,7 @@ __isl_give isl_union_pw_qpolynomial_fold *isl_union_map_apply_union_pw_qpolynomi
__isl_give isl_union_pw_qpolynomial *isl_union_pw_qpolynomial_to_polynomial(
__isl_take isl_union_pw_qpolynomial *upwqp, int sign);
ISL_DECLARE_LIST_FN(qpolynomial)
ISL_DECLARE_LIST_FN(pw_qpolynomial)
ISL_DECLARE_LIST_FN(pw_qpolynomial_fold)

View File

@ -4,6 +4,8 @@
struct isl_qpolynomial;
typedef struct isl_qpolynomial isl_qpolynomial;
ISL_DECLARE_LIST_TYPE(qpolynomial)
struct isl_term;
typedef struct isl_term isl_term;

View File

@ -144,6 +144,7 @@ isl_bool isl_schedule_plain_is_equal(__isl_keep isl_schedule *schedule1,
__isl_export
__isl_give isl_schedule_node *isl_schedule_get_root(
__isl_keep isl_schedule *schedule);
__isl_export
__isl_give isl_union_set *isl_schedule_get_domain(
__isl_keep isl_schedule *schedule);

View File

@ -85,6 +85,7 @@ __isl_give isl_space *isl_space_insert_dims(__isl_take isl_space *space,
enum isl_dim_type type, unsigned pos, unsigned n);
__isl_give isl_space *isl_space_join(__isl_take isl_space *left,
__isl_take isl_space *right);
__isl_export
__isl_give isl_space *isl_space_product(__isl_take isl_space *left,
__isl_take isl_space *right);
__isl_give isl_space *isl_space_domain_product(__isl_take isl_space *left,
@ -105,7 +106,9 @@ __isl_export
__isl_give isl_space *isl_space_map_from_set(__isl_take isl_space *space);
__isl_give isl_space *isl_space_map_from_domain_and_range(
__isl_take isl_space *domain, __isl_take isl_space *range);
__isl_export
__isl_give isl_space *isl_space_reverse(__isl_take isl_space *space);
__isl_export
__isl_give isl_space *isl_space_range_reverse(__isl_take isl_space *space);
__isl_give isl_space *isl_space_drop_dims(__isl_take isl_space *space,
enum isl_dim_type type, unsigned first, unsigned num);
@ -151,12 +154,14 @@ isl_bool isl_space_can_zip(__isl_keep isl_space *space);
__isl_give isl_space *isl_space_zip(__isl_take isl_space *space);
isl_bool isl_space_can_curry(__isl_keep isl_space *space);
__isl_export
__isl_give isl_space *isl_space_curry(__isl_take isl_space *space);
isl_bool isl_space_can_range_curry(__isl_keep isl_space *space);
__isl_give isl_space *isl_space_range_curry(__isl_take isl_space *space);
isl_bool isl_space_can_uncurry(__isl_keep isl_space *space);
__isl_export
__isl_give isl_space *isl_space_uncurry(__isl_take isl_space *space);
isl_bool isl_space_is_domain(__isl_keep isl_space *space1,

View File

@ -164,10 +164,16 @@ __isl_give isl_union_map *isl_union_map_intersect_range_space(
__isl_take isl_union_map *umap, __isl_take isl_space *space);
__isl_give isl_union_map *isl_union_map_intersect_range(
__isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
__isl_export
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_domain(
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
__isl_export
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_range(
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
__isl_export
__isl_give isl_union_map *isl_union_map_intersect_range_factor_domain(
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
__isl_export
__isl_give isl_union_map *isl_union_map_intersect_range_factor_range(
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
@ -310,9 +316,15 @@ __isl_overload
__isl_give isl_union_map *isl_union_map_eq_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *isl_union_map_lex_le_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *isl_union_map_lex_lt_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *isl_union_map_lex_ge_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);
__isl_give isl_union_map *isl_union_map_lex_gt_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa);

View File

@ -1,7 +1,7 @@
#!/bin/sh
# install - install a program, script, or datafile
scriptversion=2014-09-12.12; # UTC
scriptversion=2018-03-11.20; # UTC
# This originates from X11R5 (mit/util/scripts/install.sh), which was
# later released in X11R6 (xc/config/util/install.sh) with the
@ -271,15 +271,18 @@ do
fi
dst=$dst_arg
# If destination is a directory, append the input filename; won't work
# if double slashes aren't ignored.
# If destination is a directory, append the input filename.
if test -d "$dst"; then
if test "$is_target_a_directory" = never; then
echo "$0: $dst_arg: Is a directory" >&2
exit 1
fi
dstdir=$dst
dst=$dstdir/`basename "$src"`
dstbase=`basename "$src"`
case $dst in
*/) dst=$dst$dstbase;;
*) dst=$dst/$dstbase;;
esac
dstdir_status=0
else
dstdir=`dirname "$dst"`
@ -288,6 +291,11 @@ do
fi
fi
case $dstdir in
*/) dstdirslash=$dstdir;;
*) dstdirslash=$dstdir/;;
esac
obsolete_mkdir_used=false
if test $dstdir_status != 0; then
@ -324,14 +332,16 @@ do
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
;;
*)
# $RANDOM is not portable (e.g. dash); use it when possible to
# lower collision chance
# Note that $RANDOM variable is not portable (e.g. dash); Use it
# here however when possible just to lower collision chance.
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
# As "mkdir -p" follows symlinks and we work in /tmp possibly; so
# create the $tmpdir first (and fail if unsuccessful) to make sure
# that nobody tries to guess the $tmpdir name.
# Because "mkdir -p" follows existing symlinks and we likely work
# directly in world-writeable /tmp, make sure that the '$tmpdir'
# directory is successfully created first before we actually test
# 'mkdir -p' feature.
if (umask $mkdir_umask &&
$mkdirprog $mkdir_mode "$tmpdir" &&
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
@ -434,8 +444,8 @@ do
else
# Make a couple of temp file names in the proper directory.
dsttmp=$dstdir/_inst.$$_
rmtmp=$dstdir/_rm.$$_
dsttmp=${dstdirslash}_inst.$$_
rmtmp=${dstdirslash}_rm.$$_
# Trap to clean up those temp files at exit.
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
@ -500,9 +510,9 @@ do
done
# Local variables:
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -1,7 +1,7 @@
# Makefile.in generated by automake 1.15.1 from Makefile.am.
# Makefile.in generated by automake 1.16.1 from Makefile.am.
# @configure_input@
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
# This Makefile.in is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -141,7 +141,12 @@ am__v_at_0 = @
am__v_at_1 =
DEFAULT_INCLUDES =
depcomp = $(SHELL) $(top_srcdir)/depcomp
am__depfiles_maybe = depfiles
am__maybe_remake_depfiles = depfiles
am__depfiles_remade = ./$(DEPDIR)/extract_interface-cpp.Po \
./$(DEPDIR)/extract_interface-cpp_conversion.Po \
./$(DEPDIR)/extract_interface-extract_interface.Po \
./$(DEPDIR)/extract_interface-generator.Po \
./$(DEPDIR)/extract_interface-python.Po
am__mv = mv -f
CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
@ -416,8 +421,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
echo ' $(SHELL) ./config.status'; \
$(SHELL) ./config.status;; \
*) \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
esac;
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
@ -463,11 +468,17 @@ mostlyclean-compile:
distclean-compile:
-rm -f *.tab.c
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp_conversion.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-extract_interface.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-generator.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-python.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp_conversion.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-extract_interface.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-generator.Po@am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-python.Po@am__quote@ # am--include-marker
$(am__depfiles_remade):
@$(MKDIR_P) $(@D)
@echo '# dummy' >$@-t && $(am__mv) $@-t $@
am--depfiles: $(am__depfiles_remade)
.cc.o:
@am__fastdepCXX_TRUE@ $(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
@ -628,7 +639,10 @@ distclean-tags:
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
-rm -f cscope.out cscope.in.out cscope.po.out cscope.files
distdir: $(DISTFILES)
distdir: $(BUILT_SOURCES)
$(MAKE) $(AM_MAKEFLAGS) distdir-am
distdir-am: $(DISTFILES)
$(am__remove_distdir)
test -d "$(distdir)" || mkdir "$(distdir)"
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
@ -832,7 +846,11 @@ clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \
distclean: distclean-am
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
-rm -rf ./$(DEPDIR)
-rm -f ./$(DEPDIR)/extract_interface-cpp.Po
-rm -f ./$(DEPDIR)/extract_interface-cpp_conversion.Po
-rm -f ./$(DEPDIR)/extract_interface-extract_interface.Po
-rm -f ./$(DEPDIR)/extract_interface-generator.Po
-rm -f ./$(DEPDIR)/extract_interface-python.Po
-rm -f Makefile
distclean-am: clean-am distclean-compile distclean-generic \
distclean-hdr distclean-libtool distclean-tags
@ -880,7 +898,11 @@ installcheck-am:
maintainer-clean: maintainer-clean-am
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
-rm -rf $(top_srcdir)/autom4te.cache
-rm -rf ./$(DEPDIR)
-rm -f ./$(DEPDIR)/extract_interface-cpp.Po
-rm -f ./$(DEPDIR)/extract_interface-cpp_conversion.Po
-rm -f ./$(DEPDIR)/extract_interface-extract_interface.Po
-rm -f ./$(DEPDIR)/extract_interface-generator.Po
-rm -f ./$(DEPDIR)/extract_interface-python.Po
-rm -f Makefile
maintainer-clean-am: distclean-am maintainer-clean-generic
@ -901,22 +923,22 @@ uninstall-am:
.MAKE: all install-am install-strip
.PHONY: CTAGS GTAGS TAGS all all-am am--refresh check check-am clean \
clean-cscope clean-generic clean-libtool clean-noinstPROGRAMS \
cscope cscopelist-am ctags ctags-am dist dist-all dist-bzip2 \
dist-gzip dist-lzip dist-shar dist-tarZ dist-xz dist-zip \
distcheck distclean distclean-compile distclean-generic \
distclean-hdr distclean-libtool distclean-tags distcleancheck \
distdir distuninstallcheck dvi dvi-am html html-am info \
info-am install install-am install-data install-data-am \
install-dvi install-dvi-am install-exec install-exec-am \
install-html install-html-am install-info install-info-am \
install-man install-pdf install-pdf-am install-ps \
install-ps-am install-strip installcheck installcheck-am \
installdirs maintainer-clean maintainer-clean-generic \
mostlyclean mostlyclean-compile mostlyclean-generic \
mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \
uninstall-am
.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles am--refresh check \
check-am clean clean-cscope clean-generic clean-libtool \
clean-noinstPROGRAMS cscope cscopelist-am ctags ctags-am dist \
dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \
dist-xz dist-zip distcheck distclean distclean-compile \
distclean-generic distclean-hdr distclean-libtool \
distclean-tags distcleancheck distdir distuninstallcheck dvi \
dvi-am html html-am info info-am install install-am \
install-data install-data-am install-dvi install-dvi-am \
install-exec install-exec-am install-html install-html-am \
install-info install-info-am install-man install-pdf \
install-pdf-am install-ps install-ps-am install-strip \
installcheck installcheck-am installdirs maintainer-clean \
maintainer-clean-generic mostlyclean mostlyclean-compile \
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
tags tags-am uninstall uninstall-am
.PRECIOUS: Makefile

View File

@ -1,6 +1,6 @@
# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -20,7 +20,7 @@ You have another version of autoconf. It may work, but is not guaranteed to.
If you have problems, you may need to regenerate the build system entirely.
To do so, use the procedure documented by the package, typically 'autoreconf'.])])
# Copyright (C) 2002-2017 Free Software Foundation, Inc.
# Copyright (C) 2002-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
# generated from the m4 files accompanying Automake X.Y.
# (This private macro should not be called outside this file.)
AC_DEFUN([AM_AUTOMAKE_VERSION],
[am__api_version='1.15'
[am__api_version='1.16'
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
dnl require some minimum version. Point them to the right macro.
m4_if([$1], [1.15.1], [],
m4_if([$1], [1.16.1], [],
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
])
@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
[AM_AUTOMAKE_VERSION([1.15.1])dnl
[AM_AUTOMAKE_VERSION([1.16.1])dnl
m4_ifndef([AC_AUTOCONF_VERSION],
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -110,7 +110,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
# AM_CONDITIONAL -*- Autoconf -*-
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -141,7 +141,7 @@ AC_CONFIG_COMMANDS_PRE(
Usually this means the macro was only invoked conditionally.]])
fi])])
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -332,13 +332,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
# Generate code to set up dependency tracking. -*- Autoconf -*-
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.
# _AM_OUTPUT_DEPENDENCY_COMMANDS
# ------------------------------
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
@ -346,49 +345,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
case $CONFIG_FILES in
*\'*) eval set x "$CONFIG_FILES" ;;
*) set x $CONFIG_FILES ;;
esac
# TODO: see whether this extra hack can be removed once we start
# requiring Autoconf 2.70 or later.
AS_CASE([$CONFIG_FILES],
[*\'*], [eval set x "$CONFIG_FILES"],
[*], [set x $CONFIG_FILES])
shift
for mf
# Used to flag and report bootstrapping failures.
am_rc=0
for am_mf
do
# Strip MF so we end up with the name of the file.
mf=`echo "$mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile or not.
# We used to match only the files named 'Makefile.in', but
# some people rename them; so instead we look at the file content.
# Grep'ing the first line is not enough: some people post-process
# each Makefile.in and add a new line on top of each file to say so.
# Grep'ing the whole file is not good either: AIX grep has a line
am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile which includes
# dependency-tracking related rules and includes.
# Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
dirpart=`AS_DIRNAME("$mf")`
else
continue
fi
# Extract the definition of DEPDIR, am__include, and am__quote
# from the Makefile without running 'make'.
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
test -z "$DEPDIR" && continue
am__include=`sed -n 's/^am__include = //p' < "$mf"`
test -z "$am__include" && continue
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
# Find all dependency output files, they are included files with
# $(DEPDIR) in their names. We invoke sed twice because it is the
# simplest approach to changing $(DEPDIR) to its actual value in the
# expansion.
for file in `sed -n "
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
# Make sure the directory exists.
test -f "$dirpart/$file" && continue
fdir=`AS_DIRNAME(["$file"])`
AS_MKDIR_P([$dirpart/$fdir])
# echo "creating $dirpart/$file"
echo '# dummy' > "$dirpart/$file"
done
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|| continue
am_dirpart=`AS_DIRNAME(["$am_mf"])`
am_filepart=`AS_BASENAME(["$am_mf"])`
AM_RUN_LOG([cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles]) || am_rc=$?
done
if test $am_rc -ne 0; then
AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
for automatic dependency tracking. Try re-running configure with the
'--disable-dependency-tracking' option to at least be able to build
the package (albeit without support for automatic dependency tracking).])
fi
AS_UNSET([am_dirpart])
AS_UNSET([am_filepart])
AS_UNSET([am_mf])
AS_UNSET([am_rc])
rm -f conftest-deps.mk
}
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
@ -397,18 +388,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# -----------------------------
# This macro should only be invoked once -- use via AC_REQUIRE.
#
# This code is only required when automatic dependency tracking
# is enabled. FIXME. This creates each '.P' file that we will
# need in order to bootstrap the dependency handling code.
# This code is only required when automatic dependency tracking is enabled.
# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
# order to bootstrap the dependency handling code.
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
[AC_CONFIG_COMMANDS([depfiles],
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
])
[AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
# Do all the work for Automake. -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -495,8 +485,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
# We need awk for the "check" target (and possibly the TAP driver). The
# system "awk" is bad on some platforms.
@ -563,7 +553,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
that behaves properly: <http://www.gnu.org/software/coreutils/>.
that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@ -605,7 +595,7 @@ for _am_header in $config_headers :; do
done
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -626,7 +616,7 @@ if test x"${install_sh+set}" != xset; then
fi
AC_SUBST([install_sh])])
# Copyright (C) 2003-2017 Free Software Foundation, Inc.
# Copyright (C) 2003-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -647,7 +637,7 @@ AC_SUBST([am__leading_dot])])
# Check to see how 'make' treats includes. -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -655,49 +645,42 @@ AC_SUBST([am__leading_dot])])
# AM_MAKE_INCLUDE()
# -----------------
# Check to see how make treats includes.
# Check whether make has an 'include' directive that can support all
# the idioms we need for our automatic dependency tracking code.
AC_DEFUN([AM_MAKE_INCLUDE],
[am_make=${MAKE-make}
cat > confinc << 'END'
[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
cat > confinc.mk << 'END'
am__doit:
@echo this is the am__doit target
@echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
# If we don't find an include directive, just comment out the code.
AC_MSG_CHECKING([for style of include used by $am_make])
am__include="#"
am__quote=
_am_result=none
# First try GNU make style include.
echo "include confinc" > confmf
# Ignore all kinds of additional output from 'make'.
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=include
am__quote=
_am_result=GNU
;;
esac
# Now try BSD make style include.
if test "$am__include" = "#"; then
echo '.include "confinc"' > confmf
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=.include
am__quote="\""
_am_result=BSD
;;
esac
fi
AC_SUBST([am__include])
AC_SUBST([am__quote])
AC_MSG_RESULT([$_am_result])
rm -f confinc confmf
])
# BSD make does it like this.
echo '.include "confinc.mk" # ignored' > confmf.BSD
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
echo 'include confinc.mk # ignored' > confmf.GNU
_am_result=no
for s in GNU BSD; do
AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
AS_CASE([$?:`cat confinc.out 2>/dev/null`],
['0:this is the am__doit target'],
[AS_CASE([$s],
[BSD], [am__include='.include' am__quote='"'],
[am__include='include' am__quote=''])])
if test "$am__include" != "#"; then
_am_result="yes ($s style)"
break
fi
done
rm -f confinc.* confmf.*
AC_MSG_RESULT([${_am_result}])
AC_SUBST([am__include])])
AC_SUBST([am__quote])])
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -736,7 +719,7 @@ fi
# Helper functions for option handling. -*- Autoconf -*-
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -765,7 +748,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
AC_DEFUN([_AM_IF_OPTION],
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -812,7 +795,7 @@ AC_LANG_POP([C])])
# For backward compatibility.
AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -831,7 +814,7 @@ AC_DEFUN([AM_RUN_LOG],
# Check to make sure that the build environment is sane. -*- Autoconf -*-
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -912,7 +895,7 @@ AC_CONFIG_COMMANDS_PRE(
rm -f conftest.file
])
# Copyright (C) 2009-2017 Free Software Foundation, Inc.
# Copyright (C) 2009-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -972,7 +955,7 @@ AC_SUBST([AM_BACKSLASH])dnl
_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
])
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1000,7 +983,7 @@ fi
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
AC_SUBST([INSTALL_STRIP_PROGRAM])])
# Copyright (C) 2006-2017 Free Software Foundation, Inc.
# Copyright (C) 2006-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@ -1019,7 +1002,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
# Check how to create a tarball. -*- Autoconf -*-
# Copyright (C) 2004-2017 Free Software Foundation, Inc.
# Copyright (C) 2004-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,

View File

@ -1,9 +1,9 @@
#! /bin/sh
# Wrapper for compilers which do not understand '-c -o'.
scriptversion=2012-10-14.11; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1999-2014 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# Written by Tom Tromey <tromey@cygnus.com>.
#
# This program is free software; you can redistribute it and/or modify
@ -17,7 +17,7 @@ scriptversion=2012-10-14.11; # UTC
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -255,7 +255,8 @@ EOF
echo "compile $scriptversion"
exit $?
;;
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
func_cl_wrapper "$@" # Doesn't return...
;;
esac
@ -339,9 +340,9 @@ exit $ret
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -700,7 +700,6 @@ am__nodep
AMDEPBACKSLASH
AMDEP_FALSE
AMDEP_TRUE
am__quote
am__include
DEPDIR
OBJEXT
@ -775,7 +774,8 @@ PACKAGE_VERSION
PACKAGE_TARNAME
PACKAGE_NAME
PATH_SEPARATOR
SHELL'
SHELL
am__quote'
ac_subst_files=''
ac_user_opts='
enable_option_checking
@ -2437,7 +2437,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
am__api_version='1.15'
am__api_version='1.16'
# Find a good install program. We prefer a C program (faster),
# so one script is as good as another. But avoid the broken or
@ -2953,8 +2953,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
mkdir_p='$(MKDIR_P)'
# We need awk for the "check" target (and possibly the TAP driver). The
@ -3005,7 +3005,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
that behaves properly: <http://www.gnu.org/software/coreutils/>.
that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@ -3566,45 +3566,45 @@ DEPDIR="${am__leading_dot}deps"
ac_config_commands="$ac_config_commands depfiles"
am_make=${MAKE-make}
cat > confinc << 'END'
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
cat > confinc.mk << 'END'
am__doit:
@echo this is the am__doit target
@echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
# If we don't find an include directive, just comment out the code.
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
$as_echo_n "checking for style of include used by $am_make... " >&6; }
am__include="#"
am__quote=
_am_result=none
# First try GNU make style include.
echo "include confinc" > confmf
# Ignore all kinds of additional output from 'make'.
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=include
am__quote=
_am_result=GNU
;;
esac
# Now try BSD make style include.
if test "$am__include" = "#"; then
echo '.include "confinc"' > confmf
case `$am_make -s -f confmf 2> /dev/null` in #(
*the\ am__doit\ target*)
am__include=.include
am__quote="\""
_am_result=BSD
# BSD make does it like this.
echo '.include "confinc.mk" # ignored' > confmf.BSD
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
echo 'include confinc.mk # ignored' > confmf.GNU
_am_result=no
for s in GNU BSD; do
{ echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
(${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }
case $?:`cat confinc.out 2>/dev/null` in #(
'0:this is the am__doit target') :
case $s in #(
BSD) :
am__include='.include' am__quote='"' ;; #(
*) :
am__include='include' am__quote='' ;;
esac ;; #(
*) :
;;
esac
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
$as_echo "$_am_result" >&6; }
rm -f confinc confmf
esac
if test "$am__include" != "#"; then
_am_result="yes ($s style)"
break
fi
done
rm -f confinc.* confmf.*
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
$as_echo "${_am_result}" >&6; }
# Check whether --enable-dependency-tracking was given.
if test "${enable_dependency_tracking+set}" = set; then :
@ -8137,7 +8137,7 @@ esac
fi
: ${AR=ar}
: ${AR_FLAGS=cru}
: ${AR_FLAGS=cr}
@ -8638,11 +8638,8 @@ _LT_EOF
test $ac_status = 0; }; then
# Now try to grab the symbols.
nlist=conftest.nm
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5
(eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; } && test -s "$nlist"; then
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&5
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&5 && test -s "$nlist"; then
# Try sorting and uniquifying the output.
if sort "$nlist" | uniq > "$nlist"T; then
mv -f "$nlist"T "$nlist"
@ -9861,8 +9858,8 @@ int forced_loaded() { return 2;}
_LT_EOF
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5
echo "$AR cru libconftest.a conftest.o" >&5
$AR cru libconftest.a conftest.o 2>&5
echo "$AR cr libconftest.a conftest.o" >&5
$AR cr libconftest.a conftest.o 2>&5
echo "$RANLIB libconftest.a" >&5
$RANLIB libconftest.a 2>&5
cat > conftest.c << _LT_EOF
@ -10835,6 +10832,12 @@ lt_prog_compiler_static=
lt_prog_compiler_pic='-KPIC'
lt_prog_compiler_static='-static'
;;
# flang / f18. f95 an alias for gfortran or flang on Debian
flang* | f18* | f95*)
lt_prog_compiler_wl='-Wl,'
lt_prog_compiler_pic='-fPIC'
lt_prog_compiler_static='-static'
;;
# icc used to be incompatible with GCC.
# ICC 10 doesn't accept -KPIC any more.
icc* | ifort*)
@ -14777,7 +14780,7 @@ with_gnu_ld=$lt_cv_prog_gnu_ld
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
GXX=no
@ -15269,7 +15272,7 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -15334,7 +15337,7 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -15673,7 +15676,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# FIXME: insert proper C++ library support
@ -15757,7 +15760,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# g++ 2.7 appears to require '-G' NOT '-shared' on this
# platform.
@ -15768,7 +15771,7 @@ fi
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
fi
hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir'
@ -19319,7 +19322,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
#
# INIT-COMMANDS
#
AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
# The HP-UX ksh and POSIX shell print the target directory to stdout
@ -20313,29 +20316,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
case $CONFIG_FILES in
*\'*) eval set x "$CONFIG_FILES" ;;
*) set x $CONFIG_FILES ;;
esac
# TODO: see whether this extra hack can be removed once we start
# requiring Autoconf 2.70 or later.
case $CONFIG_FILES in #(
*\'*) :
eval set x "$CONFIG_FILES" ;; #(
*) :
set x $CONFIG_FILES ;; #(
*) :
;;
esac
shift
for mf
# Used to flag and report bootstrapping failures.
am_rc=0
for am_mf
do
# Strip MF so we end up with the name of the file.
mf=`echo "$mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile or not.
# We used to match only the files named 'Makefile.in', but
# some people rename them; so instead we look at the file content.
# Grep'ing the first line is not enough: some people post-process
# each Makefile.in and add a new line on top of each file to say so.
# Grep'ing the whole file is not good either: AIX grep has a line
am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
# Check whether this is an Automake generated Makefile which includes
# dependency-tracking related rules and includes.
# Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
dirpart=`$as_dirname -- "$mf" ||
$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$mf" : 'X\(//\)[^/]' \| \
X"$mf" : 'X\(//\)$' \| \
X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$mf" |
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|| continue
am_dirpart=`$as_dirname -- "$am_mf" ||
$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$am_mf" : 'X\(//\)[^/]' \| \
X"$am_mf" : 'X\(//\)$' \| \
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$am_mf" |
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
s//\1/
q
@ -20353,53 +20362,48 @@ $as_echo X"$mf" |
q
}
s/.*/./; q'`
else
continue
fi
# Extract the definition of DEPDIR, am__include, and am__quote
# from the Makefile without running 'make'.
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
test -z "$DEPDIR" && continue
am__include=`sed -n 's/^am__include = //p' < "$mf"`
test -z "$am__include" && continue
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
# Find all dependency output files, they are included files with
# $(DEPDIR) in their names. We invoke sed twice because it is the
# simplest approach to changing $(DEPDIR) to its actual value in the
# expansion.
for file in `sed -n "
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
# Make sure the directory exists.
test -f "$dirpart/$file" && continue
fdir=`$as_dirname -- "$file" ||
$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
X"$file" : 'X\(//\)[^/]' \| \
X"$file" : 'X\(//\)$' \| \
X"$file" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X"$file" |
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
am_filepart=`$as_basename -- "$am_mf" ||
$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
X"$am_mf" : 'X\(//\)$' \| \
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
$as_echo X/"$am_mf" |
sed '/^.*\/\([^/][^/]*\)\/*$/{
s//\1/
q
}
/^X\(\/\/\)[^/].*/{
/^X\/\(\/\/\)$/{
s//\1/
q
}
/^X\(\/\/\)$/{
s//\1/
q
}
/^X\(\/\).*/{
/^X\/\(\/\).*/{
s//\1/
q
}
s/.*/./; q'`
as_dir=$dirpart/$fdir; as_fn_mkdir_p
# echo "creating $dirpart/$file"
echo '# dummy' > "$dirpart/$file"
done
{ echo "$as_me:$LINENO: cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles" >&5
(cd "$am_dirpart" \
&& sed -e '/# am--include-marker/d' "$am_filepart" \
| $MAKE -f - am--depfiles) >&5 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } || am_rc=$?
done
if test $am_rc -ne 0; then
{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
as_fn_error $? "Something went wrong bootstrapping makefile fragments
for automatic dependency tracking. Try re-running configure with the
'--disable-dependency-tracking' option to at least be able to build
the package (albeit without support for automatic dependency tracking).
See \`config.log' for more details" "$LINENO" 5; }
fi
{ am_dirpart=; unset am_dirpart;}
{ am_filepart=; unset am_filepart;}
{ am_mf=; unset am_mf;}
{ am_rc=; unset am_rc;}
rm -f conftest-deps.mk
}
;;
"libtool":C)

View File

@ -397,7 +397,7 @@ void cpp_generator::print_method<cpp_generator::decl>(ostream &os,
* inline explicit val(ctx ctx, const std::string &str);
*/
void cpp_generator::print_constructors_decl(ostream &os,
const isl_class &clazz)
const isl_class &clazz)
{
function_set::const_iterator in;
const function_set &constructors = clazz.constructors;
@ -643,7 +643,7 @@ void cpp_generator::print_persistent_callback_data(ostream &os,
* public methods for setting the persistent callbacks.
*/
void cpp_generator::print_persistent_callbacks_decl(ostream &os,
const isl_class &clazz)
const isl_class &clazz)
{
std::string cppstring = type2cpp(clazz);
const char *cppname = cppstring.c_str();
@ -1223,7 +1223,7 @@ void cpp_generator::print_method<cpp_generator::impl>(ostream &os,
/* Print implementations of constructors for class "clazz" to "os".
*/
void cpp_generator::print_constructors_impl(ostream &os,
const isl_class &clazz)
const isl_class &clazz)
{
function_set::const_iterator in;
const function_set constructors = clazz.constructors;
@ -1405,7 +1405,7 @@ void cpp_generator::print_ctx_impl(ostream &os, const isl_class &clazz)
* of "clazz".
*/
void cpp_generator::print_persistent_callbacks_impl(ostream &os,
const isl_class &clazz)
const isl_class &clazz)
{
std::string cppstring = type2cpp(clazz);
const char *cppname = cppstring.c_str();
@ -1502,7 +1502,6 @@ void cpp_generator::print_set_enums_impl(ostream &os, const isl_class &clazz,
const vector<set_enum> &set_enums = clazz.set_enums.at(fd);
for (it = set_enums.begin(); it != set_enums.end(); ++it) {
osprintf(os, "\n");
print_set_enum_impl(os, clazz, fd, it->name, it->method_name);
}
}
@ -1984,7 +1983,8 @@ ParmVarDecl *cpp_generator::get_param(FunctionDecl *fd, int pos,
* For static functions and constructors all parameters of the original isl
* function are exposed.
*
* Parameters that are defined as __isl_keep or are of type string, are passed
* Parameters that are defined as __isl_keep, are of type string or
* are callbacks, are passed
* as const reference, which allows the compiler to optimize the parameter
* transfer.
*

View File

@ -1,9 +1,9 @@
#! /bin/sh
# depcomp - compile a program generating dependencies as side-effects
scriptversion=2016-01-11.22; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -783,7 +783,7 @@ exit 0
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"

View File

@ -367,6 +367,8 @@ static bool less_name(const FunctionDecl *a, const FunctionDecl *b)
* functions as belonging to the subclasses.
* Sort the names of the functions based on their lengths
* to ensure that nested subclasses are handled later.
*
* Also extract information about automatic conversion functions.
*/
generator::generator(SourceManager &SM, set<RecordDecl *> &exported_types,
set<FunctionDecl *> exported_functions, set<FunctionDecl *> functions) :

View File

@ -1,7 +1,7 @@
#!/bin/sh
# install - install a program, script, or datafile
scriptversion=2014-09-12.12; # UTC
scriptversion=2018-03-11.20; # UTC
# This originates from X11R5 (mit/util/scripts/install.sh), which was
# later released in X11R6 (xc/config/util/install.sh) with the
@ -271,15 +271,18 @@ do
fi
dst=$dst_arg
# If destination is a directory, append the input filename; won't work
# if double slashes aren't ignored.
# If destination is a directory, append the input filename.
if test -d "$dst"; then
if test "$is_target_a_directory" = never; then
echo "$0: $dst_arg: Is a directory" >&2
exit 1
fi
dstdir=$dst
dst=$dstdir/`basename "$src"`
dstbase=`basename "$src"`
case $dst in
*/) dst=$dst$dstbase;;
*) dst=$dst/$dstbase;;
esac
dstdir_status=0
else
dstdir=`dirname "$dst"`
@ -288,6 +291,11 @@ do
fi
fi
case $dstdir in
*/) dstdirslash=$dstdir;;
*) dstdirslash=$dstdir/;;
esac
obsolete_mkdir_used=false
if test $dstdir_status != 0; then
@ -324,14 +332,16 @@ do
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
;;
*)
# $RANDOM is not portable (e.g. dash); use it when possible to
# lower collision chance
# Note that $RANDOM variable is not portable (e.g. dash); Use it
# here however when possible just to lower collision chance.
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
# As "mkdir -p" follows symlinks and we work in /tmp possibly; so
# create the $tmpdir first (and fail if unsuccessful) to make sure
# that nobody tries to guess the $tmpdir name.
# Because "mkdir -p" follows existing symlinks and we likely work
# directly in world-writeable /tmp, make sure that the '$tmpdir'
# directory is successfully created first before we actually test
# 'mkdir -p' feature.
if (umask $mkdir_umask &&
$mkdirprog $mkdir_mode "$tmpdir" &&
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
@ -434,8 +444,8 @@ do
else
# Make a couple of temp file names in the proper directory.
dsttmp=$dstdir/_inst.$$_
rmtmp=$dstdir/_rm.$$_
dsttmp=${dstdirslash}_inst.$$_
rmtmp=${dstdirslash}_rm.$$_
# Trap to clean up those temp files at exit.
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
@ -500,9 +510,9 @@ do
done
# Local variables:
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -1,4 +1,4 @@
isl_dlname='libisl.so.22'
isl_dlname='libisl.so.23'
import os
from ctypes import *
from ctypes.util import find_library
@ -286,6 +286,13 @@ class union_pw_multi_aff(object):
if res < 0:
raise
return bool(res)
def preimage_domain_wrapped_domain(*args):
if len(args) == 2 and args[1].__class__ is union_pw_multi_aff:
ctx = args[0].ctx
res = isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(isl.isl_union_pw_multi_aff_copy(args[0].ptr), isl.isl_union_pw_multi_aff_copy(args[1].ptr))
obj = union_pw_multi_aff(ctx=ctx, ptr=res)
return obj
raise Error
def pullback(*args):
if len(args) == 2 and args[1].__class__ is union_pw_multi_aff:
ctx = args[0].ctx
@ -412,6 +419,8 @@ isl.isl_union_pw_multi_aff_intersect_params.argtypes = [c_void_p, c_void_p]
isl.isl_union_pw_multi_aff_involves_locals.argtypes = [c_void_p]
isl.isl_union_pw_multi_aff_isa_pw_multi_aff.argtypes = [c_void_p]
isl.isl_union_pw_multi_aff_plain_is_empty.argtypes = [c_void_p]
isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff.restype = c_void_p
isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff.argtypes = [c_void_p, c_void_p]
isl.isl_union_pw_multi_aff_pullback_union_pw_multi_aff.restype = c_void_p
isl.isl_union_pw_multi_aff_pullback_union_pw_multi_aff.argtypes = [c_void_p, c_void_p]
isl.isl_union_pw_multi_aff_range_factor_domain.restype = c_void_p
@ -623,6 +632,17 @@ class multi_union_pw_aff(object):
res = isl.isl_multi_union_pw_aff_intersect_params(isl.isl_multi_union_pw_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = multi_union_pw_aff(ctx=ctx, ptr=res)
return obj
def involves_nan(arg0):
try:
if not arg0.__class__ is multi_union_pw_aff:
arg0 = multi_union_pw_aff(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_multi_union_pw_aff_involves_nan(arg0.ptr)
if res < 0:
raise
return bool(res)
def neg(arg0):
try:
if not arg0.__class__ is multi_union_pw_aff:
@ -805,6 +825,7 @@ isl.isl_multi_union_pw_aff_intersect_domain.restype = c_void_p
isl.isl_multi_union_pw_aff_intersect_domain.argtypes = [c_void_p, c_void_p]
isl.isl_multi_union_pw_aff_intersect_params.restype = c_void_p
isl.isl_multi_union_pw_aff_intersect_params.argtypes = [c_void_p, c_void_p]
isl.isl_multi_union_pw_aff_involves_nan.argtypes = [c_void_p]
isl.isl_multi_union_pw_aff_neg.restype = c_void_p
isl.isl_multi_union_pw_aff_neg.argtypes = [c_void_p]
isl.isl_multi_union_pw_aff_plain_is_equal.argtypes = [c_void_p, c_void_p]
@ -1375,6 +1396,17 @@ class multi_pw_aff(multi_union_pw_aff):
res = isl.isl_multi_pw_aff_intersect_params(isl.isl_multi_pw_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = multi_pw_aff(ctx=ctx, ptr=res)
return obj
def involves_nan(arg0):
try:
if not arg0.__class__ is multi_pw_aff:
arg0 = multi_pw_aff(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_multi_pw_aff_involves_nan(arg0.ptr)
if res < 0:
raise
return bool(res)
def involves_param(*args):
if len(args) == 2 and (args[1].__class__ is id or type(args[1]) == str):
args = list(args)
@ -1685,6 +1717,7 @@ isl.isl_multi_pw_aff_intersect_domain.restype = c_void_p
isl.isl_multi_pw_aff_intersect_domain.argtypes = [c_void_p, c_void_p]
isl.isl_multi_pw_aff_intersect_params.restype = c_void_p
isl.isl_multi_pw_aff_intersect_params.argtypes = [c_void_p, c_void_p]
isl.isl_multi_pw_aff_involves_nan.argtypes = [c_void_p]
isl.isl_multi_pw_aff_involves_param_id.argtypes = [c_void_p, c_void_p]
isl.isl_multi_pw_aff_involves_param_id_list.argtypes = [c_void_p, c_void_p]
isl.isl_multi_pw_aff_max.restype = c_void_p
@ -1943,6 +1976,14 @@ class pw_multi_aff(union_pw_multi_aff, multi_pw_aff):
res = isl.isl_pw_multi_aff_gist(isl.isl_pw_multi_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = pw_multi_aff(ctx=ctx, ptr=res)
return obj
@staticmethod
def identity_on_domain(*args):
if len(args) == 1 and args[0].__class__ is space:
ctx = args[0].ctx
res = isl.isl_pw_multi_aff_identity_on_domain_space(isl.isl_space_copy(args[0].ptr))
obj = pw_multi_aff(ctx=ctx, ptr=res)
return obj
raise Error
def insert_domain(arg0, arg1):
try:
if not arg0.__class__ is pw_multi_aff:
@ -2041,6 +2082,13 @@ class pw_multi_aff(union_pw_multi_aff, multi_pw_aff):
if res < 0:
raise
return int(res)
def preimage_domain_wrapped_domain(*args):
if len(args) == 2 and args[1].__class__ is pw_multi_aff:
ctx = args[0].ctx
res = isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(isl.isl_pw_multi_aff_copy(args[0].ptr), isl.isl_pw_multi_aff_copy(args[1].ptr))
obj = pw_multi_aff(ctx=ctx, ptr=res)
return obj
raise Error
def product(arg0, arg1):
try:
if not arg0.__class__ is pw_multi_aff:
@ -2228,6 +2276,8 @@ isl.isl_pw_multi_aff_get_space.restype = c_void_p
isl.isl_pw_multi_aff_get_space.argtypes = [c_void_p]
isl.isl_pw_multi_aff_gist.restype = c_void_p
isl.isl_pw_multi_aff_gist.argtypes = [c_void_p, c_void_p]
isl.isl_pw_multi_aff_identity_on_domain_space.restype = c_void_p
isl.isl_pw_multi_aff_identity_on_domain_space.argtypes = [c_void_p]
isl.isl_pw_multi_aff_insert_domain.restype = c_void_p
isl.isl_pw_multi_aff_insert_domain.argtypes = [c_void_p, c_void_p]
isl.isl_pw_multi_aff_intersect_domain.restype = c_void_p
@ -2241,6 +2291,8 @@ isl.isl_pw_multi_aff_max_multi_val.argtypes = [c_void_p]
isl.isl_pw_multi_aff_min_multi_val.restype = c_void_p
isl.isl_pw_multi_aff_min_multi_val.argtypes = [c_void_p]
isl.isl_pw_multi_aff_n_piece.argtypes = [c_void_p]
isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff.restype = c_void_p
isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff.argtypes = [c_void_p, c_void_p]
isl.isl_pw_multi_aff_product.restype = c_void_p
isl.isl_pw_multi_aff_product.argtypes = [c_void_p, c_void_p]
isl.isl_pw_multi_aff_pullback_multi_aff.restype = c_void_p
@ -3187,6 +3239,17 @@ class multi_aff(pw_multi_aff, multi_pw_aff):
if res < 0:
raise
return bool(res)
def involves_nan(arg0):
try:
if not arg0.__class__ is multi_aff:
arg0 = multi_aff(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_multi_aff_involves_nan(arg0.ptr)
if res < 0:
raise
return bool(res)
def neg(arg0):
try:
if not arg0.__class__ is multi_aff:
@ -3406,6 +3469,7 @@ isl.isl_multi_aff_identity_on_domain_space.argtypes = [c_void_p]
isl.isl_multi_aff_insert_domain.restype = c_void_p
isl.isl_multi_aff_insert_domain.argtypes = [c_void_p, c_void_p]
isl.isl_multi_aff_involves_locals.argtypes = [c_void_p]
isl.isl_multi_aff_involves_nan.argtypes = [c_void_p]
isl.isl_multi_aff_neg.restype = c_void_p
isl.isl_multi_aff_neg.argtypes = [c_void_p]
isl.isl_multi_aff_plain_is_equal.argtypes = [c_void_p, c_void_p]
@ -3592,6 +3656,18 @@ class aff(pw_aff, multi_aff):
res = isl.isl_aff_ge_set(isl.isl_aff_copy(arg0.ptr), isl.isl_aff_copy(arg1.ptr))
obj = set(ctx=ctx, ptr=res)
return obj
def constant_val(arg0):
try:
if not arg0.__class__ is aff:
arg0 = aff(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_aff_get_constant_val(arg0.ptr)
obj = val(ctx=ctx, ptr=res)
return obj
def get_constant_val(arg0):
return arg0.constant_val()
def gist(arg0, arg1):
try:
if not arg0.__class__ is aff:
@ -3622,6 +3698,17 @@ class aff(pw_aff, multi_aff):
res = isl.isl_aff_gt_set(isl.isl_aff_copy(arg0.ptr), isl.isl_aff_copy(arg1.ptr))
obj = set(ctx=ctx, ptr=res)
return obj
def is_cst(arg0):
try:
if not arg0.__class__ is aff:
arg0 = aff(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_aff_is_cst(arg0.ptr)
if res < 0:
raise
return bool(res)
def le_set(arg0, arg1):
try:
if not arg0.__class__ is aff:
@ -3797,10 +3884,13 @@ isl.isl_aff_floor.restype = c_void_p
isl.isl_aff_floor.argtypes = [c_void_p]
isl.isl_aff_ge_set.restype = c_void_p
isl.isl_aff_ge_set.argtypes = [c_void_p, c_void_p]
isl.isl_aff_get_constant_val.restype = c_void_p
isl.isl_aff_get_constant_val.argtypes = [c_void_p]
isl.isl_aff_gist.restype = c_void_p
isl.isl_aff_gist.argtypes = [c_void_p, c_void_p]
isl.isl_aff_gt_set.restype = c_void_p
isl.isl_aff_gt_set.argtypes = [c_void_p, c_void_p]
isl.isl_aff_is_cst.argtypes = [c_void_p]
isl.isl_aff_le_set.restype = c_void_p
isl.isl_aff_le_set.argtypes = [c_void_p, c_void_p]
isl.isl_aff_lt_set.restype = c_void_p
@ -6641,6 +6731,36 @@ class union_map(object):
obj = union_map(ctx=ctx, ptr=res)
return obj
raise Error
def intersect_domain_factor_domain(arg0, arg1):
try:
if not arg0.__class__ is union_map:
arg0 = union_map(arg0)
except:
raise
try:
if not arg1.__class__ is union_map:
arg1 = union_map(arg1)
except:
raise
ctx = arg0.ctx
res = isl.isl_union_map_intersect_domain_factor_domain(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
obj = union_map(ctx=ctx, ptr=res)
return obj
def intersect_domain_factor_range(arg0, arg1):
try:
if not arg0.__class__ is union_map:
arg0 = union_map(arg0)
except:
raise
try:
if not arg1.__class__ is union_map:
arg1 = union_map(arg1)
except:
raise
ctx = arg0.ctx
res = isl.isl_union_map_intersect_domain_factor_range(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
obj = union_map(ctx=ctx, ptr=res)
return obj
def intersect_params(arg0, arg1):
try:
if not arg0.__class__ is union_map:
@ -6668,6 +6788,36 @@ class union_map(object):
obj = union_map(ctx=ctx, ptr=res)
return obj
raise Error
def intersect_range_factor_domain(arg0, arg1):
try:
if not arg0.__class__ is union_map:
arg0 = union_map(arg0)
except:
raise
try:
if not arg1.__class__ is union_map:
arg1 = union_map(arg1)
except:
raise
ctx = arg0.ctx
res = isl.isl_union_map_intersect_range_factor_domain(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
obj = union_map(ctx=ctx, ptr=res)
return obj
def intersect_range_factor_range(arg0, arg1):
try:
if not arg0.__class__ is union_map:
arg0 = union_map(arg0)
except:
raise
try:
if not arg1.__class__ is union_map:
arg1 = union_map(arg1)
except:
raise
ctx = arg0.ctx
res = isl.isl_union_map_intersect_range_factor_range(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
obj = union_map(ctx=ctx, ptr=res)
return obj
def is_bijective(arg0):
try:
if not arg0.__class__ is union_map:
@ -7133,12 +7283,20 @@ isl.isl_union_map_intersect_domain_space.restype = c_void_p
isl.isl_union_map_intersect_domain_space.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_domain_union_set.restype = c_void_p
isl.isl_union_map_intersect_domain_union_set.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_domain_factor_domain.restype = c_void_p
isl.isl_union_map_intersect_domain_factor_domain.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_domain_factor_range.restype = c_void_p
isl.isl_union_map_intersect_domain_factor_range.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_params.restype = c_void_p
isl.isl_union_map_intersect_params.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_range_space.restype = c_void_p
isl.isl_union_map_intersect_range_space.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_range_union_set.restype = c_void_p
isl.isl_union_map_intersect_range_union_set.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_range_factor_domain.restype = c_void_p
isl.isl_union_map_intersect_range_factor_domain.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_intersect_range_factor_range.restype = c_void_p
isl.isl_union_map_intersect_range_factor_range.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_is_bijective.argtypes = [c_void_p]
isl.isl_union_map_is_disjoint.argtypes = [c_void_p, c_void_p]
isl.isl_union_map_is_empty.argtypes = [c_void_p]
@ -7584,6 +7742,36 @@ class map(union_map):
res = isl.isl_map_intersect_domain(isl.isl_map_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def intersect_domain_factor_domain(arg0, arg1):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
try:
if not arg1.__class__ is map:
arg1 = map(arg1)
except:
return union_map(arg0).intersect_domain_factor_domain(arg1)
ctx = arg0.ctx
res = isl.isl_map_intersect_domain_factor_domain(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def intersect_domain_factor_range(arg0, arg1):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
try:
if not arg1.__class__ is map:
arg1 = map(arg1)
except:
return union_map(arg0).intersect_domain_factor_range(arg1)
ctx = arg0.ctx
res = isl.isl_map_intersect_domain_factor_range(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def intersect_params(arg0, arg1):
try:
if not arg0.__class__ is map:
@ -7614,6 +7802,36 @@ class map(union_map):
res = isl.isl_map_intersect_range(isl.isl_map_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def intersect_range_factor_domain(arg0, arg1):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
try:
if not arg1.__class__ is map:
arg1 = map(arg1)
except:
return union_map(arg0).intersect_range_factor_domain(arg1)
ctx = arg0.ctx
res = isl.isl_map_intersect_range_factor_domain(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def intersect_range_factor_range(arg0, arg1):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
try:
if not arg1.__class__ is map:
arg1 = map(arg1)
except:
return union_map(arg0).intersect_range_factor_range(arg1)
ctx = arg0.ctx
res = isl.isl_map_intersect_range_factor_range(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def is_bijective(arg0):
try:
if not arg0.__class__ is map:
@ -7796,11 +8014,6 @@ class map(union_map):
res = isl.isl_map_lower_bound_multi_pw_aff(isl.isl_map_copy(args[0].ptr), isl.isl_multi_pw_aff_copy(args[1].ptr))
obj = map(ctx=ctx, ptr=res)
return obj
if len(args) == 2 and args[1].__class__ is multi_val:
ctx = args[0].ctx
res = isl.isl_map_lower_bound_multi_val(isl.isl_map_copy(args[0].ptr), isl.isl_multi_val_copy(args[1].ptr))
obj = map(ctx=ctx, ptr=res)
return obj
raise Error
def max_multi_pw_aff(arg0):
try:
@ -7861,6 +8074,21 @@ class map(union_map):
obj = map(ctx=ctx, ptr=res)
return obj
raise Error
def product(arg0, arg1):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
try:
if not arg1.__class__ is map:
arg1 = map(arg1)
except:
return union_map(arg0).product(arg1)
ctx = arg0.ctx
res = isl.isl_map_product(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def project_out_all_params(arg0):
try:
if not arg0.__class__ is map:
@ -8013,11 +8241,6 @@ class map(union_map):
res = isl.isl_map_upper_bound_multi_pw_aff(isl.isl_map_copy(args[0].ptr), isl.isl_multi_pw_aff_copy(args[1].ptr))
obj = map(ctx=ctx, ptr=res)
return obj
if len(args) == 2 and args[1].__class__ is multi_val:
ctx = args[0].ctx
res = isl.isl_map_upper_bound_multi_val(isl.isl_map_copy(args[0].ptr), isl.isl_multi_val_copy(args[1].ptr))
obj = map(ctx=ctx, ptr=res)
return obj
raise Error
def wrap(arg0):
try:
@ -8029,6 +8252,16 @@ class map(union_map):
res = isl.isl_map_wrap(isl.isl_map_copy(arg0.ptr))
obj = set(ctx=ctx, ptr=res)
return obj
def zip(arg0):
try:
if not arg0.__class__ is map:
arg0 = map(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_map_zip(isl.isl_map_copy(arg0.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
isl.isl_map_from_basic_map.restype = c_void_p
isl.isl_map_from_basic_map.argtypes = [c_void_p]
@ -8089,10 +8322,18 @@ isl.isl_map_intersect.restype = c_void_p
isl.isl_map_intersect.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_domain.restype = c_void_p
isl.isl_map_intersect_domain.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_domain_factor_domain.restype = c_void_p
isl.isl_map_intersect_domain_factor_domain.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_domain_factor_range.restype = c_void_p
isl.isl_map_intersect_domain_factor_range.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_params.restype = c_void_p
isl.isl_map_intersect_params.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_range.restype = c_void_p
isl.isl_map_intersect_range.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_range_factor_domain.restype = c_void_p
isl.isl_map_intersect_range_factor_domain.argtypes = [c_void_p, c_void_p]
isl.isl_map_intersect_range_factor_range.restype = c_void_p
isl.isl_map_intersect_range_factor_range.argtypes = [c_void_p, c_void_p]
isl.isl_map_is_bijective.argtypes = [c_void_p]
isl.isl_map_is_disjoint.argtypes = [c_void_p, c_void_p]
isl.isl_map_is_empty.argtypes = [c_void_p]
@ -8119,8 +8360,6 @@ isl.isl_map_lexmin_pw_multi_aff.restype = c_void_p
isl.isl_map_lexmin_pw_multi_aff.argtypes = [c_void_p]
isl.isl_map_lower_bound_multi_pw_aff.restype = c_void_p
isl.isl_map_lower_bound_multi_pw_aff.argtypes = [c_void_p, c_void_p]
isl.isl_map_lower_bound_multi_val.restype = c_void_p
isl.isl_map_lower_bound_multi_val.argtypes = [c_void_p, c_void_p]
isl.isl_map_max_multi_pw_aff.restype = c_void_p
isl.isl_map_max_multi_pw_aff.argtypes = [c_void_p]
isl.isl_map_min_multi_pw_aff.restype = c_void_p
@ -8137,6 +8376,8 @@ isl.isl_map_preimage_range_multi_aff.restype = c_void_p
isl.isl_map_preimage_range_multi_aff.argtypes = [c_void_p, c_void_p]
isl.isl_map_preimage_range_pw_multi_aff.restype = c_void_p
isl.isl_map_preimage_range_pw_multi_aff.argtypes = [c_void_p, c_void_p]
isl.isl_map_product.restype = c_void_p
isl.isl_map_product.argtypes = [c_void_p, c_void_p]
isl.isl_map_project_out_all_params.restype = c_void_p
isl.isl_map_project_out_all_params.argtypes = [c_void_p]
isl.isl_map_range.restype = c_void_p
@ -8165,10 +8406,10 @@ isl.isl_map_unshifted_simple_hull.restype = c_void_p
isl.isl_map_unshifted_simple_hull.argtypes = [c_void_p]
isl.isl_map_upper_bound_multi_pw_aff.restype = c_void_p
isl.isl_map_upper_bound_multi_pw_aff.argtypes = [c_void_p, c_void_p]
isl.isl_map_upper_bound_multi_val.restype = c_void_p
isl.isl_map_upper_bound_multi_val.argtypes = [c_void_p, c_void_p]
isl.isl_map_wrap.restype = c_void_p
isl.isl_map_wrap.argtypes = [c_void_p]
isl.isl_map_zip.restype = c_void_p
isl.isl_map_zip.argtypes = [c_void_p]
isl.isl_map_copy.restype = c_void_p
isl.isl_map_copy.argtypes = [c_void_p]
isl.isl_map_free.restype = c_void_p
@ -9692,6 +9933,16 @@ class set(union_set):
res = isl.isl_set_subtract(isl.isl_set_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
obj = set(ctx=ctx, ptr=res)
return obj
def translation(arg0):
try:
if not arg0.__class__ is set:
arg0 = set(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_set_translation(isl.isl_set_copy(arg0.ptr))
obj = map(ctx=ctx, ptr=res)
return obj
def unbind_params(arg0, arg1):
try:
if not arg0.__class__ is set:
@ -9881,6 +10132,8 @@ isl.isl_set_sample_point.restype = c_void_p
isl.isl_set_sample_point.argtypes = [c_void_p]
isl.isl_set_subtract.restype = c_void_p
isl.isl_set_subtract.argtypes = [c_void_p, c_void_p]
isl.isl_set_translation.restype = c_void_p
isl.isl_set_translation.argtypes = [c_void_p]
isl.isl_set_unbind_params.restype = c_void_p
isl.isl_set_unbind_params.argtypes = [c_void_p, c_void_p]
isl.isl_set_unbind_params_insert_domain.restype = c_void_p
@ -10794,6 +11047,17 @@ class multi_val(object):
return obj
def get_space(arg0):
return arg0.space()
def involves_nan(arg0):
try:
if not arg0.__class__ is multi_val:
arg0 = multi_val(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_multi_val_involves_nan(arg0.ptr)
if res < 0:
raise
return bool(res)
def max(arg0, arg1):
try:
if not arg0.__class__ is multi_val:
@ -10985,6 +11249,7 @@ isl.isl_multi_val_get_list.restype = c_void_p
isl.isl_multi_val_get_list.argtypes = [c_void_p]
isl.isl_multi_val_get_space.restype = c_void_p
isl.isl_multi_val_get_space.argtypes = [c_void_p]
isl.isl_multi_val_involves_nan.argtypes = [c_void_p]
isl.isl_multi_val_max.restype = c_void_p
isl.isl_multi_val_max.argtypes = [c_void_p, c_void_p]
isl.isl_multi_val_min.restype = c_void_p
@ -11451,6 +11716,18 @@ class schedule(object):
res = isl.isl_schedule_from_domain(isl.isl_union_set_copy(arg0.ptr))
obj = schedule(ctx=ctx, ptr=res)
return obj
def domain(arg0):
try:
if not arg0.__class__ is schedule:
arg0 = schedule(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_schedule_get_domain(arg0.ptr)
obj = union_set(ctx=ctx, ptr=res)
return obj
def get_domain(arg0):
return arg0.domain()
def map(arg0):
try:
if not arg0.__class__ is schedule:
@ -11487,6 +11764,8 @@ isl.isl_schedule_read_from_str.restype = c_void_p
isl.isl_schedule_read_from_str.argtypes = [Context, c_char_p]
isl.isl_schedule_from_domain.restype = c_void_p
isl.isl_schedule_from_domain.argtypes = [c_void_p]
isl.isl_schedule_get_domain.restype = c_void_p
isl.isl_schedule_get_domain.argtypes = [c_void_p]
isl.isl_schedule_get_map.restype = c_void_p
isl.isl_schedule_get_map.argtypes = [c_void_p]
isl.isl_schedule_get_root.restype = c_void_p
@ -13269,6 +13548,16 @@ class space(object):
obj = space(ctx=ctx, ptr=res)
return obj
raise Error
def curry(arg0):
try:
if not arg0.__class__ is space:
arg0 = space(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_space_curry(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def domain(arg0):
try:
if not arg0.__class__ is space:
@ -13346,6 +13635,21 @@ class space(object):
res = isl.isl_space_params(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def product(arg0, arg1):
try:
if not arg0.__class__ is space:
arg0 = space(arg0)
except:
raise
try:
if not arg1.__class__ is space:
arg1 = space(arg1)
except:
raise
ctx = arg0.ctx
res = isl.isl_space_product(isl.isl_space_copy(arg0.ptr), isl.isl_space_copy(arg1.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def range(arg0):
try:
if not arg0.__class__ is space:
@ -13356,6 +13660,36 @@ class space(object):
res = isl.isl_space_range(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def range_reverse(arg0):
try:
if not arg0.__class__ is space:
arg0 = space(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_space_range_reverse(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def reverse(arg0):
try:
if not arg0.__class__ is space:
arg0 = space(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_space_reverse(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
def uncurry(arg0):
try:
if not arg0.__class__ is space:
arg0 = space(arg0)
except:
raise
ctx = arg0.ctx
res = isl.isl_space_uncurry(isl.isl_space_copy(arg0.ptr))
obj = space(ctx=ctx, ptr=res)
return obj
@staticmethod
def unit():
ctx = Context.getDefaultInstance()
@ -13387,6 +13721,8 @@ isl.isl_space_add_named_tuple_id_ui.restype = c_void_p
isl.isl_space_add_named_tuple_id_ui.argtypes = [c_void_p, c_void_p, c_int]
isl.isl_space_add_unnamed_tuple_ui.restype = c_void_p
isl.isl_space_add_unnamed_tuple_ui.argtypes = [c_void_p, c_int]
isl.isl_space_curry.restype = c_void_p
isl.isl_space_curry.argtypes = [c_void_p]
isl.isl_space_domain.restype = c_void_p
isl.isl_space_domain.argtypes = [c_void_p]
isl.isl_space_flatten_domain.restype = c_void_p
@ -13399,8 +13735,16 @@ isl.isl_space_map_from_set.restype = c_void_p
isl.isl_space_map_from_set.argtypes = [c_void_p]
isl.isl_space_params.restype = c_void_p
isl.isl_space_params.argtypes = [c_void_p]
isl.isl_space_product.restype = c_void_p
isl.isl_space_product.argtypes = [c_void_p, c_void_p]
isl.isl_space_range.restype = c_void_p
isl.isl_space_range.argtypes = [c_void_p]
isl.isl_space_range_reverse.restype = c_void_p
isl.isl_space_range_reverse.argtypes = [c_void_p]
isl.isl_space_reverse.restype = c_void_p
isl.isl_space_reverse.argtypes = [c_void_p]
isl.isl_space_uncurry.restype = c_void_p
isl.isl_space_uncurry.argtypes = [c_void_p]
isl.isl_space_unit.restype = c_void_p
isl.isl_space_unit.argtypes = [Context]
isl.isl_space_unwrap.restype = c_void_p

View File

@ -31,7 +31,7 @@
PROGRAM=libtool
PACKAGE=libtool
VERSION="2.4.6 Debian-2.4.6-2"
VERSION="2.4.6 Debian-2.4.6-14"
package_revision=2.4.6
@ -387,7 +387,7 @@ EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
# putting '$debug_cmd' at the start of all your functions, you can get
# bash to show function call trace with:
#
# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
# debug_cmd='echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
debug_cmd=${debug_cmd-":"}
exit_cmd=:
@ -1370,7 +1370,7 @@ func_lt_ver ()
#! /bin/sh
# Set a version string for this script.
scriptversion=2014-01-07.03; # UTC
scriptversion=2015-10-07.11; # UTC
# A portable, pluggable option parser for Bourne shell.
# Written by Gary V. Vaughan, 2010
@ -1530,6 +1530,8 @@ func_run_hooks ()
{
$debug_cmd
_G_rc_run_hooks=false
case " $hookable_fns " in
*" $1 "*) ;;
*) func_fatal_error "'$1' does not support hook funcions.n" ;;
@ -1538,16 +1540,16 @@ func_run_hooks ()
eval _G_hook_fns=\$$1_hooks; shift
for _G_hook in $_G_hook_fns; do
eval $_G_hook '"$@"'
# store returned options list back into positional
# parameters for next 'cmd' execution.
eval _G_hook_result=\$${_G_hook}_result
eval set dummy "$_G_hook_result"; shift
if eval $_G_hook '"$@"'; then
# store returned options list back into positional
# parameters for next 'cmd' execution.
eval _G_hook_result=\$${_G_hook}_result
eval set dummy "$_G_hook_result"; shift
_G_rc_run_hooks=:
fi
done
func_quote_for_eval ${1+"$@"}
func_run_hooks_result=$func_quote_for_eval_result
$_G_rc_run_hooks && func_run_hooks_result=$_G_hook_result
}
@ -1557,10 +1559,16 @@ func_run_hooks ()
## --------------- ##
# In order to add your own option parsing hooks, you must accept the
# full positional parameter list in your hook function, remove any
# options that you action, and then pass back the remaining unprocessed
# full positional parameter list in your hook function, you may remove/edit
# any options that you action, and then pass back the remaining unprocessed
# options in '<hooked_function_name>_result', escaped suitably for
# 'eval'. Like this:
# 'eval'. In this case you also must return $EXIT_SUCCESS to let the
# hook's caller know that it should pay attention to
# '<hooked_function_name>_result'. Returning $EXIT_FAILURE signalizes that
# arguments are left untouched by the hook and therefore caller will ignore the
# result variable.
#
# Like this:
#
# my_options_prep ()
# {
@ -1570,9 +1578,11 @@ func_run_hooks ()
# usage_message=$usage_message'
# -s, --silent don'\''t print informational messages
# '
#
# func_quote_for_eval ${1+"$@"}
# my_options_prep_result=$func_quote_for_eval_result
# # No change in '$@' (ignored completely by this hook). There is
# # no need to do the equivalent (but slower) action:
# # func_quote_for_eval ${1+"$@"}
# # my_options_prep_result=$func_quote_for_eval_result
# false
# }
# func_add_hook func_options_prep my_options_prep
#
@ -1581,25 +1591,37 @@ func_run_hooks ()
# {
# $debug_cmd
#
# args_changed=false
#
# # Note that for efficiency, we parse as many options as we can
# # recognise in a loop before passing the remainder back to the
# # caller on the first unrecognised argument we encounter.
# while test $# -gt 0; do
# opt=$1; shift
# case $opt in
# --silent|-s) opt_silent=: ;;
# --silent|-s) opt_silent=:
# args_changed=:
# ;;
# # Separate non-argument short options:
# -s*) func_split_short_opt "$_G_opt"
# set dummy "$func_split_short_opt_name" \
# "-$func_split_short_opt_arg" ${1+"$@"}
# shift
# args_changed=:
# ;;
# *) set dummy "$_G_opt" "$*"; shift; break ;;
# *) # Make sure the first unrecognised option "$_G_opt"
# # is added back to "$@", we could need that later
# # if $args_changed is true.
# set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
# esac
# done
#
# func_quote_for_eval ${1+"$@"}
# my_silent_option_result=$func_quote_for_eval_result
# if $args_changed; then
# func_quote_for_eval ${1+"$@"}
# my_silent_option_result=$func_quote_for_eval_result
# fi
#
# $args_changed
# }
# func_add_hook func_parse_options my_silent_option
#
@ -1611,16 +1633,32 @@ func_run_hooks ()
# $opt_silent && $opt_verbose && func_fatal_help "\
# '--silent' and '--verbose' options are mutually exclusive."
#
# func_quote_for_eval ${1+"$@"}
# my_option_validation_result=$func_quote_for_eval_result
# false
# }
# func_add_hook func_validate_options my_option_validation
#
# You'll alse need to manually amend $usage_message to reflect the extra
# You'll also need to manually amend $usage_message to reflect the extra
# options you parse. It's preferable to append if you can, so that
# multiple option parsing hooks can be added safely.
# func_options_finish [ARG]...
# ----------------------------
# Finishing the option parse loop (call 'func_options' hooks ATM).
func_options_finish ()
{
$debug_cmd
_G_func_options_finish_exit=false
if func_run_hooks func_options ${1+"$@"}; then
func_options_finish_result=$func_run_hooks_result
_G_func_options_finish_exit=:
fi
$_G_func_options_finish_exit
}
# func_options [ARG]...
# ---------------------
# All the functions called inside func_options are hookable. See the
@ -1630,17 +1668,28 @@ func_options ()
{
$debug_cmd
func_options_prep ${1+"$@"}
eval func_parse_options \
${func_options_prep_result+"$func_options_prep_result"}
eval func_validate_options \
${func_parse_options_result+"$func_parse_options_result"}
_G_rc_options=false
eval func_run_hooks func_options \
${func_validate_options_result+"$func_validate_options_result"}
for my_func in options_prep parse_options validate_options options_finish
do
if eval func_$my_func '${1+"$@"}'; then
eval _G_res_var='$'"func_${my_func}_result"
eval set dummy "$_G_res_var" ; shift
_G_rc_options=:
fi
done
# save modified positional parameters for caller
func_options_result=$func_run_hooks_result
# Save modified positional parameters for caller. As a top-level
# options-parser function we always need to set the 'func_options_result'
# variable (regardless the $_G_rc_options value).
if $_G_rc_options; then
func_options_result=$_G_res_var
else
func_quote_for_eval ${1+"$@"}
func_options_result=$func_quote_for_eval_result
fi
$_G_rc_options
}
@ -1649,9 +1698,9 @@ func_options ()
# All initialisations required before starting the option parse loop.
# Note that when calling hook functions, we pass through the list of
# positional parameters. If a hook function modifies that list, and
# needs to propogate that back to rest of this script, then the complete
# needs to propagate that back to rest of this script, then the complete
# modified list must be put in 'func_run_hooks_result' before
# returning.
# returning $EXIT_SUCCESS (otherwise $EXIT_FAILURE is returned).
func_hookable func_options_prep
func_options_prep ()
{
@ -1661,10 +1710,14 @@ func_options_prep ()
opt_verbose=false
opt_warning_types=
func_run_hooks func_options_prep ${1+"$@"}
_G_rc_options_prep=false
if func_run_hooks func_options_prep ${1+"$@"}; then
_G_rc_options_prep=:
# save modified positional parameters for caller
func_options_prep_result=$func_run_hooks_result
fi
# save modified positional parameters for caller
func_options_prep_result=$func_run_hooks_result
$_G_rc_options_prep
}
@ -1678,18 +1731,20 @@ func_parse_options ()
func_parse_options_result=
_G_rc_parse_options=false
# this just eases exit handling
while test $# -gt 0; do
# Defer to hook functions for initial option parsing, so they
# get priority in the event of reusing an option name.
func_run_hooks func_parse_options ${1+"$@"}
# Adjust func_parse_options positional parameters to match
eval set dummy "$func_run_hooks_result"; shift
if func_run_hooks func_parse_options ${1+"$@"}; then
eval set dummy "$func_run_hooks_result"; shift
_G_rc_parse_options=:
fi
# Break out of the loop if we already parsed every option.
test $# -gt 0 || break
_G_match_parse_options=:
_G_opt=$1
shift
case $_G_opt in
@ -1704,7 +1759,10 @@ func_parse_options ()
;;
--warnings|--warning|-W)
test $# = 0 && func_missing_arg $_G_opt && break
if test $# = 0 && func_missing_arg $_G_opt; then
_G_rc_parse_options=:
break
fi
case " $warning_categories $1" in
*" $1 "*)
# trailing space prevents matching last $1 above
@ -1757,15 +1815,25 @@ func_parse_options ()
shift
;;
--) break ;;
--) _G_rc_parse_options=: ; break ;;
-*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
*) set dummy "$_G_opt" ${1+"$@"}; shift
_G_match_parse_options=false
break
;;
esac
$_G_match_parse_options && _G_rc_parse_options=:
done
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
func_parse_options_result=$func_quote_for_eval_result
if $_G_rc_parse_options; then
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
func_parse_options_result=$func_quote_for_eval_result
fi
$_G_rc_parse_options
}
@ -1778,16 +1846,21 @@ func_validate_options ()
{
$debug_cmd
_G_rc_validate_options=false
# Display all warnings if -W was not given.
test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
func_run_hooks func_validate_options ${1+"$@"}
if func_run_hooks func_validate_options ${1+"$@"}; then
# save modified positional parameters for caller
func_validate_options_result=$func_run_hooks_result
_G_rc_validate_options=:
fi
# Bail if the options were screwed!
$exit_cmd $EXIT_FAILURE
# save modified positional parameters for caller
func_validate_options_result=$func_run_hooks_result
$_G_rc_validate_options
}
@ -2068,7 +2141,7 @@ include the following information:
compiler: $LTCC
compiler flags: $LTCFLAGS
linker: $LD (gnu? $with_gnu_ld)
version: $progname $scriptversion Debian-2.4.6-2
version: $progname $scriptversion Debian-2.4.6-14
automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
@ -2270,6 +2343,8 @@ libtool_options_prep ()
nonopt=
preserve_args=
_G_rc_lt_options_prep=:
# Shorthand for --mode=foo, only valid as the first argument
case $1 in
clean|clea|cle|cl)
@ -2293,11 +2368,18 @@ libtool_options_prep ()
uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
shift; set dummy --mode uninstall ${1+"$@"}; shift
;;
*)
_G_rc_lt_options_prep=false
;;
esac
# Pass back the list of options.
func_quote_for_eval ${1+"$@"}
libtool_options_prep_result=$func_quote_for_eval_result
if $_G_rc_lt_options_prep; then
# Pass back the list of options.
func_quote_for_eval ${1+"$@"}
libtool_options_prep_result=$func_quote_for_eval_result
fi
$_G_rc_lt_options_prep
}
func_add_hook func_options_prep libtool_options_prep
@ -2309,9 +2391,12 @@ libtool_parse_options ()
{
$debug_cmd
_G_rc_lt_parse_options=false
# Perform our own loop to consume as many options as possible in
# each iteration.
while test $# -gt 0; do
_G_match_lt_parse_options=:
_G_opt=$1
shift
case $_G_opt in
@ -2386,15 +2471,22 @@ libtool_parse_options ()
func_append preserve_args " $_G_opt"
;;
# An option not handled by this hook function:
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
# An option not handled by this hook function:
*) set dummy "$_G_opt" ${1+"$@"} ; shift
_G_match_lt_parse_options=false
break
;;
esac
$_G_match_lt_parse_options && _G_rc_lt_parse_options=:
done
if $_G_rc_lt_parse_options; then
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
libtool_parse_options_result=$func_quote_for_eval_result
fi
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
libtool_parse_options_result=$func_quote_for_eval_result
$_G_rc_lt_parse_options
}
func_add_hook func_parse_options libtool_parse_options
@ -7275,10 +7367,13 @@ func_mode_link ()
# -specs=* GCC specs files
# -stdlib=* select c++ std lib with clang
# -fsanitize=* Clang/GCC memory and address sanitizer
# -fuse-ld=* Linker select flags for GCC
# -static-* direct GCC to link specific libraries statically
# -fcilkplus Cilk Plus language extension features for C/C++
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
-O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
-specs=*|-fsanitize=*)
-specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus)
func_quote_for_eval "$arg"
arg=$func_quote_for_eval_result
func_append compile_command " $arg"

View File

@ -1,9 +1,9 @@
#! /bin/sh
# Common wrapper for a few potentially missing GNU programs.
scriptversion=2013-10-28.13; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1996-2014 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
# This program is free software; you can redistribute it and/or modify
@ -17,7 +17,7 @@ scriptversion=2013-10-28.13; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -101,9 +101,9 @@ else
exit $st
fi
perl_URL=http://www.perl.org/
flex_URL=http://flex.sourceforge.net/
gnu_software_URL=http://www.gnu.org/software
perl_URL=https://www.perl.org/
flex_URL=https://github.com/westes/flex
gnu_software_URL=https://www.gnu.org/software
program_details ()
{
@ -207,9 +207,9 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \
exit $st
# Local variables:
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -4,7 +4,7 @@
* Copyright 2012-2014 Ecole Normale Superieure
* Copyright 2014 INRIA Rocquencourt
* Copyright 2016 Sven Verdoolaege
* Copyright 2018 Cerebras Systems
* Copyright 2018,2020 Cerebras Systems
*
* Use of this software is governed by the MIT license
*
@ -196,6 +196,23 @@ __isl_give isl_aff *isl_aff_nan_on_domain(__isl_take isl_local_space *ls)
return isl_aff_set_nan(aff);
}
/* Return an affine expression defined on the specified domain space
* that represents NaN.
*/
__isl_give isl_aff *isl_aff_nan_on_domain_space(__isl_take isl_space *space)
{
return isl_aff_nan_on_domain(isl_local_space_from_space(space));
}
/* Return a piecewise affine expression defined on the specified domain space
* that represents NaN.
*/
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
__isl_take isl_space *space)
{
return isl_pw_aff_from_aff(isl_aff_nan_on_domain_space(space));
}
/* Return a piecewise affine expression defined on the specified domain
* that represents NaN.
*/
@ -901,25 +918,12 @@ __isl_give isl_aff *isl_aff_add_constant(__isl_take isl_aff *aff, isl_int v)
return aff;
}
/* Add "v" to the constant term of "aff".
*
* A NaN is unaffected by this operation.
/* Add "v" to the constant term of "aff",
* in case "aff" is a rational expression.
*/
__isl_give isl_aff *isl_aff_add_constant_val(__isl_take isl_aff *aff,
static __isl_give isl_aff *isl_aff_add_rat_constant_val(__isl_take isl_aff *aff,
__isl_take isl_val *v)
{
if (!aff || !v)
goto error;
if (isl_aff_is_nan(aff) || isl_val_is_zero(v)) {
isl_val_free(v);
return aff;
}
if (!isl_val_is_rat(v))
isl_die(isl_aff_get_ctx(aff), isl_error_invalid,
"expecting rational value", goto error);
aff = isl_aff_cow(aff);
if (!aff)
goto error;
@ -953,6 +957,58 @@ error:
return NULL;
}
/* Return the first argument and free the second.
*/
static __isl_give isl_aff *pick_free(__isl_take isl_aff *aff,
__isl_take isl_val *v)
{
isl_val_free(v);
return aff;
}
/* Replace the first argument by NaN and free the second argument.
*/
static __isl_give isl_aff *set_nan_free_val(__isl_take isl_aff *aff,
__isl_take isl_val *v)
{
isl_val_free(v);
return isl_aff_set_nan(aff);
}
/* Add "v" to the constant term of "aff".
*
* A NaN is unaffected by this operation.
* Conversely, adding a NaN turns "aff" into a NaN.
*/
__isl_give isl_aff *isl_aff_add_constant_val(__isl_take isl_aff *aff,
__isl_take isl_val *v)
{
isl_bool is_nan, is_zero, is_rat;
is_nan = isl_aff_is_nan(aff);
is_zero = isl_val_is_zero(v);
if (is_nan < 0 || is_zero < 0)
goto error;
if (is_nan || is_zero)
return pick_free(aff, v);
is_nan = isl_val_is_nan(v);
is_rat = isl_val_is_rat(v);
if (is_nan < 0 || is_rat < 0)
goto error;
if (is_nan)
return set_nan_free_val(aff, v);
if (!is_rat)
isl_die(isl_aff_get_ctx(aff), isl_error_invalid,
"expecting rational value or NaN", goto error);
return isl_aff_add_rat_constant_val(aff, v);
error:
isl_aff_free(aff);
isl_val_free(v);
return NULL;
}
__isl_give isl_aff *isl_aff_add_constant_si(__isl_take isl_aff *aff, int v)
{
isl_int t;
@ -4151,6 +4207,18 @@ __isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
return isl_pw_multi_aff_from_multi_aff(isl_multi_aff_identity(space));
}
/* Create a piecewise multi expression that maps elements in the given space
* to themselves.
*/
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity_on_domain_space(
__isl_take isl_space *space)
{
isl_multi_aff *ma;
ma = isl_multi_aff_identity_on_domain_space(space);
return isl_pw_multi_aff_from_multi_aff(ma);
}
/* Exploit the equalities in "eq" to simplify the affine expressions.
*/
static __isl_give isl_multi_aff *isl_multi_aff_substitute_equalities(
@ -6432,6 +6500,23 @@ error:
#include <isl_multi_zero_templ.c>
#include <isl_multi_unbind_params_templ.c>
/* If "mpa" has an explicit domain, then intersect the domain of "map"
* with this explicit domain.
*/
__isl_give isl_map *isl_map_intersect_multi_pw_aff_explicit_domain(
__isl_take isl_map *map, __isl_keep isl_multi_pw_aff *mpa)
{
isl_set *dom;
if (!isl_multi_pw_aff_has_explicit_domain(mpa))
return map;
dom = isl_multi_pw_aff_domain(isl_multi_pw_aff_copy(mpa));
map = isl_map_intersect_domain(map, dom);
return map;
}
/* Are all elements of "mpa" piecewise constants?
*/
isl_bool isl_multi_pw_aff_is_cst(__isl_keep isl_multi_pw_aff *mpa)
@ -7372,17 +7457,24 @@ __isl_give isl_map *isl_map_eq_at_multi_pw_aff(__isl_take isl_map *map,
}
/* Return a map containing pairs of elements in the domains of "mpa1" and "mpa2"
* where the function values of "mpa1" lexicographically satisfies "base"
* compared to that of "mpa2". "space" is the space of the result.
* where the function values of "mpa1" lexicographically satisfies
* "strict_base"/"base" compared to that of "mpa2".
* "space" is the space of the result.
* The parameters of "mpa1" and "mpa2" are assumed to have been aligned.
*
* "mpa1" lexicographically satisfies "base" compared to "mpa2"
* if its i-th element satisfies "base" when compared to
* the i-th element of "mpa2" while all previous elements are
* "mpa1" lexicographically satisfies "strict_base"/"base" compared to "mpa2"
* if, for some i, the i-th element of "mpa1" satisfies "strict_base"/"base"
* when compared to the i-th element of "mpa2" while all previous elements are
* pairwise equal.
* In particular, if i corresponds to the final elements
* then they need to satisfy "base", while "strict_base" needs to be satisfied
* for other values of i.
* If "base" is a strict order, then "base" and "strict_base" are the same.
*/
static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
__isl_keep isl_multi_pw_aff *mpa1, __isl_keep isl_multi_pw_aff *mpa2,
__isl_give isl_map *(*strict_base)(__isl_take isl_pw_aff *pa1,
__isl_take isl_pw_aff *pa2),
__isl_give isl_map *(*base)(__isl_take isl_pw_aff *pa1,
__isl_take isl_pw_aff *pa2),
__isl_take isl_space *space)
@ -7398,16 +7490,19 @@ static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
rest = isl_map_universe(space);
for (i = 0; i < n; ++i) {
int last;
isl_pw_aff *pa1, *pa2;
isl_map *map;
last = i == n - 1;
pa1 = isl_multi_pw_aff_get_pw_aff(mpa1, i);
pa2 = isl_multi_pw_aff_get_pw_aff(mpa2, i);
map = base(pa1, pa2);
map = last ? base(pa1, pa2) : strict_base(pa1, pa2);
map = isl_map_intersect(map, isl_map_copy(rest));
res = isl_map_union(res, map);
if (i == n - 1)
if (last)
continue;
pa1 = isl_multi_pw_aff_get_pw_aff(mpa1, i);
@ -7421,19 +7516,27 @@ static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
}
#undef ORDER
#define ORDER le
#define ORDER le
#undef STRICT_ORDER
#define STRICT_ORDER lt
#include "isl_aff_lex_templ.c"
#undef ORDER
#define ORDER lt
#define ORDER lt
#undef STRICT_ORDER
#define STRICT_ORDER lt
#include "isl_aff_lex_templ.c"
#undef ORDER
#define ORDER ge
#define ORDER ge
#undef STRICT_ORDER
#define STRICT_ORDER gt
#include "isl_aff_lex_templ.c"
#undef ORDER
#define ORDER gt
#define ORDER gt
#undef STRICT_ORDER
#define STRICT_ORDER gt
#include "isl_aff_lex_templ.c"
/* Compare two isl_affs.
@ -7689,6 +7792,104 @@ isl_union_pw_multi_aff_apply_union_pw_multi_aff(
return isl_union_pw_multi_aff_pullback_union_pw_multi_aff(upma2, upma1);
}
#undef TYPE
#define TYPE isl_pw_multi_aff
static
#include "isl_copy_tuple_id_templ.c"
/* Given a function "pma1" of the form A[B -> C] -> D and
* a function "pma2" of the form E -> B,
* replace the domain of the wrapped relation inside the domain of "pma1"
* by the preimage with respect to "pma2".
* In other words, plug in "pma2" in this nested domain.
* The result is of the form A[E -> C] -> D.
*
* In particular, extend E -> B to A[E -> C] -> A[B -> C] and
* plug that into "pma1".
*/
__isl_give isl_pw_multi_aff *
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2)
{
isl_space *pma1_space, *pma2_space;
isl_space *space;
isl_pw_multi_aff *id;
pma1_space = isl_pw_multi_aff_peek_space(pma1);
pma2_space = isl_pw_multi_aff_peek_space(pma2);
if (isl_space_check_domain_is_wrapping(pma1_space) < 0)
goto error;
if (isl_space_check_wrapped_tuple_is_equal(pma1_space,
isl_dim_in, isl_dim_in, pma2_space, isl_dim_out) < 0)
goto error;
space = isl_space_domain(isl_space_copy(pma1_space));
space = isl_space_range(isl_space_unwrap(space));
id = isl_pw_multi_aff_identity_on_domain_space(space);
pma2 = isl_pw_multi_aff_product(pma2, id);
pma2 = isl_pw_multi_aff_copy_tuple_id(pma2, isl_dim_in,
pma1_space, isl_dim_in);
pma2 = isl_pw_multi_aff_copy_tuple_id(pma2, isl_dim_out,
pma1_space, isl_dim_in);
return isl_pw_multi_aff_pullback_pw_multi_aff(pma1, pma2);
error:
isl_pw_multi_aff_free(pma1);
isl_pw_multi_aff_free(pma2);
return NULL;
}
/* If data->pma and "pma2" are such that
* data->pma is of the form A[B -> C] -> D and
* "pma2" is of the form E -> B,
* then replace the domain of the wrapped relation
* inside the domain of data->pma by the preimage with respect to "pma2" and
* add the result to data->res.
*/
static isl_stat preimage_domain_wrapped_domain_entry(
__isl_take isl_pw_multi_aff *pma2, void *user)
{
struct isl_union_pw_multi_aff_bin_data *data = user;
isl_space *pma1_space, *pma2_space;
isl_bool match;
pma1_space = isl_pw_multi_aff_peek_space(data->pma);
pma2_space = isl_pw_multi_aff_peek_space(pma2);
match = isl_space_domain_is_wrapping(pma1_space);
if (match >= 0 && match)
match = isl_space_wrapped_tuple_is_equal(pma1_space, isl_dim_in,
isl_dim_in, pma2_space, isl_dim_out);
if (match < 0 || !match) {
isl_pw_multi_aff_free(pma2);
return match < 0 ? isl_stat_error : isl_stat_ok;
}
pma2 = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
isl_pw_multi_aff_copy(data->pma), pma2);
data->res = isl_union_pw_multi_aff_add_pw_multi_aff(data->res, pma2);
return isl_stat_non_null(data->res);
}
/* For each pair of functions A[B -> C] -> D in "upma1" and
* E -> B in "upma2",
* replace the domain of the wrapped relation inside the domain of the first
* by the preimage with respect to the second and collect the results.
* In other words, plug in the second function in this nested domain.
* The results are of the form A[E -> C] -> D.
*/
__isl_give isl_union_pw_multi_aff *
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
__isl_take isl_union_pw_multi_aff *upma1,
__isl_take isl_union_pw_multi_aff *upma2)
{
return bin_op(upma1, upma2, &preimage_domain_wrapped_domain_entry);
}
/* Check that the domain space of "upa" matches "space".
*
* This function is called from isl_multi_union_pw_aff_set_union_pw_aff and

View File

@ -17,15 +17,19 @@
* The parameters of "mpa1" and "mpa2" are assumed to have been aligned.
*
* "mpa1" is in the given lexicographic order compared to "mpa2"
* if its i-th element is in that order compared to
* if, for some i, the i-th element of "mpa1" is in that order compared to
* the i-th element of "mpa2" while all previous elements are
* pairwise equal.
* pairwise equal, where the order needs to be strict (not-equal)
* if i corresponds to anything but the last element.
* The strict version of "ORDER" is defined by "STRICT_ORDER",
* which is the same if "ORDER" itself is strict.
*/
static __isl_give isl_map *FN(FN(isl_multi_pw_aff_lex,ORDER),map_on_space)(
__isl_keep isl_multi_pw_aff *mpa1, __isl_keep isl_multi_pw_aff *mpa2,
__isl_take isl_space *space)
{
return isl_multi_pw_aff_lex_map_on_space(mpa1, mpa2,
&FN(FN(isl_pw_aff,STRICT_ORDER),map),
&FN(FN(isl_pw_aff,ORDER),map), space);
}

View File

@ -200,6 +200,9 @@ __isl_give isl_basic_set *isl_aff_pos_basic_set(__isl_take isl_aff *aff);
#undef EXPLICIT_DOMAIN
__isl_give isl_map *isl_map_intersect_multi_pw_aff_explicit_domain(
__isl_take isl_map *map, __isl_keep isl_multi_pw_aff *mpa);
#undef EL
#define EL isl_union_pw_aff

View File

@ -17,6 +17,7 @@
static struct isl_arg help_arg[] = {
ISL_ARG_PHANTOM_BOOL('h', "help", NULL, "print this help, then exit")
{ isl_arg_end }
};
static void set_default_choice(struct isl_arg *arg, void *opt)

View File

@ -5187,6 +5187,32 @@ static __isl_give isl_ast_graft_list *build_ast_from_leaf(
return list;
}
/* Check that the band partial schedule "partial" does not filter out
* any statement instances, as specified by the range of "executed".
*/
static isl_stat check_band_schedule_total_on_instances(
__isl_keep isl_multi_union_pw_aff *partial,
__isl_keep isl_union_map *executed)
{
isl_bool subset;
isl_union_set *domain, *instances;
instances = isl_union_map_range(isl_union_map_copy(executed));
partial = isl_multi_union_pw_aff_copy(partial);
domain = isl_multi_union_pw_aff_domain(partial);
subset = isl_union_set_is_subset(instances, domain);
isl_union_set_free(domain);
isl_union_set_free(instances);
if (subset < 0)
return isl_stat_error;
if (!subset)
isl_die(isl_union_map_get_ctx(executed), isl_error_invalid,
"band node is not allowed to drop statement instances",
return isl_stat_error);
return isl_stat_ok;
}
/* Generate an AST that visits the elements in the domain of "executed"
* in the relative order specified by the band node "node" and its descendants.
*
@ -5224,6 +5250,9 @@ static __isl_give isl_ast_graft_list *build_ast_from_band(
isl_ast_build_get_space(build, 1));
space = isl_multi_union_pw_aff_get_space(extra);
if (check_band_schedule_total_on_instances(extra, executed) < 0)
executed = isl_union_map_free(executed);
extra_umap = isl_union_map_from_multi_union_pw_aff(extra);
extra_umap = isl_union_map_reverse(extra_umap);

View File

@ -99,11 +99,18 @@ error:
* which is the case if we select exactly one vertex (i.e., one of the
* exponents in "k" is exactly "d") and if that vertex
* is integral for all values of the parameters.
*
* If the degree "d" is zero, then there are no exponents.
* Since the polynomial is a constant expression in this case,
* the bound is necessarily tight.
*/
static isl_bool is_tight(int *k, int n, int d, isl_cell *cell)
{
int i;
if (d == 0)
return isl_bool_true;
for (i = 0; i < n; ++i) {
int v;
if (!k[i])
@ -352,43 +359,34 @@ error:
* We compute the chamber decomposition of the parametric polytope "bset"
* and then perform bernstein expansion on the parametric vertices
* that are active on each chamber.
*
* If the polynomial does not depend on the set variables
* (and in particular if the number of set variables is zero)
* then the bound is equal to the polynomial and
* no actual bernstein expansion needs to be performed.
*/
static __isl_give isl_pw_qpolynomial_fold *bernstein_coefficients_base(
__isl_take isl_basic_set *bset,
__isl_take isl_qpolynomial *poly, struct bernstein_data *data,
isl_bool *tight)
{
int degree;
isl_size nvar;
isl_space *space;
isl_pw_qpolynomial_fold *pwf;
isl_vertices *vertices;
isl_bool covers;
nvar = isl_basic_set_dim(bset, isl_dim_set);
if (nvar < 0)
bset = isl_basic_set_free(bset);
if (nvar == 0) {
isl_set *dom;
isl_qpolynomial_fold *fold;
if (nvar == 0)
return isl_qpolynomial_cst_bound(bset, poly, data->type, tight);
fold = isl_qpolynomial_fold_alloc(data->type, poly);
dom = isl_set_from_basic_set(bset);
if (tight)
*tight = isl_bool_true;
pwf = isl_pw_qpolynomial_fold_alloc(data->type, dom, fold);
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
}
if (isl_qpolynomial_is_zero(poly)) {
isl_set *dom;
isl_qpolynomial_fold *fold;
fold = isl_qpolynomial_fold_alloc(data->type, poly);
dom = isl_set_from_basic_set(bset);
pwf = isl_pw_qpolynomial_fold_alloc(data->type, dom, fold);
if (tight)
*tight = isl_bool_true;
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
}
degree = isl_qpolynomial_degree(poly);
if (degree < -1)
bset = isl_basic_set_free(bset);
if (degree <= 0)
return isl_qpolynomial_cst_bound(bset, poly, data->type, tight);
space = isl_basic_set_get_space(bset);
space = isl_space_params(space);
@ -482,7 +480,7 @@ static __isl_give isl_pw_qpolynomial_fold *bernstein_coefficients_factors(
goto error;
if (f->n_group == 0) {
isl_factorizer_free(f);
return bernstein_coefficients_base(bset, poly, data, tight);
return bernstein_coefficients_base(bset, poly, data, tight);
}
set = isl_set_from_basic_set(bset);
@ -575,11 +573,9 @@ isl_stat isl_qpolynomial_bound_on_domain_bernstein(
pwf = bernstein_coefficients_base(bset, poly, &data, tp);
if (tight)
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(bound->pwf_tight, pwf);
return isl_bound_add_tight(bound, pwf);
else
bound->pwf = isl_pw_qpolynomial_fold_fold(bound->pwf, pwf);
return isl_stat_ok;
return isl_bound_add(bound, pwf);
error:
isl_basic_set_free(bset);
isl_qpolynomial_free(poly);

View File

@ -16,23 +16,91 @@
#include <isl_polynomial_private.h>
#include <isl_options_private.h>
/* Given a polynomial "poly" that is constant in terms
* of the domain variables, construct a polynomial reduction
* of type "type" that is equal to "poly" on "bset",
* with the domain projected onto the parameters.
*/
__isl_give isl_pw_qpolynomial_fold *isl_qpolynomial_cst_bound(
__isl_take isl_basic_set *bset, __isl_take isl_qpolynomial *poly,
enum isl_fold type, isl_bool *tight)
{
isl_set *dom;
isl_qpolynomial_fold *fold;
isl_pw_qpolynomial_fold *pwf;
fold = isl_qpolynomial_fold_alloc(type, poly);
dom = isl_set_from_basic_set(bset);
if (tight)
*tight = isl_bool_true;
pwf = isl_pw_qpolynomial_fold_alloc(type, dom, fold);
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
}
/* Add the bound "pwf", which is not known to be tight,
* to the output of "bound".
*/
isl_stat isl_bound_add(struct isl_bound *bound,
__isl_take isl_pw_qpolynomial_fold *pwf)
{
bound->pwf = isl_pw_qpolynomial_fold_fold(bound->pwf, pwf);
return isl_stat_non_null(bound->pwf);
}
/* Add the bound "pwf", which is known to be tight,
* to the output of "bound".
*/
isl_stat isl_bound_add_tight(struct isl_bound *bound,
__isl_take isl_pw_qpolynomial_fold *pwf)
{
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(bound->pwf_tight, pwf);
return isl_stat_non_null(bound->pwf);
}
/* Given a polynomial "poly" that is constant in terms
* of the domain variables and the domain "bset",
* construct the corresponding polynomial reduction and
* add it to the tight bounds of "bound".
*/
static isl_stat add_constant_poly(__isl_take isl_basic_set *bset,
__isl_take isl_qpolynomial *poly, struct isl_bound *bound)
{
isl_pw_qpolynomial_fold *pwf;
pwf = isl_qpolynomial_cst_bound(bset, poly, bound->type, NULL);
return isl_bound_add_tight(bound, pwf);
}
/* Compute a bound on the polynomial defined over the parametric polytope
* using either range propagation or bernstein expansion and
* store the result in bound->pwf and bound->pwf_tight.
* Since bernstein expansion requires bounded domains, we apply
* range propagation on unbounded domains. Otherwise, we respect the choice
* of the user.
*
* If the polynomial does not depend on the set variables
* then the bound is equal to the polynomial and
* it can be added to "bound" directly.
*/
static isl_stat compressed_guarded_poly_bound(__isl_take isl_basic_set *bset,
__isl_take isl_qpolynomial *poly, void *user)
{
struct isl_bound *bound = (struct isl_bound *)user;
isl_ctx *ctx;
int bounded;
int degree;
if (!bset || !poly)
goto error;
if (bset->ctx->opt->bound == ISL_BOUND_RANGE)
degree = isl_qpolynomial_degree(poly);
if (degree < -1)
goto error;
if (degree <= 0)
return add_constant_poly(bset, poly, bound);
ctx = isl_basic_set_get_ctx(bset);
if (ctx->opt->bound == ISL_BOUND_RANGE)
return isl_qpolynomial_bound_on_domain_range(bset, poly, bound);
bounded = isl_basic_set_is_bounded(bset);
@ -94,9 +162,8 @@ static isl_stat unwrapped_guarded_poly_bound(__isl_take isl_basic_set *bset,
bound->pwf_tight = isl_pw_qpolynomial_fold_morph_domain(
bound->pwf_tight, morph);
bound->pwf = isl_pw_qpolynomial_fold_fold(top_pwf, bound->pwf);
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(top_pwf_tight,
bound->pwf_tight);
isl_bound_add(bound, top_pwf);
isl_bound_add_tight(bound, top_pwf_tight);
return r;
error:
@ -105,6 +172,24 @@ error:
return isl_stat_error;
}
/* Update bound->pwf and bound->pwf_tight with a bound
* of type bound->type on the polynomial "poly" over the domain "bset".
*
* If the original problem had a wrapped relation in the domain,
* meaning that the bound should be computed over the range
* of this relation, then temporarily treat the domain dimensions
* of this wrapped relation as parameters, compute a bound
* in terms of these and the original parameters,
* turn the parameters back into set dimensions and
* add the results to bound->pwf and bound->pwf_tight.
*
* Note that even though "bset" is known to live in the same space
* as the domain of "poly", the names of the set dimensions
* may be different (or missing). Make sure the naming is exactly
* the same before turning these dimensions into parameters
* to ensure that the spaces are still the same after
* this operation.
*/
static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
__isl_take isl_qpolynomial *poly, void *user)
{
@ -124,6 +209,9 @@ static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
if (nparam < 0 || n_in < 0)
goto error;
space = isl_qpolynomial_get_domain_space(poly);
bset = isl_basic_set_reset_space(bset, space);
bset = isl_basic_set_move_dims(bset, isl_dim_param, nparam,
isl_dim_set, 0, n_in);
poly = isl_qpolynomial_move_dims(poly, isl_dim_param, nparam,
@ -148,9 +236,8 @@ static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
bound->pwf_tight = isl_pw_qpolynomial_fold_reset_space(bound->pwf_tight,
isl_space_copy(bound->dim));
bound->pwf = isl_pw_qpolynomial_fold_fold(top_pwf, bound->pwf);
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(top_pwf_tight,
bound->pwf_tight);
isl_bound_add(bound, top_pwf);
isl_bound_add_tight(bound, top_pwf_tight);
return r;
error:

View File

@ -17,4 +17,13 @@ struct isl_bound {
isl_pw_qpolynomial_fold *pwf_tight;
};
__isl_give isl_pw_qpolynomial_fold *isl_qpolynomial_cst_bound(
__isl_take isl_basic_set *bset, __isl_take isl_qpolynomial *poly,
enum isl_fold type, isl_bool *tight);
isl_stat isl_bound_add(struct isl_bound *bound,
__isl_take isl_pw_qpolynomial_fold *pwf);
isl_stat isl_bound_add_tight(struct isl_bound *bound,
__isl_take isl_pw_qpolynomial_fold *pwf);
#endif

View File

@ -2618,6 +2618,7 @@ __isl_give isl_basic_map *isl_basic_map_plain_unshifted_simple_hull(
bmap1 = isl_basic_map_drop_constraints_involving_unknown_divs(bmap1);
bmap2 = isl_basic_map_drop_constraints_involving_unknown_divs(bmap2);
bmap1 = isl_basic_map_order_divs(bmap1);
bmap2 = isl_basic_map_align_divs(bmap2, bmap1);
bmap1 = isl_basic_map_align_divs(bmap1, bmap2);
bmap1 = isl_basic_map_sort_constraints(bmap1);

View File

@ -0,0 +1,33 @@
/*
* Copyright 2019 Cerebras Systems
*
* Use of this software is governed by the MIT license
*
* Written by Sven Verdoolaege,
* Cerebras Systems, 175 S San Antonio Rd, Los Altos, CA, USA
*/
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
#define FN(TYPE,NAME) xFN(TYPE,NAME)
/* Copy the identifier of tuple "src_type" in "src"
* to that of "dst_type" in "dst", if there is any such identifier.
*/
__isl_give TYPE *FN(TYPE,copy_tuple_id)(__isl_take TYPE *dst,
enum isl_dim_type dst_type, __isl_keep isl_space *src,
enum isl_dim_type src_type)
{
isl_bool has_id;
isl_id *id;
has_id = isl_space_has_tuple_id(src, src_type);
if (has_id < 0)
return FN(TYPE,free)(dst);
if (!has_id)
return dst;
id = isl_space_get_tuple_id(src, src_type);
dst = FN(TYPE,set_tuple_id)(dst, dst_type, id);
return dst;
}

File diff suppressed because it is too large Load Diff

View File

@ -593,10 +593,7 @@ static __isl_give isl_pw_aff *add_cst(__isl_take isl_pw_aff *pwaff, isl_int v)
*/
static __isl_give isl_pw_aff *nan_on_domain(__isl_keep isl_space *space)
{
isl_local_space *ls;
ls = isl_local_space_from_space(isl_space_copy(space));
return isl_pw_aff_nan_on_domain(ls);
return isl_pw_aff_nan_on_domain_space(isl_space_copy(space));
}
static __isl_give isl_pw_aff *accept_affine(__isl_keep isl_stream *s,
@ -2602,24 +2599,28 @@ static struct isl_obj obj_read_poly(__isl_keep isl_stream *s,
static struct isl_obj obj_read_poly_or_fold(__isl_keep isl_stream *s,
__isl_take isl_set *set, struct vars *v, int n)
{
int min, max;
struct isl_obj obj = { isl_obj_pw_qpolynomial_fold, NULL };
isl_pw_qpolynomial *pwqp;
isl_pw_qpolynomial_fold *pwf = NULL;
enum isl_fold fold;
if (!isl_stream_eat_if_available(s, ISL_TOKEN_MAX))
max = isl_stream_eat_if_available(s, ISL_TOKEN_MAX);
min = !max && isl_stream_eat_if_available(s, ISL_TOKEN_MIN);
if (!min && !max)
return obj_read_poly(s, set, v, n);
fold = max ? isl_fold_max : isl_fold_min;
if (isl_stream_eat(s, '('))
goto error;
pwqp = read_term(s, set, v);
pwf = isl_pw_qpolynomial_fold_from_pw_qpolynomial(isl_fold_max, pwqp);
pwf = isl_pw_qpolynomial_fold_from_pw_qpolynomial(fold, pwqp);
while (isl_stream_eat_if_available(s, ',')) {
isl_pw_qpolynomial_fold *pwf_i;
pwqp = read_term(s, set, v);
pwf_i = isl_pw_qpolynomial_fold_from_pw_qpolynomial(isl_fold_max,
pwqp);
pwf_i = isl_pw_qpolynomial_fold_from_pw_qpolynomial(fold, pwqp);
pwf = isl_pw_qpolynomial_fold_fold(pwf, pwf_i);
}
@ -3385,7 +3386,43 @@ __isl_give isl_pw_qpolynomial *isl_pw_qpolynomial_read_from_file(isl_ctx *ctx,
return pwqp;
}
/* Is the next token an identifer not in "v"?
/* Read an isl_pw_qpolynomial_fold from "s".
* First read a generic object and
* then check that it is an isl_pw_qpolynomial_fold.
*/
__isl_give isl_pw_qpolynomial_fold *isl_stream_read_pw_qpolynomial_fold(
__isl_keep isl_stream *s)
{
struct isl_obj obj;
obj = obj_read(s);
if (obj.v && obj.type != isl_obj_pw_qpolynomial_fold)
isl_die(s->ctx, isl_error_invalid, "invalid input", goto error);
return obj.v;
error:
obj.type->free(obj.v);
return NULL;
}
/* Read an isl_pw_qpolynomial_fold from "str".
*/
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_read_from_str(
isl_ctx *ctx, const char *str)
{
isl_pw_qpolynomial_fold *pwqp;
isl_stream *s;
s = isl_stream_new_str(ctx, str);
if (!s)
return NULL;
pwqp = isl_stream_read_pw_qpolynomial_fold(s);
isl_stream_free(s);
return pwqp;
}
/* Is the next token an identifier not in "v"?
*/
static int next_is_fresh_ident(__isl_keep isl_stream *s, struct vars *v)
{

View File

@ -0,0 +1,10 @@
#ifndef ISL_LIST_PRIVATE_H
#define ISL_LIST_PRIVATE_H
#include <isl/list.h>
#define ISL_DECLARE_LIST_FN_PRIVATE(EL) \
__isl_keep isl_##EL *isl_##EL##_list_peek( \
__isl_keep isl_##EL##_list *list, int index);
#endif

View File

@ -265,7 +265,7 @@ isl_size FN(FN(LIST(EL),n),EL_BASE)(__isl_keep LIST(EL) *list)
/* Return the element at position "index" in "list".
*/
static __isl_keep EL *FN(LIST(EL),peek)(__isl_keep LIST(EL) *list, int index)
__isl_keep EL *FN(LIST(EL),peek)(__isl_keep LIST(EL) *list, int index)
{
if (FN(LIST(EL),check_index)(list, index) < 0)
return NULL;

View File

@ -37,7 +37,7 @@ uint32_t isl_local_space_get_hash(__isl_keep isl_local_space *ls)
return 0;
hash = isl_hash_init();
space_hash = isl_space_get_hash(ls->dim);
space_hash = isl_space_get_full_hash(isl_local_space_peek_space(ls));
isl_hash_hash(hash, space_hash);
div_hash = isl_mat_get_hash(ls->div);
isl_hash_hash(hash, div_hash);
@ -163,14 +163,7 @@ isl_bool isl_local_space_is_set(__isl_keep isl_local_space *ls)
#define TYPE isl_local_space
#include "isl_type_has_equal_space_bin_templ.c"
/* Is the space of "ls" equal to "space"?
*/
isl_bool isl_local_space_has_space(__isl_keep isl_local_space *ls,
__isl_keep isl_space *space)
{
return isl_space_is_equal(isl_local_space_peek_space(ls), space);
}
#include "isl_type_has_space_templ.c"
/* Check that the space of "ls" is equal to "space".
*/

View File

@ -6864,6 +6864,18 @@ __isl_give isl_set *isl_set_upper_bound_val(__isl_take isl_set *set,
return set_from_map(isl_map_upper_bound_val(map, type, pos, value));
}
/* If "mv" has an explicit domain, then intersect the domain of "map"
* with this explicit domain.
*
* An isl_multi_val object never has an explicit domain,
* so simply return "map".
*/
static __isl_give isl_map *isl_map_intersect_multi_val_explicit_domain(
__isl_take isl_map *map, __isl_keep isl_multi_val *mv)
{
return map;
}
#undef BASE
#define BASE val
#include "isl_map_bound_templ.c"
@ -6921,15 +6933,6 @@ __isl_give isl_set *isl_set_lower_bound_multi_val(__isl_take isl_set *set,
return set_bound_multi_val(set, lower, &map_lower_bound_val);
}
/* Force the values of the output dimensions of "map"
* to be no smaller than the corresponding values in "lower".
*/
__isl_give isl_map *isl_map_lower_bound_multi_val(__isl_take isl_map *map,
__isl_take isl_multi_val *lower)
{
return map_bound_multi_val(map, lower, &map_lower_bound_val);
}
/* Wrapper around isl_map_upper_bound_val for use in map_bound_multi_val,
* setting a bound on the given output dimension.
*/
@ -6948,15 +6951,6 @@ __isl_give isl_set *isl_set_upper_bound_multi_val(__isl_take isl_set *set,
return set_bound_multi_val(set, upper, &map_upper_bound_val);
}
/* Force the values of the set dimensions of "set"
* to be no greater than the corresponding values in "upper".
*/
__isl_give isl_map *isl_map_upper_bound_multi_val(__isl_take isl_map *map,
__isl_take isl_multi_val *upper)
{
return map_bound_multi_val(map, upper, &map_upper_bound_val);
}
/* Force the symbolic constant expression "bound"
* to satisfy the relation "order" with respect to
* the output variable at position "pos" of "map".
@ -8287,6 +8281,11 @@ error:
return NULL;
}
#undef TYPE
#define TYPE isl_map
static
#include "isl_copy_tuple_id_templ.c"
/* Data structure that specifies how isl_map_intersect_factor
* should operate.
*
@ -8322,8 +8321,7 @@ static __isl_give isl_map *isl_map_intersect_factor(
__isl_take isl_map *map, __isl_take isl_map *factor,
struct isl_intersect_factor_control *control)
{
isl_bool equal, has_id;
isl_id *id;
isl_bool equal;
isl_space *space;
isl_map *other, *product;
@ -8336,19 +8334,12 @@ static __isl_give isl_map *isl_map_intersect_factor(
}
space = isl_map_get_space(map);
has_id = isl_space_has_tuple_id(space, control->preserve_type);
if (has_id < 0)
space = isl_space_free(space);
else if (has_id)
id = isl_space_get_tuple_id(space, control->preserve_type);
other = isl_map_universe(control->other_factor(space));
product = control->product(factor, other);
if (has_id >= 0 && has_id)
product = isl_map_set_tuple_id(product,
control->preserve_type, id);
space = isl_map_peek_space(map);
product = isl_map_copy_tuple_id(product, control->preserve_type,
space, control->preserve_type);
return map_intersect(map, product);
error:
isl_map_free(map);
@ -8372,6 +8363,21 @@ static __isl_give isl_map *isl_map_reverse_range_product(
return isl_map_range_product(map2, map1);
}
/* Given a map "map" in a space [A -> B] -> C and a map "factor"
* in the space A -> C, return the intersection.
*/
__isl_give isl_map *isl_map_intersect_domain_factor_domain(
__isl_take isl_map *map, __isl_take isl_map *factor)
{
struct isl_intersect_factor_control control = {
.preserve_type = isl_dim_in,
.other_factor = isl_space_domain_factor_range,
.product = isl_map_domain_product,
};
return isl_map_intersect_factor(map, factor, &control);
}
/* Given a map "map" in a space [A -> B] -> C and a map "factor"
* in the space B -> C, return the intersection.
*/
@ -8604,6 +8610,17 @@ isl_bool isl_map_tuple_is_equal(__isl_keep isl_map *map1,
return isl_space_tuple_is_equal(space1, type1, space2, type2);
}
/* Is the space of "obj" equal to "space", ignoring parameters?
*/
isl_bool isl_map_has_space_tuples(__isl_keep isl_map *map,
__isl_keep isl_space *space)
{
isl_space *map_space;
map_space = isl_map_peek_space(map);
return isl_space_has_equal_tuples(map_space, space);
}
/* Check that "map" is a transformation, i.e.,
* that it relates elements from the same space.
*/
@ -8707,6 +8724,20 @@ __isl_give isl_map *isl_map_deltas_map(__isl_take isl_map *map)
&isl_basic_map_deltas_map);
}
/* Return pairs of elements { x -> y } such that y - x is in "deltas".
*/
__isl_give isl_map *isl_set_translation(__isl_take isl_set *deltas)
{
isl_space *space;
isl_map *map;
space = isl_space_map_from_set(isl_set_get_space(deltas));
map = isl_map_deltas_map(isl_map_universe(space));
map = isl_map_intersect_range(map, deltas);
return isl_set_unwrap(isl_map_domain(map));
}
__isl_give isl_basic_map *isl_basic_map_identity(__isl_take isl_space *space)
{
isl_size n_in, n_out;
@ -9022,6 +9053,7 @@ isl_stat isl_basic_set_check_equal_space(__isl_keep isl_basic_set *bset1,
#include "isl_type_has_equal_space_bin_templ.c"
#include "isl_type_check_equal_space_templ.c"
#include "isl_type_has_space_templ.c"
isl_bool isl_set_has_equal_space(__isl_keep isl_set *set1,
__isl_keep isl_set *set2)
@ -9480,6 +9512,16 @@ static int find_div(__isl_keep isl_basic_map *dst,
/* Align the divs of "dst" to those of "src", adding divs from "src"
* if needed. That is, make sure that the first src->n_div divs
* of the result are equal to those of src.
* The integer division of "src" are assumed to be ordered.
*
* The integer divisions are swapped into the right position
* (possibly after adding them first). This may result
* in the remaining integer divisions appearing in the wrong order,
* i.e., with some integer division appearing before
* some other integer division on which it depends.
* The integer divisions therefore need to be ordered.
* This will not affect the integer divisions aligned to those of "src",
* since "src" is assumed to have ordered integer divisions.
*
* The result is not finalized as by design it will have redundant
* divs if any divs from "src" were copied.
@ -9511,10 +9553,6 @@ __isl_give isl_basic_map *isl_basic_map_align_divs(
if (v_div < 0)
return isl_basic_map_free(dst);
src = isl_basic_map_order_divs(isl_basic_map_copy(src));
if (!src)
return isl_basic_map_free(dst);
extended = 0;
dst_n_div = isl_basic_map_dim(dst, isl_dim_div);
if (dst_n_div < 0)
@ -9528,32 +9566,27 @@ __isl_give isl_basic_map *isl_basic_map_align_divs(
int extra = src->n_div - i;
dst = isl_basic_map_cow(dst);
if (!dst)
goto error;
return isl_basic_map_free(dst);
dst = isl_basic_map_extend(dst,
extra, 0, 2 * extra);
extended = 1;
}
j = isl_basic_map_alloc_div(dst);
if (j < 0)
goto error;
return isl_basic_map_free(dst);
isl_seq_cpy(dst->div[j], src->div[i], 1+1+v_div+i);
isl_seq_clr(dst->div[j]+1+1+v_div+i, dst->n_div - i);
dst_n_div++;
dst = isl_basic_map_add_div_constraints(dst, j);
if (!dst)
goto error;
return isl_basic_map_free(dst);
}
if (j != i)
dst = isl_basic_map_swap_div(dst, i, j);
if (!dst)
goto error;
return isl_basic_map_free(dst);
}
isl_basic_map_free(src);
return dst;
error:
isl_basic_map_free(src);
isl_basic_map_free(dst);
return NULL;
return isl_basic_map_order_divs(dst);
}
__isl_give isl_map *isl_map_align_divs_internal(__isl_take isl_map *map)
@ -9565,6 +9598,7 @@ __isl_give isl_map *isl_map_align_divs_internal(__isl_take isl_map *map)
if (map->n == 0)
return map;
map = isl_map_compute_divs(map);
map = isl_map_order_divs(map);
map = isl_map_cow(map);
if (!map)
return NULL;
@ -9613,6 +9647,7 @@ __isl_give isl_map *isl_map_align_divs_to_basic_map_list(
isl_basic_map *bmap;
bmap = isl_basic_map_list_get_basic_map(list, i);
bmap = isl_basic_map_order_divs(bmap);
map->p[0] = isl_basic_map_align_divs(map->p[0], bmap);
isl_basic_map_free(bmap);
}

View File

@ -25,6 +25,9 @@ static isl_stat FN(check_map_equal_tuples_multi,BASE)(__isl_keep isl_map *map,
/* Apply "map_bound" to "map" with the corresponding value in "bound"
* for each output dimension.
* If "bound" has an explicit domain (which implies that "bound"
* is zero-dimensional), then intersect the domain of "map"
* with this explicit domain instead.
*/
static __isl_give isl_map *FN(map_bound_multi,BASE)(__isl_take isl_map *map,
__isl_take MULTI(BASE) *bound,
@ -44,6 +47,7 @@ static __isl_give isl_map *FN(map_bound_multi,BASE)(__isl_take isl_map *map,
el = FN(MULTI(BASE),get_at)(bound, i);
map = map_bound(map, i, el);
}
map = FN(FN(isl_map_intersect_multi,BASE),explicit_domain)(map, bound);
FN(MULTI(BASE),free)(bound);
return map;
error:

View File

@ -562,6 +562,10 @@ isl_bool isl_map_space_tuple_is_equal(__isl_keep isl_map *map,
isl_bool isl_map_tuple_is_equal(__isl_keep isl_map *map1,
enum isl_dim_type type1, __isl_keep isl_map *map2,
enum isl_dim_type type2);
isl_bool isl_map_has_space(__isl_keep isl_map *map,
__isl_keep isl_space *space);
isl_bool isl_map_has_space_tuples(__isl_keep isl_map *map,
__isl_keep isl_space *space);
isl_bool isl_basic_map_is_transformation(__isl_keep isl_basic_map *bmap);
isl_stat isl_map_check_transformation(__isl_keep isl_map *map);

View File

@ -2149,6 +2149,7 @@ static __isl_give isl_basic_map *isl_basic_map_remove_shifted_constraints(
return bmap;
}
bmap = isl_basic_map_order_divs(bmap);
context = isl_basic_map_align_divs(context, bmap);
bmap = isl_basic_map_align_divs(bmap, context);
@ -3284,6 +3285,7 @@ __isl_give isl_basic_map *isl_basic_map_gist(__isl_take isl_basic_map *bmap,
bmap = isl_basic_map_remove_redundancies(bmap);
context = isl_basic_map_remove_redundancies(context);
bmap = isl_basic_map_order_divs(bmap);
context = isl_basic_map_align_divs(context, bmap);
n_div = isl_basic_map_dim(context, isl_dim_div);
@ -3520,6 +3522,7 @@ __isl_give isl_basic_map *isl_basic_map_plain_gist(
isl_die(isl_basic_map_get_ctx(bmap), isl_error_invalid,
"context has unknown divs", goto error);
context = isl_basic_map_order_divs(context);
bmap = isl_basic_map_align_divs(bmap, context);
bmap = isl_basic_map_gauss(bmap, NULL);
bmap = isl_basic_map_sort_constraints(bmap);

View File

@ -64,12 +64,14 @@ __isl_give isl_mat *isl_mat_alloc(isl_ctx *ctx,
mat->block = isl_blk_alloc(ctx, n_row * n_col);
if (isl_blk_is_error(mat->block))
goto error;
mat->row = isl_alloc_array(ctx, isl_int *, n_row);
mat->row = isl_calloc_array(ctx, isl_int *, n_row);
if (n_row && !mat->row)
goto error;
for (i = 0; i < n_row; ++i)
mat->row[i] = mat->block.data + i * n_col;
if (n_col != 0) {
for (i = 0; i < n_row; ++i)
mat->row[i] = mat->block.data + i * n_col;
}
mat->ctx = ctx;
isl_ctx_ref(ctx);
@ -646,9 +648,6 @@ __isl_give isl_mat *isl_mat_left_hermite(__isl_take isl_mat *M, int neg,
*U = NULL;
if (Q)
*Q = NULL;
if (!M)
goto error;
M = isl_mat_cow(M);
if (!M)
goto error;
if (U) {
@ -662,6 +661,13 @@ __isl_give isl_mat *isl_mat_left_hermite(__isl_take isl_mat *M, int neg,
goto error;
}
if (M->n_col == 0)
return M;
M = isl_mat_cow(M);
if (!M)
goto error;
col = 0;
isl_int_init(c);
for (row = 0; row < M->n_row; ++row) {

View File

@ -18,6 +18,8 @@
#include <isl_space_private.h>
#include <isl_equalities.h>
#include <isl_id_private.h>
#include <isl_aff_private.h>
#include <isl_vec_private.h>
isl_ctx *isl_morph_get_ctx(__isl_keep isl_morph *morph)
{
@ -179,12 +181,46 @@ __isl_give isl_multi_aff *isl_morph_get_var_multi_aff(
/* Return the domain space of "morph".
*/
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph)
static __isl_keep isl_space *isl_morph_peek_dom_space(
__isl_keep isl_morph *morph)
{
if (!morph)
return NULL;
return isl_basic_set_get_space(morph->dom);
return isl_basic_set_peek_space(morph->dom);
}
/* Return a copy of the domain space of "morph".
*/
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph)
{
return isl_space_copy(isl_morph_peek_dom_space(morph));
}
/* Check that the match against "space" with result "match" was successful.
*/
static isl_stat check_space_match(__isl_keep isl_space *space, isl_bool match)
{
if (match < 0)
return isl_stat_error;
if (!match)
isl_die(isl_space_get_ctx(space), isl_error_invalid,
"spaces don't match", return isl_stat_error);
return isl_stat_ok;
}
/* Check that "morph" can be applied to the "space".
*/
isl_stat isl_morph_check_applies(__isl_keep isl_morph *morph,
__isl_keep isl_space *space)
{
isl_space *dom_space;
isl_bool applies;
dom_space = isl_morph_peek_dom_space(morph);
applies = isl_space_is_equal(dom_space, space);
return check_space_match(space, applies);
}
__isl_give isl_space *isl_morph_get_ran_space(__isl_keep isl_morph *morph)
@ -573,191 +609,96 @@ __isl_give isl_morph *isl_basic_set_parameter_compression(
return isl_morph_alloc(dom, ran, map, inv);
}
/* Add stride constraints to "bset" based on the inverse mapping
* that was plugged in. In particular, if morph maps x' to x,
* the constraints of the original input
*
* A x' + b >= 0
*
* have been rewritten to
*
* A inv x + b >= 0
*
* However, this substitution may loose information on the integrality of x',
* so we need to impose that
*
* inv x
*
* is integral. If inv = B/d, this means that we need to impose that
*
* B x = 0 mod d
*
* or
*
* exists alpha in Z^m: B x = d alpha
*
* This function is similar to add_strides in isl_affine_hull.c
/* Construct an isl_multi_aff that corresponds
* to the affine transformation matrix "mat" and
* that lives in an anonymous space.
*/
static __isl_give isl_basic_set *add_strides(__isl_take isl_basic_set *bset,
__isl_keep isl_morph *morph)
static __isl_give isl_multi_aff *isl_multi_aff_from_aff_mat_anonymous(
__isl_take isl_mat *mat)
{
int i, div, k;
isl_int gcd;
isl_size n_row, n_col;
isl_ctx *ctx;
isl_space *space;
if (isl_int_is_one(morph->inv->row[0][0]))
return bset;
ctx = isl_mat_get_ctx(mat);
n_row = isl_mat_rows(mat);
n_col = isl_mat_cols(mat);
if (n_row < 0 || n_col < 0)
space = NULL;
else
space = isl_space_alloc(ctx, 0, n_col - 1, n_row - 1);
isl_int_init(gcd);
for (i = 0; 1 + i < morph->inv->n_row; ++i) {
isl_seq_gcd(morph->inv->row[1 + i], morph->inv->n_col, &gcd);
if (isl_int_is_divisible_by(gcd, morph->inv->row[0][0]))
continue;
div = isl_basic_set_alloc_div(bset);
if (div < 0)
goto error;
isl_int_set_si(bset->div[div][0], 0);
k = isl_basic_set_alloc_equality(bset);
if (k < 0)
goto error;
isl_seq_cpy(bset->eq[k], morph->inv->row[1 + i],
morph->inv->n_col);
isl_seq_clr(bset->eq[k] + morph->inv->n_col, bset->n_div);
isl_int_set(bset->eq[k][morph->inv->n_col + div],
morph->inv->row[0][0]);
}
isl_int_clear(gcd);
return bset;
error:
isl_int_clear(gcd);
isl_basic_set_free(bset);
return NULL;
return isl_multi_aff_from_aff_mat(space, mat);
}
/* Apply the morphism to the basic set.
* We basically just compute the preimage of "bset" under the inverse mapping
* in morph, add in stride constraints and intersect with the range
* of the morphism.
* In particular, compute the preimage of "bset" under the inverse mapping
* in morph and intersect with the range of the morphism.
* Note that the mapping in morph applies to both parameters and set dimensions,
* so the parameters need to be treated as set dimensions during the call
* to isl_basic_set_preimage_multi_aff.
*/
__isl_give isl_basic_set *isl_morph_basic_set(__isl_take isl_morph *morph,
__isl_take isl_basic_set *bset)
{
isl_basic_set *res = NULL;
isl_mat *mat = NULL;
int i, k;
int max_stride;
isl_size n_param;
isl_space *space;
isl_multi_aff *ma;
if (!morph || isl_basic_set_check_equal_space(bset, morph->dom) < 0)
goto error;
max_stride = morph->inv->n_row - 1;
if (isl_int_is_one(morph->inv->row[0][0]))
max_stride = 0;
res = isl_basic_set_alloc_space(isl_space_copy(morph->ran->dim),
bset->n_div + max_stride, bset->n_eq + max_stride, bset->n_ineq);
for (i = 0; i < bset->n_div; ++i)
if (isl_basic_set_alloc_div(res) < 0)
goto error;
mat = isl_mat_sub_alloc6(bset->ctx, bset->eq, 0, bset->n_eq,
0, morph->inv->n_row);
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
if (!mat)
n_param = isl_basic_set_dim(morph->dom, isl_dim_param);
if (n_param < 0)
goto error;
for (i = 0; i < bset->n_eq; ++i) {
k = isl_basic_set_alloc_equality(res);
if (k < 0)
goto error;
isl_seq_cpy(res->eq[k], mat->row[i], mat->n_col);
isl_seq_scale(res->eq[k] + mat->n_col, bset->eq[i] + mat->n_col,
morph->inv->row[0][0], bset->n_div);
}
isl_mat_free(mat);
mat = isl_mat_sub_alloc6(bset->ctx, bset->ineq, 0, bset->n_ineq,
0, morph->inv->n_row);
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
if (!mat)
goto error;
for (i = 0; i < bset->n_ineq; ++i) {
k = isl_basic_set_alloc_inequality(res);
if (k < 0)
goto error;
isl_seq_cpy(res->ineq[k], mat->row[i], mat->n_col);
isl_seq_scale(res->ineq[k] + mat->n_col,
bset->ineq[i] + mat->n_col,
morph->inv->row[0][0], bset->n_div);
}
isl_mat_free(mat);
ma = isl_multi_aff_from_aff_mat_anonymous(isl_mat_copy(morph->inv));
mat = isl_mat_sub_alloc6(bset->ctx, bset->div, 0, bset->n_div,
1, morph->inv->n_row);
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
if (!mat)
goto error;
for (i = 0; i < bset->n_div; ++i) {
isl_int_mul(res->div[i][0],
morph->inv->row[0][0], bset->div[i][0]);
isl_seq_cpy(res->div[i] + 1, mat->row[i], mat->n_col);
isl_seq_scale(res->div[i] + 1 + mat->n_col,
bset->div[i] + 1 + mat->n_col,
morph->inv->row[0][0], bset->n_div);
}
isl_mat_free(mat);
res = add_strides(res, morph);
if (isl_basic_set_is_rational(bset))
res = isl_basic_set_set_rational(res);
res = isl_basic_set_simplify(res);
res = isl_basic_set_finalize(res);
res = isl_basic_set_intersect(res, isl_basic_set_copy(morph->ran));
bset = isl_basic_set_move_dims(bset, isl_dim_set, 0,
isl_dim_param, 0, n_param);
bset = isl_basic_set_preimage_multi_aff(bset, ma);
space = isl_basic_set_get_space(morph->ran);
bset = isl_basic_set_reset_space(bset, space);
bset = isl_basic_set_intersect(bset, isl_basic_set_copy(morph->ran));
isl_morph_free(morph);
isl_basic_set_free(bset);
return res;
return bset;
error:
isl_mat_free(mat);
isl_morph_free(morph);
isl_basic_set_free(bset);
isl_basic_set_free(res);
return NULL;
}
/* Apply the morphism to the set.
* In particular, compute the preimage of "set" under the inverse mapping
* in morph and intersect with the range of the morphism.
* Note that the mapping in morph applies to both parameters and set dimensions,
* so the parameters need to be treated as set dimensions during the call
* to isl_set_preimage_multi_aff.
*/
__isl_give isl_set *isl_morph_set(__isl_take isl_morph *morph,
__isl_take isl_set *set)
{
int i;
isl_size n_param;
isl_space *space;
isl_multi_aff *ma;
isl_basic_set *ran;
if (!morph || isl_set_basic_set_check_equal_space(set, morph->dom) < 0)
goto error;
set = isl_set_cow(set);
if (!set)
n_param = isl_basic_set_dim(morph->dom, isl_dim_param);
if (n_param < 0)
goto error;
isl_space_free(set->dim);
set->dim = isl_space_copy(morph->ran->dim);
if (!set->dim)
goto error;
ma = isl_multi_aff_from_aff_mat_anonymous(isl_mat_copy(morph->inv));
for (i = 0; i < set->n; ++i) {
set->p[i] = isl_morph_basic_set(isl_morph_copy(morph), set->p[i]);
if (!set->p[i])
goto error;
}
set = isl_set_move_dims(set, isl_dim_set, 0, isl_dim_param, 0, n_param);
set = isl_set_preimage_multi_aff(set, ma);
space = isl_basic_set_get_space(morph->ran);
set = isl_set_reset_space(set, space);
ran = isl_basic_set_copy(morph->ran);
set = isl_set_intersect(set, isl_set_from_basic_set(ran));
isl_morph_free(morph);
ISL_F_CLR(set, ISL_SET_NORMALIZED);
return set;
error:
isl_set_free(set);

View File

@ -45,6 +45,9 @@ __isl_give isl_morph *isl_morph_copy(__isl_keep isl_morph *morph);
__isl_give isl_morph *isl_morph_identity(__isl_keep isl_basic_set *bset);
__isl_null isl_morph *isl_morph_free(__isl_take isl_morph *morph);
isl_stat isl_morph_check_applies(__isl_keep isl_morph *morph,
__isl_keep isl_space *space);
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph);
__isl_give isl_space *isl_morph_get_ran_space(__isl_keep isl_morph *morph);
__isl_give isl_multi_aff *isl_morph_get_var_multi_aff(

View File

@ -19,8 +19,8 @@
* for a single dimension.
*
* If the resulting multi piecewise affine expression has
* an explicit domain, then assign it the parameter domain of the input.
* In other cases, the parameter domain is stored in the individual elements.
* an explicit domain, then assign it the (parameter) domain of the input.
* In other cases, the (parameter) domain is stored in the individual elements.
*/
static __isl_give isl_multi_pw_aff *FN(BASE,opt_mpa)(__isl_take TYPE *obj,
__isl_give isl_pw_aff *(*opt)(__isl_take TYPE *obj, int pos))
@ -42,8 +42,8 @@ static __isl_give isl_multi_pw_aff *FN(BASE,opt_mpa)(__isl_take TYPE *obj,
if (isl_multi_pw_aff_has_explicit_domain(mpa)) {
isl_set *dom;
dom = FN(TYPE,params)(FN(TYPE,copy)(obj));
mpa = isl_multi_pw_aff_intersect_params(mpa, dom);
dom = FN(TYPE,domain)(FN(TYPE,copy)(obj));
mpa = isl_multi_pw_aff_intersect_domain(mpa, dom);
}
FN(TYPE,free)(obj);

View File

@ -1988,16 +1988,25 @@ static __isl_give isl_printer *qpolynomial_fold_print(
__isl_keep isl_qpolynomial_fold *fold, __isl_take isl_printer *p)
{
int i;
isl_qpolynomial_list *list;
isl_size n;
list = isl_qpolynomial_fold_peek_list(fold);
n = isl_qpolynomial_list_size(list);
if (n < 0)
return isl_printer_free(p);
if (fold->type == isl_fold_min)
p = isl_printer_print_str(p, "min");
else if (fold->type == isl_fold_max)
p = isl_printer_print_str(p, "max");
p = isl_printer_print_str(p, "(");
for (i = 0; i < fold->n; ++i) {
for (i = 0; i < n; ++i) {
isl_qpolynomial *qp;
if (i)
p = isl_printer_print_str(p, ", ");
p = print_qpolynomial(p, fold->qp[i]);
qp = isl_qpolynomial_list_peek(list, i);
p = print_qpolynomial(p, qp);
}
p = isl_printer_print_str(p, ")");
return p;
@ -2337,17 +2346,26 @@ static __isl_give isl_printer *print_qpolynomial_fold_c(
__isl_keep isl_qpolynomial_fold *fold)
{
int i;
isl_qpolynomial_list *list;
isl_size n;
for (i = 0; i < fold->n - 1; ++i)
list = isl_qpolynomial_fold_peek_list(fold);
n = isl_qpolynomial_list_size(list);
if (n < 0)
return isl_printer_free(p);
for (i = 0; i < n - 1; ++i)
if (fold->type == isl_fold_min)
p = isl_printer_print_str(p, "min(");
else if (fold->type == isl_fold_max)
p = isl_printer_print_str(p, "max(");
for (i = 0; i < fold->n; ++i) {
for (i = 0; i < n; ++i) {
isl_qpolynomial *qp;
if (i)
p = isl_printer_print_str(p, ", ");
p = print_qpolynomial_c(p, space, fold->qp[i]);
qp = isl_qpolynomial_list_peek(list, i);
p = print_qpolynomial_c(p, space, qp);
if (i)
p = isl_printer_print_str(p, ")");
}

View File

@ -28,6 +28,11 @@
#include <isl_val_private.h>
#include <isl_config.h>
#undef EL_BASE
#define EL_BASE qpolynomial
#include <isl_list_templ.c>
#undef EL_BASE
#define EL_BASE pw_qpolynomial
@ -4384,16 +4389,17 @@ __isl_give isl_qpolynomial *isl_qpolynomial_morph_domain(
int i;
int n_sub;
isl_ctx *ctx;
isl_space *space;
isl_poly **subs;
isl_mat *mat, *diag;
qp = isl_qpolynomial_cow(qp);
if (!qp || !morph)
space = isl_qpolynomial_peek_domain_space(qp);
if (isl_morph_check_applies(morph, space) < 0)
goto error;
ctx = qp->dim->ctx;
isl_assert(ctx, isl_space_is_equal(qp->dim, morph->dom->dim), goto error);
ctx = isl_qpolynomial_get_ctx(qp);
n_sub = morph->inv->n_row - 1;
if (morph->inv->n_row != morph->inv->n_col)
n_sub += qp->div->n_row;

View File

@ -5,6 +5,7 @@
#include <isl_morph.h>
#include <isl/polynomial.h>
#include <isl_reordering.h>
#include "isl_list_private.h"
struct isl_poly {
int ref;
@ -40,6 +41,11 @@ struct isl_qpolynomial {
isl_poly *poly;
};
#undef EL
#define EL isl_qpolynomial
#include <isl_list_templ.h>
struct isl_term {
int ref;
@ -86,10 +92,7 @@ struct isl_qpolynomial_fold {
enum isl_fold type;
isl_space *dim;
int n;
size_t size;
struct isl_qpolynomial *qp[1];
isl_qpolynomial_list *list;
};
struct isl_pw_qpolynomial_fold_piece {
@ -202,6 +205,9 @@ __isl_give isl_qpolynomial_fold *isl_qpolynomial_fold_cow(
__isl_give isl_qpolynomial_fold *isl_qpolynomial_fold_dup(
__isl_keep isl_qpolynomial_fold *fold);
__isl_keep isl_qpolynomial_list *isl_qpolynomial_fold_peek_list(
__isl_keep isl_qpolynomial_fold *fold);
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_cow(
__isl_take isl_pw_qpolynomial_fold *pwf);
@ -289,3 +295,5 @@ __isl_give isl_union_pw_qpolynomial *isl_union_pw_qpolynomial_mul_isl_int(
__isl_give isl_union_pw_qpolynomial_fold *
isl_union_pw_qpolynomial_fold_mul_isl_int(
__isl_take isl_union_pw_qpolynomial_fold *upwf, isl_int v);
ISL_DECLARE_LIST_FN_PRIVATE(qpolynomial)

View File

@ -1434,14 +1434,29 @@ static __isl_keep isl_set *FN(PW,peek_domain_at)(__isl_keep PW *pw, int pos)
return pw->p[pos].set;
}
/* Return a copy of the cell at position "pos" in "pw".
*/
__isl_give isl_set *FN(PW,get_domain_at)(__isl_keep PW *pw, int pos)
{
return isl_set_copy(FN(PW,peek_domain_at)(pw, pos));
}
/* Return the base expression associated to
* the cell at position "pos" in "pw".
*/
static __isl_keep EL *FN(PW,peek_base_at)(__isl_keep PW *pw, int pos)
{
if (FN(PW,check_pos)(pw, pos) < 0)
return NULL;
return pw->p[pos].FIELD;
}
/* Return a copy of the base expression associated to
* the cell at position "pos" in "pw".
*/
__isl_give EL *FN(PW,get_base_at)(__isl_keep PW *pw, int pos)
{
if (FN(PW,check_pos)(pw, pos) < 0)
return NULL;
return FN(EL,copy)(pw->p[pos].FIELD);
return FN(EL,copy)(FN(PW,peek_base_at)(pw, pos));
}
/* Return the base expression associated to

View File

@ -1,6 +1,7 @@
/*
* Copyright 2011 INRIA Saclay
* Copyright 2012 Ecole Normale Superieure
* Copyright 2020 Cerebras Systems
*
* Use of this software is governed by the MIT license
*
@ -8,6 +9,7 @@
* Parc Club Orsay Universite, ZAC des vignes, 4 rue Jacques Monod,
* 91893 Orsay, France
* and Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
* and Cerebras Systems, 175 S San Antonio Rd, Los Altos, CA, USA
*/
#include <isl_pw_macro.h>
@ -69,29 +71,173 @@ static __isl_give isl_set *FN(PW,worse_or_out)(__isl_take isl_set *set,
return isl_set_union(set_worse, set_out);
}
/* Given two piecewise expressions "pw1" and "pw2", replace their domains
* by the sets in "list1" and "list2" and combine the results into
/* Internal data structure used by isl_pw_*_union_opt_cmp
* that keeps track of a piecewise expression with updated cells.
* "pw" holds the original piecewise expression.
* "list" holds the updated cells.
*/
S(PW,union_opt_cmp_data) {
PW *pw;
isl_set_list *cell;
};
/* Free all memory allocated for "data".
*/
static void FN(PW,union_opt_cmp_data_clear)(S(PW,union_opt_cmp_data) *data)
{
isl_set_list_free(data->cell);
FN(PW,free)(data->pw);
}
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
* a set "better" where the piece from data_j->pw is better
* than the piece from data_i->pw,
* (further) update the specified cells such that only the better elements
* remain on the (non-empty) intersection.
*
* Let C be the set "better".
* Let A be the cell data_i->cell[i] and B the cell data_j->cell[j].
*
* The elements in C need to be removed from A, except for those parts
* that lie outside of B. That is,
*
* A <- (A \setminus C) \cup ((A \cap C) \setminus B')
*
* Conversely, the elements in B need to be restricted to C, except
* for those parts that lie outside of A. That is
*
* B <- (B \cap C) \cup ((B \setminus C) \setminus A')
*
* Since all pairs of pieces are considered, the domains are updated
* several times. A and B refer to these updated domains
* (kept track of in data_i->cell[i] and data_j->cell[j]), while A' and B' refer
* to the original domains of the pieces. It is safe to use these
* original domains because the difference between, say, A' and A is
* the domains of pw2-pieces that have been removed before and
* those domains are disjoint from B. A' is used instead of A
* because the continued updating of A may result in this domain
* getting broken up into more disjuncts.
*/
static isl_stat FN(PW,union_opt_cmp_split)(S(PW,union_opt_cmp_data) *data_i,
int i, S(PW,union_opt_cmp_data) *data_j, int j,
__isl_take isl_set *better)
{
isl_set *set_i, *set_j;
set_i = isl_set_list_get_set(data_i->cell, i);
set_j = FN(PW,get_domain_at)(data_j->pw, j);
set_i = FN(PW,worse_or_out)(set_i, isl_set_copy(better), set_j);
data_i->cell = isl_set_list_set_set(data_i->cell, i, set_i);
set_i = FN(PW,get_domain_at)(data_i->pw, i);
set_j = isl_set_list_get_set(data_j->cell, j);
set_j = FN(PW,better_or_out)(set_j, better, set_i);
data_j->cell = isl_set_list_set_set(data_j->cell, j, set_j);
return isl_stat_ok;
}
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
* a function "cmp" that returns the set of elements where
* "el1" is "better" than "el2",
* (further) update the specified cells such that only the "better" elements
* remain on the (non-empty) intersection.
*/
static isl_stat FN(PW,union_opt_cmp_pair)(S(PW,union_opt_cmp_data) *data_i,
int i, S(PW,union_opt_cmp_data) *data_j, int j,
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
{
isl_set *better;
EL *el_i, *el_j;
el_i = FN(PW,peek_base_at)(data_i->pw, i);
el_j = FN(PW,peek_base_at)(data_j->pw, j);
better = FN(PW,better)(el_j, el_i, cmp);
return FN(PW,union_opt_cmp_split)(data_i, i, data_j, j, better);
}
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
* a function "cmp" that returns the set of elements where
* "el1" is "better" than "el2",
* (further) update the specified cells such that only the "better" elements
* remain on the (non-empty) intersection.
*
* The base computation is performed by isl_pw_*_union_opt_cmp_pair,
* which splits the cells according to the set of elements
* where the piece from data_j->pw is better than the piece from data_i->pw.
*
* In some cases, there may be a subset of the intersection
* where both pieces have the same value and can therefore
* both be considered to be "better" than the other.
* This can result in unnecessary splitting on this subset.
* Avoid some of these cases by checking whether
* data_i->pw is always better than data_j->pw on the intersection.
* In particular, do this for the special case where this intersection
* is equal to the cell "j" and data_i->pw is better on its entire cell.
*
* Similarly, if data_i->pw is never better than data_j->pw,
* then no splitting will occur and there is no need to check
* where data_j->pw is better than data_i->pw.
*/
static isl_stat FN(PW,union_opt_cmp_two)(S(PW,union_opt_cmp_data) *data_i,
int i, S(PW,union_opt_cmp_data) *data_j, int j,
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
{
isl_bool is_subset, is_empty;
isl_set *better, *set_i, *set_j;
EL *el_i, *el_j;
set_i = FN(PW,peek_domain_at)(data_i->pw, i);
set_j = FN(PW,peek_domain_at)(data_j->pw, j);
is_subset = isl_set_is_subset(set_j, set_i);
if (is_subset < 0)
return isl_stat_error;
if (!is_subset)
return FN(PW,union_opt_cmp_pair)(data_i, i, data_j, j, cmp);
el_i = FN(PW,peek_base_at)(data_i->pw, i);
el_j = FN(PW,peek_base_at)(data_j->pw, j);
better = FN(PW,better)(el_i, el_j, cmp);
is_empty = isl_set_is_empty(better);
if (is_empty >= 0 && is_empty)
return FN(PW,union_opt_cmp_split)(data_j, j, data_i, i, better);
is_subset = isl_set_is_subset(set_i, better);
if (is_subset >= 0 && is_subset)
return FN(PW,union_opt_cmp_split)(data_j, j, data_i, i, better);
isl_set_free(better);
if (is_empty < 0 || is_subset < 0)
return isl_stat_error;
return FN(PW,union_opt_cmp_pair)(data_i, i, data_j, j, cmp);
}
/* Given two piecewise expressions data1->pw and data2->pw, replace
* their domains
* by the sets in data1->cell and data2->cell and combine the results into
* a single piecewise expression.
* The pieces of "pw1" and "pw2" are assumed to have been sorted
* The pieces of data1->pw and data2->pw are assumed to have been sorted
* according to the function value expressions.
* The pieces of the result are also sorted in this way.
*
* Run through the pieces of "pw1" and "pw2" in order until they
* have both been exhausted, picking the piece from "pw1" or "pw2"
* Run through the pieces of data1->pw and data2->pw in order until they
* have both been exhausted, picking the piece from data1->pw or data2->pw
* depending on which should come first, together with the corresponding
* domain from "list1" or "list2". In cases where the next pieces
* in both "pw1" and "pw2" have the same function value expression,
* domain from data1->cell or data2->cell. In cases where the next pieces
* in both data1->pw and data2->pw have the same function value expression,
* construct only a single piece in the result with as domain
* the union of the domains in "list1" and "list2".
* the union of the domains in data1->cell and data2->cell.
*/
static __isl_give PW *FN(PW,merge)(__isl_take PW *pw1, __isl_take PW *pw2,
__isl_take isl_set_list *list1, __isl_take isl_set_list *list2)
static __isl_give PW *FN(PW,merge)(S(PW,union_opt_cmp_data) *data1,
S(PW,union_opt_cmp_data) *data2)
{
int i, j;
PW *res;
PW *pw1 = data1->pw;
PW *pw2 = data2->pw;
isl_set_list *list1 = data1->cell;
isl_set_list *list2 = data2->cell;
if (!pw1 || !pw2)
goto error;
return NULL;
res = FN(PW,alloc_size)(isl_space_copy(pw1->dim), pw1->n + pw2->n);
@ -125,17 +271,7 @@ static __isl_give PW *FN(PW,merge)(__isl_take PW *pw1, __isl_take PW *pw2,
res = FN(PW,add_piece)(res, set, el);
}
isl_set_list_free(list1);
isl_set_list_free(list2);
FN(PW,free)(pw1);
FN(PW,free)(pw2);
return res;
error:
isl_set_list_free(list1);
isl_set_list_free(list2);
FN(PW,free)(pw1);
FN(PW,free)(pw2);
return NULL;
}
/* Given a function "cmp" that returns the set of elements where
@ -148,32 +284,9 @@ error:
* Run through all pairs of pieces in "pw1" and "pw2".
* If the domains of these pieces intersect, then the intersection
* needs to be distributed over the two pieces based on "cmp".
* Let C be the set where the piece from "pw2" is better (according to "cmp")
* than the piece from "pw1". Let A be the domain of the piece from "pw1" and
* B the domain of the piece from "pw2".
*
* The elements in C need to be removed from A, except for those parts
* that lie outside of B. That is,
*
* A <- (A \setminus C) \cup ((A \cap C) \setminus B')
*
* Conversely, the elements in B need to be restricted to C, except
* for those parts that lie outside of A. That is
*
* B <- (B \cap C) \cup ((B \setminus C) \setminus A')
*
* Since all pairs of pieces are considered, the domains are updated
* several times. A and B refer to these updated domains
* (kept track of in "list1" and "list2"), while A' and B' refer
* to the original domains of the pieces. It is safe to use these
* original domains because the difference between, say, A' and A is
* the domains of pw2-pieces that have been removed before and
* those domains are disjoint from B. A' is used instead of A
* because the continued updating of A may result in this domain
* getting broken up into more disjuncts.
*
* After the updated domains have been computed, the result is constructed
* from "pw1", "pw2", "list1" and "list2". If there are any pieces
* from "pw1", "pw2", data[0].cell and data[1].cell. If there are any pieces
* in "pw1" and "pw2" with the same function value expression, then
* they are combined into a single piece in the result.
* In order to be able to do this efficiently, the pieces of "pw1" and
@ -183,11 +296,11 @@ static __isl_give PW *FN(PW,union_opt_cmp)(
__isl_take PW *pw1, __isl_take PW *pw2,
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
{
S(PW,union_opt_cmp_data) data[2] = { { pw1, NULL }, { pw2, NULL } };
int i, j;
isl_size n1, n2;
PW *res = NULL;
isl_ctx *ctx;
isl_set *set = NULL;
isl_set_list *list1 = NULL, *list2 = NULL;
if (!pw1 || !pw2)
goto error;
@ -207,47 +320,40 @@ static __isl_give PW *FN(PW,union_opt_cmp)(
return pw1;
}
pw1 = FN(PW,sort)(pw1);
pw2 = FN(PW,sort)(pw2);
if (!pw1 || !pw2)
for (i = 0; i < 2; ++i) {
data[i].pw = FN(PW,sort)(data[i].pw);
data[i].cell = FN(PW,extract_domains)(data[i].pw);
}
n1 = FN(PW,n_piece)(data[0].pw);
n2 = FN(PW,n_piece)(data[1].pw);
if (n1 < 0 || n2 < 0)
goto error;
list1 = FN(PW,extract_domains)(pw1);
list2 = FN(PW,extract_domains)(pw2);
for (i = 0; i < pw1->n; ++i) {
for (j = 0; j < pw2->n; ++j) {
for (i = 0; i < n1; ++i) {
for (j = 0; j < n2; ++j) {
isl_bool disjoint;
isl_set *better, *set_i, *set_j;
isl_set *set_i, *set_j;
disjoint = isl_set_is_disjoint(pw1->p[i].set,
pw2->p[j].set);
set_i = FN(PW,peek_domain_at)(data[0].pw, i);
set_j = FN(PW,peek_domain_at)(data[1].pw, j);
disjoint = isl_set_is_disjoint(set_i, set_j);
if (disjoint < 0)
goto error;
if (disjoint)
continue;
better = FN(PW,better)(pw2->p[j].FIELD,
pw1->p[i].FIELD, cmp);
set_i = isl_set_list_get_set(list1, i);
set_j = isl_set_copy(pw2->p[j].set);
set_i = FN(PW,worse_or_out)(set_i,
isl_set_copy(better), set_j);
list1 = isl_set_list_set_set(list1, i, set_i);
set_i = isl_set_copy(pw1->p[i].set);
set_j = isl_set_list_get_set(list2, j);
set_j = FN(PW,better_or_out)(set_j, better, set_i);
list2 = isl_set_list_set_set(list2, j, set_j);
if (FN(PW,union_opt_cmp_two)(&data[0], i,
&data[1], j, cmp) < 0)
goto error;
}
}
res = FN(PW,merge)(pw1, pw2, list1, list2);
res = FN(PW,merge)(&data[0], &data[1]);
for (i = 0; i < 2; ++i)
FN(PW,union_opt_cmp_data_clear)(&data[i]);
return res;
error:
isl_set_list_free(list1);
isl_set_list_free(list2);
FN(PW,free)(pw1);
FN(PW,free)(pw2);
isl_set_free(set);
for (i = 0; i < 2; ++i)
FN(PW,union_opt_cmp_data_clear)(&data[i]);
return FN(PW,free)(res);
}

View File

@ -125,9 +125,12 @@ void isl_seq_combine(isl_int *dst, isl_int m1, isl_int *src1,
isl_int_clear(tmp);
}
/*
* Let d = dst[pos] and s = src[pos]
* dst is replaced by |s| dst - sgn(s)d src
/* Eliminate element "pos" from "dst" using "src".
* In particular, let d = dst[pos] and s = src[pos], then
* dst is replaced by (|s| dst - sgn(s)d src)/gcd(s,d),
* such that dst[pos] is zero after the elimination.
* If "m" is not NULL, then *m is multiplied by |s|/gcd(s,d).
* That is, it is multiplied by the same factor as "dst".
*/
void isl_seq_elim(isl_int *dst, isl_int *src, unsigned pos, unsigned len,
isl_int *m)

View File

@ -121,6 +121,22 @@ static isl_stat isl_space_check_is_map(__isl_keep isl_space *space)
return isl_stat_ok;
}
/* Check that "space" is the space of a map
* where the domain is a wrapped map space.
*/
isl_stat isl_space_check_domain_is_wrapping(__isl_keep isl_space *space)
{
isl_bool wrapping;
wrapping = isl_space_domain_is_wrapping(space);
if (wrapping < 0)
return isl_stat_error;
if (!wrapping)
isl_die(isl_space_get_ctx(space), isl_error_invalid,
"domain not a product", return isl_stat_error);
return isl_stat_ok;
}
/* Check that "space" is the space of a map
* where the range is a wrapped map space.
*/
@ -929,6 +945,20 @@ isl_bool isl_space_has_equal_tuples(__isl_keep isl_space *space1,
space2, isl_dim_out);
}
/* Check that a match involving "space" was successful.
* That is, check that "match" is equal to isl_bool_true.
*/
static isl_stat check_match(__isl_keep isl_space *space, isl_bool match)
{
if (match < 0)
return isl_stat_error;
if (!match)
isl_die(isl_space_get_ctx(space), isl_error_invalid,
"incompatible spaces", return isl_stat_error);
return isl_stat_ok;
}
/* Check that the two spaces are the same,
* apart from positions and names of parameters.
*/
@ -938,13 +968,7 @@ isl_stat isl_space_check_equal_tuples(__isl_keep isl_space *space1,
isl_bool is_equal;
is_equal = isl_space_has_equal_tuples(space1, space2);
if (is_equal < 0)
return isl_stat_error;
if (!is_equal)
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
"incompatible spaces", return isl_stat_error);
return isl_stat_ok;
return check_match(space1, is_equal);
}
/* Check if the tuple of type "type1" of "space1" is the same as
@ -989,6 +1013,41 @@ isl_bool isl_space_tuple_is_equal(__isl_keep isl_space *space1,
return isl_bool_true;
}
/* Is the tuple "inner" within the wrapped relation inside tuple "outer"
* of "space1" equal to tuple "type2" of "space2"?
*/
isl_bool isl_space_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
enum isl_dim_type outer, enum isl_dim_type inner,
__isl_keep isl_space *space2, enum isl_dim_type type2)
{
int pos;
isl_space *nested;
if (!space1)
return isl_bool_error;
if (outer != isl_dim_in && outer != isl_dim_out)
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
"only input, output and set tuples "
"can have nested relations", return isl_bool_error);
pos = outer - isl_dim_in;
nested = isl_space_peek_nested(space1, pos);
return isl_space_tuple_is_equal(nested, inner, space2, type2);
}
/* Check that the tuple "inner" within the wrapped relation inside tuple "outer"
* of "space1" is equal to tuple "type2" of "space2".
*/
isl_stat isl_space_check_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
enum isl_dim_type outer, enum isl_dim_type inner,
__isl_keep isl_space *space2, enum isl_dim_type type2)
{
isl_bool is_equal;
is_equal = isl_space_wrapped_tuple_is_equal(space1, outer, inner,
space2, type2);
return check_match(space1, is_equal);
}
static isl_bool match(__isl_keep isl_space *space1, enum isl_dim_type type1,
__isl_keep isl_space *space2, enum isl_dim_type type2)
{
@ -1525,11 +1584,8 @@ __isl_give isl_space *isl_space_domain_factor_domain(
isl_space *nested;
isl_space *domain;
if (!space)
return NULL;
if (!isl_space_domain_is_wrapping(space))
isl_die(isl_space_get_ctx(space), isl_error_invalid,
"domain not a product", return isl_space_free(space));
if (isl_space_check_domain_is_wrapping(space) < 0)
return isl_space_free(space);
nested = space->nested[0];
domain = isl_space_copy(space);
@ -1564,11 +1620,8 @@ __isl_give isl_space *isl_space_domain_factor_range(
isl_space *nested;
isl_space *range;
if (!space)
return NULL;
if (!isl_space_domain_is_wrapping(space))
isl_die(isl_space_get_ctx(space), isl_error_invalid,
"domain not a product", return isl_space_free(space));
if (isl_space_check_domain_is_wrapping(space) < 0)
return isl_space_free(space);
nested = space->nested[0];
range = isl_space_copy(space);
@ -2424,13 +2477,7 @@ isl_stat isl_space_check_domain_tuples(__isl_keep isl_space *space1,
isl_bool is_equal;
is_equal = isl_space_has_domain_tuples(space1, space2);
if (is_equal < 0)
return isl_stat_error;
if (!is_equal)
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
"incompatible spaces", return isl_stat_error);
return isl_stat_ok;
return check_match(space1, is_equal);
}
/* Check that the tuples of "space1" correspond to those
@ -2581,6 +2628,8 @@ static uint32_t isl_hash_tuples_domain(uint32_t hash,
/* Return a hash value that digests the tuples of "space",
* i.e., that ignores the parameters.
* Changes in this function should be reflected
* in isl_space_get_tuple_domain_hash.
*/
uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space)
{
@ -2595,7 +2644,9 @@ uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space)
return hash;
}
uint32_t isl_space_get_hash(__isl_keep isl_space *space)
/* Return the hash value of "space".
*/
uint32_t isl_space_get_full_hash(__isl_keep isl_space *space)
{
uint32_t hash;
@ -2609,11 +2660,11 @@ uint32_t isl_space_get_hash(__isl_keep isl_space *space)
return hash;
}
/* Return the hash value of the domain of "space".
* That is, isl_space_get_domain_hash(space) is equal to
* isl_space_get_hash(isl_space_domain(space)).
/* Return the hash value of the domain tuple of "space".
* That is, isl_space_get_tuple_domain_hash(space) is equal to
* isl_space_get_tuple_hash(isl_space_domain(space)).
*/
uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space)
uint32_t isl_space_get_tuple_domain_hash(__isl_keep isl_space *space)
{
uint32_t hash;
@ -2621,7 +2672,6 @@ uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space)
return 0;
hash = isl_hash_init();
hash = isl_hash_params(hash, space);
hash = isl_hash_tuples_domain(hash, space);
return hash;

View File

@ -28,8 +28,8 @@ __isl_give isl_space *isl_space_underlying(__isl_take isl_space *space,
unsigned n_div);
uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space);
uint32_t isl_space_get_hash(__isl_keep isl_space *space);
uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space);
uint32_t isl_space_get_tuple_domain_hash(__isl_keep isl_space *space);
uint32_t isl_space_get_full_hash(__isl_keep isl_space *space);
isl_bool isl_space_has_domain_tuples(__isl_keep isl_space *space1,
__isl_keep isl_space *space2);
@ -43,6 +43,12 @@ isl_bool isl_space_is_range_internal(__isl_keep isl_space *space1,
__isl_keep isl_space *space2);
isl_stat isl_space_check_domain_wrapped_domain_tuples(
__isl_keep isl_space *space1, __isl_keep isl_space *space2);
isl_bool isl_space_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
enum isl_dim_type outer, enum isl_dim_type inner,
__isl_keep isl_space *space2, enum isl_dim_type type2);
isl_stat isl_space_check_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
enum isl_dim_type outer, enum isl_dim_type inner,
__isl_keep isl_space *space2, enum isl_dim_type type2);
isl_size isl_space_wrapped_dim(__isl_keep isl_space *space,
enum isl_dim_type outer, enum isl_dim_type inner);
@ -66,6 +72,7 @@ __isl_give isl_space *isl_space_reset(__isl_take isl_space *space,
enum isl_dim_type type);
__isl_give isl_space *isl_space_flatten(__isl_take isl_space *space);
isl_stat isl_space_check_domain_is_wrapping(__isl_keep isl_space *space);
isl_stat isl_space_check_range_is_wrapping(__isl_keep isl_space *space);
__isl_give isl_space *isl_space_replace_params(__isl_take isl_space *dst,

View File

@ -1787,17 +1787,6 @@ int isl_tab_insert_var(struct isl_tab *tab, int r)
return r;
}
/* Add a variable to the tableau and allocate a column for it.
* Return the index into the variable array "var".
*/
int isl_tab_allocate_var(struct isl_tab *tab)
{
if (!tab)
return -1;
return isl_tab_insert_var(tab, tab->n_var);
}
/* Add a row to the tableau. The row is given as an affine combination
* of the original variables and needs to be expressed in terms of the
* column variables.
@ -3884,7 +3873,8 @@ static isl_stat drop_bmap_div(struct isl_tab *tab, int pos)
if (n_div < 0)
return isl_stat_error;
off = tab->n_var - n_div;
if (isl_basic_map_drop_div(tab->bmap, pos - off) < 0)
tab->bmap = isl_basic_map_drop_div(tab->bmap, pos - off);
if (!tab->bmap)
return isl_stat_error;
if (tab->samples) {
tab->samples = isl_mat_drop_cols(tab->samples, 1 + pos, 1);

View File

@ -299,7 +299,6 @@ struct isl_tab *isl_tab_product(struct isl_tab *tab1, struct isl_tab *tab2);
int isl_tab_extend_cons(struct isl_tab *tab, unsigned n_new) WARN_UNUSED;
int isl_tab_allocate_con(struct isl_tab *tab) WARN_UNUSED;
int isl_tab_extend_vars(struct isl_tab *tab, unsigned n_new) WARN_UNUSED;
int isl_tab_allocate_var(struct isl_tab *tab) WARN_UNUSED;
int isl_tab_insert_var(struct isl_tab *tab, int pos) WARN_UNUSED;
int isl_tab_pivot(struct isl_tab *tab, int row, int col) WARN_UNUSED;
int isl_tab_add_row(struct isl_tab *tab, isl_int *line) WARN_UNUSED;

View File

@ -4379,6 +4379,7 @@ static __isl_give isl_basic_map *align_context_divs(
}
other = bmap_n_div - common;
if (dom->n_div - common > 0) {
bmap = isl_basic_map_cow(bmap);
bmap = isl_basic_map_extend(bmap, dom->n_div - common, 0, 0);
if (!bmap)
return NULL;

View File

@ -1402,76 +1402,47 @@ static isl_stat test_plain_unshifted_simple_hull_special(isl_ctx *ctx)
return isl_stat_ok;
}
/* Pairs of maps and the corresponding expected results of
* isl_map_plain_unshifted_simple_hull.
*/
struct {
const char *map;
const char *hull;
} plain_unshifted_simple_hull_tests[] = {
{ "{ [i] -> [j] : i >= 1 and j >= 1 or i >= 2 and j <= 10 }",
"{ [i] -> [j] : i >= 1 }" },
{ "{ [n] -> [i,j,k] : (i mod 3 = 2 and j mod 4 = 2) or "
"(j mod 4 = 2 and k mod 6 = n) }",
"{ [n] -> [i,j,k] : j mod 4 = 2 }" },
};
/* Basic tests for isl_map_plain_unshifted_simple_hull.
*/
static int test_plain_unshifted_simple_hull(isl_ctx *ctx)
{
int i;
isl_map *map;
isl_basic_map *hull, *expected;
isl_bool equal;
for (i = 0; i < ARRAY_SIZE(plain_unshifted_simple_hull_tests); ++i) {
const char *str;
str = plain_unshifted_simple_hull_tests[i].map;
map = isl_map_read_from_str(ctx, str);
str = plain_unshifted_simple_hull_tests[i].hull;
expected = isl_basic_map_read_from_str(ctx, str);
hull = isl_map_plain_unshifted_simple_hull(map);
equal = isl_basic_map_is_equal(hull, expected);
isl_basic_map_free(hull);
isl_basic_map_free(expected);
if (equal < 0)
return -1;
if (!equal)
isl_die(ctx, isl_error_unknown, "unexpected hull",
return -1);
}
return 0;
}
/* Pairs of sets and the corresponding expected results of
* isl_set_unshifted_simple_hull.
/* Inputs for simple hull tests, consisting of
* the specific simple hull function, the input set and the expected result.
*/
struct {
__isl_give isl_basic_set *(*fn)(__isl_take isl_set *set);
const char *set;
const char *hull;
} unshifted_simple_hull_tests[] = {
{ "{ [0,x,y] : x <= -1; [1,x,y] : x <= y <= -x; [2,x,y] : x <= 1 }",
} simple_hull_tests[] = {
{ &isl_set_plain_unshifted_simple_hull,
"{ [i,j] : i >= 1 and j >= 1 or i >= 2 and j <= 10 }",
"{ [i,j] : i >= 1 }" },
{ &isl_set_plain_unshifted_simple_hull,
"{ [n,i,j,k] : (i mod 3 = 2 and j mod 4 = 2) or "
"(j mod 4 = 2 and k mod 6 = n) }",
"{ [n,i,j,k] : j mod 4 = 2 }" },
{ &isl_set_unshifted_simple_hull,
"{ [0,x,y] : x <= -1; [1,x,y] : x <= y <= -x; [2,x,y] : x <= 1 }",
"{ [t,x,y] : 0 <= t <= 2 and x <= 1 }" },
{ &isl_set_simple_hull,
"{ [a, b] : b <= 0 and "
"2*floor((-2*floor((b)/2))/5) >= a - floor((b)/2); "
"[a, b] : a mod 2 = 0 }",
"{ [a, b] }" },
};
/* Basic tests for isl_set_unshifted_simple_hull.
/* Basic tests for various simple hull functions.
*/
static int test_unshifted_simple_hull(isl_ctx *ctx)
static int test_various_simple_hull(isl_ctx *ctx)
{
int i;
isl_set *set;
isl_basic_set *hull, *expected;
isl_bool equal;
for (i = 0; i < ARRAY_SIZE(unshifted_simple_hull_tests); ++i) {
for (i = 0; i < ARRAY_SIZE(simple_hull_tests); ++i) {
const char *str;
str = unshifted_simple_hull_tests[i].set;
str = simple_hull_tests[i].set;
set = isl_set_read_from_str(ctx, str);
str = unshifted_simple_hull_tests[i].hull;
str = simple_hull_tests[i].hull;
expected = isl_basic_set_read_from_str(ctx, str);
hull = isl_set_unshifted_simple_hull(set);
hull = simple_hull_tests[i].fn(set);
equal = isl_basic_set_is_equal(hull, expected);
isl_basic_set_free(hull);
isl_basic_set_free(expected);
@ -1508,9 +1479,7 @@ static int test_simple_hull(struct isl_ctx *ctx)
if (test_plain_unshifted_simple_hull_special(ctx) < 0)
return -1;
if (test_plain_unshifted_simple_hull(ctx) < 0)
return -1;
if (test_unshifted_simple_hull(ctx) < 0)
if (test_various_simple_hull(ctx) < 0)
return -1;
return 0;
@ -1683,33 +1652,6 @@ static int test_convex_hull(isl_ctx *ctx)
return 0;
}
void test_gist_case(struct isl_ctx *ctx, const char *name)
{
char *filename;
FILE *input;
struct isl_basic_set *bset1, *bset2;
filename = get_filename(ctx, name, "polylib");
assert(filename);
input = fopen(filename, "r");
assert(input);
bset1 = isl_basic_set_read_from_file(ctx, input);
bset2 = isl_basic_set_read_from_file(ctx, input);
bset1 = isl_basic_set_gist(bset1, bset2);
bset2 = isl_basic_set_read_from_file(ctx, input);
assert(isl_basic_set_is_equal(bset1, bset2) == 1);
isl_basic_set_free(bset1);
isl_basic_set_free(bset2);
free(filename);
fclose(input);
}
/* Check that computing the gist of "map" with respect to "context"
* does not make any copy of "map" get marked empty.
* Earlier versions of isl would end up doing that.
@ -1858,6 +1800,9 @@ struct {
const char *context;
const char *gist;
} gist_tests[] = {
{ "{ [1, -1, 3] }",
"{ [1, b, 2 - b] : -1 <= b <= 2 }",
"{ [a, -1, c] }" },
{ "{ [a, b, c] : a <= 15 and a >= 1 }",
"{ [a, b, c] : exists (e0 = floor((-1 + a)/16): a >= 1 and "
"c <= 30 and 32e0 >= -62 + 2a + 2b - c and b >= 0) }",
@ -1982,8 +1927,6 @@ static int test_gist(struct isl_ctx *ctx)
if (test_gist_fail(ctx) < 0)
return -1;
test_gist_case(ctx, "gist1");
str = "[p0, p2, p3, p5, p6, p10] -> { [] : "
"exists (e0 = [(15 + p0 + 15p6 + 15p10)/16], e1 = [(p5)/8], "
"e2 = [(p6)/128], e3 = [(8p2 - p5)/128], "
@ -3177,6 +3120,53 @@ static int test_min_special2(isl_ctx *ctx)
return 0;
}
/* Check that the result of isl_set_min_multi_pw_aff
* on the union of the sets with string descriptions "s1" and "s2"
* consists of a single expression (on a single cell).
*/
static isl_stat check_single_expr_min(isl_ctx *ctx, const char *s1,
const char *s2)
{
isl_size n;
isl_set *set1, *set2;
isl_multi_pw_aff *mpa;
isl_pw_multi_aff *pma;
set1 = isl_set_read_from_str(ctx, s1);
set2 = isl_set_read_from_str(ctx, s2);
set1 = isl_set_union(set1, set2);
mpa = isl_set_min_multi_pw_aff(set1);
pma = isl_pw_multi_aff_from_multi_pw_aff(mpa);
n = isl_pw_multi_aff_n_piece(pma);
isl_pw_multi_aff_free(pma);
if (n < 0)
return isl_stat_error;
if (n != 1)
isl_die(ctx, isl_error_unknown, "expecting single expression",
return isl_stat_error);
return isl_stat_ok;
}
/* A specialized isl_set_min_multi_pw_aff test that checks
* that the minimum of 2N and 3N for N >= 0 is represented
* by a single expression, without splitting off the special case N = 0.
* Do this for both orderings.
*/
static int test_min_mpa(isl_ctx *ctx)
{
const char *s1, *s2;
s1 = "[N=0:] -> { [1, 3N:] }";
s2 = "[N=0:] -> { [10, 2N:] }";
if (check_single_expr_min(ctx, s1, s2) < 0)
return -1;
if (check_single_expr_min(ctx, s2, s1) < 0)
return -1;
return 0;
}
struct {
const char *set;
const char *obj;
@ -3870,67 +3860,88 @@ static int test_union(isl_ctx *ctx)
return 0;
}
/* Check that computing a bound of a non-zero polynomial over an unbounded
* domain does not produce a rational value.
* In particular, check that the upper bound is infinity.
/* Inputs for basic isl_pw_qpolynomial_bound tests.
* "type" is the type of bound that should be computed.
* "poly" is a string representation of the input.
* "bound" is a string representation of the expected result.
* "tight" is set if the result is expected to be tight.
*/
static int test_bound_unbounded_domain(isl_ctx *ctx)
static struct {
int tight;
enum isl_fold type;
const char *poly;
const char *bound;
} bound_tests[] = {
/* Check that computing a bound of a non-zero polynomial
* over an unbounded domain does not produce a rational value.
* In particular, check that the upper bound is infinity.
*/
{ 0, isl_fold_max, "{ [m, n] -> -m * n }", "{ max(infty) }" },
{ 1, isl_fold_max, "{ [[a, b, c, d] -> [e]] -> 0 }",
"{ [a, b, c, d] -> max(0) }" },
{ 1, isl_fold_max, "{ [[x] -> [x]] -> 1 : exists a : x = 2 a }",
"{ [x] -> max(1) : x mod 2 = 0 }" },
{ 1, isl_fold_min, "{ [x=5:10] -> (x + 2)^2 }", "{ min(49) }" },
{ 1, isl_fold_max, "{ [0:10] -> 1 }", "{ max(1) }" },
{ 1, isl_fold_max, "{ [[m] -> [0:m]] -> m^2 }",
"{ [m] -> max(m^2) : m >= 0 }" },
};
/* Check that the bound computation can handle differences
* in domain dimension names of the input polynomial and its domain.
*/
static isl_stat test_bound_space(isl_ctx *ctx)
{
const char *str;
isl_pw_qpolynomial *pwqp;
isl_pw_qpolynomial_fold *pwf, *pwf2;
isl_bool equal;
str = "{ [m,n] -> -m * n }";
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
str = "{ infty }";
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
pwf2 = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
equal = isl_pw_qpolynomial_fold_plain_is_equal(pwf, pwf2);
isl_pw_qpolynomial_fold_free(pwf);
isl_pw_qpolynomial_fold_free(pwf2);
if (equal < 0)
return -1;
if (!equal)
isl_die(ctx, isl_error_unknown,
"expecting infinite polynomial bound", return -1);
return 0;
}
static int test_bound(isl_ctx *ctx)
{
const char *str;
isl_size dim;
isl_set *set;
isl_pw_qpolynomial *pwqp;
isl_pw_qpolynomial_fold *pwf;
if (test_bound_unbounded_domain(ctx) < 0)
str = "{ [[c] -> [c]] }";
set = isl_set_read_from_str(ctx, str);
str = "{ [[a] -> [b]] -> 1 }";
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
pwqp = isl_pw_qpolynomial_intersect_domain(pwqp, set);
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
isl_pw_qpolynomial_fold_free(pwf);
return isl_stat_non_null(pwf);
}
/* Perform basic isl_pw_qpolynomial_bound tests.
*/
static int test_bound(isl_ctx *ctx)
{
int i;
if (test_bound_space(ctx) < 0)
return -1;
str = "{ [[a, b, c, d] -> [e]] -> 0 }";
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
dim = isl_pw_qpolynomial_fold_dim(pwf, isl_dim_in);
isl_pw_qpolynomial_fold_free(pwf);
if (dim < 0)
return -1;
if (dim != 4)
isl_die(ctx, isl_error_unknown, "unexpected input dimension",
return -1);
for (i = 0; i < ARRAY_SIZE(bound_tests); ++i) {
const char *str;
enum isl_fold type;
isl_bool equal, tight;
isl_pw_qpolynomial *pwqp;
isl_pw_qpolynomial_fold *pwf1, *pwf2;
str = "{ [[x]->[x]] -> 1 : exists a : x = 2 a }";
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
dim = isl_pw_qpolynomial_fold_dim(pwf, isl_dim_in);
isl_pw_qpolynomial_fold_free(pwf);
if (dim < 0)
return -1;
if (dim != 1)
isl_die(ctx, isl_error_unknown, "unexpected input dimension",
return -1);
str = bound_tests[i].poly;
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
type = bound_tests[i].type;
pwf1 = isl_pw_qpolynomial_bound(pwqp, type, &tight);
str = bound_tests[i].bound;
pwf2 = isl_pw_qpolynomial_fold_read_from_str(ctx, str);
equal = isl_pw_qpolynomial_fold_plain_is_equal(pwf1, pwf2);
isl_pw_qpolynomial_fold_free(pwf2);
isl_pw_qpolynomial_fold_free(pwf1);
if (equal < 0)
return -1;
if (!equal)
isl_die(ctx, isl_error_unknown,
"incorrect bound result", return -1);
if (bound_tests[i].tight && !tight)
isl_die(ctx, isl_error_unknown,
"bound unexpectedly not tight", return -1);
}
return 0;
}
@ -5600,6 +5611,26 @@ struct {
{ &isl_union_pw_multi_aff_union_add, "{ B[x] -> A[1] : x <= 0 }",
"{ B[x] -> A[2] : x >= 0 }",
"{ B[x] -> A[1] : x < 0; B[x] -> A[2] : x > 0; B[0] -> A[3] }" },
{
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
"{ B[x] -> C[x + 2] }",
"{ D[y] -> B[2y] }",
"{ }" },
{
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
"{ [A[x] -> B[x + 1]] -> C[x + 2] }",
"{ D[y] -> B[2y] }",
"{ }" },
{
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
"{ [A[x] -> B[x + 1]] -> C[x + 2]; B[x] -> C[x + 2] }",
"{ D[y] -> A[2y] }",
"{ [D[y] -> B[2y + 1]] -> C[2y + 2] }" },
{
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
"{ T[A[x] -> B[x + 1]] -> C[x + 2]; B[x] -> C[x + 2] }",
"{ D[y] -> A[2y] }",
"{ T[D[y] -> B[2y + 1]] -> C[2y + 2] }" },
};
/* Perform some basic tests of binary operations on
@ -7938,6 +7969,18 @@ static struct {
"[n] -> { A[i] -> [] : 0 <= i <= n; B[] -> [] }",
"[m] -> { A[i] -> [] : 0 <= i <= m; C[] -> [] }",
"[m, n] -> { A[i] -> [] : 0 <= i <= n and i <= m }" },
{ &isl_union_map_intersect_domain_factor_domain,
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
"[N] -> { B[i] -> C[N] }",
"{ }" },
{ &isl_union_map_intersect_domain_factor_domain,
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
"[N] -> { A[i] -> C[N] }",
"[N] -> { [A[N - 2] -> B[N - 1]] -> C[N] }" },
{ &isl_union_map_intersect_domain_factor_domain,
"{ T[A[i] -> B[i + 1]] -> C[i + 2] }",
"[N] -> { A[i] -> C[N] }",
"[N] -> { T[A[N - 2] -> B[N - 1]] -> C[N] }" },
{ &isl_union_map_intersect_domain_factor_range,
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
"[N] -> { B[i] -> C[N] }",
@ -8160,11 +8203,21 @@ struct {
"{ A[i,j] -> B[i',j'] }",
"F[{ A[i,j] -> [i] : i > j; B[i,j] -> [i] }]",
"{ A[i,j] -> B[i,j'] : i > j }" },
{ &isl_union_map_lex_le_at_multi_union_pw_aff,
"{ A[i,j] -> B[i',j'] }",
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
"{ A[i,j] -> B[i',j'] : i,j <<= i',j' }" },
{ &isl_union_map_lex_lt_at_multi_union_pw_aff,
"{ A[i,j] -> B[i',j'] }",
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
"{ A[i,j] -> B[i',j'] : i,j << i',j' }" },
{ &isl_union_map_lex_ge_at_multi_union_pw_aff,
"{ A[i,j] -> B[i',j'] }",
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
"{ A[i,j] -> B[i',j'] : i,j >>= i',j' }" },
{ &isl_union_map_lex_gt_at_multi_union_pw_aff,
"{ A[i,j] -> B[i',j'] }",
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
@ -10006,6 +10059,48 @@ static isl_stat test_multi_pw_aff_3(isl_ctx *ctx)
return isl_stat_ok;
}
/* String descriptions of boxes that
* are used for reconstructing box maps from their lower and upper bounds.
*/
static const char *multi_pw_aff_box_tests[] = {
"{ A[x, y] -> [] : x + y >= 0 }",
"[N] -> { A[x, y] -> [x] : x + y <= N }",
"[N] -> { A[x, y] -> [x : y] : x + y <= N }",
};
/* Check that map representations of boxes can be reconstructed
* from their lower and upper bounds.
*/
static isl_stat test_multi_pw_aff_box(isl_ctx *ctx)
{
int i;
for (i = 0; i < ARRAY_SIZE(multi_pw_aff_box_tests); ++i) {
const char *str;
isl_bool equal;
isl_map *map, *box;
isl_multi_pw_aff *min, *max;
str = multi_pw_aff_box_tests[i];
map = isl_map_read_from_str(ctx, str);
min = isl_map_min_multi_pw_aff(isl_map_copy(map));
max = isl_map_max_multi_pw_aff(isl_map_copy(map));
box = isl_map_universe(isl_map_get_space(map));
box = isl_map_lower_bound_multi_pw_aff(box, min);
box = isl_map_upper_bound_multi_pw_aff(box, max);
equal = isl_map_is_equal(map, box);
isl_map_free(map);
isl_map_free(box);
if (equal < 0)
return isl_stat_error;
if (!equal)
isl_die(ctx, isl_error_unknown,
"unexpected result", return isl_stat_error);
}
return isl_stat_ok;
}
/* Perform some tests on multi piecewise affine expressions.
*/
static int test_multi_pw_aff(isl_ctx *ctx)
@ -10016,6 +10111,8 @@ static int test_multi_pw_aff(isl_ctx *ctx)
return -1;
if (test_multi_pw_aff_3(ctx) < 0)
return -1;
if (test_multi_pw_aff_box(ctx) < 0)
return -1;
return 0;
}
@ -10560,7 +10657,7 @@ static int test_tile(isl_ctx *ctx)
}
/* Check that the domain hash of a space is equal to the hash
* of the domain of the space.
* of the domain of the space, both ignoring parameters.
*/
static int test_domain_hash(isl_ctx *ctx)
{
@ -10571,9 +10668,9 @@ static int test_domain_hash(isl_ctx *ctx)
map = isl_map_read_from_str(ctx, "[n] -> { A[B[x] -> C[]] -> D[] }");
space = isl_map_get_space(map);
isl_map_free(map);
hash1 = isl_space_get_domain_hash(space);
hash1 = isl_space_get_tuple_domain_hash(space);
space = isl_space_domain(space);
hash2 = isl_space_get_hash(space);
hash2 = isl_space_get_tuple_hash(space);
isl_space_free(space);
if (!space)
@ -10761,6 +10858,7 @@ struct {
{ "intersect", &test_intersect },
{ "lexmin", &test_lexmin },
{ "min", &test_min },
{ "set lower bounds", &test_min_mpa },
{ "gist", &test_gist },
{ "piecewise quasi-polynomials", &test_pwqp },
{ "lift", &test_lift },

View File

@ -34,7 +34,6 @@ int test_imath_internals()
assert(MP_SMALL_MAX == LONG_MAX);
assert(sizeof(mp_usmall) == sizeof(unsigned long));
assert(MP_USMALL_MIN == ULONG_MIN);
assert(MP_USMALL_MAX == ULONG_MAX);
retval = mp_int_init_value(&val, 0);

View File

@ -0,0 +1,18 @@
/*
* Copyright 2013 Ecole Normale Superieure
*
* Use of this software is governed by the MIT license
*
* Written by Sven Verdoolaege,
* Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
*/
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
#define FN(TYPE,NAME) xFN(TYPE,NAME)
/* Is the space of "obj" equal to "space"?
*/
isl_bool FN(TYPE,has_space)(__isl_keep TYPE *obj, __isl_keep isl_space *space)
{
return isl_space_is_equal(FN(TYPE,peek_space)(obj), space);
}

View File

@ -24,53 +24,57 @@ static __isl_give isl_val *FN(UNION,eval_void)(__isl_take UNION *u,
return isl_val_nan(ctx);
}
/* Do the tuples of "space" correspond to those of the domain of "part"?
* That is, is the domain space of "part" equal to "space", ignoring parameters?
/* Internal data structure for isl_union_*_eval.
*
* "pnt" is the point in which the function is evaluated.
* "v" stores the result and is initialized to zero.
*/
static isl_bool FN(UNION,has_domain_space_tuples)(const void *entry,
const void *val)
{
PART *part = (PART *)entry;
isl_space *space = (isl_space *) val;
S(UNION,eval_data) {
isl_point *pnt;
isl_val *v;
};
return FN(PART,has_domain_space_tuples)(part, space);
/* Update the evaluation in data->v based on the evaluation of "part".
*
* Only (at most) a single part on which this function is called
* is assumed to evaluate to anything other than zero.
* Since the value is initialized to zero, the evaluation of "part"
* can simply be added.
*/
static isl_stat FN(UNION,eval_entry)(__isl_take PART *part, void *user)
{
S(UNION,eval_data) *data = user;
isl_val *v;
v = FN(PART,eval)(part, isl_point_copy(data->pnt));
data->v = isl_val_add(data->v, v);
return isl_stat_non_null(data->v);
}
/* Evaluate "u" in the point "pnt".
*/
__isl_give isl_val *FN(UNION,eval)(__isl_take UNION *u,
__isl_take isl_point *pnt)
{
uint32_t hash;
struct isl_hash_table_entry *entry;
S(UNION,eval_data) data = { pnt };
isl_bool is_void;
isl_space *space;
isl_val *v;
if (!u || !pnt)
goto error;
is_void = isl_point_is_void(pnt);
if (is_void < 0)
goto error;
if (is_void)
return FN(UNION,eval_void)(u, pnt);
space = isl_space_copy(pnt->dim);
if (!space)
goto error;
hash = isl_space_get_hash(space);
entry = isl_hash_table_find(u->space->ctx, &u->table,
hash, &FN(UNION,has_domain_space_tuples),
space, 0);
isl_space_free(space);
if (!entry)
goto error;
if (entry == isl_hash_table_entry_none) {
v = isl_val_zero(isl_point_get_ctx(pnt));
isl_point_free(pnt);
} else {
v = FN(PART,eval)(FN(PART,copy)(entry->data), pnt);
}
data.v = isl_val_zero(isl_point_get_ctx(pnt));
space = isl_point_peek_space(pnt);
if (FN(UNION,foreach_on_domain)(u, space,
&FN(UNION,eval_entry), &data) < 0)
data.v = isl_val_free(data.v);
FN(UNION,free)(u);
return v;
isl_point_free(pnt);
return data.v;
error:
FN(UNION,free)(u);
isl_point_free(pnt);

View File

@ -32,6 +32,13 @@
#include <uset_from_umap.c>
#include <set_list_from_map_list_inl.c>
#undef TYPE
#define TYPE isl_union_map
static
#include "has_single_reference_templ.c"
static
#include "check_single_reference_templ.c"
/* Return the number of parameters of "umap", where "type"
* is required to be set to isl_dim_param.
*/
@ -402,20 +409,58 @@ isl_bool isl_union_set_space_has_equal_params(__isl_keep isl_union_set *uset,
return isl_union_map_space_has_equal_params(uset_to_umap(uset), space);
}
static isl_bool has_space(const void *entry, const void *val)
/* Is the space of the map at "entry" equal to "space", ignoring parameters?
*/
static isl_bool has_space_tuples(const void *entry, const void *val)
{
isl_map *map = (isl_map *)entry;
isl_space *space = (isl_space *) val;
return isl_space_is_equal(map->dim, space);
return isl_map_has_space_tuples(map, space);
}
/* Find the entry in "umap" with space "space" (ignoring parameters),
* returning isl_hash_table_entry_none if no such entry appears in "umap" and
* NULL on error.
* If "reserve" is set, then an entry is created if it does
* not exist already. Since this modifies the hash table in-place,
* this means "umap" must have a single reference when "reserve" is set.
*/
static struct isl_hash_table_entry *isl_union_map_find_entry(
__isl_keep isl_union_map *umap, __isl_keep isl_space *space,
int reserve)
{
uint32_t hash;
if (!umap || !space)
return NULL;
if (reserve && isl_union_map_check_single_reference(umap) < 0)
return NULL;
hash = isl_space_get_tuple_hash(space);
return isl_hash_table_find(isl_union_map_get_ctx(umap), &umap->table,
hash, &has_space_tuples, space, reserve);
}
/* Find the entry in "uset" with space "space" (ignoring parameters),
* returning isl_hash_table_entry_none if no such entry appears in "uset" and
* NULL on error.
* If "reserve" is set, then an entry is created if it does
* not exist already. In this case, a NULL return indicates an error.
*/
struct isl_hash_table_entry *isl_union_set_find_entry(
__isl_keep isl_union_set *uset, __isl_keep isl_space *space,
int reserve)
{
return isl_union_map_find_entry(uset_to_umap(uset), space, reserve);
}
__isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap,
__isl_take isl_map *map)
{
uint32_t hash;
struct isl_hash_table_entry *entry;
isl_bool aligned;
isl_space *space;
if (!map || !umap)
goto error;
@ -435,12 +480,8 @@ __isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap,
umap = isl_union_map_cow(umap);
if (!map || !umap)
goto error;
hash = isl_space_get_hash(map->dim);
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
&has_space, map->dim, 1);
space = isl_map_peek_space(map);
entry = isl_union_map_find_entry(umap, space, 1);
if (!entry)
goto error;
@ -701,17 +742,9 @@ __isl_give isl_set *isl_set_from_union_set(__isl_take isl_union_set *uset)
__isl_give isl_map *isl_union_map_extract_map(__isl_keep isl_union_map *umap,
__isl_take isl_space *space)
{
uint32_t hash;
struct isl_hash_table_entry *entry;
space = isl_space_drop_all_params(space);
space = isl_space_align_params(space, isl_union_map_get_space(umap));
if (!umap || !space)
goto error;
hash = isl_space_get_hash(space);
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
&has_space, space, 0);
entry = isl_union_map_find_entry(umap, space, 0);
if (!entry)
goto error;
if (entry == isl_hash_table_entry_none)
@ -734,17 +767,11 @@ __isl_give isl_set *isl_union_set_extract_set(__isl_keep isl_union_set *uset,
isl_bool isl_union_map_contains(__isl_keep isl_union_map *umap,
__isl_keep isl_space *space)
{
uint32_t hash;
struct isl_hash_table_entry *entry;
space = isl_space_drop_all_params(isl_space_copy(space));
space = isl_space_align_params(space, isl_union_map_get_space(umap));
if (!space)
return isl_bool_error;
hash = isl_space_get_hash(space);
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
&has_space, space, 0);
entry = isl_union_map_find_entry(umap, space, 0);
isl_space_free(space);
if (!entry)
return isl_bool_error;
@ -903,7 +930,6 @@ static __isl_give isl_space *identity(__isl_take isl_space *space)
static __isl_keep isl_maybe_isl_map bin_try_get_match(
struct isl_union_map_gen_bin_data *data, __isl_keep isl_map *map)
{
uint32_t hash;
struct isl_hash_table_entry *entry2;
isl_space *space;
isl_maybe_isl_map res = { isl_bool_error, NULL };
@ -918,12 +944,7 @@ static __isl_keep isl_maybe_isl_map bin_try_get_match(
space = isl_map_get_space(map);
if (data->control->match_space != &identity)
space = data->control->match_space(space);
if (!space)
return res;
hash = isl_space_get_hash(space);
entry2 = isl_hash_table_find(isl_union_map_get_ctx(data->umap2),
&data->umap2->table, hash,
&has_space, space, 0);
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
isl_space_free(space);
if (entry2)
res.valid = isl_bool_ok(entry2 != isl_hash_table_entry_none);
@ -1119,14 +1140,13 @@ struct isl_union_map_match_bin_data {
static isl_stat match_bin_entry(void **entry, void *user)
{
struct isl_union_map_match_bin_data *data = user;
uint32_t hash;
struct isl_hash_table_entry *entry2;
isl_space *space;
isl_map *map = *entry;
int empty;
hash = isl_space_get_hash(map->dim);
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
hash, &has_space, map->dim, 0);
space = isl_map_peek_space(map);
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
if (!entry2)
return isl_stat_error;
if (entry2 == isl_hash_table_entry_none)
@ -1446,6 +1466,22 @@ __isl_give isl_union_map *isl_union_map_intersect_range(
return isl_union_map_intersect_range_union_set(umap, uset);
}
/* Intersect each map in "umap" in a space [A -> B] -> C
* with the corresponding map in "factor" in the space A -> C and
* collect the results.
*/
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_domain(
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor)
{
struct isl_bin_op_control control = {
.filter = &isl_map_domain_is_wrapping,
.match_space = &isl_space_domain_factor_domain,
.fn_map = &isl_map_intersect_domain_factor_domain,
};
return gen_bin_op(umap, factor, &control);
}
/* Intersect each map in "umap" in a space [A -> B] -> C
* with the corresponding map in "factor" in the space B -> C and
* collect the results.
@ -2484,13 +2520,12 @@ struct isl_union_map_is_subset_data {
static isl_stat is_subset_entry(void **entry, void *user)
{
struct isl_union_map_is_subset_data *data = user;
uint32_t hash;
struct isl_hash_table_entry *entry2;
isl_space *space;
isl_map *map = *entry;
hash = isl_space_get_hash(map->dim);
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
hash, &has_space, map->dim, 0);
space = isl_map_peek_space(map);
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
if (!entry2)
return isl_stat_error;
if (entry2 == isl_hash_table_entry_none) {
@ -2515,28 +2550,16 @@ isl_bool isl_union_map_is_subset(__isl_keep isl_union_map *umap1,
{
struct isl_union_map_is_subset_data data = { NULL, isl_bool_true };
umap1 = isl_union_map_copy(umap1);
umap2 = isl_union_map_copy(umap2);
umap1 = isl_union_map_align_params(umap1, isl_union_map_get_space(umap2));
umap2 = isl_union_map_align_params(umap2, isl_union_map_get_space(umap1));
if (!umap1 || !umap2)
goto error;
return isl_bool_error;
data.umap2 = umap2;
if (isl_hash_table_foreach(umap1->dim->ctx, &umap1->table,
&is_subset_entry, &data) < 0 &&
data.is_subset)
goto error;
isl_union_map_free(umap1);
isl_union_map_free(umap2);
return isl_bool_error;
return data.is_subset;
error:
isl_union_map_free(umap1);
isl_union_map_free(umap2);
return isl_bool_error;
}
isl_bool isl_union_set_is_subset(__isl_keep isl_union_set *uset1,
@ -2601,13 +2624,12 @@ struct isl_union_map_is_disjoint_data {
static isl_stat is_disjoint_entry(void **entry, void *user)
{
struct isl_union_map_is_disjoint_data *data = user;
uint32_t hash;
struct isl_hash_table_entry *entry2;
isl_space *space;
isl_map *map = *entry;
hash = isl_space_get_hash(map->dim);
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
hash, &has_space, map->dim, 0);
space = isl_map_peek_space(map);
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
if (!entry2)
return isl_stat_error;
if (entry2 == isl_hash_table_entry_none)
@ -4234,27 +4256,21 @@ __isl_give isl_union_map *isl_union_map_eq_at_multi_union_pw_aff(
&isl_multi_pw_aff_eq_map);
}
/* Return the subset of "umap" where the domain has a lexicographically
* smaller "mupa" value than the range.
*/
__isl_give isl_union_map *isl_union_map_lex_lt_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa)
{
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
&isl_multi_pw_aff_lex_lt_map);
}
#undef ORDER
#define ORDER le
#include "isl_union_map_lex_templ.c"
/* Return the subset of "umap" where the domain has a lexicographically
* greater "mupa" value than the range.
*/
__isl_give isl_union_map *isl_union_map_lex_gt_at_multi_union_pw_aff(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa)
{
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
&isl_multi_pw_aff_lex_gt_map);
}
#undef ORDER
#define ORDER lt
#include "isl_union_map_lex_templ.c"
#undef ORDER
#define ORDER ge
#include "isl_union_map_lex_templ.c"
#undef ORDER
#define ORDER gt
#include "isl_union_map_lex_templ.c"
/* Return the union of the elements in the list "list".
*/

View File

@ -0,0 +1,23 @@
/*
* Copyright 2014 INRIA Rocquencourt
*
* Use of this software is governed by the MIT license
*
* Written by Sven Verdoolaege,
* Inria Paris - Rocquencourt, Domaine de Voluceau - Rocquencourt,
* B.P. 105 - 78153 Le Chesnay, France
*/
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
#define FN(TYPE,NAME) xFN(TYPE,NAME)
/* Return the subset of "umap" where the domain and the range
* have "mupa" values that lexicographically compare as "ORDER".
*/
__isl_give isl_union_map *FN(FN(isl_union_map_lex,ORDER),at_multi_union_pw_aff)(
__isl_take isl_union_map *umap,
__isl_take isl_multi_union_pw_aff *mupa)
{
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
&FN(FN(isl_multi_pw_aff_lex,ORDER),map));
}

View File

@ -10,6 +10,10 @@ struct isl_union_map {
struct isl_hash_table table;
};
struct isl_hash_table_entry *isl_union_set_find_entry(
__isl_keep isl_union_set *uset, __isl_keep isl_space *space,
int reserve);
__isl_keep isl_space *isl_union_map_peek_space(__isl_keep isl_union_map *umap);
__isl_keep isl_space *isl_union_set_peek_space(__isl_keep isl_union_set *uset);
isl_bool isl_union_map_is_params(__isl_keep isl_union_map *umap);

View File

@ -18,7 +18,7 @@
/* A group of expressions defined over the same domain space "domain_space".
* The entries of "part_table" are the individual expressions,
* keyed on the entire space of the expression.
* keyed on the entire space of the expression (ignoring parameters).
*
* Each UNION has its own groups, so there can only ever be a single
* reference to each group.
@ -30,7 +30,8 @@ S(UNION,group) {
/* A union of expressions defined over different disjoint domains.
* "space" describes the parameters.
* The entries of "table" are keyed on the domain space of the entry and
* The entries of "table" are keyed on the domain space of the entry
* (ignoring parameters) and
* contain groups of expressions that are defined over the same domain space.
*/
struct UNION {
@ -158,14 +159,16 @@ error:
return NULL;
}
/* Is the space of "entry" equal to "space"?
/* Is the space of "entry" equal to "space", ignoring parameters?
*/
static isl_bool FN(UNION,has_space)(const void *entry, const void *val)
static isl_bool FN(UNION,has_space_tuples)(const void *entry, const void *val)
{
PART *part = (PART *) entry;
isl_space *space = (isl_space *) val;
isl_space *part_space;
return isl_space_is_equal(part->dim, space);
part_space = FN(PART,peek_space)(part);
return isl_space_has_equal_tuples(part_space, space);
}
/* Return a group equal to "group", but with a single reference.
@ -221,15 +224,15 @@ isl_stat FN(FN(UNION,foreach),BASE)(__isl_keep UNION *u,
}
/* Is the domain space of the group of expressions at "entry"
* equal to that of "space"?
* equal to that of "space", ignoring parameters?
*/
static isl_bool FN(UNION,group_has_same_domain_space)(const void *entry,
static isl_bool FN(UNION,group_has_same_domain_space_tuples)(const void *entry,
const void *val)
{
S(UNION,group) *group = (S(UNION,group) *) entry;
isl_space *space = (isl_space *) val;
return isl_space_is_domain_internal(group->domain_space, space);
return isl_space_has_domain_tuples(group->domain_space, space);
}
/* Return the entry, if any, in "u" that lives in "space".
@ -254,9 +257,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
return NULL;
ctx = FN(UNION,get_ctx)(u);
hash = isl_space_get_domain_hash(space);
hash = isl_space_get_tuple_domain_hash(space);
group_entry = isl_hash_table_find(ctx, &u->table, hash,
&FN(UNION,group_has_same_domain_space), space, reserve);
&FN(UNION,group_has_same_domain_space_tuples), space, reserve);
if (!group_entry || group_entry == isl_hash_table_entry_none)
return group_entry;
if (reserve && !group_entry->data) {
@ -270,9 +273,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
}
if (!group)
return NULL;
hash = isl_space_get_hash(space);
hash = isl_space_get_tuple_hash(space);
return isl_hash_table_find(ctx, &group->part_table, hash,
&FN(UNION,has_space), space, reserve);
&FN(UNION,has_space_tuples), space, reserve);
}
/* Remove "part_entry" from the hash table of "u".
@ -297,9 +300,9 @@ static __isl_give UNION *FN(UNION,remove_part_entry)(__isl_take UNION *u,
part = part_entry->data;
ctx = FN(UNION,get_ctx)(u);
space = FN(PART,peek_space)(part);
hash = isl_space_get_domain_hash(space);
hash = isl_space_get_tuple_domain_hash(space);
group_entry = isl_hash_table_find(ctx, &u->table, hash,
&FN(UNION,group_has_same_domain_space), space, 0);
&FN(UNION,group_has_same_domain_space_tuples), space, 0);
if (!group_entry)
return FN(UNION,free)(u);
if (group_entry == isl_hash_table_entry_none)
@ -383,9 +386,9 @@ static isl_stat FN(UNION,check_disjoint_domain_other)(__isl_keep UNION *u,
return isl_stat_error;
ctx = FN(UNION,get_ctx)(u);
space = FN(PART,peek_space)(part);
hash = isl_space_get_domain_hash(space);
hash = isl_space_get_tuple_domain_hash(space);
group_entry = isl_hash_table_find(ctx, &u->table, hash,
&FN(UNION,group_has_same_domain_space), space, 0);
&FN(UNION,group_has_same_domain_space_tuples), space, 0);
if (!group_entry)
return isl_stat_error;
if (group_entry == isl_hash_table_entry_none)

View File

@ -15,7 +15,8 @@
/* A union of expressions defined over different domain spaces.
* "space" describes the parameters.
* The entries of "table" are keyed on the domain space of the entry.
* The entries of "table" are keyed on the domain space of the entry
* (ignoring parameters).
*/
struct UNION {
int ref;
@ -63,9 +64,10 @@ isl_stat FN(FN(UNION,foreach),BASE)(__isl_keep UNION *u,
&FN(UNION,call_on_copy), &data);
}
/* Is the domain space of "entry" equal to the domain of "space"?
/* Is the domain space of "entry" equal to the domain of "space",
* ignoring parameters?
*/
static isl_bool FN(UNION,has_same_domain_space)(const void *entry,
static isl_bool FN(UNION,has_same_domain_space_tuples)(const void *entry,
const void *val)
{
PART *part = (PART *)entry;
@ -100,9 +102,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
return NULL;
ctx = FN(UNION,get_ctx)(u);
hash = isl_space_get_domain_hash(space);
hash = isl_space_get_tuple_domain_hash(space);
entry = isl_hash_table_find(ctx, &u->table, hash,
&FN(UNION,has_same_domain_space), space, reserve);
&FN(UNION,has_same_domain_space_tuples), space, reserve);
if (!entry || entry == isl_hash_table_entry_none)
return entry;
if (reserve && !entry->data)
@ -178,6 +180,47 @@ static isl_stat FN(UNION,foreach_inplace)(__isl_keep UNION *u,
return isl_hash_table_foreach(ctx, &u->table, fn, user);
}
static isl_bool FN(PART,has_domain_space_tuples)(__isl_keep PART *part,
__isl_keep isl_space *space);
/* Do the tuples of "space" correspond to those of the domain of "part"?
* That is, is the domain space of "part" equal to "space", ignoring parameters?
*/
static isl_bool FN(UNION,has_domain_space_tuples)(const void *entry,
const void *val)
{
PART *part = (PART *)entry;
isl_space *space = (isl_space *) val;
return FN(PART,has_domain_space_tuples)(part, space);
}
/* Call "fn" on each part of "u" that has domain space "space".
*
* Since each entry is defined over a different domain space,
* simply look for an entry with the given domain space and
* call "fn" on the corresponding part if there is one.
*/
isl_stat FN(UNION,foreach_on_domain)(__isl_keep UNION *u,
__isl_keep isl_space *space,
isl_stat (*fn)(__isl_take PART *part, void *user), void *user)
{
uint32_t hash;
struct isl_hash_table_entry *entry;
if (!u || !space)
return isl_stat_error;
hash = isl_space_get_tuple_hash(space);
entry = isl_hash_table_find(FN(UNION,get_ctx)(u), &u->table,
hash, &FN(UNION,has_domain_space_tuples),
space, 0);
if (!entry)
return isl_stat_error;
if (entry == isl_hash_table_entry_none)
return isl_stat_ok;
return fn(FN(PART,copy)(entry->data), user);
}
static isl_stat FN(UNION,free_u_entry)(void **entry, void *user)
{
PART *part = *entry;

View File

@ -143,8 +143,6 @@ __isl_give PART *FN(FN(UNION,extract),BASE)(__isl_keep UNION *u,
{
struct isl_hash_table_entry *entry;
space = isl_space_replace_params(space, FN(UNION,peek_space)(u));
entry = FN(UNION,find_part_entry)(u, space, 0);
if (!entry)
goto error;
@ -736,24 +734,15 @@ S(UNION,match_domain_data) {
S(UNION,match_domain_control) *control;
};
static isl_bool FN(UNION,set_has_space)(const void *entry, const void *val)
{
isl_set *set = (isl_set *)entry;
isl_space *space = (isl_space *)val;
return isl_space_is_equal(set->dim, space);
}
/* Find the set in data->uset that lives in the same space as the domain
* of "part", apply data->fn to *entry and this set (if any), and add
* the result to data->res.
* of "part" (ignoring parameters), apply data->fn to *entry and this set
* (if any), and add the result to data->res.
*/
static isl_stat FN(UNION,match_domain_entry)(__isl_take PART *part, void *user)
{
S(UNION,match_domain_data) *data = user;
uint32_t hash;
struct isl_hash_table_entry *entry2;
isl_space *space, *uset_space;
isl_space *space;
if (data->control->filter) {
isl_bool pass = data->control->filter(part);
@ -763,14 +752,10 @@ static isl_stat FN(UNION,match_domain_entry)(__isl_take PART *part, void *user)
}
}
uset_space = isl_union_set_peek_space(data->uset);
space = FN(PART,get_domain_space)(part);
if (data->control->match_space)
space = data->control->match_space(space);
space = isl_space_replace_params(space, uset_space);
hash = isl_space_get_hash(space);
entry2 = isl_hash_table_find(data->uset->dim->ctx, &data->uset->table,
hash, &FN(UNION,set_has_space), space, 0);
entry2 = isl_union_set_find_entry(data->uset, space, 0);
isl_space_free(space);
if (!entry2 || entry2 == isl_hash_table_entry_none) {
FN(PART,free)(part);

View File

@ -31,7 +31,7 @@
PROGRAM=libtool
PACKAGE=libtool
VERSION="2.4.6 Debian-2.4.6-2"
VERSION="2.4.6 Debian-2.4.6-14"
package_revision=2.4.6
@ -387,7 +387,7 @@ EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
# putting '$debug_cmd' at the start of all your functions, you can get
# bash to show function call trace with:
#
# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
# debug_cmd='echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
debug_cmd=${debug_cmd-":"}
exit_cmd=:
@ -1370,7 +1370,7 @@ func_lt_ver ()
#! /bin/sh
# Set a version string for this script.
scriptversion=2014-01-07.03; # UTC
scriptversion=2015-10-07.11; # UTC
# A portable, pluggable option parser for Bourne shell.
# Written by Gary V. Vaughan, 2010
@ -1530,6 +1530,8 @@ func_run_hooks ()
{
$debug_cmd
_G_rc_run_hooks=false
case " $hookable_fns " in
*" $1 "*) ;;
*) func_fatal_error "'$1' does not support hook funcions.n" ;;
@ -1538,16 +1540,16 @@ func_run_hooks ()
eval _G_hook_fns=\$$1_hooks; shift
for _G_hook in $_G_hook_fns; do
eval $_G_hook '"$@"'
# store returned options list back into positional
# parameters for next 'cmd' execution.
eval _G_hook_result=\$${_G_hook}_result
eval set dummy "$_G_hook_result"; shift
if eval $_G_hook '"$@"'; then
# store returned options list back into positional
# parameters for next 'cmd' execution.
eval _G_hook_result=\$${_G_hook}_result
eval set dummy "$_G_hook_result"; shift
_G_rc_run_hooks=:
fi
done
func_quote_for_eval ${1+"$@"}
func_run_hooks_result=$func_quote_for_eval_result
$_G_rc_run_hooks && func_run_hooks_result=$_G_hook_result
}
@ -1557,10 +1559,16 @@ func_run_hooks ()
## --------------- ##
# In order to add your own option parsing hooks, you must accept the
# full positional parameter list in your hook function, remove any
# options that you action, and then pass back the remaining unprocessed
# full positional parameter list in your hook function, you may remove/edit
# any options that you action, and then pass back the remaining unprocessed
# options in '<hooked_function_name>_result', escaped suitably for
# 'eval'. Like this:
# 'eval'. In this case you also must return $EXIT_SUCCESS to let the
# hook's caller know that it should pay attention to
# '<hooked_function_name>_result'. Returning $EXIT_FAILURE signalizes that
# arguments are left untouched by the hook and therefore caller will ignore the
# result variable.
#
# Like this:
#
# my_options_prep ()
# {
@ -1570,9 +1578,11 @@ func_run_hooks ()
# usage_message=$usage_message'
# -s, --silent don'\''t print informational messages
# '
#
# func_quote_for_eval ${1+"$@"}
# my_options_prep_result=$func_quote_for_eval_result
# # No change in '$@' (ignored completely by this hook). There is
# # no need to do the equivalent (but slower) action:
# # func_quote_for_eval ${1+"$@"}
# # my_options_prep_result=$func_quote_for_eval_result
# false
# }
# func_add_hook func_options_prep my_options_prep
#
@ -1581,25 +1591,37 @@ func_run_hooks ()
# {
# $debug_cmd
#
# args_changed=false
#
# # Note that for efficiency, we parse as many options as we can
# # recognise in a loop before passing the remainder back to the
# # caller on the first unrecognised argument we encounter.
# while test $# -gt 0; do
# opt=$1; shift
# case $opt in
# --silent|-s) opt_silent=: ;;
# --silent|-s) opt_silent=:
# args_changed=:
# ;;
# # Separate non-argument short options:
# -s*) func_split_short_opt "$_G_opt"
# set dummy "$func_split_short_opt_name" \
# "-$func_split_short_opt_arg" ${1+"$@"}
# shift
# args_changed=:
# ;;
# *) set dummy "$_G_opt" "$*"; shift; break ;;
# *) # Make sure the first unrecognised option "$_G_opt"
# # is added back to "$@", we could need that later
# # if $args_changed is true.
# set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
# esac
# done
#
# func_quote_for_eval ${1+"$@"}
# my_silent_option_result=$func_quote_for_eval_result
# if $args_changed; then
# func_quote_for_eval ${1+"$@"}
# my_silent_option_result=$func_quote_for_eval_result
# fi
#
# $args_changed
# }
# func_add_hook func_parse_options my_silent_option
#
@ -1611,16 +1633,32 @@ func_run_hooks ()
# $opt_silent && $opt_verbose && func_fatal_help "\
# '--silent' and '--verbose' options are mutually exclusive."
#
# func_quote_for_eval ${1+"$@"}
# my_option_validation_result=$func_quote_for_eval_result
# false
# }
# func_add_hook func_validate_options my_option_validation
#
# You'll alse need to manually amend $usage_message to reflect the extra
# You'll also need to manually amend $usage_message to reflect the extra
# options you parse. It's preferable to append if you can, so that
# multiple option parsing hooks can be added safely.
# func_options_finish [ARG]...
# ----------------------------
# Finishing the option parse loop (call 'func_options' hooks ATM).
func_options_finish ()
{
$debug_cmd
_G_func_options_finish_exit=false
if func_run_hooks func_options ${1+"$@"}; then
func_options_finish_result=$func_run_hooks_result
_G_func_options_finish_exit=:
fi
$_G_func_options_finish_exit
}
# func_options [ARG]...
# ---------------------
# All the functions called inside func_options are hookable. See the
@ -1630,17 +1668,28 @@ func_options ()
{
$debug_cmd
func_options_prep ${1+"$@"}
eval func_parse_options \
${func_options_prep_result+"$func_options_prep_result"}
eval func_validate_options \
${func_parse_options_result+"$func_parse_options_result"}
_G_rc_options=false
eval func_run_hooks func_options \
${func_validate_options_result+"$func_validate_options_result"}
for my_func in options_prep parse_options validate_options options_finish
do
if eval func_$my_func '${1+"$@"}'; then
eval _G_res_var='$'"func_${my_func}_result"
eval set dummy "$_G_res_var" ; shift
_G_rc_options=:
fi
done
# save modified positional parameters for caller
func_options_result=$func_run_hooks_result
# Save modified positional parameters for caller. As a top-level
# options-parser function we always need to set the 'func_options_result'
# variable (regardless the $_G_rc_options value).
if $_G_rc_options; then
func_options_result=$_G_res_var
else
func_quote_for_eval ${1+"$@"}
func_options_result=$func_quote_for_eval_result
fi
$_G_rc_options
}
@ -1649,9 +1698,9 @@ func_options ()
# All initialisations required before starting the option parse loop.
# Note that when calling hook functions, we pass through the list of
# positional parameters. If a hook function modifies that list, and
# needs to propogate that back to rest of this script, then the complete
# needs to propagate that back to rest of this script, then the complete
# modified list must be put in 'func_run_hooks_result' before
# returning.
# returning $EXIT_SUCCESS (otherwise $EXIT_FAILURE is returned).
func_hookable func_options_prep
func_options_prep ()
{
@ -1661,10 +1710,14 @@ func_options_prep ()
opt_verbose=false
opt_warning_types=
func_run_hooks func_options_prep ${1+"$@"}
_G_rc_options_prep=false
if func_run_hooks func_options_prep ${1+"$@"}; then
_G_rc_options_prep=:
# save modified positional parameters for caller
func_options_prep_result=$func_run_hooks_result
fi
# save modified positional parameters for caller
func_options_prep_result=$func_run_hooks_result
$_G_rc_options_prep
}
@ -1678,18 +1731,20 @@ func_parse_options ()
func_parse_options_result=
_G_rc_parse_options=false
# this just eases exit handling
while test $# -gt 0; do
# Defer to hook functions for initial option parsing, so they
# get priority in the event of reusing an option name.
func_run_hooks func_parse_options ${1+"$@"}
# Adjust func_parse_options positional parameters to match
eval set dummy "$func_run_hooks_result"; shift
if func_run_hooks func_parse_options ${1+"$@"}; then
eval set dummy "$func_run_hooks_result"; shift
_G_rc_parse_options=:
fi
# Break out of the loop if we already parsed every option.
test $# -gt 0 || break
_G_match_parse_options=:
_G_opt=$1
shift
case $_G_opt in
@ -1704,7 +1759,10 @@ func_parse_options ()
;;
--warnings|--warning|-W)
test $# = 0 && func_missing_arg $_G_opt && break
if test $# = 0 && func_missing_arg $_G_opt; then
_G_rc_parse_options=:
break
fi
case " $warning_categories $1" in
*" $1 "*)
# trailing space prevents matching last $1 above
@ -1757,15 +1815,25 @@ func_parse_options ()
shift
;;
--) break ;;
--) _G_rc_parse_options=: ; break ;;
-*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
*) set dummy "$_G_opt" ${1+"$@"}; shift
_G_match_parse_options=false
break
;;
esac
$_G_match_parse_options && _G_rc_parse_options=:
done
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
func_parse_options_result=$func_quote_for_eval_result
if $_G_rc_parse_options; then
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
func_parse_options_result=$func_quote_for_eval_result
fi
$_G_rc_parse_options
}
@ -1778,16 +1846,21 @@ func_validate_options ()
{
$debug_cmd
_G_rc_validate_options=false
# Display all warnings if -W was not given.
test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
func_run_hooks func_validate_options ${1+"$@"}
if func_run_hooks func_validate_options ${1+"$@"}; then
# save modified positional parameters for caller
func_validate_options_result=$func_run_hooks_result
_G_rc_validate_options=:
fi
# Bail if the options were screwed!
$exit_cmd $EXIT_FAILURE
# save modified positional parameters for caller
func_validate_options_result=$func_run_hooks_result
$_G_rc_validate_options
}
@ -2068,7 +2141,7 @@ include the following information:
compiler: $LTCC
compiler flags: $LTCFLAGS
linker: $LD (gnu? $with_gnu_ld)
version: $progname $scriptversion Debian-2.4.6-2
version: $progname $scriptversion Debian-2.4.6-14
automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
@ -2270,6 +2343,8 @@ libtool_options_prep ()
nonopt=
preserve_args=
_G_rc_lt_options_prep=:
# Shorthand for --mode=foo, only valid as the first argument
case $1 in
clean|clea|cle|cl)
@ -2293,11 +2368,18 @@ libtool_options_prep ()
uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
shift; set dummy --mode uninstall ${1+"$@"}; shift
;;
*)
_G_rc_lt_options_prep=false
;;
esac
# Pass back the list of options.
func_quote_for_eval ${1+"$@"}
libtool_options_prep_result=$func_quote_for_eval_result
if $_G_rc_lt_options_prep; then
# Pass back the list of options.
func_quote_for_eval ${1+"$@"}
libtool_options_prep_result=$func_quote_for_eval_result
fi
$_G_rc_lt_options_prep
}
func_add_hook func_options_prep libtool_options_prep
@ -2309,9 +2391,12 @@ libtool_parse_options ()
{
$debug_cmd
_G_rc_lt_parse_options=false
# Perform our own loop to consume as many options as possible in
# each iteration.
while test $# -gt 0; do
_G_match_lt_parse_options=:
_G_opt=$1
shift
case $_G_opt in
@ -2386,15 +2471,22 @@ libtool_parse_options ()
func_append preserve_args " $_G_opt"
;;
# An option not handled by this hook function:
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
# An option not handled by this hook function:
*) set dummy "$_G_opt" ${1+"$@"} ; shift
_G_match_lt_parse_options=false
break
;;
esac
$_G_match_lt_parse_options && _G_rc_lt_parse_options=:
done
if $_G_rc_lt_parse_options; then
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
libtool_parse_options_result=$func_quote_for_eval_result
fi
# save modified positional parameters for caller
func_quote_for_eval ${1+"$@"}
libtool_parse_options_result=$func_quote_for_eval_result
$_G_rc_lt_parse_options
}
func_add_hook func_parse_options libtool_parse_options
@ -7275,10 +7367,13 @@ func_mode_link ()
# -specs=* GCC specs files
# -stdlib=* select c++ std lib with clang
# -fsanitize=* Clang/GCC memory and address sanitizer
# -fuse-ld=* Linker select flags for GCC
# -static-* direct GCC to link specific libraries statically
# -fcilkplus Cilk Plus language extension features for C/C++
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
-O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
-specs=*|-fsanitize=*)
-specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus)
func_quote_for_eval "$arg"
arg=$func_quote_for_eval_result
func_append compile_command " $arg"

View File

@ -1041,8 +1041,8 @@ int forced_loaded() { return 2;}
_LT_EOF
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD
echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD
$AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD
echo "$AR cr libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD
$AR cr libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD
echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD
$RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD
cat > conftest.c << _LT_EOF
@ -1492,7 +1492,7 @@ need_locks=$enable_libtool_lock
m4_defun([_LT_PROG_AR],
[AC_CHECK_TOOLS(AR, [ar], false)
: ${AR=ar}
: ${AR_FLAGS=cru}
: ${AR_FLAGS=cr}
_LT_DECL([], [AR], [1], [The archiver])
_LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive])
@ -4063,7 +4063,8 @@ _LT_EOF
if AC_TRY_EVAL(ac_compile); then
# Now try to grab the symbols.
nlist=conftest.nm
if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&AS_MESSAGE_LOG_FD
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&AS_MESSAGE_LOG_FD && test -s "$nlist"; then
# Try sorting and uniquifying the output.
if sort "$nlist" | uniq > "$nlist"T; then
mv -f "$nlist"T "$nlist"
@ -4703,6 +4704,12 @@ m4_if([$1], [CXX], [
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
;;
# flang / f18. f95 an alias for gfortran or flang on Debian
flang* | f18* | f95*)
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
;;
# icc used to be incompatible with GCC.
# ICC 10 doesn't accept -KPIC any more.
icc* | ifort*)
@ -6438,7 +6445,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
GXX=no
@ -6813,7 +6820,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -6878,7 +6885,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
if test yes = "$GXX"; then
@ -7217,7 +7224,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# FIXME: insert proper C++ library support
@ -7301,7 +7308,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
else
# g++ 2.7 appears to require '-G' NOT '-shared' on this
# platform.
@ -7312,7 +7319,7 @@ if test yes != "$_lt_caught_CXX_error"; then
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
fi
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir'

View File

@ -1,9 +1,9 @@
#! /bin/sh
# Common wrapper for a few potentially missing GNU programs.
scriptversion=2013-10-28.13; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 1996-2014 Free Software Foundation, Inc.
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
# This program is free software; you can redistribute it and/or modify
@ -17,7 +17,7 @@ scriptversion=2013-10-28.13; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -101,9 +101,9 @@ else
exit $st
fi
perl_URL=http://www.perl.org/
flex_URL=http://flex.sourceforge.net/
gnu_software_URL=http://www.gnu.org/software
perl_URL=https://www.perl.org/
flex_URL=https://github.com/westes/flex
gnu_software_URL=https://www.gnu.org/software
program_details ()
{
@ -207,9 +207,9 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \
exit $st
# Local variables:
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -1,9 +1,9 @@
#!/bin/sh
# py-compile - Compile a Python program
scriptversion=2016-01-11.22; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 2000-2017 Free Software Foundation, Inc.
# Copyright (C) 2000-2018 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -162,7 +162,7 @@ sys.stdout.write('\n')" 2>/dev/null || :
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"

View File

@ -1,9 +1,9 @@
#! /bin/sh
# test-driver - basic testsuite driver script.
scriptversion=2013-07-13.22; # UTC
scriptversion=2018-03-07.03; # UTC
# Copyright (C) 2011-2014 Free Software Foundation, Inc.
# Copyright (C) 2011-2018 Free Software Foundation, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@ -16,7 +16,7 @@ scriptversion=2013-07-13.22; # UTC
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@ -140,9 +140,9 @@ echo ":copy-in-global-log: $gcopy" >> $trs_file
# Local Variables:
# mode: shell-script
# sh-indentation: 2
# eval: (add-hook 'write-file-hooks 'time-stamp)
# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC"
# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:

View File

@ -1,9 +1,9 @@
if (m >= 1) {
S1(0, 1, 1, 1);
if (m >= 2) {
S2(0, 1, 1, 1, 1, 1, 2, 1);
S3(0, 1, 1, 2, 1, 1, 1, 2);
S4(0, 1, 2, 2, 1, 1, 2, 2);
S3(0, 1, 1, 2, 1, 1, 1, 2);
S2(0, 1, 1, 1, 1, 1, 2, 1);
}
S8(0, 1);
for (int c0 = 1; c0 < 2 * m - 1; c0 += 1) {
@ -12,45 +12,45 @@ if (m >= 1) {
S5(m - 2, 1, m - 1, 1, m - 1, 1, m, 1);
S1(m - 1, 1, m, 1);
S3(m - 1, 1, m, 2, m, 1, m, 2);
} else if (m >= c0 + 2) {
S5(c0 - 1, 1, c0, 1, c0, 1, c0 + 1, 1);
S1(c0, 1, c0 + 1, 1);
S2(c0, 1, c0 + 1, 1, c0 + 1, 1, c0 + 2, 1);
S4(c0, 1, c0 + 2, 2, c0 + 1, 1, c0 + 2, 2);
S3(c0, 1, c0 + 1, 2, c0 + 1, 1, c0 + 1, 2);
} else {
} else if (c0 >= m) {
S5(c0 - 1, -m + c0 + 2, c0, -m + c0 + 2, m - 1, -m + c0 + 2, m, -m + c0 + 2);
S6(c0 - 1, -m + c0 + 1, c0, -m + c0 + 2, m, -m + c0 + 1, m, -m + c0 + 2);
S1(c0, -m + c0 + 2, m, -m + c0 + 2);
S3(c0, -m + c0 + 2, c0 + 1, -m + c0 + 3, m, -m + c0 + 2, m, -m + c0 + 3);
} else {
S5(c0 - 1, 1, c0, 1, c0, 1, c0 + 1, 1);
S1(c0, 1, c0 + 1, 1);
S3(c0, 1, c0 + 1, 2, c0 + 1, 1, c0 + 1, 2);
S4(c0, 1, c0 + 2, 2, c0 + 1, 1, c0 + 2, 2);
S2(c0, 1, c0 + 1, 1, c0 + 1, 1, c0 + 2, 1);
}
for (int c1 = max(2, -m + c0 + 3); c1 <= min(m - 1, c0); c1 += 1) {
S5(c0 - 1, c1, c0, c1, c0 - c1 + 1, c1, c0 - c1 + 2, c1);
S7(c0 - 1, c1 - 1, c0 + 1, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 3, c1);
S6(c0 - 1, c1 - 1, c0, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 2, c1);
S7(c0 - 1, c1 - 1, c0 + 1, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 3, c1);
S1(c0, c1, c0 - c1 + 2, c1);
S2(c0, c1, c0 + 1, c1, c0 - c1 + 2, c1, c0 - c1 + 3, c1);
S4(c0, c1, c0 + 2, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 3, c1 + 1);
S3(c0, c1, c0 + 1, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 2, c1 + 1);
S4(c0, c1, c0 + 2, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 3, c1 + 1);
S2(c0, c1, c0 + 1, c1, c0 - c1 + 2, c1, c0 - c1 + 3, c1);
}
if (c0 + 1 == m) {
S7(m - 2, m - 1, m, m, 1, m - 1, 2, m);
S6(m - 2, m - 1, m - 1, m, 1, m - 1, 1, m);
S7(m - 2, m - 1, m, m, 1, m - 1, 2, m);
S1(m - 1, m, 1, m);
S2(m - 1, m, m, m, 1, m, 2, m);
} else if (m >= c0 + 2) {
} else if (c0 >= m) {
S5(c0 - 1, m, c0, m, -m + c0 + 1, m, -m + c0 + 2, m);
S6(c0 - 1, m - 1, c0, m, -m + c0 + 2, m - 1, -m + c0 + 2, m);
S7(c0 - 1, m - 1, c0 + 1, m, -m + c0 + 2, m - 1, -m + c0 + 3, m);
S1(c0, m, -m + c0 + 2, m);
S2(c0, m, c0 + 1, m, -m + c0 + 2, m, -m + c0 + 3, m);
} else {
S6(c0 - 1, c0, c0, c0 + 1, 1, c0, 1, c0 + 1);
S7(c0 - 1, c0, c0 + 1, c0 + 1, 1, c0, 2, c0 + 1);
S1(c0, c0 + 1, 1, c0 + 1);
S2(c0, c0 + 1, c0 + 1, c0 + 1, 1, c0 + 1, 2, c0 + 1);
S4(c0, c0 + 1, c0 + 2, c0 + 2, 1, c0 + 1, 2, c0 + 2);
S3(c0, c0 + 1, c0 + 1, c0 + 2, 1, c0 + 1, 1, c0 + 2);
} else {
S5(c0 - 1, m, c0, m, -m + c0 + 1, m, -m + c0 + 2, m);
S7(c0 - 1, m - 1, c0 + 1, m, -m + c0 + 2, m - 1, -m + c0 + 3, m);
S6(c0 - 1, m - 1, c0, m, -m + c0 + 2, m - 1, -m + c0 + 2, m);
S1(c0, m, -m + c0 + 2, m);
S2(c0, m, c0 + 1, m, -m + c0 + 2, m, -m + c0 + 3, m);
S4(c0, c0 + 1, c0 + 2, c0 + 2, 1, c0 + 1, 2, c0 + 2);
S2(c0, c0 + 1, c0 + 1, c0 + 1, 1, c0 + 1, 2, c0 + 1);
}
} else {
S5(2 * m - 3, m, 2 * m - 2, m, m - 1, m, m, m);

View File

@ -2,6 +2,8 @@ for (int c0 = 0; c0 <= min(min(T_2 - 1, T_67 - 1), T_66); c0 += 1) {
S1(c0);
S2(c0);
}
for (int c0 = T_2; c0 <= min(T_67 - 1, T_66); c0 += 1)
S2(c0);
for (int c0 = max(0, T_66 + 1); c0 < min(T_2, T_67); c0 += 1)
S1(c0);
for (int c0 = T_67; c0 <= min(T_2 - 1, T_66); c0 += 1) {
@ -10,7 +12,5 @@ for (int c0 = T_67; c0 <= min(T_2 - 1, T_66); c0 += 1) {
}
for (int c0 = max(T_67, T_66 + 1); c0 < T_2; c0 += 1)
S1(c0);
for (int c0 = T_2; c0 <= min(T_67 - 1, T_66); c0 += 1)
S2(c0);
if (T_2 == 0 && T_67 == 0)
S1(0);

View File

@ -3,8 +3,8 @@ for (int c0 = 1; c0 <= min(M, N); c0 += 1) {
for (int c1 = 1; c1 <= M; c1 += 1)
S2(c0, c1);
}
for (int c0 = N + 1; c0 <= M; c0 += 1)
S1(c0);
for (int c0 = M + 1; c0 <= N; c0 += 1)
for (int c1 = 1; c1 <= M; c1 += 1)
S2(c0, c1);
for (int c0 = N + 1; c0 <= M; c0 += 1)
S1(c0);

View File

@ -36,18 +36,16 @@ for (int c0 = 0; c0 <= 36; c0 += 1) {
for (int c1 = 1; c1 <= 18; c1 += 1) {
for (int c2 = -8 * c1; c2 <= min(6, -8 * c1 + 24); c2 += 1)
S3(c0, c1, c2);
if (c1 == 2) {
S3(c0, 2, 7);
} else if (c0 <= 34 && c1 == 1) {
if (c0 <= 34 && c1 == 1) {
S3(c0, 1, 7);
} else if (c1 == 2) {
S3(c0, 2, 7);
} else if (c0 >= 35 && c1 == 1) {
S3(c0, 1, 7);
S7(c0, 1, 7);
}
for (int c2 = 8; c2 <= min(-8 * c1 + 24, c1 - (6 * c0 + 77) / 77 + 12); c2 += 1)
S3(c0, c1, c2);
for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1)
S6(c0, c1, c2);
if (c1 == 1) {
for (int c2 = -((6 * c0 + 77) / 77) + 14; c2 <= 13; c2 += 1) {
S3(c0, 1, c2);
@ -56,6 +54,8 @@ for (int c0 = 0; c0 <= 36; c0 += 1) {
for (int c2 = 14; c2 <= 16; c2 += 1)
S3(c0, 1, c2);
}
for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1)
S6(c0, c1, c2);
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1)
S1(c0, c1, c2);
}
@ -77,14 +77,6 @@ for (int c0 = 37; c0 <= 218; c0 += 1) {
for (int c2 = -2 * c1 + 30; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
S1(c0, c1, c2);
}
for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
if (7 * c1 + 114 >= 2 * c0)
S7(c0, c1, 6);
for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
S6(c0, c1, c2);
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
S1(c0, c1, c2);
}
if (c0 <= 148)
for (int c1 = max(0, (c0 + 5) / 14 - 8); c1 < c0 / 14 - 5; c1 += 1) {
if (c1 == 0)
@ -95,6 +87,14 @@ for (int c0 = 37; c0 <= 218; c0 += 1) {
if (c0 >= 70 && c0 % 14 >= 9)
for (int c2 = max((c0 + 5) / 14 + 18, -((3 * c0 + 14) / 14) + c0 / 14 + 44); c2 <= -((3 * c0 + 17) / 14) + c0 / 14 + 51; c2 += 1)
S1(c0, c0 / 14 - 5, c2);
for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
if (7 * c1 + 114 >= 2 * c0)
S7(c0, c1, 6);
for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
S6(c0, c1, c2);
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
S1(c0, c1, c2);
}
for (int c1 = max(0, (c0 + 5) / 14 - 5); c1 < c0 / 14 - 2; c1 += 1) {
for (int c2 = max(c1, -2 * c1 + 6); c2 <= min(c1 + 5, -2 * c1 + 24); c2 += 1)
S9(c0, c1, c2);

View File

@ -4,10 +4,10 @@ for (int c0 = N + 1; c0 <= 2 * N; c0 += 1)
for (int c1 = 1; c1 <= N; c1 += 1)
S2(c1, -N + c0);
for (int c0 = 2 * N + 1; c0 <= M + N; c0 += 1) {
for (int c1 = 1; c1 <= N; c1 += 1)
S2(c1, -N + c0);
for (int c1 = 1; c1 <= N; c1 += 1)
S3(c1, -2 * N + c0);
for (int c1 = 1; c1 <= N; c1 += 1)
S2(c1, -N + c0);
}
for (int c0 = M + N + 1; c0 <= M + 2 * N; c0 += 1)
for (int c1 = 1; c1 <= N; c1 += 1)

View File

@ -1,8 +1,8 @@
for (int c0 = M + 1; c0 <= 2 * M; c0 += 1)
S1(-M + c0);
for (int c0 = 2 * M + 1; c0 <= M + N; c0 += 1) {
S2(-2 * M + c0);
S1(-M + c0);
S2(-2 * M + c0);
}
for (int c0 = M + N + 1; c0 <= 2 * M + N; c0 += 1)
S2(-2 * M + c0);

View File

@ -3,8 +3,8 @@ for (int c0 = 0; c0 <= M; c0 += 1) {
S1(c0, c1);
S2(c0, c1);
}
for (int c1 = c0 + 1; c1 <= N; c1 += 1)
S2(c0, c1);
for (int c1 = max(0, N + 1); c1 <= c0; c1 += 1)
S1(c0, c1);
for (int c1 = c0 + 1; c1 <= N; c1 += 1)
S2(c0, c1);
}

View File

@ -1,18 +1,18 @@
if (M >= 0 && N >= 0)
for (int c0 = -4; c0 <= 3 * M + N; c0 += 1) {
if (c0 >= 3 * M) {
S2(M, -3 * M + c0);
} else if (3 * M >= c0 + 4 && (c0 + 1) % 3 == 0) {
if (3 * M >= c0 + 4 && (c0 + 1) % 3 == 0) {
S1((c0 + 4) / 3, 0);
} else if (c0 >= 3 * M) {
S2(M, -3 * M + c0);
}
for (int c1 = max(-3 * M + c0 + 3, (c0 + 6) % 3); c1 <= min(N - 1, c0); c1 += 3) {
S2((c0 - c1) / 3, c1);
S1(((c0 - c1) / 3) + 1, c1 + 1);
}
if (3 * M + N >= c0 + 3 && c0 >= N && (N - c0) % 3 == 0) {
S2((-N + c0) / 3, N);
} else if (N >= c0 + 4 && c0 >= -3) {
if (N >= c0 + 4 && c0 >= -3) {
S1(0, c0 + 4);
} else if (3 * M + N >= c0 + 3 && c0 >= N && (N - c0) % 3 == 0) {
S2((-N + c0) / 3, N);
}
for (int c1 = max(-3 * M + c0, (c0 + 6) % 3); c1 <= min(N, c0); c1 += 3)
S3((c0 - c1) / 3, c1);

View File

@ -4,12 +4,12 @@ for (int c0 = 1; c0 <= 2; c0 += 1)
for (int c0 = 3; c0 <= N; c0 += 1) {
for (int c1 = 1; c1 <= min(M, c0 - 1); c1 += 1)
S1(c0, c1);
if (c0 >= M + 1) {
S2(c0, c0);
} else {
if (M >= c0) {
S1(c0, c0);
S2(c0, c0);
}
for (int c1 = c0 + 1; c1 <= M; c1 += 1)
S1(c0, c1);
if (c0 >= M + 1)
S2(c0, c0);
}

View File

@ -14,8 +14,8 @@ for (int c0 = 2; c0 <= min(2 * n, n + 29); c0 += 1) {
}
}
for (int c1 = -c0 + c0 / 2 + 3; c1 <= min(-1, n - c0); c1 += 1) {
S6(-c1 + 2, c0 + c1 - 2);
S4(-c1, c0 + c1);
S6(-c1 + 2, c0 + c1 - 2);
for (int c2 = 1; c2 <= -c1; c2 += 1)
S5(-c1 + 1, c0 + c1 - 1, c2);
}
@ -24,23 +24,22 @@ for (int c0 = 2; c0 <= min(2 * n, n + 29); c0 += 1) {
for (int c2 = 1; c2 < -n + c0; c2 += 1)
S5(-n + c0, n, c2);
}
if (n >= 3 && c0 == n + 2) {
S1(n + 1);
S6(2, n);
if (c0 >= n + 3 && 2 * n >= c0 + 1)
S6(-n + c0, n);
if (c0 >= n + 3) {
S1(c0 - 1);
} else {
if (c0 >= n + 3 && 2 * n >= c0 + 1)
S6(-n + c0, n);
if (c0 >= n + 3) {
if (n + 1 >= c0 && c0 <= 4) {
S1(c0 - 1);
} else {
if (n + 1 >= c0 && c0 <= 4) {
S1(c0 - 1);
} else if (c0 >= 5 && n + 1 >= c0) {
S1(c0 - 1);
S6(2, c0 - 2);
}
if (n + 1 >= c0)
S6(1, c0 - 1);
} else if (c0 >= 5 && n + 1 >= c0) {
S1(c0 - 1);
S6(2, c0 - 2);
}
if (n + 1 >= c0) {
S6(1, c0 - 1);
} else if (n >= 3) {
S1(n + 1);
S6(2, n);
}
}
if (n == 2 && c0 == 4)
@ -67,8 +66,8 @@ for (int c0 = n + 30; c0 <= 2 * n; c0 += 1) {
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
}
for (int c1 = -c0 + c0 / 2 + 3; c1 <= n - c0; c1 += 1) {
S6(-c1 + 2, c0 + c1 - 2);
S4(-c1, c0 + c1);
S6(-c1 + 2, c0 + c1 - 2);
for (int c2 = 1; c2 <= -c1; c2 += 1)
S5(-c1 + 1, c0 + c1 - 1, c2);
}

View File

@ -3,14 +3,19 @@ for (int c0 = -27 * n + 2; c0 <= 1; c0 += 1)
for (int c0 = 2; c0 <= n + 29; c0 += 1) {
if (c0 >= 3) {
S4(c0 - c0 / 2 - 1, c0 / 2 + 1);
if (c0 >= 5 && 2 * n >= c0 + 3) {
if (c0 <= 4) {
S1(c0 - 1);
} else if (c0 + 2 >= 2 * n) {
for (int c2 = 1; c2 < -n + c0; c2 += 1)
S5(-n + c0, n, c2);
} else {
S4(c0 - c0 / 2 - 2, c0 / 2 + 2);
for (int c2 = 1; c2 < c0 - c0 / 2 - 1; c2 += 1)
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
}
for (int c1 = -c0 + c0 / 2 + 3; c1 <= min(-1, n - c0); c1 += 1) {
S6(-c1 + 2, c0 + c1 - 2);
S4(-c1, c0 + c1);
S6(-c1 + 2, c0 + c1 - 2);
for (int c2 = 1; c2 <= -c1; c2 += 1)
S5(-c1 + 1, c0 + c1 - 1, c2);
}
@ -18,26 +23,19 @@ for (int c0 = 2; c0 <= n + 29; c0 += 1) {
S6(-n + c0 + 1, n - 1);
for (int c2 = 1; c2 < -n + c0; c2 += 1)
S5(-n + c0, n, c2);
if (c0 == n + 2) {
S1(n + 1);
S6(2, n);
}
} else if (c0 + 2 >= 2 * n) {
for (int c2 = 1; c2 < -n + c0; c2 += 1)
S5(-n + c0, n, c2);
}
if (c0 >= n + 3) {
S6(-n + c0, n);
S1(c0 - 1);
} else if (c0 == n + 2) {
S1(n + 1);
S6(2, n);
} else {
if (c0 >= 5 && n + 1 >= c0) {
if (c0 >= 5) {
S1(c0 - 1);
S6(2, c0 - 2);
} else if (c0 <= 4) {
S1(c0 - 1);
}
if (n + 1 >= c0)
S6(1, c0 - 1);
S6(1, c0 - 1);
}
} else {
S1(1);
@ -59,8 +57,8 @@ for (int c0 = n + 30; c0 <= 2 * n; c0 += 1) {
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
}
for (int c1 = -c0 + c0 / 2 + 3; c1 <= n - c0; c1 += 1) {
S6(-c1 + 2, c0 + c1 - 2);
S4(-c1, c0 + c1);
S6(-c1 + 2, c0 + c1 - 2);
for (int c2 = 1; c2 <= -c1; c2 += 1)
S5(-c1 + 1, c0 + c1 - 1, c2);
}

Some files were not shown because too many files have changed in this diff Show More