#sat-solver #rustsat #debug-mode #debugging

rustsat-cadical

Interface to the SAT solver CaDiCaL for the RustSAT library

13 unstable releases (3 breaking)

new 0.4.3 Dec 20, 2024
0.4.1 Oct 16, 2024
0.3.1 Jun 12, 2024
0.2.4 Feb 23, 2024
0.2.0 Oct 30, 2023

#2074 in Algorithms

Download history 11/week @ 2024-09-19 11/week @ 2024-09-26 7/week @ 2024-10-03 193/week @ 2024-10-10 148/week @ 2024-10-17 15/week @ 2024-10-24 10/week @ 2024-10-31 5/week @ 2024-11-07 3/week @ 2024-11-14 3/week @ 2024-11-21 3/week @ 2024-11-28 40/week @ 2024-12-05 137/week @ 2024-12-12

184 downloads per month
Used in 2 crates

MIT license

800KB
19K SLoC

Check & Test crates.io docs.rs License

rustsat-cadical - Interface to the CaDiCaL SAT Solver for RustSAT

Armin Biere's SAT solver CaDiCaL to be used with the RustSAT library.

Note: at the moment this crate is known to not work on Windows since CaDiCaL is non-trivial to get to work on Windows.

Features

  • debug: if this feature is enables, the Cpp library will be built with debug and check functionality if the Rust project is built in debug mode
  • safe: disable writing through popen for more safe usage of the library in applications
  • quiet: exclude message and profiling code (logging too)
  • logging: include logging code (but disabled by default)

CaDiCaL Versions

CaDiCaL versions can be selected via cargo crate features. All CaDiCaL versions up to Version 2.1.1 are available. For the full list of versions and the changelog see the CaDiCaL releases.

Without any features selected, the newest version will be used. If conflicting CaDiCaL versions are requested, the newest requested version will be selected.

Customization

In order to build a custom version of CaDiCaL, this crate supports two environment variables to customize the Cpp source code that CaDiCaL is built from.

  • CADICAL_PATCHES allows to specify a list of colon-separated paths to patch files that will be applied to the CaDiCaL source repository before building it. These patches are applied in order of appearance after the patches of this crate have been applied.
  • CADICAL_SRC_DIR allows for overriding where the Cpp library is built from. By default this crate fetches the appropriate code from the GitHub repository. If this variable is set, the directory specified there is used instead. Note that when using this variable, the crate will not apply any patches, the user is responsible for applying the appropriate and necessary patches from the patches/ directory.

Dependencies

~3–15MB
~220K SLoC