3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-10-25 17:04:36 +00:00
z3/scripts
Clemens Eisenhofer 002d166f72
Xor (#6448)
* Added function to select the next variable to split on

* Fixed typo

* Small fixes

* uint -> int

* Fixed missing assignment for binary clauses

* Memory leak in .NET user-propagator
The user-propagator object has to be manually disposed (IDisposable), otherwise it stays in memory forever, as it cannot be garbage collected automatically

* Throw an exception if variable passed to decide is already assigned instead of running in an assertion violation

* Update (not compiling yet)

* #6429

* remove ternary clause optimization

Removing ternary clause optimization from sat_solver simplifies special case handling of ternary clauses throughout the sat solver and dependent solvers (pb_solver). Benchmarking on QF_BV suggests the ternary clause optimization does not have any effect. While removing ternary clause optimization two bugs in unit propagation were also uncovered: it missed propagations when the only a single undef literal remained in the non-watched literals and it did not update blocked literals in cases where it could in the watch list. These performance bugs were for general clauses, ternary clause propagation did not miss propagations (and don't use blocked literals), but fixing these issues for general clauses appear to have made ternary clause optimization irrelevant based on what was measured.

* Update: Missing data-structures (still not compiling)

* Nearly compiling

* Some missing arguments

* Polishing

* Only conflicts/propagations/justifications are missing for making it compile

* Added propagation (justifications for them are still missing)

* Use the right deallocation

* Use Z3's memory allocation system

* Ported "seen"

* Polishing

* Added 64-bit "1" counting

* More polishing

* minor fixes

- ensure mk_extract performs simplification to distribute over extract and removing extract if the range is the entire bit-vector
- ensure bool_rewriter simplifeis disjunctions when applicable.

* adding simplifiers layer

simplifiers layer is a common substrate for global non-incremental and incremental processing.
The first two layers are new, but others are to be ported form tactics.

- bv::slice - rewrites equations to cut-dice-slice bit-vector extractions until they align. It creates opportunities for rewriting portions of bit-vectors to common sub-expressions, including values.
- euf::completion - generalizes the KB simplifcation from asserted formulas to use the E-graph to establish a global and order-independent canonization.

The interface dependent_expr_simplifier is amenable to forming tactics. Plugins for asserted-formulas is also possible but not yet realized.

* Create bv_slice_tactic.cpp

missing file

* adding virtual destructor

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>

* Added 64-bit "1" counting (#6434)

* Memory leak in .NET user-propagator
The user-propagator object has to be manually disposed (IDisposable), otherwise it stays in memory forever, as it cannot be garbage collected automatically

* Throw an exception if variable passed to decide is already assigned instead of running in an assertion violation

* Added 64-bit "1" counting

* remove incorrect assertion

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>

* Added limit to "visit" to allow detecting multiple visits (#6435)

* Memory leak in .NET user-propagator
The user-propagator object has to be manually disposed (IDisposable), otherwise it stays in memory forever, as it cannot be garbage collected automatically

* Throw an exception if variable passed to decide is already assigned instead of running in an assertion violation

* Added limit to "visit" to allow detecting multiple visits

* Putting visit in a separate class
(Reason: We will probably need two of them in the sat::solver)

* Bugfix

* init solve_eqs

* working on solve_eqs

* Update .gitignore

* wip - converting the equation solver as a simplifier

* make visited_helper independent of literals

re-introduce shorthands in sat::solver for visited and have them convert literals to unsigned.

* build fix

* move model and proof converters to self-contained module

* Create solve_eqs2_tactic.h

* add converters module to python build

* move tactic_params to params

* move more converters

* move horn_subsume_model_converter to ast/converters

* add initial stubs for model reconstruction trail

* fixing build

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>

* fixes #6439 #6436

* It's compiling (However, two important functions are commented out)

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
Co-authored-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2022-11-10 09:05:17 -08:00
..
build-win-signed.yml Publish Z3 symbols (#6280) 2022-08-17 07:30:55 -07:00
build_libcxx_msan.sh restore exec bit on configure & scripts/*.sh 2020-05-16 20:07:36 +01:00
coverage.yml jobs 2021-07-30 22:38:56 -07:00
generate-doc.yml ocamldoc 2021-01-29 06:47:10 -08:00
jsdoctest.yml Standardize ubutu-latest vmImage 2022-08-15 07:55:45 -07:00
mk_consts_files.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_copyright.py tabs 2016-01-04 21:04:07 +00:00
mk_def_file.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_exception.py checkpoint 2012-10-23 12:12:59 -07:00
mk_genfile_common.py minor code simplifications 2022-08-20 12:56:45 +01:00
mk_gparams_register_modules_cpp.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_install_tactic_cpp.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_make.py removed comments 2016-02-14 19:57:21 +00:00
mk_mem_initializer_cpp.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_nuget_task.py Standardize ubutu-latest vmImage 2022-08-15 07:55:45 -07:00
mk_pat_db.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
mk_project.py Xor (#6448) 2022-11-10 09:05:17 -08:00
mk_unix_dist.py mk_unix_dist.py: Fix --nopython 2022-08-04 07:54:10 +03:00
mk_util.py Change to 4 digit assembly version (#6297) 2022-08-31 06:46:06 -07:00
mk_win_dist.py Change to 4 digit assembly version (#6297) 2022-08-31 06:46:06 -07:00
nightly.yaml increment version per release notes 2022-10-19 13:21:26 -07:00
policy.json add ESRP signing of nuget packages 2019-02-27 14:43:39 -08:00
pyg2hpp.py try without #!/bin/env python #5397 2021-07-10 15:20:56 +02:00
README updated docs 2012-10-25 18:46:37 -07:00
release.yml increment version per release notes 2022-10-19 13:21:26 -07:00
test-examples-cmake.yml remove test-examples from MacOS build, re-add maxsat example 2020-05-19 13:52:44 -07:00
test-java-cmake.yml separate failing java test 2019-06-12 08:13:57 -07:00
test-jupyter.yml extract jupyter template 2019-06-11 11:52:42 -07:00
test-regressions-coverage.yml rename 2021-07-29 11:32:20 -07:00
test-regressions.yml more templates 2019-06-12 08:35:34 -07:00
test-z3.yml update pipelines 2019-06-12 01:25:43 -07:00
trackall.sh restore exec bit on configure & scripts/*.sh 2020-05-16 20:07:36 +01:00
update_api.py added API to monitor clause inferences 2022-10-19 08:34:55 -07:00
update_header_guards.py tabs 2016-01-04 21:04:07 +00:00
update_include.py update header include generation to use relative paths #534 2017-08-03 08:50:04 -07:00
vsts-mac.sh remove stale references to gac/csc 2020-07-26 12:03:03 -07:00
vsts-vs2013.cmd remove python doc test 2018-03-20 13:37:04 -07:00
vsts-vs2017.cmd rename additional build options #2709 2019-11-18 23:02:44 -08:00

Instructions for updating external Z3 API
-----------------------------------------

The python "macros": def_Type() and def_API() are used to add new types and function definitions to the Z3 API.
The .h files provided to `mk_bindings(API_files)` contain these definitions.
See src\api\z3_api.h for many examples.

The bindings for .Net and Python are generated when mk_make.py is invoked.