#sat-solver #sat #minisat #formula #glucose #cadical #slover

rssat

rssat is a Rust library that provides Rust bindings for multiple popular SAT solvers

3 releases

0.1.4 Sep 30, 2024
0.1.2 Sep 30, 2024
0.1.1 Sep 30, 2024
0.1.0 Sep 30, 2024

#263 in Math

Download history 422/week @ 2024-09-27 49/week @ 2024-10-04 2/week @ 2024-10-11

86 downloads per month

MIT license

32KB
569 lines

rssat

github crates.io docs.rs

rssat is a Rust library that provides Rust bindings for multiple popular SAT solvers. Currently supported solvers include:

We thank the contributors of these excellent projects.

Features

  • Unified Rust interface for different SAT solvers
  • Support for adding clauses
  • Solving SAT problems and returning results
  • Access to native bindings for advanced functionality
  • Support reading formulas from files

Build Requirements

To build RSsat, you need the following tools and libraries:

  • C++ compiler (e.g., GCC, Clang)
  • CMake
  • patch command
  • Other standard build tools (make, etc.)

Installation

[dependencies]
rssat = "0.1.2"

Usage Example

Here's a simple example using the CaDiCaL solver:

use rssat::solver::{CaDiCaLSolver, Status,Solver};

fn main() {
    let mut solver = CaDiCaLSolver::new();
    
    solver.add_clause(&vec![1, 2]);
    solver.add_clause(&vec![-1, -2]);
    solver.add_clause(&vec![3]);
    
    
    match solver.solve() {
        Status::SATISFIABLE(vec) => {
            println!("Satisfiable solution: {:?}", vec);
        },
        Status::UNSATISFIABLE => {
            println!("Unsatisfiable");
        },
        Status::UNKNOWN => {
            println!("Unknown");
        },
    }
}

Native Bindings

For advanced usage, you can access the native bindings of each solver. This allows you to use solver-specific features that are not part of the unified interface.

Future Work

  • Improve documentation to enhance user experience

Contributing

Issue reports and pull requests are welcome!

License

MIT License

Dependencies

~0.3–5MB
~94K SLoC