|
Release Notes for MiniSat 2.2.0
|
|
===============================
|
|
|
|
Changes since version 2.0:
|
|
|
|
* Started using a more standard release numbering.
|
|
|
|
* Includes some now well-known heuristics: phase-saving and luby
|
|
restarts. The old heuristics are still present and can be activated
|
|
if needed.
|
|
|
|
* Detection/Handling of out-of-memory and vector capacity
|
|
overflow. This is fairly new and relatively untested.
|
|
|
|
* Simple resource controls: CPU-time, memory, number of
|
|
conflicts/decisions.
|
|
|
|
* CPU-time limiting is implemented by a more general, but simple,
|
|
asynchronous interruption feature. This means that the solving
|
|
procedure can be interrupted from another thread or in a signal
|
|
handler.
|
|
|
|
* Improved portability with respect to building on Solaris and with
|
|
Visual Studio. This is not regularly tested and chances are that
|
|
this have been broken since, but should be fairly easy to fix if
|
|
so.
|
|
|
|
* Changed C++ file-extention to the less problematic ".cc".
|
|
|
|
* Source code is now namespace-protected
|
|
|
|
* Introducing a new Clause Memory Allocator that brings reduced
|
|
memory consumption on 64-bit architechtures and improved
|
|
performance (to some extent). The allocator uses a region-based
|
|
approach were all references to clauses are represented as a 32-bit
|
|
index into a global memory region that contains all clauses. To
|
|
free up and compact memory it uses a simple copying garbage
|
|
collector.
|
|
|
|
* Improved unit-propagation by Blocking Literals. For each entry in
|
|
the watcher lists, pair the pointer to a clause with some
|
|
(arbitrary) literal from the clause. The idea is that if the
|
|
literal is currently true (i.e. the clause is satisfied) the
|
|
watchers of the clause does not need to be altered. This can thus
|
|
be detected without touching the clause's memory at all. As often
|
|
as can be done cheaply, the blocking literal for entries to the
|
|
watcher list of a literal 'p' is set to the other literal watched
|
|
in the corresponding clause.
|
|
|
|
* Basic command-line/option handling system. Makes it easy to specify
|
|
options in the class that they affect, and whenever that class is
|
|
used in an executable, parsing of options and help messages are
|
|
brought in automatically.
|
|
|
|
* General clean-up and various minor bug-fixes.
|
|
|
|
* Changed implementation of variable-elimination/model-extension:
|
|
|
|
- The interface is changed so that arbitrary remembering is no longer
|
|
possible. If you need to mention some variable again in the future,
|
|
this variable has to be frozen.
|
|
|
|
- When eliminating a variable, only clauses that contain the variable
|
|
with one sign is necessary to store. Thereby making the other sign
|
|
a "default" value when extending models.
|
|
|
|
- The memory consumption for eliminated clauses is further improved
|
|
by storing all eliminated clauses in a single contiguous vector.
|
|
|
|
* Some common utility code (I/O, Parsing, CPU-time, etc) is ripped
|
|
out and placed in a separate "utils" directory.
|
|
|
|
* The DIMACS parse is refactored so that it can be reused in other
|
|
applications (not very elegant, but at least possible).
|
|
|
|
* Some simple improvements to scalability of preprocessing, using
|
|
more lazy clause removal from data-structures and a couple of
|
|
ad-hoc limits (the longest clause that can be produced in variable
|
|
elimination, and the longest clause used in backward subsumption).
|