3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-10-25 08:54:35 +00:00
z3/src/util
Lev Nachmanson 3b5337823a extract gomory cut functionality in one method
Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

prepare calculate U in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

naive algorithm for HNF and m <= n

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

naive algorithm for HNF

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

introduces reverse matrix into Hermite Normal Form calculation

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on more efficient hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

use smarter templates in lu.h

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

the new lu scheme compiles

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

simple test passes with the modified lu

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

fix the build on windows

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

playing with the example from cutting the mix

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf, add extended_gcd_minimal_uv()

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on extended_gcd_minimal_uv

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf, add extended_gcd_minimal_uv()

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

more tests and bug fixes in hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf modulo version

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf modulo version, more tests pass

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

a rough version of hnf passed the tests

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

fix build in release

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

fixes in determinant calculations

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

work on hnf

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

create a stub for hnf_cuts

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

create a stub for hnf_cuts

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

create a stub for hnf_cuts

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

general_matrix etc.

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

general_matrix etc.

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

rename cut_solver to chase_cut_solver

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

rename cut_solver to chase_cut_solver

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>

hnf_cutter

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>
2018-06-27 11:39:41 -07:00
..
lp extract gomory cut functionality in one method 2018-06-27 11:39:41 -07:00
approx_nat.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
approx_nat.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
approx_set.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
approx_set.h fixes for #1296, removing COMPILE_TIME_ASSERT 2017-10-09 13:59:44 -07:00
array.h Use nullptr. 2018-02-12 14:05:55 +07:00
array_map.h remove reinterpret cast occurrences that require disabling strict alias analysis #987 #1210 2017-08-17 20:28:49 -07:00
backtrackable_set.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
basic_interval.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
bit_util.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
bit_util.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
bit_vector.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
bit_vector.h Use nullptr. 2018-02-12 14:05:55 +07:00
buffer.h fix vector<> to support non-POD types 2017-10-16 00:54:29 +01:00
cancel_eh.h Use override rather than virtual. 2018-02-09 21:19:27 +07:00
chashtable.h Use nullptr. 2018-02-12 14:05:55 +07:00
checked_int64.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
CMakeLists.txt move min_cut, fix #1321 2017-10-25 02:59:04 -07:00
cmd_context_types.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
cmd_context_types.h Use nullptr. 2018-02-12 14:05:55 +07:00
common_msgs.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
common_msgs.h include rlimit in nlsat, include dedicated error message, for issue #216 2015-09-29 09:16:46 -07:00
container_util.h Fix code formatting: Incorrect indentation. 2018-01-02 23:11:36 +07:00
cooperate.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
cooperate.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
critical_flet.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
debug.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
debug.h fixes for #1296, removing COMPILE_TIME_ASSERT 2017-10-09 13:59:44 -07:00
dec_ref_util.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
dependency.h Use nullptr. 2018-02-12 14:05:55 +07:00
dictionary.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
dlist.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
double_manager.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
ema.h fix ema 2018-05-05 13:58:47 +02:00
env_params.cpp fix #1604 2018-04-29 10:04:42 -07:00
env_params.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
error_codes.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
event_handler.h ensure that timeouts are distinguished from other cancel events #848 2017-08-18 14:54:54 -07:00
ext_gcd.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
ext_numeral.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
f2n.h fix build of unit tests 2017-10-16 00:54:30 +01:00
file_path.h Use nullptr. 2018-02-12 14:05:55 +07:00
fixed_bit_vector.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
fixed_bit_vector.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
gparams.cpp merge 2018-05-01 07:43:29 -07:00
gparams.h fix #1604 2018-04-29 10:04:42 -07:00
hash.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
hash.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
hashtable.h merge with master 2018-03-25 14:57:01 -07:00
heap.h testing memory defragmentation, prefetch, delay ate 2018-04-27 17:59:03 +02:00
hwf.cpp merge with pull request #1557 2018-04-07 17:22:49 -07:00
hwf.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
id_gen.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
inf_eps_rational.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
inf_int_rational.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
inf_int_rational.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
inf_rational.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
inf_rational.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
inf_s_integer.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
inf_s_integer.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
lbool.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
lbool.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
list.h Use nullptr. 2018-02-12 14:05:55 +07:00
luby.cpp checkpoint 2012-10-21 13:32:12 -07:00
luby.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
machine.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
map.h Use nullptr. 2018-02-12 14:05:55 +07:00
max_cliques.h merge with master branch 2017-09-19 09:39:22 -07:00
memory_manager.cpp merge with master 2018-03-25 14:57:01 -07:00
memory_manager.h merge with master 2018-03-25 14:57:01 -07:00
min_cut.cpp remove ast.h reference 2017-10-25 09:49:53 -07:00
min_cut.h remove ast.h reference 2017-10-25 09:49:53 -07:00
mpbq.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpbq.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpbqi.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
mpf.cpp merge with pull request #1557 2018-04-07 17:22:49 -07:00
mpf.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpff.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpff.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpfx.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpfx.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpn.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpn.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
mpq.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
mpq.h extract gomory cut functionality in one method 2018-06-27 11:39:41 -07:00
mpq_inf.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
mpq_inf.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
mpz.cpp enable non-expression bodies of quantifiers to fix #1667 2018-06-07 22:03:03 -07:00
mpz.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
mpzzp.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
nat_set.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
numeral_buffer.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
obj_hashtable.h merge with master 2018-03-25 14:57:01 -07:00
obj_mark.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
obj_pair_hashtable.h added TODO markers in theory_str.h for moving to obj_map, remove include of stdbool for now 2018-03-16 07:46:27 -07:00
obj_pair_set.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
obj_ref.h add obj_ref::operator=(obj_ref &&) + a few explicit uses 2018-06-26 17:00:56 +01:00
obj_ref_hashtable.h fix build of obj_ref_hashtable 2017-12-08 14:22:25 +05:30
obj_triple_hashtable.h Use nullptr. 2018-02-12 14:05:55 +07:00
object_allocator.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
optional.h Use nullptr. 2018-02-12 14:05:55 +07:00
page.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
page.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
params.cpp merge 2018-04-30 09:30:43 -07:00
params.h Use nullptr. 2018-02-12 14:05:55 +07:00
parray.h Use nullptr. 2018-02-12 14:05:55 +07:00
permutation.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
permutation.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
plugin_manager.h integrate lambda expressions 2018-06-26 07:23:04 -07:00
pool.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
pop_scopes.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
prime_generator.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
prime_generator.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
ptr_scoped_buffer.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
queue.h parallel verison of ccc 2017-04-25 16:56:39 -07:00
rational.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
rational.h extract gomory cut functionality in one method 2018-06-27 11:39:41 -07:00
ref.h Use nullptr. 2018-02-12 14:05:55 +07:00
ref_buffer.h remove proof_converter from tactic application, removing nlsat_tactic 2017-11-17 23:32:29 -08:00
ref_util.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
ref_vector.h add move constructor to ref_vector 2017-10-16 00:54:31 +01:00
region.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
region.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
resource_limit.h bug fixes 2017-12-23 14:42:21 -08:00
rlimit.cpp Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
rlimit.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
s_integer.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
s_integer.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
scoped_ctrl_c.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
scoped_ctrl_c.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
scoped_numeral.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
scoped_numeral_buffer.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
scoped_numeral_vector.h fix vector<> to support non-POD types 2017-10-16 00:54:29 +01:00
scoped_ptr_vector.h Use nullptr. 2018-02-12 14:05:55 +07:00
scoped_timer.cpp fix #1592 #1587 2018-04-25 11:18:24 +02:00
scoped_timer.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
scoped_vector.h recognize theory_i_arith to fix #1200 2017-08-13 10:22:36 -07:00
sexpr.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
sexpr.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
small_object_allocator.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
small_object_allocator.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
smt2_util.cpp fix #1621 2018-05-18 14:30:27 -07:00
smt2_util.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
sorting_network.h dealing with compilers that don't take typename in non-template classes 2018-05-23 09:11:33 -07:00
sstream.h fix license in sstream 2018-01-29 19:14:17 -08:00
stack.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
stack.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
statistics.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
statistics.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
stats.h print_stat_f: Remove implicit conversion of float to double. 2018-01-02 22:50:50 +07:00
stopwatch.h Add support for NetBSD 2018-03-13 21:59:35 +01:00
str_hashtable.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
stream_buffer.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
string_buffer.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
symbol.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
symbol.h Use nullptr. 2018-02-12 14:05:55 +07:00
symbol_table.h Use nullptr. 2018-02-12 14:05:55 +07:00
timeit.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
timeit.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
timeout.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
timeout.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
timer.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
timer.h Do not request time stamp if not needed 2016-11-23 16:38:21 +01:00
top_sort.h integrate lambda expressions 2018-06-26 07:23:04 -07:00
total_order.h Remove int64, uint64 typedefs in favor of int64_t / uint64_t. 2018-03-31 14:45:04 +07:00
tptr.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
trace.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
trace.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
trail.h Use nullptr. 2018-02-12 14:05:55 +07:00
uint_map.h make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
uint_set.h working on parallel solver 2017-10-10 16:35:05 -07:00
union_find.h Use override rather than virtual. 2018-02-10 09:56:33 +07:00
util.cpp fix build 2018-05-01 09:39:19 -07:00
util.h use quotes 2018-06-15 15:53:47 -07:00
vector.h merge with master 2018-03-25 14:57:01 -07:00
version.h.cmake.in [CMake] Support including Git hash and description into the build. 2017-03-12 22:11:59 +00:00
version.h.in Added full version strings and associated API functions. 2016-07-28 18:06:02 +01:00
warning.cpp Use nullptr. 2018-02-12 14:05:55 +07:00
warning.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00
z3_exception.cpp make include paths uniformly use path relative to src. #534 2017-07-31 13:24:11 -07:00
z3_exception.h Use override rather than virtual. 2018-02-09 21:19:27 +07:00
z3_omp.h update header guards to be C++ style. Fixes issue #9 2015-07-08 23:18:40 -07:00